diff options
author | Pavel Emelyanov <xemul@openvz.org> | 2007-10-10 05:29:29 -0400 |
---|---|---|
committer | David S. Miller <davem@sunset.davemloft.net> | 2007-10-10 19:55:33 -0400 |
commit | cf7732e4cc14b56d593ff53352673e1fd5e3ba52 (patch) | |
tree | 3479e278b72f9d535a58066bc2a26238806252ce /net/ipv6/ip6_flowlabel.c | |
parent | 39699037a5c94d7cd1363dfe48a50c78c643fd9a (diff) |
[NET]: Make core networking code use seq_open_private
This concerns the ipv4 and ipv6 code mostly, but also the netlink
and unix sockets.
The netlink code is an example of how to use the __seq_open_private()
call - it saves the net namespace on this private.
Signed-off-by: Pavel Emelyanov <xemul@openvz.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/ipv6/ip6_flowlabel.c')
-rw-r--r-- | net/ipv6/ip6_flowlabel.c | 20 |
1 files changed, 2 insertions, 18 deletions
diff --git a/net/ipv6/ip6_flowlabel.c b/net/ipv6/ip6_flowlabel.c index 1791399c7f10..217d60f9fc80 100644 --- a/net/ipv6/ip6_flowlabel.c +++ b/net/ipv6/ip6_flowlabel.c | |||
@@ -658,24 +658,8 @@ static const struct seq_operations ip6fl_seq_ops = { | |||
658 | 658 | ||
659 | static int ip6fl_seq_open(struct inode *inode, struct file *file) | 659 | static int ip6fl_seq_open(struct inode *inode, struct file *file) |
660 | { | 660 | { |
661 | struct seq_file *seq; | 661 | return seq_open_private(file, &ip6fl_seq_ops, |
662 | int rc = -ENOMEM; | 662 | sizeof(struct ip6fl_iter_state)); |
663 | struct ip6fl_iter_state *s = kzalloc(sizeof(*s), GFP_KERNEL); | ||
664 | |||
665 | if (!s) | ||
666 | goto out; | ||
667 | |||
668 | rc = seq_open(file, &ip6fl_seq_ops); | ||
669 | if (rc) | ||
670 | goto out_kfree; | ||
671 | |||
672 | seq = file->private_data; | ||
673 | seq->private = s; | ||
674 | out: | ||
675 | return rc; | ||
676 | out_kfree: | ||
677 | kfree(s); | ||
678 | goto out; | ||
679 | } | 663 | } |
680 | 664 | ||
681 | static const struct file_operations ip6fl_seq_fops = { | 665 | static const struct file_operations ip6fl_seq_fops = { |