Skip site navigation (1)Skip section navigation (2)
Date:      Tue, 22 Nov 2016 11:23:14 +0000 (UTC)
From:      "Andrey V. Elsukov" <ae@FreeBSD.org>
To:        src-committers@freebsd.org, svn-src-projects@freebsd.org
Subject:   svn commit: r308982 - projects/ipsec/sys/netipsec
Message-ID:  <201611221123.uAMBNE2Y003937@repo.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: ae
Date: Tue Nov 22 11:23:14 2016
New Revision: 308982
URL: https://svnweb.freebsd.org/changeset/base/308982

Log:
  Modify key_getnewspid() to use SPHASH.
  Make key_newreqid() to be global, it will be used from outside key.c.

Modified:
  projects/ipsec/sys/netipsec/key.c

Modified: projects/ipsec/sys/netipsec/key.c
==============================================================================
--- projects/ipsec/sys/netipsec/key.c	Tue Nov 22 11:18:19 2016	(r308981)
+++ projects/ipsec/sys/netipsec/key.c	Tue Nov 22 11:23:14 2016	(r308982)
@@ -1407,17 +1407,19 @@ key_msg2sp(struct sadb_x_policy *xpl0, s
 	*error = 0;
 	return (newsp);
 }
-static u_int32_t
-key_newreqid()
+
+uint32_t
+key_newreqid(void)
 {
-	static u_int32_t auto_reqid = IPSEC_MANUAL_REQID_MAX + 1;
+	static uint32_t auto_reqid = IPSEC_MANUAL_REQID_MAX + 1;
 
-	auto_reqid = (auto_reqid == ~0
-			? IPSEC_MANUAL_REQID_MAX + 1 : auto_reqid + 1);
+	if (auto_reqid == ~0)
+		auto_reqid = IPSEC_MANUAL_REQID_MAX + 1;
+	else
+		auto_reqid++;
 
 	/* XXX should be unique check */
-
-	return auto_reqid;
+	return (auto_reqid);
 }
 
 /*
@@ -1783,30 +1785,32 @@ key_spdadd(struct socket *so, struct mbu
  *	0:	failure.
  *	others: success.
  */
-static u_int32_t
-key_getnewspid()
+static uint32_t
+key_getnewspid(void)
 {
-	u_int32_t newid = 0;
-	int count = V_key_spi_trycnt;	/* XXX */
 	struct secpolicy *sp;
+	uint32_t newid = 0;
+	int count = V_key_spi_trycnt;	/* XXX */
 
-	/* when requesting to allocate spi ranged */
+	SPTREE_WLOCK_ASSERT();
 	while (count--) {
-		newid = (V_policy_id = (V_policy_id == ~0 ? 1 : V_policy_id + 1));
-
-		if ((sp = key_getspbyid(newid)) == NULL)
+		if (V_policy_id == ~0) /* overflowed */
+			newid = V_policy_id = 1;
+		else
+			newid = ++V_policy_id;
+		LIST_FOREACH(sp, SPHASH_HASH(newid), idhash) {
+			if (sp->id == newid)
+				break;
+		}
+		if (sp == NULL)
 			break;
-
-		KEY_FREESP(&sp);
 	}
-
 	if (count == 0 || newid == 0) {
-		ipseclog((LOG_DEBUG, "%s: to allocate policy id is failed.\n",
-			__func__));
-		return 0;
+		ipseclog((LOG_DEBUG, "%s: failed to allocate policy id.\n",
+		    __func__));
+		return (0);
 	}
-
-	return newid;
+	return (newid);
 }
 
 /*



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201611221123.uAMBNE2Y003937>