From: Denis Efremov Date: Sat, 11 Aug 2012 20:26:31 +0000 (+0000) Subject: macvtap: rcu_dereference outside read-lock section X-Git-Tag: submit/tizen_common/20140905.094502~4646^2~2 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=3a7f8c34fefb109903af9a0fac6d0d05f93335c5;p=sdk%2Femulator%2Femulator-kernel.git macvtap: rcu_dereference outside read-lock section rcu_dereference occurs in update section. Replacement by rcu_dereference_protected in order to prevent lockdep complaint. Found by Linux Driver Verification project (linuxtesting.org) Signed-off-by: Denis Efremov Acked-by: Michael S. Tsirkin Signed-off-by: David S. Miller --- diff --git a/drivers/net/macvtap.c b/drivers/net/macvtap.c index 0737bd4d1669..0f0f9ce3a776 100644 --- a/drivers/net/macvtap.c +++ b/drivers/net/macvtap.c @@ -94,7 +94,8 @@ static int get_slot(struct macvlan_dev *vlan, struct macvtap_queue *q) int i; for (i = 0; i < MAX_MACVTAP_QUEUES; i++) { - if (rcu_dereference(vlan->taps[i]) == q) + if (rcu_dereference_protected(vlan->taps[i], + lockdep_is_held(&macvtap_lock)) == q) return i; }