diff options
Diffstat (limited to 'net/ipv4')
-rw-r--r-- | net/ipv4/netfilter/ipt_recent.c | 15 | ||||
-rw-r--r-- | net/ipv4/netfilter/nf_conntrack_l3proto_ipv4_compat.c | 36 |
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 = { | |||
381 | static int recent_seq_open(struct inode *inode, struct file *file) | 381 | static 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; | ||
401 | out: | ||
402 | return ret; | ||
403 | } | 392 | } |
404 | 393 | ||
405 | static ssize_t recent_proc_write(struct file *file, const char __user *input, | 394 | static 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 | ||
175 | static int ct_open(struct inode *inode, struct file *file) | 175 | static 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; | ||
190 | out_free: | ||
191 | kfree(st); | ||
192 | return ret; | ||
193 | } | 179 | } |
194 | 180 | ||
195 | static const struct file_operations ct_file_ops = { | 181 | static const struct file_operations ct_file_ops = { |
@@ -291,22 +277,8 @@ static const struct seq_operations exp_seq_ops = { | |||
291 | 277 | ||
292 | static int exp_open(struct inode *inode, struct file *file) | 278 | static 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; | ||
307 | out_free: | ||
308 | kfree(st); | ||
309 | return ret; | ||
310 | } | 282 | } |
311 | 283 | ||
312 | static const struct file_operations ip_exp_file_ops = { | 284 | static const struct file_operations ip_exp_file_ops = { |