Commit 4b200e39 authored by Taehee Yoo's avatar Taehee Yoo Committed by David S. Miller

mld: convert ip6_sf_list to RCU

The ip6_sf_list has been protected by mca_lock(spin_lock) so that the
critical section is atomic context. In order to switch this context,
changing locking is needed. The ip6_sf_list actually already protected
by RTNL So if it's converted to use RCU, its control path context can
be switched to sleepable.
But It doesn't remove mca_lock yet because ifmcaddr6 isn't converted
to RCU yet. So, It's not fully converted to the sleepable context.
Suggested-by: default avatarCong Wang <xiyou.wangcong@gmail.com>
Signed-off-by: default avatarTaehee Yoo <ap420073@gmail.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 882ba1f7
...@@ -97,12 +97,13 @@ struct ipv6_mc_socklist { ...@@ -97,12 +97,13 @@ struct ipv6_mc_socklist {
}; };
struct ip6_sf_list { struct ip6_sf_list {
struct ip6_sf_list *sf_next; struct ip6_sf_list __rcu *sf_next;
struct in6_addr sf_addr; struct in6_addr sf_addr;
unsigned long sf_count[2]; /* include/exclude counts */ unsigned long sf_count[2]; /* include/exclude counts */
unsigned char sf_gsresp; /* include in g & s response? */ unsigned char sf_gsresp; /* include in g & s response? */
unsigned char sf_oldin; /* change state */ unsigned char sf_oldin; /* change state */
unsigned char sf_crcount; /* retrans. left to send */ unsigned char sf_crcount; /* retrans. left to send */
struct rcu_head rcu;
}; };
#define MAF_TIMER_RUNNING 0x01 #define MAF_TIMER_RUNNING 0x01
...@@ -115,8 +116,8 @@ struct ifmcaddr6 { ...@@ -115,8 +116,8 @@ struct ifmcaddr6 {
struct in6_addr mca_addr; struct in6_addr mca_addr;
struct inet6_dev *idev; struct inet6_dev *idev;
struct ifmcaddr6 *next; struct ifmcaddr6 *next;
struct ip6_sf_list *mca_sources; struct ip6_sf_list __rcu *mca_sources;
struct ip6_sf_list *mca_tomb; struct ip6_sf_list __rcu *mca_tomb;
unsigned int mca_sfmode; unsigned int mca_sfmode;
unsigned char mca_crcount; unsigned char mca_crcount;
unsigned long mca_sfcount[2]; unsigned long mca_sfcount[2];
......
This diff is collapsed.
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