[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <CADvbK_fPbz+Rso6ADXh2PpUYoMRtHnbJdu4VygckAjDiW1MzSw@mail.gmail.com>
Date: Wed, 30 Jan 2019 15:03:01 +0800
From: Xin Long <lucien.xin@...il.com>
To: Neil Horman <nhorman@...driver.com>
Cc: network dev <netdev@...r.kernel.org>, linux-sctp@...r.kernel.org,
Marcelo Ricardo Leitner <marcelo.leitner@...il.com>,
davem <davem@...emloft.net>
Subject: Re: [PATCH net-next 02/24] sctp: use SCTP_FUTURE_ASSOC for
SCTP_PEER_ADDR_PARAMS sockopt
On Wed, Jan 30, 2019 at 5:25 AM Neil Horman <nhorman@...driver.com> wrote:
>
> On Mon, Jan 28, 2019 at 03:08:24PM +0800, Xin Long wrote:
> > Check with SCTP_FUTURE_ASSOC instead in
> > sctp_/setgetsockopt_peer_addr_params, it's compatible with 0.
> >
> > Signed-off-by: Xin Long <lucien.xin@...il.com>
> > ---
> > net/sctp/socket.c | 18 ++++++++++--------
> > 1 file changed, 10 insertions(+), 8 deletions(-)
> >
> > diff --git a/net/sctp/socket.c b/net/sctp/socket.c
> > index a52d132..4c43b95 100644
> > --- a/net/sctp/socket.c
> > +++ b/net/sctp/socket.c
> > @@ -2750,12 +2750,13 @@ static int sctp_setsockopt_peer_addr_params(struct sock *sk,
> > return -EINVAL;
> > }
> >
> > - /* Get association, if assoc_id != 0 and the socket is a one
> > - * to many style socket, and an association was not found, then
> > - * the id was invalid.
> > + /* Get association, if assoc_id != SCTP_FUTURE_ASSOC and the
> > + * socket is a one to many style socket, and an association
> > + * was not found, then the id was invalid.
> > */
> > asoc = sctp_id2assoc(sk, params.spp_assoc_id);
> > - if (!asoc && params.spp_assoc_id && sctp_style(sk, UDP))
> > + if (!asoc && params.spp_assoc_id != SCTP_FUTURE_ASSOC &&
> Sorry to follow up, but I misspoke in my previous email, I should have said, why
> do we only allow future associations as the only special case association id
> here? Since the function is meant to set a specific association id, it seems to
> me that you would want to:
>
> a) allow setting of a specific id
> b) allow setting of all association ids on the socket
> (SCTP_CURRENT_ASSOC)
> c) allow recording of a set of params to apply to all current and future
> associations (FUTURE/ALL).
>
> (a) is already handled clearly, but (b) and (c) require more work on this
> function than just checking association id on entry.
Hi, Neil,
Note that not all sockopts support both of them, like
we don't allow some sockopt to be applied to current assocs.
and we don't allow some to be applied to future assocs.
SCTP_FUTURE_ASSOC means sock's xxxx only
SCTP_CURRENT_ASSOC means all sock->asocs' xxxx only
If we only check assoc_id != SCTP_FUTURE_ASSOC, it means this
sockopt doesn't support for all sock->asocs xxxx setting,
or getting (like all sockopts getting).
If we only check assoc_id != SCTP_CURRENT_ASSOC, it means this
sockopt doesn't support for sock's xxxx setting (like Patch 11)
As for SCTP_ALL_ASSOC, it means both of sock's and sock->asocs
xxxx, not either of them. So we don't allow it in here.
As you can see, in this patchset:
1. for sockopt setting:
these who only support FUTURE will check SCTP_FUTURE_ASSOC, like Patch 2-10.
these who only support CURRENT will check SCTP_CURRENT_ASSOC, like Patch 11.
these who support both FUTURE and CURRENT will check assoc_id >
SCTP_ALL_ASSOC, like Patch 12-24.
2. for sockopt getting:
all sockopts will check SCTP_FUTURE_ASSOC. (as it's impossible to
get all sock->asocs' xxxx)
>
> I think this comment may apply to all the socket option functions
>
> > + sctp_style(sk, UDP))
> > return -EINVAL;
> >
> > /* Heartbeat demand can only be sent on a transport or
> > @@ -5676,12 +5677,13 @@ static int sctp_getsockopt_peer_addr_params(struct sock *sk, int len,
> > }
> > }
> >
> > - /* Get association, if assoc_id != 0 and the socket is a one
> > - * to many style socket, and an association was not found, then
> > - * the id was invalid.
> > + /* Get association, if assoc_id != SCTP_FUTURE_ASSOC and the
> > + * socket is a one to many style socket, and an association
> > + * was not found, then the id was invalid.
> > */
> > asoc = sctp_id2assoc(sk, params.spp_assoc_id);
> > - if (!asoc && params.spp_assoc_id && sctp_style(sk, UDP)) {
> > + if (!asoc && params.spp_assoc_id != SCTP_FUTURE_ASSOC &&
> > + sctp_style(sk, UDP)) {
> > pr_debug("%s: failed no association\n", __func__);
> > return -EINVAL;
> > }
> > --
> > 2.1.0
> >
> >
Powered by blists - more mailing lists