On Tue, Jan 24, 2017 at 08:26:29PM +0100, Pablo Neira Ayuso wrote: > On Sun, Jan 22, 2017 at 10:10:32PM +0800, Liping Zhang wrote: > > From: Liping Zhang <zlpnobody@xxxxxxxxx> > > > > First, log prefix will be truncated to NF_LOG_PREFIXLEN-1, i.e. 127, > > at nf_log_packet(), so the extra part is useless. > > > > Second, after adding a log rule with a very very long prefix, we will > > fail to dump the nft rules after this _special_ one, but acctually, > > they do exist. For example: > > # name_65000=$(printf "%0.sQ" {1..65000}) > > # nft add rule filter output log prefix "$name_65000" > > # nft add rule filter output counter > > # nft add rule filter output counter > > # nft list chain filter output > > table ip filter { > > chain output { > > type filter hook output priority 0; policy accept; > > } > > } > > > > So now, restrict the log prefix length to NF_LOG_PREFIXLEN-1. > > > > Fixes: 96518518cc41 ("netfilter: add nftables") > > Signed-off-by: Liping Zhang <zlpnobody@xxxxxxxxx> > > --- > > I think this is different with http://patchwork.ozlabs.org/patch/717635/. > > So another separate patch will be better. > > > > include/uapi/linux/netfilter/nf_log.h | 2 ++ > > net/netfilter/nf_log.c | 1 - > > net/netfilter/nft_log.c | 3 ++- > > 3 files changed, 4 insertions(+), 2 deletions(-) > > > > diff --git a/include/uapi/linux/netfilter/nf_log.h b/include/uapi/linux/netfilter/nf_log.h > > index 8be21e0..d0b5fa9 100644 > > --- a/include/uapi/linux/netfilter/nf_log.h > > +++ b/include/uapi/linux/netfilter/nf_log.h > > @@ -9,4 +9,6 @@ > > #define NF_LOG_MACDECODE 0x20 /* Decode MAC header */ > > #define NF_LOG_MASK 0x2f > > > > +#define NF_LOG_PREFIXLEN 128 > > Nitpick: xt_LOG allows 30 bytes, so we can probably stick to 32 bytes > here. Then, wait for usecases for larger strings, enlarging things is > easier than shrinking stuff later on (we can't actually, given that we > would break backward). > > Probably we can keep __NF_LOG_PREFIXLEN 128 for what it already exists > in nf_log.c internally, and expose NF_LOG_PREFIXLEN of 32 bytes? Hm. We've been exposing 128 bytes already since the beginning given we lacked any validation. Then, this patch is fine. Applied, thanks. -- 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