From: Christophe Gouault <christophe.gouault@6wind.com>
To: David Miller <davem@davemloft.net>
Cc: netdev@vger.kernel.org
Subject: Re: IPsec: Why do pfkey_getspi and xfrm_alloc_userspi call xfrm_find_acq_byseq?
Date: Mon, 23 Aug 2010 15:30:46 +0200 [thread overview]
Message-ID: <4C727806.3060102@6wind.com> (raw)
In-Reply-To: <20100822.005353.260099324.davem@davemloft.net>
Hi David,
First of all, thank you for your answer.
David Miller wrote:
> From: Christophe Gouault <christophe.gouault@6wind.com>
> Date: Thu, 19 Aug 2010 14:55:21 +0200
>
>> The call to xfrm_find_acq_byseq() by the pfkey_getspi() and
>> xfrm_alloc_userspi() functions is quite costly and proves to entail
>> scalability issues when performing thousands of IKE negotiations with
>> racoon (from ipsec-tools distribution) or charon (from strongswan
>> distribution).
>>
>> Removing this call in the kernel drastically accelerates the
>> processing and does not seem to entail functional problems.
>>
>> For now, I don't see the point of this call. I need to understand its
>> purpose, because I'm highly tempted to simply remove it.
> First of all, removing a function because you don't understand
> why it's there is rarely a good idea :-)
Yes, don't worry, I never act that way. I was deliberately a little
provocative ;-)
> I think the semantics require that we check for existing ACQUIRE
> state entries before we allocate an SPI.
Well, I still don't see in which case this can happen. The only
situations in which an ACQUIRE state entry is created is when an acquire
message is raised by the kernel (this creates a temporary outbound
state) or when a getspi is issued from the userland (this creates a
temporary state, as far as I know, this is the future inbound state
negotiated by IKE).
In my humble opinion, issuing a getspi for the output state does not
make sense since the SPI is chosen by the destination host.
So the possibly existing ACQUIRE state entry would be the result of a
former getspi with the same value of the seq field. So this call would
aim at cancelling a former call to getspi, maybe to cope with an
application that would retry a failed negotiation before the former
getspi expired?... I'm not really convinced by this explanation.
But there are maybe other uses of the getspi call than assigning a SPI
for the inbound state of an IKE negotiation...
> The likelyhood of breaking something if you remove the call is very
> high.
Probably. I'm still interested in a concrete example ;-)
Christophe
next prev parent reply other threads:[~2010-08-23 13:33 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
2010-08-19 12:55 IPsec: Why do pfkey_getspi and xfrm_alloc_userspi call xfrm_find_acq_byseq? Christophe Gouault
2010-08-22 7:53 ` David Miller
2010-08-23 13:30 ` Christophe Gouault [this message]
2010-08-23 14:47 ` Christophe Gouault
2010-09-12 18:47 ` David Miller
-- strict thread matches above, loose matches on Subject: below --
2010-08-17 8:46 Christophe Gouault
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=4C727806.3060102@6wind.com \
--to=christophe.gouault@6wind.com \
--cc=davem@davemloft.net \
--cc=netdev@vger.kernel.org \
/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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.