diff options
author | Eric Dumazet <edumazet@google.com> | 2013-03-06 23:20:32 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2013-03-07 16:33:10 -0500 |
commit | 7f0e44ac9f7f12a2519bfed9ea4df3c1471bd8bb (patch) | |
tree | 0e61610fbe1c25de0b9c8e7376c9151b60a5c605 /net/ipv6/ip6_flowlabel.c | |
parent | bf5e4dd6b26058d1a31864ea1a7002172023b147 (diff) |
ipv6 flowlabel: add __rcu annotations
Commit 18367681a10b (ipv6 flowlabel: Convert np->ipv6_fl_list to RCU.)
omitted proper __rcu annotations.
Signed-off-by: Eric Dumazet <edumazet@google.com>
Cc: YOSHIFUJI Hideaki <yoshfuji@linux-ipv6.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/ipv6/ip6_flowlabel.c')
-rw-r--r-- | net/ipv6/ip6_flowlabel.c | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/net/ipv6/ip6_flowlabel.c b/net/ipv6/ip6_flowlabel.c index b973ed3d06cf..46e88433ec7d 100644 --- a/net/ipv6/ip6_flowlabel.c +++ b/net/ipv6/ip6_flowlabel.c | |||
@@ -144,7 +144,9 @@ static void ip6_fl_gc(unsigned long dummy) | |||
144 | spin_lock(&ip6_fl_lock); | 144 | spin_lock(&ip6_fl_lock); |
145 | 145 | ||
146 | for (i=0; i<=FL_HASH_MASK; i++) { | 146 | for (i=0; i<=FL_HASH_MASK; i++) { |
147 | struct ip6_flowlabel *fl, **flp; | 147 | struct ip6_flowlabel *fl; |
148 | struct ip6_flowlabel __rcu **flp; | ||
149 | |||
148 | flp = &fl_ht[i]; | 150 | flp = &fl_ht[i]; |
149 | while ((fl = rcu_dereference_protected(*flp, | 151 | while ((fl = rcu_dereference_protected(*flp, |
150 | lockdep_is_held(&ip6_fl_lock))) != NULL) { | 152 | lockdep_is_held(&ip6_fl_lock))) != NULL) { |
@@ -179,7 +181,9 @@ static void __net_exit ip6_fl_purge(struct net *net) | |||
179 | 181 | ||
180 | spin_lock(&ip6_fl_lock); | 182 | spin_lock(&ip6_fl_lock); |
181 | for (i = 0; i <= FL_HASH_MASK; i++) { | 183 | for (i = 0; i <= FL_HASH_MASK; i++) { |
182 | struct ip6_flowlabel *fl, **flp; | 184 | struct ip6_flowlabel *fl; |
185 | struct ip6_flowlabel __rcu **flp; | ||
186 | |||
183 | flp = &fl_ht[i]; | 187 | flp = &fl_ht[i]; |
184 | while ((fl = rcu_dereference_protected(*flp, | 188 | while ((fl = rcu_dereference_protected(*flp, |
185 | lockdep_is_held(&ip6_fl_lock))) != NULL) { | 189 | lockdep_is_held(&ip6_fl_lock))) != NULL) { |
@@ -506,7 +510,8 @@ int ipv6_flowlabel_opt(struct sock *sk, char __user *optval, int optlen) | |||
506 | struct ipv6_pinfo *np = inet6_sk(sk); | 510 | struct ipv6_pinfo *np = inet6_sk(sk); |
507 | struct in6_flowlabel_req freq; | 511 | struct in6_flowlabel_req freq; |
508 | struct ipv6_fl_socklist *sfl1=NULL; | 512 | struct ipv6_fl_socklist *sfl1=NULL; |
509 | struct ipv6_fl_socklist *sfl, **sflp; | 513 | struct ipv6_fl_socklist *sfl; |
514 | struct ipv6_fl_socklist __rcu **sflp; | ||
510 | struct ip6_flowlabel *fl, *fl1 = NULL; | 515 | struct ip6_flowlabel *fl, *fl1 = NULL; |
511 | 516 | ||
512 | 517 | ||