From: Pablo Neira Ayuso <pablo@netfilter.org>
To: Florian Westphal <fw@strlen.de>
Cc: Liping Zhang <zlpnobody@163.com>,
netfilter-devel@vger.kernel.org,
Liping Zhang <liping.zhang@spreadtrum.com>
Subject: Re: [PATCH V2 iptables] extensions: libxt_connlabel: Add translation to nft
Date: Mon, 18 Jul 2016 22:18:05 +0200 [thread overview]
Message-ID: <20160718201805.GA4432@salvia> (raw)
In-Reply-To: <20160717104159.GA21065@breakpoint.cc>
On Sun, Jul 17, 2016 at 12:41:59PM +0200, Florian Westphal wrote:
> Pablo Neira Ayuso <pablo@netfilter.org> wrote:
> > On Sat, Jul 16, 2016 at 08:12:51PM +0200, Florian Westphal wrote:
> > > Pablo Neira Ayuso <pablo@netfilter.org> wrote:
> > > > On Sat, Jul 16, 2016 at 04:51:30PM +0200, Pablo Neira Ayuso wrote:
> > > > > On Sat, Jul 16, 2016 at 06:42:24PM +0800, Liping Zhang wrote:
> > > > > > # iptables-translate -A INPUT -m connlabel ! --label bit40 --set
> > > > > > nft add rule ip filter INPUT ct label set bit40 ct label and bit40 != bit40 counter
> > > > >
> > > > > I think this logic is inverted, I mean:
> > > > >
> > > > > nft add rule ip filter INPUT ct label and bit40 != bit40 ct label set bit40 counter
> > > > > ---------------------------
> > > > >
> > > > > test should happen before set.
> > > >
> > > > BTW, why not simply translate this to:
> > > >
> > > > nft add rule ip filter INPUT ct label set bit40 counter
> > >
> > > Its not the same as the bloated version.
> > >
> > > The set operation will only ever fail in case the conntrack doesn't have a label
> > >
> > > extension or is untracked/invalid, but if that is the case we get
> > > different results:
> > >
> > > nft add rule ip filter INPUT ct label set bit40 ct label and bit40 != bit40 counter
> > >
> > > -> counter Increments for every packet that lacks a conntrack, or the
> > > conntrack extension
> > >
> > > nft add rule ip filter INPUT ct label set bit40 counter
> > >
> > > -> counter Increments for every packet (we don't set NFT_BREAK anywhere
> > > in the setter).
>
> > set operations are not expected to return anything at all, they must
> > always evaluate true.
>
> Yes.
>
> > This behaviour is deviating from what we have in other set operations,
> > this is clearly inconsistent.
>
> How so?
So this is there just to cover the fail the ENOSPC when setting label?
This internal behaviour in xt connlabel seems confusing to me, this
rule:
iptables -A INPUT -m connlabel ! --label bit40 --set
following the reading from left to right convention tells me:
if not bit40 set, then set it.
But this is actually setting in first place inconditionally, then
checking this is not set, what is the use case for this?
Actually the kernel code first sets the bit, then checks if this is
unset for this. Note iptables-save displays this in that way as
output.
You can probably introduce in iptables something like:
iptables -A INPUT -m connlabel --set-label bit40
that we can naturally map to nftables for newcomers using this, as
well as less expensive.
next prev parent reply other threads:[~2016-07-18 20:18 UTC|newest]
Thread overview: 11+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-07-16 10:42 [PATCH V2 iptables] extensions: libxt_connlabel: Add translation to nft Liping Zhang
2016-07-16 10:49 ` Florian Westphal
2016-07-16 14:48 ` Pablo Neira Ayuso
2016-07-16 14:51 ` Pablo Neira Ayuso
2016-07-16 14:55 ` Pablo Neira Ayuso
2016-07-16 18:12 ` Florian Westphal
2016-07-17 10:24 ` Pablo Neira Ayuso
2016-07-17 10:41 ` Florian Westphal
2016-07-18 20:18 ` Pablo Neira Ayuso [this message]
2016-07-18 21:02 ` Florian Westphal
2016-07-16 17:59 ` Florian Westphal
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20160718201805.GA4432@salvia \
--to=pablo@netfilter.org \
--cc=fw@strlen.de \
--cc=liping.zhang@spreadtrum.com \
--cc=netfilter-devel@vger.kernel.org \
--cc=zlpnobody@163.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).