Commit f8a6f206 authored by Hideaki Yoshifuji's avatar Hideaki Yoshifuji Committed by Stephen Hemminger

[NET]: Fix OOPS in multicast procfs usage.

Fix several refcntmistakes in seq_file handlers for
/proc/net/{igmp,igmp6,msfilter,msfilter6}
parent f081f8b4
...@@ -2122,6 +2122,7 @@ static inline struct ip_mc_list *igmp_mc_get_first(struct seq_file *seq) ...@@ -2122,6 +2122,7 @@ static inline struct ip_mc_list *igmp_mc_get_first(struct seq_file *seq)
break; break;
} }
read_unlock(&in_dev->lock); read_unlock(&in_dev->lock);
in_dev_put(in_dev);
} }
return im; return im;
} }
...@@ -2181,7 +2182,9 @@ static void igmp_mc_seq_stop(struct seq_file *seq, void *v) ...@@ -2181,7 +2182,9 @@ static void igmp_mc_seq_stop(struct seq_file *seq, void *v)
if (likely(state->in_dev != NULL)) { if (likely(state->in_dev != NULL)) {
read_unlock(&state->in_dev->lock); read_unlock(&state->in_dev->lock);
in_dev_put(state->in_dev); in_dev_put(state->in_dev);
state->in_dev = NULL;
} }
state->dev = NULL;
read_unlock(&dev_base_lock); read_unlock(&dev_base_lock);
} }
...@@ -2284,6 +2287,7 @@ static inline struct ip_sf_list *igmp_mcf_get_first(struct seq_file *seq) ...@@ -2284,6 +2287,7 @@ static inline struct ip_sf_list *igmp_mcf_get_first(struct seq_file *seq)
spin_unlock_bh(&im->lock); spin_unlock_bh(&im->lock);
} }
read_unlock_bh(&idev->lock); read_unlock_bh(&idev->lock);
in_dev_put(idev);
} }
return psf; return psf;
} }
...@@ -2350,12 +2354,16 @@ static void *igmp_mcf_seq_next(struct seq_file *seq, void *v, loff_t *pos) ...@@ -2350,12 +2354,16 @@ static void *igmp_mcf_seq_next(struct seq_file *seq, void *v, loff_t *pos)
static void igmp_mcf_seq_stop(struct seq_file *seq, void *v) static void igmp_mcf_seq_stop(struct seq_file *seq, void *v)
{ {
struct igmp_mcf_iter_state *state = igmp_mcf_seq_private(seq); struct igmp_mcf_iter_state *state = igmp_mcf_seq_private(seq);
if (likely(state->im != NULL)) if (likely(state->im != NULL)) {
spin_unlock_bh(&state->im->lock); spin_unlock_bh(&state->im->lock);
state->im = NULL;
}
if (likely(state->idev != NULL)) { if (likely(state->idev != NULL)) {
read_unlock_bh(&state->idev->lock); read_unlock_bh(&state->idev->lock);
in_dev_put(state->idev); in_dev_put(state->idev);
state->idev = NULL;
} }
state->dev = NULL;
read_unlock(&dev_base_lock); read_unlock(&dev_base_lock);
} }
......
...@@ -2078,6 +2078,7 @@ static inline struct ifmcaddr6 *igmp6_mc_get_first(struct seq_file *seq) ...@@ -2078,6 +2078,7 @@ static inline struct ifmcaddr6 *igmp6_mc_get_first(struct seq_file *seq)
break; break;
} }
read_unlock_bh(&idev->lock); read_unlock_bh(&idev->lock);
in6_dev_put(idev);
} }
return im; return im;
} }
...@@ -2135,7 +2136,9 @@ static void igmp6_mc_seq_stop(struct seq_file *seq, void *v) ...@@ -2135,7 +2136,9 @@ static void igmp6_mc_seq_stop(struct seq_file *seq, void *v)
if (likely(state->idev != NULL)) { if (likely(state->idev != NULL)) {
read_unlock_bh(&state->idev->lock); read_unlock_bh(&state->idev->lock);
in6_dev_put(state->idev); in6_dev_put(state->idev);
state->idev = NULL;
} }
state->dev = NULL;
read_unlock(&dev_base_lock); read_unlock(&dev_base_lock);
} }
...@@ -2225,6 +2228,7 @@ static inline struct ip6_sf_list *igmp6_mcf_get_first(struct seq_file *seq) ...@@ -2225,6 +2228,7 @@ static inline struct ip6_sf_list *igmp6_mcf_get_first(struct seq_file *seq)
spin_unlock_bh(&im->mca_lock); spin_unlock_bh(&im->mca_lock);
} }
read_unlock_bh(&idev->lock); read_unlock_bh(&idev->lock);
in6_dev_put(idev);
} }
return psf; return psf;
} }
...@@ -2291,12 +2295,16 @@ static void *igmp6_mcf_seq_next(struct seq_file *seq, void *v, loff_t *pos) ...@@ -2291,12 +2295,16 @@ static void *igmp6_mcf_seq_next(struct seq_file *seq, void *v, loff_t *pos)
static void igmp6_mcf_seq_stop(struct seq_file *seq, void *v) static void igmp6_mcf_seq_stop(struct seq_file *seq, void *v)
{ {
struct igmp6_mcf_iter_state *state = igmp6_mcf_seq_private(seq); struct igmp6_mcf_iter_state *state = igmp6_mcf_seq_private(seq);
if (likely(state->im != NULL)) if (likely(state->im != NULL)) {
spin_unlock_bh(&state->im->mca_lock); spin_unlock_bh(&state->im->mca_lock);
state->im = NULL;
}
if (likely(state->idev != NULL)) { if (likely(state->idev != NULL)) {
read_unlock_bh(&state->idev->lock); read_unlock_bh(&state->idev->lock);
in6_dev_put(state->idev); in6_dev_put(state->idev);
state->idev = NULL;
} }
state->dev = NULL;
read_unlock(&dev_base_lock); read_unlock(&dev_base_lock);
} }
......
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