diff options
| author | Amerigo Wang <amwang@redhat.com> | 2012-08-09 21:24:40 -0400 |
|---|---|---|
| committer | David S. Miller <davem@davemloft.net> | 2012-08-14 17:33:31 -0400 |
| commit | 57c5d46191e75312934c00eba65b13a31ca95120 (patch) | |
| tree | 18eb9488b414f0dacdf7be468985a29ceeb1f2e9 /include/linux | |
| parent | 3335f0ca130c201f8680e97f63612053fbc16e22 (diff) | |
netpoll: take rcu_read_lock_bh() in netpoll_rx()
In __netpoll_rx(), it dereferences ->npinfo without rcu_dereference_bh(),
this patch fixes it by using the 'npinfo' passed from netpoll_rx()
where it is already dereferenced with rcu_dereference_bh().
Cc: "David S. Miller" <davem@davemloft.net>
Signed-off-by: Cong Wang <amwang@redhat.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'include/linux')
| -rw-r--r-- | include/linux/netpoll.h | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/include/linux/netpoll.h b/include/linux/netpoll.h index 907812efb4d9..5d881c388273 100644 --- a/include/linux/netpoll.h +++ b/include/linux/netpoll.h | |||
| @@ -52,7 +52,7 @@ void netpoll_set_trap(int trap); | |||
| 52 | void __netpoll_cleanup(struct netpoll *np); | 52 | void __netpoll_cleanup(struct netpoll *np); |
| 53 | void __netpoll_free_rcu(struct netpoll *np); | 53 | void __netpoll_free_rcu(struct netpoll *np); |
| 54 | void netpoll_cleanup(struct netpoll *np); | 54 | void netpoll_cleanup(struct netpoll *np); |
| 55 | int __netpoll_rx(struct sk_buff *skb); | 55 | int __netpoll_rx(struct sk_buff *skb, struct netpoll_info *npinfo); |
| 56 | void netpoll_send_skb_on_dev(struct netpoll *np, struct sk_buff *skb, | 56 | void netpoll_send_skb_on_dev(struct netpoll *np, struct sk_buff *skb, |
| 57 | struct net_device *dev); | 57 | struct net_device *dev); |
| 58 | static inline void netpoll_send_skb(struct netpoll *np, struct sk_buff *skb) | 58 | static inline void netpoll_send_skb(struct netpoll *np, struct sk_buff *skb) |
| @@ -77,7 +77,7 @@ static inline bool netpoll_rx(struct sk_buff *skb) | |||
| 77 | 77 | ||
| 78 | spin_lock(&npinfo->rx_lock); | 78 | spin_lock(&npinfo->rx_lock); |
| 79 | /* check rx_flags again with the lock held */ | 79 | /* check rx_flags again with the lock held */ |
| 80 | if (npinfo->rx_flags && __netpoll_rx(skb)) | 80 | if (npinfo->rx_flags && __netpoll_rx(skb, npinfo)) |
| 81 | ret = true; | 81 | ret = true; |
| 82 | spin_unlock(&npinfo->rx_lock); | 82 | spin_unlock(&npinfo->rx_lock); |
| 83 | 83 | ||
