diff options
-rw-r--r-- | fs/proc/proc_net.c | 8 | ||||
-rw-r--r-- | include/linux/seq_file_net.h | 1 | ||||
-rw-r--r-- | net/ipv4/fib_trie.c | 9 | ||||
-rw-r--r-- | net/ipv4/proc.c | 30 | ||||
-rw-r--r-- | net/ipv6/proc.c | 10 | ||||
-rw-r--r-- | net/ipv6/route.c | 20 |
6 files changed, 16 insertions, 62 deletions
diff --git a/fs/proc/proc_net.c b/fs/proc/proc_net.c index ab232ad2e6f9..b224a28e0c15 100644 --- a/fs/proc/proc_net.c +++ b/fs/proc/proc_net.c | |||
@@ -87,6 +87,14 @@ int seq_release_net(struct inode *ino, struct file *f) | |||
87 | } | 87 | } |
88 | EXPORT_SYMBOL_GPL(seq_release_net); | 88 | EXPORT_SYMBOL_GPL(seq_release_net); |
89 | 89 | ||
90 | int single_release_net(struct inode *ino, struct file *f) | ||
91 | { | ||
92 | struct seq_file *seq = f->private_data; | ||
93 | put_net(seq->private); | ||
94 | return single_release(ino, f); | ||
95 | } | ||
96 | EXPORT_SYMBOL_GPL(single_release_net); | ||
97 | |||
90 | static struct net *get_proc_task_net(struct inode *dir) | 98 | static struct net *get_proc_task_net(struct inode *dir) |
91 | { | 99 | { |
92 | struct task_struct *task; | 100 | struct task_struct *task; |
diff --git a/include/linux/seq_file_net.h b/include/linux/seq_file_net.h index 87dcc0ecf6eb..32c89bbe24a2 100644 --- a/include/linux/seq_file_net.h +++ b/include/linux/seq_file_net.h | |||
@@ -17,6 +17,7 @@ int seq_open_net(struct inode *, struct file *, | |||
17 | int single_open_net(struct inode *, struct file *file, | 17 | int single_open_net(struct inode *, struct file *file, |
18 | int (*show)(struct seq_file *, void *)); | 18 | int (*show)(struct seq_file *, void *)); |
19 | int seq_release_net(struct inode *, struct file *); | 19 | int seq_release_net(struct inode *, struct file *); |
20 | int single_release_net(struct inode *, struct file *); | ||
20 | static inline struct net *seq_file_net(struct seq_file *seq) | 21 | static inline struct net *seq_file_net(struct seq_file *seq) |
21 | { | 22 | { |
22 | #ifdef CONFIG_NET_NS | 23 | #ifdef CONFIG_NET_NS |
diff --git a/net/ipv4/fib_trie.c b/net/ipv4/fib_trie.c index 6009df238ed9..5cb72786a8af 100644 --- a/net/ipv4/fib_trie.c +++ b/net/ipv4/fib_trie.c | |||
@@ -2254,19 +2254,12 @@ static int fib_triestat_seq_open(struct inode *inode, struct file *file) | |||
2254 | return single_open_net(inode, file, fib_triestat_seq_show); | 2254 | return single_open_net(inode, file, fib_triestat_seq_show); |
2255 | } | 2255 | } |
2256 | 2256 | ||
2257 | static int fib_triestat_seq_release(struct inode *ino, struct file *f) | ||
2258 | { | ||
2259 | struct seq_file *seq = f->private_data; | ||
2260 | put_net(seq->private); | ||
2261 | return single_release(ino, f); | ||
2262 | } | ||
2263 | |||
2264 | static const struct file_operations fib_triestat_fops = { | 2257 | static const struct file_operations fib_triestat_fops = { |
2265 | .owner = THIS_MODULE, | 2258 | .owner = THIS_MODULE, |
2266 | .open = fib_triestat_seq_open, | 2259 | .open = fib_triestat_seq_open, |
2267 | .read = seq_read, | 2260 | .read = seq_read, |
2268 | .llseek = seq_lseek, | 2261 | .llseek = seq_lseek, |
2269 | .release = fib_triestat_seq_release, | 2262 | .release = single_release_net, |
2270 | }; | 2263 | }; |
2271 | 2264 | ||
2272 | static struct node *fib_trie_get_idx(struct seq_file *seq, loff_t pos) | 2265 | static struct node *fib_trie_get_idx(struct seq_file *seq, loff_t pos) |
diff --git a/net/ipv4/proc.c b/net/ipv4/proc.c index daf5d3c80cef..834356ea99df 100644 --- a/net/ipv4/proc.c +++ b/net/ipv4/proc.c | |||
@@ -74,20 +74,12 @@ static int sockstat_seq_open(struct inode *inode, struct file *file) | |||
74 | return single_open_net(inode, file, sockstat_seq_show); | 74 | return single_open_net(inode, file, sockstat_seq_show); |
75 | } | 75 | } |
76 | 76 | ||
77 | static int sockstat_seq_release(struct inode *inode, struct file *file) | ||
78 | { | ||
79 | struct net *net = ((struct seq_file *)file->private_data)->private; | ||
80 | |||
81 | put_net(net); | ||
82 | return single_release(inode, file); | ||
83 | } | ||
84 | |||
85 | static const struct file_operations sockstat_seq_fops = { | 77 | static const struct file_operations sockstat_seq_fops = { |
86 | .owner = THIS_MODULE, | 78 | .owner = THIS_MODULE, |
87 | .open = sockstat_seq_open, | 79 | .open = sockstat_seq_open, |
88 | .read = seq_read, | 80 | .read = seq_read, |
89 | .llseek = seq_lseek, | 81 | .llseek = seq_lseek, |
90 | .release = sockstat_seq_release, | 82 | .release = single_release_net, |
91 | }; | 83 | }; |
92 | 84 | ||
93 | /* snmp items */ | 85 | /* snmp items */ |
@@ -383,20 +375,12 @@ static int snmp_seq_open(struct inode *inode, struct file *file) | |||
383 | return single_open_net(inode, file, snmp_seq_show); | 375 | return single_open_net(inode, file, snmp_seq_show); |
384 | } | 376 | } |
385 | 377 | ||
386 | static int snmp_seq_release(struct inode *inode, struct file *file) | ||
387 | { | ||
388 | struct net *net = ((struct seq_file *)file->private_data)->private; | ||
389 | |||
390 | put_net(net); | ||
391 | return single_release(inode, file); | ||
392 | } | ||
393 | |||
394 | static const struct file_operations snmp_seq_fops = { | 378 | static const struct file_operations snmp_seq_fops = { |
395 | .owner = THIS_MODULE, | 379 | .owner = THIS_MODULE, |
396 | .open = snmp_seq_open, | 380 | .open = snmp_seq_open, |
397 | .read = seq_read, | 381 | .read = seq_read, |
398 | .llseek = seq_lseek, | 382 | .llseek = seq_lseek, |
399 | .release = snmp_seq_release, | 383 | .release = single_release_net, |
400 | }; | 384 | }; |
401 | 385 | ||
402 | 386 | ||
@@ -438,20 +422,12 @@ static int netstat_seq_open(struct inode *inode, struct file *file) | |||
438 | return single_open_net(inode, file, netstat_seq_show); | 422 | return single_open_net(inode, file, netstat_seq_show); |
439 | } | 423 | } |
440 | 424 | ||
441 | static int netstat_seq_release(struct inode *inode, struct file *file) | ||
442 | { | ||
443 | struct net *net = ((struct seq_file *)file->private_data)->private; | ||
444 | |||
445 | put_net(net); | ||
446 | return single_release(inode, file); | ||
447 | } | ||
448 | |||
449 | static const struct file_operations netstat_seq_fops = { | 425 | static const struct file_operations netstat_seq_fops = { |
450 | .owner = THIS_MODULE, | 426 | .owner = THIS_MODULE, |
451 | .open = netstat_seq_open, | 427 | .open = netstat_seq_open, |
452 | .read = seq_read, | 428 | .read = seq_read, |
453 | .llseek = seq_lseek, | 429 | .llseek = seq_lseek, |
454 | .release = netstat_seq_release, | 430 | .release = single_release_net, |
455 | }; | 431 | }; |
456 | 432 | ||
457 | static __net_init int ip_proc_init_net(struct net *net) | 433 | static __net_init int ip_proc_init_net(struct net *net) |
diff --git a/net/ipv6/proc.c b/net/ipv6/proc.c index 29c5a79444c2..70940b3654a1 100644 --- a/net/ipv6/proc.c +++ b/net/ipv6/proc.c | |||
@@ -186,20 +186,12 @@ static int sockstat6_seq_open(struct inode *inode, struct file *file) | |||
186 | return single_open_net(inode, file, sockstat6_seq_show); | 186 | return single_open_net(inode, file, sockstat6_seq_show); |
187 | } | 187 | } |
188 | 188 | ||
189 | static int sockstat6_seq_release(struct inode *inode, struct file *file) | ||
190 | { | ||
191 | struct net *net = ((struct seq_file *)file->private_data)->private; | ||
192 | |||
193 | put_net(net); | ||
194 | return single_release(inode, file); | ||
195 | } | ||
196 | |||
197 | static const struct file_operations sockstat6_seq_fops = { | 189 | static const struct file_operations sockstat6_seq_fops = { |
198 | .owner = THIS_MODULE, | 190 | .owner = THIS_MODULE, |
199 | .open = sockstat6_seq_open, | 191 | .open = sockstat6_seq_open, |
200 | .read = seq_read, | 192 | .read = seq_read, |
201 | .llseek = seq_lseek, | 193 | .llseek = seq_lseek, |
202 | .release = sockstat6_seq_release, | 194 | .release = single_release_net, |
203 | }; | 195 | }; |
204 | 196 | ||
205 | static int snmp6_seq_open(struct inode *inode, struct file *file) | 197 | static int snmp6_seq_open(struct inode *inode, struct file *file) |
diff --git a/net/ipv6/route.c b/net/ipv6/route.c index fb7ff8f0c6db..cb8a51271b67 100644 --- a/net/ipv6/route.c +++ b/net/ipv6/route.c | |||
@@ -2419,20 +2419,12 @@ static int ipv6_route_open(struct inode *inode, struct file *file) | |||
2419 | return single_open_net(inode, file, ipv6_route_show); | 2419 | return single_open_net(inode, file, ipv6_route_show); |
2420 | } | 2420 | } |
2421 | 2421 | ||
2422 | static int ipv6_route_release(struct inode *inode, struct file *file) | ||
2423 | { | ||
2424 | struct seq_file *seq = file->private_data; | ||
2425 | struct net *net = seq->private; | ||
2426 | put_net(net); | ||
2427 | return single_release(inode, file); | ||
2428 | } | ||
2429 | |||
2430 | static const struct file_operations ipv6_route_proc_fops = { | 2422 | static const struct file_operations ipv6_route_proc_fops = { |
2431 | .owner = THIS_MODULE, | 2423 | .owner = THIS_MODULE, |
2432 | .open = ipv6_route_open, | 2424 | .open = ipv6_route_open, |
2433 | .read = seq_read, | 2425 | .read = seq_read, |
2434 | .llseek = seq_lseek, | 2426 | .llseek = seq_lseek, |
2435 | .release = ipv6_route_release, | 2427 | .release = single_release_net, |
2436 | }; | 2428 | }; |
2437 | 2429 | ||
2438 | static int rt6_stats_seq_show(struct seq_file *seq, void *v) | 2430 | static int rt6_stats_seq_show(struct seq_file *seq, void *v) |
@@ -2455,20 +2447,12 @@ static int rt6_stats_seq_open(struct inode *inode, struct file *file) | |||
2455 | return single_open_net(inode, file, rt6_stats_seq_show); | 2447 | return single_open_net(inode, file, rt6_stats_seq_show); |
2456 | } | 2448 | } |
2457 | 2449 | ||
2458 | static int rt6_stats_seq_release(struct inode *inode, struct file *file) | ||
2459 | { | ||
2460 | struct seq_file *seq = file->private_data; | ||
2461 | struct net *net = (struct net *)seq->private; | ||
2462 | put_net(net); | ||
2463 | return single_release(inode, file); | ||
2464 | } | ||
2465 | |||
2466 | static const struct file_operations rt6_stats_seq_fops = { | 2450 | static const struct file_operations rt6_stats_seq_fops = { |
2467 | .owner = THIS_MODULE, | 2451 | .owner = THIS_MODULE, |
2468 | .open = rt6_stats_seq_open, | 2452 | .open = rt6_stats_seq_open, |
2469 | .read = seq_read, | 2453 | .read = seq_read, |
2470 | .llseek = seq_lseek, | 2454 | .llseek = seq_lseek, |
2471 | .release = rt6_stats_seq_release, | 2455 | .release = single_release_net, |
2472 | }; | 2456 | }; |
2473 | #endif /* CONFIG_PROC_FS */ | 2457 | #endif /* CONFIG_PROC_FS */ |
2474 | 2458 | ||