aboutsummaryrefslogtreecommitdiffstats
path: root/net/ipv4
diff options
context:
space:
mode:
Diffstat (limited to 'net/ipv4')
-rw-r--r--net/ipv4/netfilter/ipt_recent.c15
-rw-r--r--net/ipv4/netfilter/nf_conntrack_l3proto_ipv4_compat.c36
2 files changed, 6 insertions, 45 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 = {