diff options
author | Pavel Emelyanov <xemul@openvz.org> | 2008-07-18 07:07:21 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2008-07-18 07:07:21 -0400 |
commit | de05c557b24c7dffc6d392e3db120cf11c9f6ae7 (patch) | |
tree | d1d6fe1323657afd7d416c6af8a62d6a9e1e1e66 | |
parent | 60bdde95807e982a824be9cfdd35055cc721a88a (diff) |
proc: consolidate per-net single_open callers
There are already 7 of them - time to kill some duplicate code.
Signed-off-by: Pavel Emelyanov <xemul@openvz.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r-- | fs/proc/proc_net.c | 24 | ||||
-rw-r--r-- | include/linux/seq_file_net.h | 2 | ||||
-rw-r--r-- | net/ipv4/fib_trie.c | 13 | ||||
-rw-r--r-- | net/ipv4/proc.c | 57 | ||||
-rw-r--r-- | net/ipv6/proc.c | 19 | ||||
-rw-r--r-- | net/ipv6/route.c | 26 |
6 files changed, 33 insertions, 108 deletions
diff --git a/fs/proc/proc_net.c b/fs/proc/proc_net.c index 83f357b30d71..ab232ad2e6f9 100644 --- a/fs/proc/proc_net.c +++ b/fs/proc/proc_net.c | |||
@@ -51,6 +51,30 @@ int seq_open_net(struct inode *ino, struct file *f, | |||
51 | } | 51 | } |
52 | EXPORT_SYMBOL_GPL(seq_open_net); | 52 | EXPORT_SYMBOL_GPL(seq_open_net); |
53 | 53 | ||
54 | int single_open_net(struct inode *inode, struct file *file, | ||
55 | int (*show)(struct seq_file *, void *)) | ||
56 | { | ||
57 | int err; | ||
58 | struct net *net; | ||
59 | |||
60 | err = -ENXIO; | ||
61 | net = get_proc_net(inode); | ||
62 | if (net == NULL) | ||
63 | goto err_net; | ||
64 | |||
65 | err = single_open(file, show, net); | ||
66 | if (err < 0) | ||
67 | goto err_open; | ||
68 | |||
69 | return 0; | ||
70 | |||
71 | err_open: | ||
72 | put_net(net); | ||
73 | err_net: | ||
74 | return err; | ||
75 | } | ||
76 | EXPORT_SYMBOL_GPL(single_open_net); | ||
77 | |||
54 | int seq_release_net(struct inode *ino, struct file *f) | 78 | int seq_release_net(struct inode *ino, struct file *f) |
55 | { | 79 | { |
56 | struct seq_file *seq; | 80 | struct seq_file *seq; |
diff --git a/include/linux/seq_file_net.h b/include/linux/seq_file_net.h index 4ac52542a563..87dcc0ecf6eb 100644 --- a/include/linux/seq_file_net.h +++ b/include/linux/seq_file_net.h | |||
@@ -14,6 +14,8 @@ struct seq_net_private { | |||
14 | 14 | ||
15 | int seq_open_net(struct inode *, struct file *, | 15 | int seq_open_net(struct inode *, struct file *, |
16 | const struct seq_operations *, int); | 16 | const struct seq_operations *, int); |
17 | int single_open_net(struct inode *, struct file *file, | ||
18 | int (*show)(struct seq_file *, void *)); | ||
17 | int seq_release_net(struct inode *, struct file *); | 19 | int seq_release_net(struct inode *, struct file *); |
18 | static inline struct net *seq_file_net(struct seq_file *seq) | 20 | static inline struct net *seq_file_net(struct seq_file *seq) |
19 | { | 21 | { |
diff --git a/net/ipv4/fib_trie.c b/net/ipv4/fib_trie.c index f155a66d6ebf..6009df238ed9 100644 --- a/net/ipv4/fib_trie.c +++ b/net/ipv4/fib_trie.c | |||
@@ -2251,18 +2251,7 @@ static int fib_triestat_seq_show(struct seq_file *seq, void *v) | |||
2251 | 2251 | ||
2252 | static int fib_triestat_seq_open(struct inode *inode, struct file *file) | 2252 | static int fib_triestat_seq_open(struct inode *inode, struct file *file) |
2253 | { | 2253 | { |
2254 | int err; | 2254 | return single_open_net(inode, file, fib_triestat_seq_show); |
2255 | struct net *net; | ||
2256 | |||
2257 | net = get_proc_net(inode); | ||
2258 | if (net == NULL) | ||
2259 | return -ENXIO; | ||
2260 | err = single_open(file, fib_triestat_seq_show, net); | ||
2261 | if (err < 0) { | ||
2262 | put_net(net); | ||
2263 | return err; | ||
2264 | } | ||
2265 | return 0; | ||
2266 | } | 2255 | } |
2267 | 2256 | ||
2268 | static int fib_triestat_seq_release(struct inode *ino, struct file *f) | 2257 | static int fib_triestat_seq_release(struct inode *ino, struct file *f) |
diff --git a/net/ipv4/proc.c b/net/ipv4/proc.c index 554390431a4e..daf5d3c80cef 100644 --- a/net/ipv4/proc.c +++ b/net/ipv4/proc.c | |||
@@ -71,24 +71,7 @@ static int sockstat_seq_show(struct seq_file *seq, void *v) | |||
71 | 71 | ||
72 | static int sockstat_seq_open(struct inode *inode, struct file *file) | 72 | static int sockstat_seq_open(struct inode *inode, struct file *file) |
73 | { | 73 | { |
74 | int err; | 74 | return single_open_net(inode, file, sockstat_seq_show); |
75 | struct net *net; | ||
76 | |||
77 | err = -ENXIO; | ||
78 | net = get_proc_net(inode); | ||
79 | if (net == NULL) | ||
80 | goto err_net; | ||
81 | |||
82 | err = single_open(file, sockstat_seq_show, net); | ||
83 | if (err < 0) | ||
84 | goto err_open; | ||
85 | |||
86 | return 0; | ||
87 | |||
88 | err_open: | ||
89 | put_net(net); | ||
90 | err_net: | ||
91 | return err; | ||
92 | } | 75 | } |
93 | 76 | ||
94 | static int sockstat_seq_release(struct inode *inode, struct file *file) | 77 | static int sockstat_seq_release(struct inode *inode, struct file *file) |
@@ -397,24 +380,7 @@ static int snmp_seq_show(struct seq_file *seq, void *v) | |||
397 | 380 | ||
398 | static int snmp_seq_open(struct inode *inode, struct file *file) | 381 | static int snmp_seq_open(struct inode *inode, struct file *file) |
399 | { | 382 | { |
400 | int err; | 383 | return single_open_net(inode, file, snmp_seq_show); |
401 | struct net *net; | ||
402 | |||
403 | err = -ENXIO; | ||
404 | net = get_proc_net(inode); | ||
405 | if (net == NULL) | ||
406 | goto err_net; | ||
407 | |||
408 | err = single_open(file, snmp_seq_show, net); | ||
409 | if (err < 0) | ||
410 | goto err_open; | ||
411 | |||
412 | return 0; | ||
413 | |||
414 | err_open: | ||
415 | put_net(net); | ||
416 | err_net: | ||
417 | return err; | ||
418 | } | 384 | } |
419 | 385 | ||
420 | static int snmp_seq_release(struct inode *inode, struct file *file) | 386 | static int snmp_seq_release(struct inode *inode, struct file *file) |
@@ -469,24 +435,7 @@ static int netstat_seq_show(struct seq_file *seq, void *v) | |||
469 | 435 | ||
470 | static int netstat_seq_open(struct inode *inode, struct file *file) | 436 | static int netstat_seq_open(struct inode *inode, struct file *file) |
471 | { | 437 | { |
472 | int err; | 438 | return single_open_net(inode, file, netstat_seq_show); |
473 | struct net *net; | ||
474 | |||
475 | err = -ENXIO; | ||
476 | net = get_proc_net(inode); | ||
477 | if (net == NULL) | ||
478 | goto err_net; | ||
479 | |||
480 | err = single_open(file, netstat_seq_show, net); | ||
481 | if (err < 0) | ||
482 | goto err_open; | ||
483 | |||
484 | return 0; | ||
485 | |||
486 | err_open: | ||
487 | put_net(net); | ||
488 | err_net: | ||
489 | return err; | ||
490 | } | 439 | } |
491 | 440 | ||
492 | static int netstat_seq_release(struct inode *inode, struct file *file) | 441 | static int netstat_seq_release(struct inode *inode, struct file *file) |
diff --git a/net/ipv6/proc.c b/net/ipv6/proc.c index cbc7e514d3ec..29c5a79444c2 100644 --- a/net/ipv6/proc.c +++ b/net/ipv6/proc.c | |||
@@ -183,24 +183,7 @@ static int snmp6_seq_show(struct seq_file *seq, void *v) | |||
183 | 183 | ||
184 | static int sockstat6_seq_open(struct inode *inode, struct file *file) | 184 | static int sockstat6_seq_open(struct inode *inode, struct file *file) |
185 | { | 185 | { |
186 | int err; | 186 | return single_open_net(inode, file, sockstat6_seq_show); |
187 | struct net *net; | ||
188 | |||
189 | err = -ENXIO; | ||
190 | net = get_proc_net(inode); | ||
191 | if (net == NULL) | ||
192 | goto err_net; | ||
193 | |||
194 | err = single_open(file, sockstat6_seq_show, net); | ||
195 | if (err < 0) | ||
196 | goto err_open; | ||
197 | |||
198 | return 0; | ||
199 | |||
200 | err_open: | ||
201 | put_net(net); | ||
202 | err_net: | ||
203 | return err; | ||
204 | } | 187 | } |
205 | 188 | ||
206 | static int sockstat6_seq_release(struct inode *inode, struct file *file) | 189 | static int sockstat6_seq_release(struct inode *inode, struct file *file) |
diff --git a/net/ipv6/route.c b/net/ipv6/route.c index 5d6c166dfbb6..fb7ff8f0c6db 100644 --- a/net/ipv6/route.c +++ b/net/ipv6/route.c | |||
@@ -2416,18 +2416,7 @@ static int ipv6_route_show(struct seq_file *m, void *v) | |||
2416 | 2416 | ||
2417 | static int ipv6_route_open(struct inode *inode, struct file *file) | 2417 | static int ipv6_route_open(struct inode *inode, struct file *file) |
2418 | { | 2418 | { |
2419 | int err; | 2419 | return single_open_net(inode, file, ipv6_route_show); |
2420 | struct net *net = get_proc_net(inode); | ||
2421 | if (!net) | ||
2422 | return -ENXIO; | ||
2423 | |||
2424 | err = single_open(file, ipv6_route_show, net); | ||
2425 | if (err < 0) { | ||
2426 | put_net(net); | ||
2427 | return err; | ||
2428 | } | ||
2429 | |||
2430 | return 0; | ||
2431 | } | 2420 | } |
2432 | 2421 | ||
2433 | static int ipv6_route_release(struct inode *inode, struct file *file) | 2422 | static int ipv6_route_release(struct inode *inode, struct file *file) |
@@ -2463,18 +2452,7 @@ static int rt6_stats_seq_show(struct seq_file *seq, void *v) | |||
2463 | 2452 | ||
2464 | static int rt6_stats_seq_open(struct inode *inode, struct file *file) | 2453 | static int rt6_stats_seq_open(struct inode *inode, struct file *file) |
2465 | { | 2454 | { |
2466 | int err; | 2455 | return single_open_net(inode, file, rt6_stats_seq_show); |
2467 | struct net *net = get_proc_net(inode); | ||
2468 | if (!net) | ||
2469 | return -ENXIO; | ||
2470 | |||
2471 | err = single_open(file, rt6_stats_seq_show, net); | ||
2472 | if (err < 0) { | ||
2473 | put_net(net); | ||
2474 | return err; | ||
2475 | } | ||
2476 | |||
2477 | return 0; | ||
2478 | } | 2456 | } |
2479 | 2457 | ||
2480 | static int rt6_stats_seq_release(struct inode *inode, struct file *file) | 2458 | static int rt6_stats_seq_release(struct inode *inode, struct file *file) |