aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--net/ipv4/netfilter/ipt_recent.c15
-rw-r--r--net/ipv4/netfilter/nf_conntrack_l3proto_ipv4_compat.c36
-rw-r--r--net/netfilter/nf_conntrack_expect.c18
-rw-r--r--net/netfilter/nf_conntrack_standalone.c18
-rw-r--r--net/netfilter/nfnetlink_log.c18
-rw-r--r--net/netfilter/nfnetlink_queue.c18
6 files changed, 14 insertions, 109 deletions
diff --git a/net/ipv4/netfilter/ipt_recent.c b/net/ipv4/netfilter/ipt_recent.c
index db2a79889f9a..11d39fb5f38b 100644
--- a/net/ipv4/netfilter/ipt_recent.c
+++ b/net/ipv4/netfilter/ipt_recent.c
@@ -381,25 +381,14 @@ static const struct seq_operations recent_seq_ops = {
381static int recent_seq_open(struct inode *inode, struct file *file) 381static int recent_seq_open(struct inode *inode, struct file *file)
382{ 382{
383 struct proc_dir_entry *pde = PDE(inode); 383 struct proc_dir_entry *pde = PDE(inode);
384 struct seq_file *seq;
385 struct recent_iter_state *st; 384 struct recent_iter_state *st;
386 int ret;
387 385
388 st = kzalloc(sizeof(*st), GFP_KERNEL); 386 st = __seq_open_private(file, &recent_seq_ops, sizeof(*st));
389 if (st == NULL) 387 if (st == NULL)
390 return -ENOMEM; 388 return -ENOMEM;
391 389
392 ret = seq_open(file, &recent_seq_ops);
393 if (ret) {
394 kfree(st);
395 goto out;
396 }
397
398 st->table = pde->data; 390 st->table = pde->data;
399 seq = file->private_data; 391 return 0;
400 seq->private = st;
401out:
402 return ret;
403} 392}
404 393
405static ssize_t recent_proc_write(struct file *file, const char __user *input, 394static ssize_t recent_proc_write(struct file *file, const char __user *input,
diff --git a/net/ipv4/netfilter/nf_conntrack_l3proto_ipv4_compat.c b/net/ipv4/netfilter/nf_conntrack_l3proto_ipv4_compat.c
index a5ae2eabf0f3..741f3dfaa5a1 100644
--- a/net/ipv4/netfilter/nf_conntrack_l3proto_ipv4_compat.c
+++ b/net/ipv4/netfilter/nf_conntrack_l3proto_ipv4_compat.c
@@ -174,22 +174,8 @@ static const struct seq_operations ct_seq_ops = {
174 174
175static int ct_open(struct inode *inode, struct file *file) 175static int ct_open(struct inode *inode, struct file *file)
176{ 176{
177 struct seq_file *seq; 177 return seq_open_private(file, &ct_seq_ops,
178 struct ct_iter_state *st; 178 sizeof(struct ct_iter_state));
179 int ret;
180
181 st = kzalloc(sizeof(struct ct_iter_state), GFP_KERNEL);
182 if (st == NULL)
183 return -ENOMEM;
184 ret = seq_open(file, &ct_seq_ops);
185 if (ret)
186 goto out_free;
187 seq = file->private_data;
188 seq->private = st;
189 return ret;
190out_free:
191 kfree(st);
192 return ret;
193} 179}
194 180
195static const struct file_operations ct_file_ops = { 181static const struct file_operations ct_file_ops = {
@@ -291,22 +277,8 @@ static const struct seq_operations exp_seq_ops = {
291 277
292static int exp_open(struct inode *inode, struct file *file) 278static int exp_open(struct inode *inode, struct file *file)
293{ 279{
294 struct seq_file *seq; 280 return seq_open_private(file, &exp_seq_ops,
295 struct ct_expect_iter_state *st; 281 sizeof(struct ct_expect_iter_state));
296 int ret;
297
298 st = kzalloc(sizeof(struct ct_expect_iter_state), GFP_KERNEL);
299 if (!st)
300 return -ENOMEM;
301 ret = seq_open(file, &exp_seq_ops);
302 if (ret)
303 goto out_free;
304 seq = file->private_data;
305 seq->private = st;
306 return ret;
307out_free:
308 kfree(st);
309 return ret;
310} 282}
311 283
312static const struct file_operations ip_exp_file_ops = { 284static const struct file_operations ip_exp_file_ops = {
diff --git a/net/netfilter/nf_conntrack_expect.c b/net/netfilter/nf_conntrack_expect.c
index 7a0ae36c9b47..175c8d1a1992 100644
--- a/net/netfilter/nf_conntrack_expect.c
+++ b/net/netfilter/nf_conntrack_expect.c
@@ -472,22 +472,8 @@ static const struct seq_operations exp_seq_ops = {
472 472
473static int exp_open(struct inode *inode, struct file *file) 473static int exp_open(struct inode *inode, struct file *file)
474{ 474{
475 struct seq_file *seq; 475 return seq_open_private(file, &exp_seq_ops,
476 struct ct_expect_iter_state *st; 476 sizeof(struct ct_expect_iter_state));
477 int ret;
478
479 st = kzalloc(sizeof(struct ct_expect_iter_state), GFP_KERNEL);
480 if (!st)
481 return -ENOMEM;
482 ret = seq_open(file, &exp_seq_ops);
483 if (ret)
484 goto out_free;
485 seq = file->private_data;
486 seq->private = st;
487 return ret;
488out_free:
489 kfree(st);
490 return ret;
491} 477}
492 478
493static const struct file_operations exp_file_ops = { 479static const struct file_operations exp_file_ops = {
diff --git a/net/netfilter/nf_conntrack_standalone.c b/net/netfilter/nf_conntrack_standalone.c
index 2a19c5f1240f..9efdd37fc195 100644
--- a/net/netfilter/nf_conntrack_standalone.c
+++ b/net/netfilter/nf_conntrack_standalone.c
@@ -195,22 +195,8 @@ static const struct seq_operations ct_seq_ops = {
195 195
196static int ct_open(struct inode *inode, struct file *file) 196static int ct_open(struct inode *inode, struct file *file)
197{ 197{
198 struct seq_file *seq; 198 return seq_open_private(file, &ct_seq_ops,
199 struct ct_iter_state *st; 199 sizeof(struct ct_iter_state));
200 int ret;
201
202 st = kzalloc(sizeof(struct ct_iter_state), GFP_KERNEL);
203 if (st == NULL)
204 return -ENOMEM;
205 ret = seq_open(file, &ct_seq_ops);
206 if (ret)
207 goto out_free;
208 seq = file->private_data;
209 seq->private = st;
210 return ret;
211out_free:
212 kfree(st);
213 return ret;
214} 200}
215 201
216static const struct file_operations ct_file_ops = { 202static const struct file_operations ct_file_ops = {
diff --git a/net/netfilter/nfnetlink_log.c b/net/netfilter/nfnetlink_log.c
index 2135926199ca..2c7bd2eb0294 100644
--- a/net/netfilter/nfnetlink_log.c
+++ b/net/netfilter/nfnetlink_log.c
@@ -951,22 +951,8 @@ static const struct seq_operations nful_seq_ops = {
951 951
952static int nful_open(struct inode *inode, struct file *file) 952static int nful_open(struct inode *inode, struct file *file)
953{ 953{
954 struct seq_file *seq; 954 return seq_open_private(file, &nful_seq_ops,
955 struct iter_state *is; 955 sizeof(struct iter_state));
956 int ret;
957
958 is = kzalloc(sizeof(*is), GFP_KERNEL);
959 if (!is)
960 return -ENOMEM;
961 ret = seq_open(file, &nful_seq_ops);
962 if (ret < 0)
963 goto out_free;
964 seq = file->private_data;
965 seq->private = is;
966 return ret;
967out_free:
968 kfree(is);
969 return ret;
970} 956}
971 957
972static const struct file_operations nful_file_ops = { 958static const struct file_operations nful_file_ops = {
diff --git a/net/netfilter/nfnetlink_queue.c b/net/netfilter/nfnetlink_queue.c
index 48e095a7de2d..49f0480afe09 100644
--- a/net/netfilter/nfnetlink_queue.c
+++ b/net/netfilter/nfnetlink_queue.c
@@ -1051,22 +1051,8 @@ static const struct seq_operations nfqnl_seq_ops = {
1051 1051
1052static int nfqnl_open(struct inode *inode, struct file *file) 1052static int nfqnl_open(struct inode *inode, struct file *file)
1053{ 1053{
1054 struct seq_file *seq; 1054 return seq_open_private(file, &nfqnl_seq_ops,
1055 struct iter_state *is; 1055 sizeof(struct iter_state));
1056 int ret;
1057
1058 is = kzalloc(sizeof(*is), GFP_KERNEL);
1059 if (!is)
1060 return -ENOMEM;
1061 ret = seq_open(file, &nfqnl_seq_ops);
1062 if (ret < 0)
1063 goto out_free;
1064 seq = file->private_data;
1065 seq->private = is;
1066 return ret;
1067out_free:
1068 kfree(is);
1069 return ret;
1070} 1056}
1071 1057
1072static const struct file_operations nfqnl_file_ops = { 1058static const struct file_operations nfqnl_file_ops = {