sctp: introduce SCTP_FUTURE/CURRENT/ALL_ASSOC
authorXin Long <lucien.xin@gmail.com>
Mon, 28 Jan 2019 07:08:23 +0000 (15:08 +0800)
committerDavid S. Miller <davem@davemloft.net>
Wed, 30 Jan 2019 08:44:06 +0000 (00:44 -0800)
This patch is to add 3 constants SCTP_FUTURE_ASSOC,
SCTP_CURRENT_ASSOC and SCTP_ALL_ASSOC for reserved
assoc_ids, as defined in rfc6458#section-7.2.

And add the process for them when doing lookup and
inserting in sctp_id2assoc and sctp_assoc_set_id.

Signed-off-by: Xin Long <lucien.xin@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
include/uapi/linux/sctp.h
net/sctp/associola.c
net/sctp/socket.c

index d584073532b81d692b150c8502235f24f0ecbd13..b8f2c4d56532584a7edc204a40b3c020e772bb69 100644 (file)
 
 typedef __s32 sctp_assoc_t;
 
+#define SCTP_FUTURE_ASSOC      0
+#define SCTP_CURRENT_ASSOC     1
+#define SCTP_ALL_ASSOC         2
+
 /* The following symbols come from the Sockets API Extensions for
  * SCTP <draft-ietf-tsvwg-sctpsocket-07.txt>.
  */
index 201c888604e403123cf5ab5defe7a75387828886..b99f163e33acdd668e5746f731c99fe1369363ba 100644 (file)
@@ -1651,8 +1651,11 @@ int sctp_assoc_set_id(struct sctp_association *asoc, gfp_t gfp)
        if (preload)
                idr_preload(gfp);
        spin_lock_bh(&sctp_assocs_id_lock);
-       /* 0 is not a valid assoc_id, must be >= 1 */
-       ret = idr_alloc_cyclic(&sctp_assocs_id, asoc, 1, 0, GFP_NOWAIT);
+       /* 0, 1, 2 are used as SCTP_FUTURE_ASSOC, SCTP_CURRENT_ASSOC and
+        * SCTP_ALL_ASSOC, so an available id must be > SCTP_ALL_ASSOC.
+        */
+       ret = idr_alloc_cyclic(&sctp_assocs_id, asoc, SCTP_ALL_ASSOC + 1, 0,
+                              GFP_NOWAIT);
        spin_unlock_bh(&sctp_assocs_id_lock);
        if (preload)
                idr_preload_end();
index f93c3cf9e5674b5d446e90ccd43611eca5fab508..a52d132470ea1583543a4b1c03c190e6955abadb 100644 (file)
@@ -248,7 +248,7 @@ struct sctp_association *sctp_id2assoc(struct sock *sk, sctp_assoc_t id)
        }
 
        /* Otherwise this is a UDP-style socket. */
-       if (!id || (id == (sctp_assoc_t)-1))
+       if (id <= SCTP_ALL_ASSOC)
                return NULL;
 
        spin_lock_bh(&sctp_assocs_id_lock);