[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <Y3zUosZQhPyoE53C@unreal>
Date: Tue, 22 Nov 2022 15:54:42 +0200
From: Leon Romanovsky <leon@...nel.org>
To: Steffen Klassert <steffen.klassert@...unet.com>
Cc: Herbert Xu <herbert@...dor.apana.org.au>,
"David S. Miller" <davem@...emloft.net>,
Eric Dumazet <edumazet@...gle.com>,
Jakub Kicinski <kuba@...nel.org>, netdev@...r.kernel.org
Subject: Re: [PATCH xfrm-next v7 6/8] xfrm: speed-up lookup of HW policies
On Tue, Nov 22, 2022 at 02:00:02PM +0100, Steffen Klassert wrote:
> On Tue, Nov 22, 2022 at 08:27:48AM +0200, Leon Romanovsky wrote:
> > On Tue, Nov 22, 2022 at 12:29:12PM +0800, Herbert Xu wrote:
> > > On Mon, Nov 21, 2022 at 03:21:45PM +0200, Leon Romanovsky wrote:
> > > >
> > > > The thing is that this SW acquire flow is a fraction case, as it applies
> > > > to locally generated traffic.
> > >
> > > A router can trigger an acquire on forwarded packets too. Without
> > > larvals this could quickly overwhelm the router.
> >
> > This series doesn't support tunnel mode yet.
>
> It does not matter if tunnel or transport mode, acquires must
> work as expected. This is a fundamental concept of IPsec, there
> is no way to tell userspace that we don't support this.
>
> > Maybe I was not clear, but I wanted to say what in eswitch case and
> > tunnel mode, the packets will be handled purely by HW without raising
> > into SW core.
>
> Can you please explain why we need host interaction for
> transport, but not for tunnel mode?
The main difference is that in transport mode, you must bring packet
to the kernel in which you configured SA/policy. It means that we must
ensure that such packets won't be checked again in SW because all packets
(encrypted and not) pass XFRM logic.
- wire -> RX NIC -> kernel -> XFRM stack (we need HW DB here to skip this stage) -> ....
... -> kernel -> XFRM stack (skip for HW SA/policies) -> TX NIC -> wire.
In tunnel mode, we arrive to XFRM when nothing IPsec related is configured.
- wire -> RX PF NIC -> eswitch NIC logic -> TX uplink NIC -> RX
representors -> XFRM stack in VM (nothing configured here) -> kernel
The most troublesome part is in TX path, where you must skip "double check"
before NIC. This check doesn't exist in tunnel mode.
In RX, there is also difference between modes due to how we are supposed
to treat headers.
Raed will add more details.
>
> And as said already, I want to see the full picture (transport
> + tunnel mode) before we merge it.
It looks like we already have this picture.
Thanks
Powered by blists - more mailing lists