Commit c8b91770 authored by Amol Grover's avatar Amol Grover Committed by David S. Miller

tcp: ipv4: Pass lockdep expression to RCU lists

md5sig->head maybe traversed using hlist_for_each_entry_rcu
outside an RCU read-side critical section but under the protection
of socket lock.

Hence, add corresponding lockdep expression to silence false-positive
warnings, and harden RCU lists.
Signed-off-by: default avatarAmol Grover <frextrite@gmail.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 0a087bf2
...@@ -1019,7 +1019,8 @@ struct tcp_md5sig_key *__tcp_md5_do_lookup(const struct sock *sk, int l3index, ...@@ -1019,7 +1019,8 @@ struct tcp_md5sig_key *__tcp_md5_do_lookup(const struct sock *sk, int l3index,
if (!md5sig) if (!md5sig)
return NULL; return NULL;
hlist_for_each_entry_rcu(key, &md5sig->head, node) { hlist_for_each_entry_rcu(key, &md5sig->head, node,
lockdep_sock_is_held(sk)) {
if (key->family != family) if (key->family != family)
continue; continue;
if (key->l3index && key->l3index != l3index) if (key->l3index && key->l3index != l3index)
...@@ -1064,7 +1065,8 @@ static struct tcp_md5sig_key *tcp_md5_do_lookup_exact(const struct sock *sk, ...@@ -1064,7 +1065,8 @@ static struct tcp_md5sig_key *tcp_md5_do_lookup_exact(const struct sock *sk,
if (family == AF_INET6) if (family == AF_INET6)
size = sizeof(struct in6_addr); size = sizeof(struct in6_addr);
#endif #endif
hlist_for_each_entry_rcu(key, &md5sig->head, node) { hlist_for_each_entry_rcu(key, &md5sig->head, node,
lockdep_sock_is_held(sk)) {
if (key->family != family) if (key->family != family)
continue; continue;
if (key->l3index && key->l3index != l3index) if (key->l3index && key->l3index != l3index)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment