diff options
Diffstat (limited to 'net/ipv4')
-rw-r--r-- | net/ipv4/fib_semantics.c | 12 | ||||
-rw-r--r-- | net/ipv4/fib_trie.c | 7 | ||||
-rw-r--r-- | net/ipv4/igmp.c | 32 |
3 files changed, 8 insertions, 43 deletions
diff --git a/net/ipv4/fib_semantics.c b/net/ipv4/fib_semantics.c index 641a5a2a9f9c..33e2c35b74b7 100644 --- a/net/ipv4/fib_semantics.c +++ b/net/ipv4/fib_semantics.c | |||
@@ -141,18 +141,8 @@ const struct fib_prop fib_props[RTN_MAX + 1] = { | |||
141 | }, | 141 | }, |
142 | }; | 142 | }; |
143 | 143 | ||
144 | |||
145 | /* Release a nexthop info record */ | 144 | /* Release a nexthop info record */ |
146 | 145 | ||
147 | static void free_fib_info_rcu(struct rcu_head *head) | ||
148 | { | ||
149 | struct fib_info *fi = container_of(head, struct fib_info, rcu); | ||
150 | |||
151 | if (fi->fib_metrics != (u32 *) dst_default_metrics) | ||
152 | kfree(fi->fib_metrics); | ||
153 | kfree(fi); | ||
154 | } | ||
155 | |||
156 | void free_fib_info(struct fib_info *fi) | 146 | void free_fib_info(struct fib_info *fi) |
157 | { | 147 | { |
158 | if (fi->fib_dead == 0) { | 148 | if (fi->fib_dead == 0) { |
@@ -166,7 +156,7 @@ void free_fib_info(struct fib_info *fi) | |||
166 | } endfor_nexthops(fi); | 156 | } endfor_nexthops(fi); |
167 | fib_info_cnt--; | 157 | fib_info_cnt--; |
168 | release_net(fi->fib_net); | 158 | release_net(fi->fib_net); |
169 | call_rcu(&fi->rcu, free_fib_info_rcu); | 159 | kfree_rcu(fi, rcu); |
170 | } | 160 | } |
171 | 161 | ||
172 | void fib_release_info(struct fib_info *fi) | 162 | void fib_release_info(struct fib_info *fi) |
diff --git a/net/ipv4/fib_trie.c b/net/ipv4/fib_trie.c index 6375c1c5f642..c779ce96e5b5 100644 --- a/net/ipv4/fib_trie.c +++ b/net/ipv4/fib_trie.c | |||
@@ -369,14 +369,9 @@ static inline void free_leaf(struct leaf *l) | |||
369 | call_rcu_bh(&l->rcu, __leaf_free_rcu); | 369 | call_rcu_bh(&l->rcu, __leaf_free_rcu); |
370 | } | 370 | } |
371 | 371 | ||
372 | static void __leaf_info_free_rcu(struct rcu_head *head) | ||
373 | { | ||
374 | kfree(container_of(head, struct leaf_info, rcu)); | ||
375 | } | ||
376 | |||
377 | static inline void free_leaf_info(struct leaf_info *leaf) | 372 | static inline void free_leaf_info(struct leaf_info *leaf) |
378 | { | 373 | { |
379 | call_rcu(&leaf->rcu, __leaf_info_free_rcu); | 374 | kfree_rcu(leaf, rcu); |
380 | } | 375 | } |
381 | 376 | ||
382 | static struct tnode *tnode_alloc(size_t size) | 377 | static struct tnode *tnode_alloc(size_t size) |
diff --git a/net/ipv4/igmp.c b/net/ipv4/igmp.c index ec03c2fda6ce..672e476c8c8a 100644 --- a/net/ipv4/igmp.c +++ b/net/ipv4/igmp.c | |||
@@ -149,17 +149,11 @@ static void ip_mc_clear_src(struct ip_mc_list *pmc); | |||
149 | static int ip_mc_add_src(struct in_device *in_dev, __be32 *pmca, int sfmode, | 149 | static int ip_mc_add_src(struct in_device *in_dev, __be32 *pmca, int sfmode, |
150 | int sfcount, __be32 *psfsrc, int delta); | 150 | int sfcount, __be32 *psfsrc, int delta); |
151 | 151 | ||
152 | |||
153 | static void ip_mc_list_reclaim(struct rcu_head *head) | ||
154 | { | ||
155 | kfree(container_of(head, struct ip_mc_list, rcu)); | ||
156 | } | ||
157 | |||
158 | static void ip_ma_put(struct ip_mc_list *im) | 152 | static void ip_ma_put(struct ip_mc_list *im) |
159 | { | 153 | { |
160 | if (atomic_dec_and_test(&im->refcnt)) { | 154 | if (atomic_dec_and_test(&im->refcnt)) { |
161 | in_dev_put(im->interface); | 155 | in_dev_put(im->interface); |
162 | call_rcu(&im->rcu, ip_mc_list_reclaim); | 156 | kfree_rcu(im, rcu); |
163 | } | 157 | } |
164 | } | 158 | } |
165 | 159 | ||
@@ -1828,12 +1822,6 @@ done: | |||
1828 | } | 1822 | } |
1829 | EXPORT_SYMBOL(ip_mc_join_group); | 1823 | EXPORT_SYMBOL(ip_mc_join_group); |
1830 | 1824 | ||
1831 | static void ip_sf_socklist_reclaim(struct rcu_head *rp) | ||
1832 | { | ||
1833 | kfree(container_of(rp, struct ip_sf_socklist, rcu)); | ||
1834 | /* sk_omem_alloc should have been decreased by the caller*/ | ||
1835 | } | ||
1836 | |||
1837 | static int ip_mc_leave_src(struct sock *sk, struct ip_mc_socklist *iml, | 1825 | static int ip_mc_leave_src(struct sock *sk, struct ip_mc_socklist *iml, |
1838 | struct in_device *in_dev) | 1826 | struct in_device *in_dev) |
1839 | { | 1827 | { |
@@ -1850,18 +1838,10 @@ static int ip_mc_leave_src(struct sock *sk, struct ip_mc_socklist *iml, | |||
1850 | rcu_assign_pointer(iml->sflist, NULL); | 1838 | rcu_assign_pointer(iml->sflist, NULL); |
1851 | /* decrease mem now to avoid the memleak warning */ | 1839 | /* decrease mem now to avoid the memleak warning */ |
1852 | atomic_sub(IP_SFLSIZE(psf->sl_max), &sk->sk_omem_alloc); | 1840 | atomic_sub(IP_SFLSIZE(psf->sl_max), &sk->sk_omem_alloc); |
1853 | call_rcu(&psf->rcu, ip_sf_socklist_reclaim); | 1841 | kfree_rcu(psf, rcu); |
1854 | return err; | 1842 | return err; |
1855 | } | 1843 | } |
1856 | 1844 | ||
1857 | |||
1858 | static void ip_mc_socklist_reclaim(struct rcu_head *rp) | ||
1859 | { | ||
1860 | kfree(container_of(rp, struct ip_mc_socklist, rcu)); | ||
1861 | /* sk_omem_alloc should have been decreased by the caller*/ | ||
1862 | } | ||
1863 | |||
1864 | |||
1865 | /* | 1845 | /* |
1866 | * Ask a socket to leave a group. | 1846 | * Ask a socket to leave a group. |
1867 | */ | 1847 | */ |
@@ -1901,7 +1881,7 @@ int ip_mc_leave_group(struct sock *sk, struct ip_mreqn *imr) | |||
1901 | rtnl_unlock(); | 1881 | rtnl_unlock(); |
1902 | /* decrease mem now to avoid the memleak warning */ | 1882 | /* decrease mem now to avoid the memleak warning */ |
1903 | atomic_sub(sizeof(*iml), &sk->sk_omem_alloc); | 1883 | atomic_sub(sizeof(*iml), &sk->sk_omem_alloc); |
1904 | call_rcu(&iml->rcu, ip_mc_socklist_reclaim); | 1884 | kfree_rcu(iml, rcu); |
1905 | return 0; | 1885 | return 0; |
1906 | } | 1886 | } |
1907 | if (!in_dev) | 1887 | if (!in_dev) |
@@ -2018,7 +1998,7 @@ int ip_mc_source(int add, int omode, struct sock *sk, struct | |||
2018 | newpsl->sl_addr[i] = psl->sl_addr[i]; | 1998 | newpsl->sl_addr[i] = psl->sl_addr[i]; |
2019 | /* decrease mem now to avoid the memleak warning */ | 1999 | /* decrease mem now to avoid the memleak warning */ |
2020 | atomic_sub(IP_SFLSIZE(psl->sl_max), &sk->sk_omem_alloc); | 2000 | atomic_sub(IP_SFLSIZE(psl->sl_max), &sk->sk_omem_alloc); |
2021 | call_rcu(&psl->rcu, ip_sf_socklist_reclaim); | 2001 | kfree_rcu(psl, rcu); |
2022 | } | 2002 | } |
2023 | rcu_assign_pointer(pmc->sflist, newpsl); | 2003 | rcu_assign_pointer(pmc->sflist, newpsl); |
2024 | psl = newpsl; | 2004 | psl = newpsl; |
@@ -2119,7 +2099,7 @@ int ip_mc_msfilter(struct sock *sk, struct ip_msfilter *msf, int ifindex) | |||
2119 | psl->sl_count, psl->sl_addr, 0); | 2099 | psl->sl_count, psl->sl_addr, 0); |
2120 | /* decrease mem now to avoid the memleak warning */ | 2100 | /* decrease mem now to avoid the memleak warning */ |
2121 | atomic_sub(IP_SFLSIZE(psl->sl_max), &sk->sk_omem_alloc); | 2101 | atomic_sub(IP_SFLSIZE(psl->sl_max), &sk->sk_omem_alloc); |
2122 | call_rcu(&psl->rcu, ip_sf_socklist_reclaim); | 2102 | kfree_rcu(psl, rcu); |
2123 | } else | 2103 | } else |
2124 | (void) ip_mc_del_src(in_dev, &msf->imsf_multiaddr, pmc->sfmode, | 2104 | (void) ip_mc_del_src(in_dev, &msf->imsf_multiaddr, pmc->sfmode, |
2125 | 0, NULL, 0); | 2105 | 0, NULL, 0); |
@@ -2316,7 +2296,7 @@ void ip_mc_drop_socket(struct sock *sk) | |||
2316 | ip_mc_dec_group(in_dev, iml->multi.imr_multiaddr.s_addr); | 2296 | ip_mc_dec_group(in_dev, iml->multi.imr_multiaddr.s_addr); |
2317 | /* decrease mem now to avoid the memleak warning */ | 2297 | /* decrease mem now to avoid the memleak warning */ |
2318 | atomic_sub(sizeof(*iml), &sk->sk_omem_alloc); | 2298 | atomic_sub(sizeof(*iml), &sk->sk_omem_alloc); |
2319 | call_rcu(&iml->rcu, ip_mc_socklist_reclaim); | 2299 | kfree_rcu(iml, rcu); |
2320 | } | 2300 | } |
2321 | rtnl_unlock(); | 2301 | rtnl_unlock(); |
2322 | } | 2302 | } |