summaryrefslogtreecommitdiff
path: root/sys/netinet
diff options
context:
space:
mode:
authorAngelos D. Keromytis <angelos@cvs.openbsd.org>2001-05-20 08:33:34 +0000
committerAngelos D. Keromytis <angelos@cvs.openbsd.org>2001-05-20 08:33:34 +0000
commit880c12b85d51bdf52ce7ad3751f7aa7a37a3f3b8 (patch)
treedd261c366e12b0973ec63f8c9757fc8f05f2921e /sys/netinet
parenta5292df8d988d051ca2f754bcabf86b067506d11 (diff)
Use packet tags to signal input IPsec processing to upper layer protocols.
Diffstat (limited to 'sys/netinet')
-rw-r--r--sys/netinet/ipsec_input.c24
1 files changed, 12 insertions, 12 deletions
diff --git a/sys/netinet/ipsec_input.c b/sys/netinet/ipsec_input.c
index 214b1155c93..f5e316fd7aa 100644
--- a/sys/netinet/ipsec_input.c
+++ b/sys/netinet/ipsec_input.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ipsec_input.c,v 1.37 2001/05/11 17:20:11 aaron Exp $ */
+/* $OpenBSD: ipsec_input.c,v 1.38 2001/05/20 08:33:33 angelos Exp $ */
/*
* The authors of this code are John Ioannidis (ji@tla.org),
@@ -261,6 +261,8 @@ ipsec_common_input_cb(struct mbuf *m, struct tdb *tdbp, int skip, int protoff)
#ifdef INET6
struct ip6_hdr *ip6, ip6n;
#endif /* INET6 */
+ struct m_tag *mtag;
+ struct tdb_ident *tdbi;
af = tdbp->tdb_dst.sa.sa_family;
sproto = tdbp->tdb_sproto;
@@ -450,23 +452,21 @@ ipsec_common_input_cb(struct mbuf *m, struct tdb *tdbp, int skip, int protoff)
* Record what we've done to the packet (under what SA it was
* processed).
*/
- /* XXX We need a better packets-attributes framework */
- if (m->m_pkthdr.tdbi)
- free(m->m_pkthdr.tdbi, M_TEMP);
-
- MALLOC(m->m_pkthdr.tdbi, void *, sizeof(struct tdb_ident), M_TEMP,
- M_NOWAIT);
- if (m->m_pkthdr.tdbi == NULL)
+ mtag = m_tag_get(PACKET_TAG_IPSEC_DONE, sizeof(struct tdb_ident),
+ M_NOWAIT);
+ if (mtag == NULL)
{
m_freem(m);
IPSEC_ISTAT(espstat.esps_hdrops, ahstat.ahs_hdrops);
return ENOMEM;
}
- bcopy(&tdbp->tdb_dst, &(((struct tdb_ident *) m->m_pkthdr.tdbi)->dst),
- sizeof(union sockaddr_union));
- ((struct tdb_ident *) m->m_pkthdr.tdbi)->proto = tdbp->tdb_sproto;
- ((struct tdb_ident *) m->m_pkthdr.tdbi)->spi = tdbp->tdb_spi;
+ tdbi = (struct tdb_ident *)(mtag + 1);
+ bcopy(&tdbp->tdb_dst, &tdbi->dst, sizeof(union sockaddr_union));
+ tdbi->proto = tdbp->tdb_sproto;
+ tdbi->spi = tdbp->tdb_spi;
+
+ m_tag_prepend(m, mtag);
if (sproto == IPPROTO_ESP)
{