diff options
author | Alexander Bluhm <bluhm@cvs.openbsd.org> | 2021-10-24 17:08:28 +0000 |
---|---|---|
committer | Alexander Bluhm <bluhm@cvs.openbsd.org> | 2021-10-24 17:08:28 +0000 |
commit | 508061dc059b1df836ec4b4922a1f03f3f4ac83a (patch) | |
tree | b1623237e1ea7f5b8be87d21da34dcbf44314495 /sys/netinet/ip_esp.c | |
parent | f984965a7b241b1574399335e368fff8570de0a9 (diff) |
There are more m_pullup() in IPsec input. Pass down the pointer
to the mbuf to update it globally. At the end it will reach
ip_deliver() which expects a pointer to an mbuf.
OK sashan@
Diffstat (limited to 'sys/netinet/ip_esp.c')
-rw-r--r-- | sys/netinet/ip_esp.c | 13 |
1 files changed, 7 insertions, 6 deletions
diff --git a/sys/netinet/ip_esp.c b/sys/netinet/ip_esp.c index fbd793ae61f..02b0540a3d6 100644 --- a/sys/netinet/ip_esp.c +++ b/sys/netinet/ip_esp.c @@ -1,4 +1,4 @@ -/* $OpenBSD: ip_esp.c,v 1.182 2021/10/24 15:47:39 tobhe Exp $ */ +/* $OpenBSD: ip_esp.c,v 1.183 2021/10/24 17:08:27 bluhm Exp $ */ /* * The authors of this code are John Ioannidis (ji@tla.org), * Angelos D. Keromytis (kermit@csd.uch.gr) and @@ -522,7 +522,7 @@ esp_input(struct mbuf **mp, struct tdb *tdb, int skip, int protoff) /* Release the crypto descriptors */ crypto_freereq(crp); - return esp_input_cb(tdb, abuf, skip, protoff, tdb->tdb_rpl, m, clen); + return esp_input_cb(tdb, abuf, skip, protoff, tdb->tdb_rpl, mp, clen); drop: m_freemp(mp); @@ -534,10 +534,11 @@ esp_input(struct mbuf **mp, struct tdb *tdb, int skip, int protoff) * ESP input callback, called directly by the crypto driver. */ int -esp_input_cb(struct tdb *tdb, uint8_t *abuf, int skip, int protoff, uint64_t rpl, - struct mbuf *m, int clen) +esp_input_cb(struct tdb *tdb, uint8_t *abuf, int skip, int protoff, + uint64_t rpl, struct mbuf **mp, int clen) { u_int8_t lastthree[3], aalg[AH_HMAC_MAX_HASHLEN]; + struct mbuf *m = *mp; int hlen, roff; struct mbuf *m1, *mo; const struct auth_hash *esph; @@ -710,10 +711,10 @@ esp_input_cb(struct tdb *tdb, uint8_t *abuf, int skip, int protoff, uint64_t rpl m_copyback(m, protoff, sizeof(u_int8_t), lastthree + 2, M_NOWAIT); /* Back to generic IPsec input processing */ - return ipsec_common_input_cb(m, tdb, skip, protoff); + return ipsec_common_input_cb(mp, tdb, skip, protoff); baddone: - m_freem(m); + m_freemp(mp); return -1; } |