Hi Pablo, 2016-07-20 16:25 GMT+08:00 Pablo Neira Ayuso <pablo@xxxxxxxxxxxxx>: > On Wed, Jul 20, 2016 at 07:00:13AM +0800, Liping Zhang wrote: >> I find that nftables already support this feature, the following command mean to truncate packets >> to 100 bytes before logging to the userspace: >> #nft add rule filter input log group 0 snaplen 100 >> >> Before my patch, it does not work. >> And after apply my patch, it works as expected. > > If I git grep NF_LOG_F_COPY_LEN from the nftables.git tree, I don't > see any reference to this flag being set. > I use this NF_LOG_F_COPY_LEN flag as internal, and when the user specify the NFTA_LOG_SNAPLEN attrribute, it will be enabled automatically. See my codes: if (tb[NFTA_LOG_SNAPLEN] != NULL) { + li->u.ulog.flags |= NF_LOG_F_COPY_LEN; - if (li->u.ulog.copy_len) { + if (li->u.ulog.flags & NF_LOG_F_COPY_LEN) { if (nla_put_be32(skb, NFTA_LOG_SNAPLEN, htonl(li->u.ulog.copy_len))) So this flag will not be setted from userspace explicitly and will not be dumped to the userspace. > Then, nft_log kernel has been actually working fine since the > beginning. It would be good anyway if we set this flag on from > userspace to leave things in consistent state. Do you mean this is something similar to "nflog-size" and "nflog-range" in xt_NFLOG? "nft log snaplen 100" cannot work since the beginning, so we should keep it unchanged? And maybe we should introduce a new option like "nft log snapsize 100"? -- 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