summaryrefslogtreecommitdiffstats
path: root/sys/net/if_ef.c
diff options
context:
space:
mode:
authorbp <bp@FreeBSD.org>2000-09-30 14:33:53 +0000
committerbp <bp@FreeBSD.org>2000-09-30 14:33:53 +0000
commit125cb222de55396adb8a20c0930141448a3ea8bc (patch)
tree1523876cca092b03a64d9e0d7831c91e061ade02 /sys/net/if_ef.c
parent22f6ca78dce2e227f0d7f15b6901a45e3fba0b23 (diff)
downloadFreeBSD-src-125cb222de55396adb8a20c0930141448a3ea8bc.zip
FreeBSD-src-125cb222de55396adb8a20c0930141448a3ea8bc.tar.gz
Properly setup link level header length for 802.2 and SNAP frames.
Diffstat (limited to 'sys/net/if_ef.c')
-rw-r--r--sys/net/if_ef.c11
1 files changed, 7 insertions, 4 deletions
diff --git a/sys/net/if_ef.c b/sys/net/if_ef.c
index e2ede08..ad28d5d 100644
--- a/sys/net/if_ef.c
+++ b/sys/net/if_ef.c
@@ -1,5 +1,5 @@
/*-
- * Copyright (c) 1999, Boris Popov
+ * Copyright (c) 1999, 2000 Boris Popov
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
@@ -92,7 +92,7 @@ static int efcount;
extern int (*ef_inputp)(struct ifnet*, struct ether_header *eh, struct mbuf *m);
extern int (*ef_outputp)(struct ifnet *ifp, struct mbuf **mp,
- struct sockaddr *dst, short *tp);
+ struct sockaddr *dst, short *tp, int *hlen);
/*
static void ef_reset (struct ifnet *);
@@ -104,7 +104,7 @@ static int ef_ioctl(struct ifnet *, u_long, caddr_t);
static void ef_start(struct ifnet *);
static int ef_input(struct ifnet*, struct ether_header *, struct mbuf *);
static int ef_output(struct ifnet *ifp, struct mbuf **mp,
- struct sockaddr *dst, short *tp);
+ struct sockaddr *dst, short *tp, int *hlen);
static int ef_load(void);
static int ef_unload(void);
@@ -430,7 +430,8 @@ ef_input(struct ifnet *ifp, struct ether_header *eh, struct mbuf *m)
}
static int
-ef_output(struct ifnet *ifp, struct mbuf **mp, struct sockaddr *dst, short *tp)
+ef_output(struct ifnet *ifp, struct mbuf **mp, struct sockaddr *dst, short *tp,
+ int *hlen)
{
struct mbuf *m = *mp;
u_char *cp;
@@ -470,6 +471,7 @@ ef_output(struct ifnet *ifp, struct mbuf **mp, struct sockaddr *dst, short *tp)
*cp++ = 0xE0;
*cp++ = 0xE0;
*cp++ = 0x03;
+ *hlen += 3;
break;
case ETHER_FT_SNAP:
M_PREPEND(m, 8, M_WAIT);
@@ -480,6 +482,7 @@ ef_output(struct ifnet *ifp, struct mbuf **mp, struct sockaddr *dst, short *tp)
type = htons(m->m_pkthdr.len);
cp = mtod(m, u_char *);
bcopy("\xAA\xAA\x03\x00\x00\x00\x81\x37", cp, 8);
+ *hlen += 8;
break;
default:
return EPFNOSUPPORT;
OpenPOWER on IntegriCloud