Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/netipsec Pass sav directly to opencrypto callback
details: https://anonhg.NetBSD.org/src/rev/9a80daa21ea2
branches: trunk
changeset: 355126:9a80daa21ea2
user: ozaki-r <ozaki-r%NetBSD.org@localhost>
date: Fri Jul 14 01:24:23 2017 +0000
description:
Pass sav directly to opencrypto callback
In a callback, use a passed sav as-is by default and look up a sav
only if the passed sav is dead.
diffstat:
sys/netipsec/key.c | 15 +++++++++-
sys/netipsec/key.h | 5 +++-
sys/netipsec/xform.h | 7 +++--
sys/netipsec/xform_ah.c | 45 ++++++++++++++++++++++------------
sys/netipsec/xform_esp.c | 59 +++++++++++++++++++++++++++-----------------
sys/netipsec/xform_ipcomp.c | 45 ++++++++++++++++++++++------------
sys/netipsec/xform_ipip.c | 8 +++---
sys/netipsec/xform_tcp.c | 6 ++--
8 files changed, 122 insertions(+), 68 deletions(-)
diffs (truncated from 479 to 300 lines):
diff -r a9aa6300f90c -r 9a80daa21ea2 sys/netipsec/key.c
--- a/sys/netipsec/key.c Thu Jul 13 22:17:09 2017 +0000
+++ b/sys/netipsec/key.c Fri Jul 14 01:24:23 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: key.c,v 1.181 2017/07/13 01:22:44 ozaki-r Exp $ */
+/* $NetBSD: key.c,v 1.182 2017/07/14 01:24:23 ozaki-r Exp $ */
/* $FreeBSD: src/sys/netipsec/key.c,v 1.3.2.3 2004/02/14 22:23:23 bms Exp $ */
/* $KAME: key.c,v 1.191 2001/06/27 10:46:49 sakane Exp $ */
@@ -32,7 +32,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: key.c,v 1.181 2017/07/13 01:22:44 ozaki-r Exp $");
+__KERNEL_RCSID(0, "$NetBSD: key.c,v 1.182 2017/07/14 01:24:23 ozaki-r Exp $");
/*
* This code is referd to RFC 2367
@@ -1246,6 +1246,17 @@
sp, sp->id, where, tag, sp->refcnt);
}
+void
+key_sa_ref(struct secasvar *sav, const char* where, int tag)
+{
+
+ SA_ADDREF2(sav, where, tag);
+
+ KEYDEBUG_PRINTF(KEYDEBUG_IPSEC_STAMP,
+ "DP cause refcnt++:%d SA:%p from %s:%u\n",
+ sav->refcnt, sav, where, tag);
+}
+
/*
* Must be called after calling key_lookup_sp*().
* For both the packet without socket and key_freeso().
diff -r a9aa6300f90c -r 9a80daa21ea2 sys/netipsec/key.h
--- a/sys/netipsec/key.h Thu Jul 13 22:17:09 2017 +0000
+++ b/sys/netipsec/key.h Fri Jul 14 01:24:23 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: key.h,v 1.21 2017/07/13 01:22:44 ozaki-r Exp $ */
+/* $NetBSD: key.h,v 1.22 2017/07/14 01:24:23 ozaki-r Exp $ */
/* $FreeBSD: src/sys/netipsec/key.h,v 1.1.4.1 2003/01/24 05:11:36 sam Exp $ */
/* $KAME: key.h,v 1.21 2001/07/27 03:51:30 itojun Exp $ */
@@ -59,6 +59,7 @@
/* NB: prepend with _ for KAME IPv6 compatbility */
void _key_freesp(struct secpolicy **, const char*, int);
void key_sp_ref(struct secpolicy *, const char*, int);
+void key_sa_ref(struct secasvar *, const char*, int);
/*
* Access to the SADB are interlocked with splsoftnet. In particular,
@@ -79,6 +80,8 @@
_key_freesp(spp, __func__, __LINE__)
#define KEY_SP_REF(sp) \
key_sp_ref(sp, __func__, __LINE__)
+#define KEY_SA_REF(sav) \
+ key_sa_ref(sav, __func__, __LINE__)
struct secasvar *key_lookup_sa(const union sockaddr_union *,
u_int, u_int32_t, u_int16_t, u_int16_t, const char*, int);
diff -r a9aa6300f90c -r 9a80daa21ea2 sys/netipsec/xform.h
--- a/sys/netipsec/xform.h Thu Jul 13 22:17:09 2017 +0000
+++ b/sys/netipsec/xform.h Fri Jul 14 01:24:23 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: xform.h,v 1.9 2017/07/05 03:44:59 ozaki-r Exp $ */
+/* $NetBSD: xform.h,v 1.10 2017/07/14 01:24:23 ozaki-r Exp $ */
/* $FreeBSD: src/sys/netipsec/xform.h,v 1.1.4.1 2003/01/24 05:11:36 sam Exp $ */
/* $OpenBSD: ip_ipsp.h,v 1.119 2002/03/14 01:27:11 millert Exp $ */
/*
@@ -62,6 +62,7 @@
/*
* Opaque data structure hung off a crypto operation descriptor.
*/
+struct secasvar;
struct tdb_crypto {
struct ipsecrequest *tc_isr; /* ipsec request state */
u_int32_t tc_spi; /* associated SPI */
@@ -70,9 +71,9 @@
u_int8_t tc_nxt; /* next protocol, e.g. IPV4 */
int tc_protoff; /* current protocol offset */
int tc_skip; /* data offset */
+ struct secasvar *tc_sav; /* ipsec SA */
};
-struct secasvar;
struct ipescrequest;
struct xformsw {
@@ -89,7 +90,7 @@
const char *xf_name; /* human-readable name */
int (*xf_init)(struct secasvar*, const struct xformsw*);/* setup */
int (*xf_zeroize)(struct secasvar*); /* cleanup */
- int (*xf_input)(struct mbuf*, const struct secasvar*, /* input */
+ int (*xf_input)(struct mbuf*, struct secasvar*, /* input */
int, int);
int (*xf_output)(struct mbuf*, /* output */
struct ipsecrequest *, struct mbuf **, int, int);
diff -r a9aa6300f90c -r 9a80daa21ea2 sys/netipsec/xform_ah.c
--- a/sys/netipsec/xform_ah.c Thu Jul 13 22:17:09 2017 +0000
+++ b/sys/netipsec/xform_ah.c Fri Jul 14 01:24:23 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: xform_ah.c,v 1.59 2017/07/13 03:25:38 ozaki-r Exp $ */
+/* $NetBSD: xform_ah.c,v 1.60 2017/07/14 01:24:23 ozaki-r Exp $ */
/* $FreeBSD: src/sys/netipsec/xform_ah.c,v 1.1.4.1 2003/01/24 05:11:36 sam Exp $ */
/* $OpenBSD: ip_ah.c,v 1.63 2001/06/26 06:18:58 angelos Exp $ */
/*
@@ -39,7 +39,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: xform_ah.c,v 1.59 2017/07/13 03:25:38 ozaki-r Exp $");
+__KERNEL_RCSID(0, "$NetBSD: xform_ah.c,v 1.60 2017/07/14 01:24:23 ozaki-r Exp $");
#if defined(_KERNEL_OPT)
#include "opt_inet.h"
@@ -614,7 +614,7 @@
* passes authentication.
*/
static int
-ah_input(struct mbuf *m, const struct secasvar *sav, int skip, int protoff)
+ah_input(struct mbuf *m, struct secasvar *sav, int skip, int protoff)
{
const struct auth_hash *ahx;
struct tdb_crypto *tc;
@@ -748,6 +748,8 @@
tc->tc_nxt = ah->ah_nxt;
tc->tc_protoff = protoff;
tc->tc_skip = skip;
+ tc->tc_sav = sav;
+ KEY_SA_REF(sav);
DPRINTF(("%s: hash over %d bytes, skip %d: "
"crda len %d skip %d inject %d\n", __func__,
@@ -803,12 +805,17 @@
s = splsoftnet();
mutex_enter(softnet_lock);
- sav = KEY_LOOKUP_SA(&tc->tc_dst, tc->tc_proto, tc->tc_spi, sport, dport);
- if (sav == NULL) {
- AH_STATINC(AH_STAT_NOTDB);
- DPRINTF(("%s: SA expired while in crypto\n", __func__));
- error = ENOBUFS; /*XXX*/
- goto bad;
+ sav = tc->tc_sav;
+ if (__predict_false(!SADB_SASTATE_USABLE_P(sav))) {
+ KEY_FREESAV(&sav);
+ sav = KEY_LOOKUP_SA(&tc->tc_dst, tc->tc_proto, tc->tc_spi,
+ sport, dport);
+ if (sav == NULL) {
+ AH_STATINC(AH_STAT_NOTDB);
+ DPRINTF(("%s: SA expired while in crypto\n", __func__));
+ error = ENOBUFS; /*XXX*/
+ goto bad;
+ }
}
saidx = &sav->sah->saidx;
@@ -954,7 +961,7 @@
)
{
char buf[IPSEC_ADDRSTRLEN];
- const struct secasvar *sav;
+ struct secasvar *sav;
const struct auth_hash *ahx;
struct cryptodesc *crda;
struct tdb_crypto *tc;
@@ -1150,6 +1157,8 @@
tc->tc_proto = sav->sah->saidx.proto;
tc->tc_skip = skip;
tc->tc_protoff = protoff;
+ tc->tc_sav = sav;
+ KEY_SA_REF(sav);
return crypto_dispatch(crp);
bad:
@@ -1182,12 +1191,16 @@
mutex_enter(softnet_lock);
isr = tc->tc_isr;
- sav = KEY_LOOKUP_SA(&tc->tc_dst, tc->tc_proto, tc->tc_spi, 0, 0);
- if (sav == NULL) {
- AH_STATINC(AH_STAT_NOTDB);
- DPRINTF(("%s: SA expired while in crypto\n", __func__));
- error = ENOBUFS; /*XXX*/
- goto bad;
+ sav = tc->tc_sav;
+ if (__predict_false(!SADB_SASTATE_USABLE_P(sav))) {
+ KEY_FREESAV(&sav);
+ sav = KEY_LOOKUP_SA(&tc->tc_dst, tc->tc_proto, tc->tc_spi, 0, 0);
+ if (sav == NULL) {
+ AH_STATINC(AH_STAT_NOTDB);
+ DPRINTF(("%s: SA expired while in crypto\n", __func__));
+ error = ENOBUFS; /*XXX*/
+ goto bad;
+ }
}
KASSERTMSG(isr->sav == sav, "SA changed");
diff -r a9aa6300f90c -r 9a80daa21ea2 sys/netipsec/xform_esp.c
--- a/sys/netipsec/xform_esp.c Thu Jul 13 22:17:09 2017 +0000
+++ b/sys/netipsec/xform_esp.c Fri Jul 14 01:24:23 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: xform_esp.c,v 1.60 2017/07/13 03:00:46 ozaki-r Exp $ */
+/* $NetBSD: xform_esp.c,v 1.61 2017/07/14 01:24:23 ozaki-r Exp $ */
/* $FreeBSD: src/sys/netipsec/xform_esp.c,v 1.2.2.1 2003/01/24 05:11:36 sam Exp $ */
/* $OpenBSD: ip_esp.c,v 1.69 2001/06/26 06:18:59 angelos Exp $ */
@@ -39,7 +39,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: xform_esp.c,v 1.60 2017/07/13 03:00:46 ozaki-r Exp $");
+__KERNEL_RCSID(0, "$NetBSD: xform_esp.c,v 1.61 2017/07/14 01:24:23 ozaki-r Exp $");
#if defined(_KERNEL_OPT)
#include "opt_inet.h"
@@ -297,7 +297,7 @@
* ESP input processing, called (eventually) through the protocol switch.
*/
static int
-esp_input(struct mbuf *m, const struct secasvar *sav, int skip, int protoff)
+esp_input(struct mbuf *m, struct secasvar *sav, int skip, int protoff)
{
const struct auth_hash *esph;
const struct enc_xform *espx;
@@ -436,6 +436,8 @@
tc->tc_proto = sav->sah->saidx.proto;
tc->tc_protoff = protoff;
tc->tc_skip = skip;
+ tc->tc_sav = sav;
+ KEY_SA_REF(sav);
/* Decryption descriptor */
if (espx) {
@@ -510,15 +512,20 @@
s = splsoftnet();
mutex_enter(softnet_lock);
- sav = KEY_LOOKUP_SA(&tc->tc_dst, tc->tc_proto, tc->tc_spi, sport, dport);
- if (sav == NULL) {
- ESP_STATINC(ESP_STAT_NOTDB);
- DPRINTF(("%s: SA expired while in crypto "
- "(SA %s/%08lx proto %u)\n", __func__,
- ipsec_address(&tc->tc_dst, buf, sizeof(buf)),
- (u_long) ntohl(tc->tc_spi), tc->tc_proto));
- error = ENOBUFS; /*XXX*/
- goto bad;
+ sav = tc->tc_sav;
+ if (__predict_false(!SADB_SASTATE_USABLE_P(sav))) {
+ KEY_FREESAV(&sav);
+ sav = KEY_LOOKUP_SA(&tc->tc_dst, tc->tc_proto, tc->tc_spi,
+ sport, dport);
+ if (sav == NULL) {
+ ESP_STATINC(ESP_STAT_NOTDB);
+ DPRINTF(("%s: SA expired while in crypto "
+ "(SA %s/%08lx proto %u)\n", __func__,
+ ipsec_address(&tc->tc_dst, buf, sizeof(buf)),
+ (u_long) ntohl(tc->tc_spi), tc->tc_proto));
+ error = ENOBUFS; /*XXX*/
+ goto bad;
+ }
}
saidx = &sav->sah->saidx;
@@ -702,7 +709,7 @@
int hlen, rlen, padding, blks, alen, i, roff;
struct mbuf *mo = NULL;
struct tdb_crypto *tc;
- const struct secasvar *sav;
+ struct secasvar *sav;
struct secasindex *saidx;
unsigned char *pad;
uint8_t prot;
@@ -900,6 +907,8 @@
tc->tc_spi = sav->spi;
tc->tc_dst = saidx->dst;
tc->tc_proto = saidx->proto;
+ tc->tc_sav = sav;
+ KEY_SA_REF(sav);
/* Crypto operation descriptor. */
crp->crp_ilen = m->m_pkthdr.len; /* Total input length. */
@@ -957,16 +966,20 @@
mutex_enter(softnet_lock);
isr = tc->tc_isr;
- sav = KEY_LOOKUP_SA(&tc->tc_dst, tc->tc_proto, tc->tc_spi, 0, 0);
- if (sav == NULL) {
- char buf[IPSEC_ADDRSTRLEN];
- ESP_STATINC(ESP_STAT_NOTDB);
- DPRINTF(("%s: SA expired while in crypto (SA %s/%08lx "
- "proto %u)\n", __func__,
- ipsec_address(&tc->tc_dst, buf, sizeof(buf)),
- (u_long) ntohl(tc->tc_spi), tc->tc_proto));
- error = ENOBUFS; /*XXX*/
- goto bad;
+ sav = tc->tc_sav;
+ if (__predict_false(!SADB_SASTATE_USABLE_P(sav))) {
Home |
Main Index |
Thread Index |
Old Index