aboutsummaryrefslogtreecommitdiff
path: root/sys/net/bpf.c
diff options
context:
space:
mode:
authorsvn2git <svn2git@FreeBSD.org>1994-05-01 08:00:00 +0000
committersvn2git <svn2git@FreeBSD.org>1994-05-01 08:00:00 +0000
commita16f65c7d117419bd266c28a1901ef129a337569 (patch)
tree2626602f66dc3551e7a7c7bc9ad763c3bc7ab40a /sys/net/bpf.c
parent8503f4f13f77abf7adc8f7e329c6f9c1d52b6a20 (diff)
Diffstat (limited to 'sys/net/bpf.c')
-rw-r--r--sys/net/bpf.c45
1 files changed, 9 insertions, 36 deletions
diff --git a/sys/net/bpf.c b/sys/net/bpf.c
index 981275b112fb..49e628783e2e 100644
--- a/sys/net/bpf.c
+++ b/sys/net/bpf.c
@@ -36,7 +36,7 @@
* SUCH DAMAGE.
*
* from: @(#)bpf.c 7.5 (Berkeley) 7/15/91
- * $Id: bpf.c,v 1.2 1993/10/16 17:43:03 rgrimes Exp $
+ * $Id: bpf.c,v 1.4 1994/01/31 07:34:36 davidg Exp $
*/
#include "bpfilter.h"
@@ -200,6 +200,14 @@ bpf_movein(uio, linktype, mp, sockp)
error = UIOMOVE((caddr_t)sockp->sa_data, hlen, UIO_WRITE, uio);
if (error)
goto bad;
+
+ if (linktype == DLT_EN10MB) {
+ /* Adjust the protocol field. */
+ struct ether_header *eh;
+ eh = (struct ether_header *)sockp->sa_data;
+ eh->ether_type = ntohs(eh->ether_type);
+ }
+
}
error = UIOMOVE(mtod(m, caddr_t), len - hlen, UIO_WRITE, uio);
if (!error)
@@ -1221,41 +1229,6 @@ bpfattach(driverp, ifp, dlt, hdrlen)
printf("bpf: %s%d attached\n", ifp->if_name, ifp->if_unit);
}
-#if BSD >= 199103
-/* XXX This routine belongs in net/if.c. */
-/*
- * Set/clear promiscuous mode on interface ifp based on the truth value
- * of pswitch. The calls are reference counted so that only the first
- * "on" request actually has an effect, as does the final "off" request.
- * Results are undefined if the "off" and "on" requests are not matched.
- */
-int
-ifpromisc(ifp, pswitch)
- struct ifnet *ifp;
- int pswitch;
-{
- struct ifreq ifr;
- /*
- * If the device is not configured up, we cannot put it in
- * promiscuous mode.
- */
- if ((ifp->if_flags & IFF_UP) == 0)
- return (ENETDOWN);
-
- if (pswitch) {
- if (ifp->if_pcount++ != 0)
- return (0);
- ifp->if_flags |= IFF_PROMISC;
- } else {
- if (--ifp->if_pcount > 0)
- return (0);
- ifp->if_flags &= ~IFF_PROMISC;
- }
- ifr.ifr_flags = ifp->if_flags;
- return ((*ifp->if_ioctl)(ifp, SIOCSIFFLAGS, (caddr_t)&ifr));
-}
-#endif
-
#if BSD < 199103
/*
* Allocate some memory for bpf. This is temporary SunOS support, and