On Tue, 2014-09-23 at 18:05 +0100, Rob Jones wrote: > Reduce boilerplate code by using __seq_open_private() instead of seq_open() > in xt_match_open() and xt_target_open(). > > Signed-off-by: Rob Jones <rob.jones@xxxxxxxxxxxxxxx> > --- > > This patch uses an existing variant of seq_open() to reduce the kernel code > size. > > The only significant variation from the pre-existing code is the fact that > __seq_open_private() calls kzalloc() rather than kmalloc(), which could > conceivably have an impact on timing. > > This version 2 incorporates a minor initialisation simplification (resulting > from kzalloc() being used) requested by netfilter-devel@xxxxxxxxxxxxxxx [...] > --- a/net/netfilter/x_tables.c > +++ b/net/netfilter/x_tables.c > @@ -1080,7 +1080,6 @@ static void *xt_mttg_seq_start(struct seq_file *seq, loff_t *pos, > struct nf_mttg_trav *trav = seq->private; > unsigned int j; > > - trav->class = MTTG_TRAV_INIT; > for (j = 0; j < *pos; ++j) > if (xt_mttg_seq_next(seq, NULL, NULL, is_target) == NULL) > return NULL; [...] I'm fairly sure this simplification is wrong, as xt_mttg_seq_start() is potentially called multiple times on the same file handle. Ben. -- To unsubscribe from this list: send the line "unsubscribe netfilter-devel" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html