Re: Q: locking mechanisms

From: Urs Thuermann
Date: Tue Jul 04 2006 - 08:58:34 EST


Thomas Gleixner <tglx@xxxxxxxxxxxxx> writes:

> Does Documentation/listRCU.txt answer your questions ?

It doesn't answer my question. I have code that receives network
packets by registering with dev_add_pack(). Each packet received is
then delivered to a list of receivers, where this list can contain quite
a lot of items:

receive_function(struct sk_buff *skb, struct net_device *dev,
struct packet_type *pt, struct net_device *orig_dev)
{
...
rcu_read_lock();
head = find_list(dev);
hlist_for_each_entry_rcu(p, n, head, list) {
deliver_packet_to_receiver(skb, p);
}
rcu_read_unlock();
}

The deliver_packet_to_receiver() function finally ends up in a call to
sock_queue_rcv_skb().

My questions was, wether I should worry to "hold" the rcu_read_lock for
the time of the list traversal since the list can be quite long and
preemption is disabled between rcu_read_lock() and rcu_read_unlock().


urs
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/