1996-08-05 14:02:38 +00:00
|
|
|
/*
|
|
|
|
* Fundamental constants relating to ethernet.
|
|
|
|
*
|
1999-08-28 01:08:13 +00:00
|
|
|
* $FreeBSD$
|
1996-08-05 14:02:38 +00:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
1996-08-06 21:14:36 +00:00
|
|
|
#ifndef _NET_ETHERNET_H_
|
|
|
|
#define _NET_ETHERNET_H_
|
|
|
|
|
|
|
|
/*
|
|
|
|
* The number of bytes in an ethernet (MAC) address.
|
|
|
|
*/
|
1996-08-05 14:02:38 +00:00
|
|
|
#define ETHER_ADDR_LEN 6
|
1996-08-06 21:14:36 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* The number of bytes in the type field.
|
|
|
|
*/
|
|
|
|
#define ETHER_TYPE_LEN 2
|
|
|
|
|
|
|
|
/*
|
|
|
|
* The number of bytes in the trailing CRC field.
|
|
|
|
*/
|
|
|
|
#define ETHER_CRC_LEN 4
|
|
|
|
|
|
|
|
/*
|
|
|
|
* The length of the combined header.
|
|
|
|
*/
|
|
|
|
#define ETHER_HDR_LEN (ETHER_ADDR_LEN*2+ETHER_TYPE_LEN)
|
|
|
|
|
|
|
|
/*
|
|
|
|
* The minimum packet length.
|
|
|
|
*/
|
|
|
|
#define ETHER_MIN_LEN 64
|
|
|
|
|
|
|
|
/*
|
|
|
|
* The maximum packet length.
|
|
|
|
*/
|
|
|
|
#define ETHER_MAX_LEN 1518
|
|
|
|
|
|
|
|
/*
|
|
|
|
* A macro to validate a length with
|
|
|
|
*/
|
|
|
|
#define ETHER_IS_VALID_LEN(foo) \
|
|
|
|
((foo) >= ETHER_MIN_LEN && (foo) <= ETHER_MAX_LEN)
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Structure of a 10Mb/s Ethernet header.
|
|
|
|
*/
|
|
|
|
struct ether_header {
|
|
|
|
u_char ether_dhost[ETHER_ADDR_LEN];
|
|
|
|
u_char ether_shost[ETHER_ADDR_LEN];
|
|
|
|
u_short ether_type;
|
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Structure of a 48-bit Ethernet address.
|
|
|
|
*/
|
|
|
|
struct ether_addr {
|
|
|
|
u_char octet[ETHER_ADDR_LEN];
|
|
|
|
};
|
|
|
|
|
1997-01-03 19:51:54 +00:00
|
|
|
#define ETHERTYPE_PUP 0x0200 /* PUP protocol */
|
|
|
|
#define ETHERTYPE_IP 0x0800 /* IP protocol */
|
1999-11-05 14:41:39 +00:00
|
|
|
#define ETHERTYPE_ARP 0x0806 /* Addr. resolution protocol */
|
|
|
|
#define ETHERTYPE_REVARP 0x8035 /* reverse Addr. resolution protocol */
|
|
|
|
#define ETHERTYPE_VLAN 0x8100 /* IEEE 802.1Q VLAN tagging */
|
|
|
|
#define ETHERTYPE_IPV6 0x86dd /* IPv6 */
|
1997-01-03 19:51:54 +00:00
|
|
|
#define ETHERTYPE_LOOPBACK 0x9000 /* used to test interfaces */
|
|
|
|
/* XXX - add more useful types here */
|
|
|
|
|
|
|
|
/*
|
|
|
|
* The ETHERTYPE_NTRAILER packet types starting at ETHERTYPE_TRAIL have
|
|
|
|
* (type-ETHERTYPE_TRAIL)*512 bytes of data followed
|
|
|
|
* by an ETHER type (as given above) and then the (variable-length) header.
|
|
|
|
*/
|
|
|
|
#define ETHERTYPE_TRAIL 0x1000 /* Trailer packet */
|
|
|
|
#define ETHERTYPE_NTRAILER 16
|
|
|
|
|
|
|
|
#define ETHERMTU (ETHER_MAX_LEN-ETHER_HDR_LEN-ETHER_CRC_LEN)
|
|
|
|
#define ETHERMIN (ETHER_MIN_LEN-ETHER_HDR_LEN-ETHER_CRC_LEN)
|
|
|
|
|
2000-06-26 23:34:54 +00:00
|
|
|
#ifdef _KERNEL
|
|
|
|
|
2000-07-13 22:54:34 +00:00
|
|
|
/*
|
|
|
|
* For device drivers to specify whether they support BPF or not
|
|
|
|
*/
|
|
|
|
#define ETHER_BPF_UNSUPPORTED 0
|
|
|
|
#define ETHER_BPF_SUPPORTED 1
|
|
|
|
|
2000-06-29 22:30:42 +00:00
|
|
|
struct ifnet;
|
|
|
|
struct mbuf;
|
|
|
|
|
2000-06-26 23:34:54 +00:00
|
|
|
extern void (*ng_ether_input_p)(struct ifnet *ifp,
|
|
|
|
struct mbuf **mp, struct ether_header *eh);
|
|
|
|
extern void (*ng_ether_input_orphan_p)(struct ifnet *ifp,
|
|
|
|
struct mbuf *m, struct ether_header *eh);
|
|
|
|
extern int (*ng_ether_output_p)(struct ifnet *ifp, struct mbuf **mp);
|
|
|
|
extern void (*ng_ether_attach_p)(struct ifnet *ifp);
|
|
|
|
extern void (*ng_ether_detach_p)(struct ifnet *ifp);
|
|
|
|
|
2001-09-05 21:10:28 +00:00
|
|
|
extern int (*vlan_input_p)(struct ether_header *eh, struct mbuf *m);
|
|
|
|
extern int (*vlan_input_tag_p)(struct ether_header *eh, struct mbuf *m,
|
|
|
|
u_int16_t t);
|
2001-12-03 17:28:27 +00:00
|
|
|
#define _VLAN_INPUT(eh, m) do { \
|
2001-09-05 21:10:28 +00:00
|
|
|
if (vlan_input_p != NULL) { \
|
|
|
|
if ((*vlan_input_p)(eh, m) == -1) \
|
2001-12-03 17:28:27 +00:00
|
|
|
(m)->m_pkthdr.rcvif->if_noproto++; \
|
2001-09-05 21:10:28 +00:00
|
|
|
} else { \
|
|
|
|
m_free(m); \
|
2001-12-03 17:28:27 +00:00
|
|
|
(m)->m_pkthdr.rcvif->if_noproto++; \
|
2001-09-05 21:10:28 +00:00
|
|
|
} \
|
|
|
|
} while (0)
|
|
|
|
|
2001-12-03 17:28:27 +00:00
|
|
|
#define VLAN_INPUT(eh, m) do { \
|
2001-09-05 21:10:28 +00:00
|
|
|
/* XXX: lock */ \
|
2001-12-03 17:28:27 +00:00
|
|
|
_VLAN_INPUT(eh, m); \
|
2001-09-05 21:10:28 +00:00
|
|
|
/* XXX: unlock */ \
|
|
|
|
} while (0)
|
|
|
|
|
2001-12-03 17:28:27 +00:00
|
|
|
#define _VLAN_INPUT_TAG(eh, m, t) do { \
|
2001-09-05 21:10:28 +00:00
|
|
|
if (vlan_input_tag_p != NULL) { \
|
|
|
|
if ((*vlan_input_tag_p)(eh, m, t) == -1) \
|
2001-12-03 17:28:27 +00:00
|
|
|
(m)->m_pkthdr.rcvif->if_noproto++; \
|
2001-09-05 21:10:28 +00:00
|
|
|
} else { \
|
|
|
|
m_free(m); \
|
2001-12-03 17:28:27 +00:00
|
|
|
(m)->m_pkthdr.rcvif->if_noproto++; \
|
2001-09-05 21:10:28 +00:00
|
|
|
} \
|
|
|
|
} while (0)
|
|
|
|
|
2001-12-03 17:28:27 +00:00
|
|
|
#define VLAN_INPUT_TAG(eh, m, t) do { \
|
2001-09-05 21:10:28 +00:00
|
|
|
/* XXX: lock */ \
|
2001-12-03 17:28:27 +00:00
|
|
|
_VLAN_INPUT_TAG(eh, m, t); \
|
2001-09-05 21:10:28 +00:00
|
|
|
/* XXX: unlock */ \
|
|
|
|
} while (0)
|
|
|
|
|
2000-06-26 23:34:54 +00:00
|
|
|
#else /* _KERNEL */
|
|
|
|
|
1996-12-19 15:42:52 +00:00
|
|
|
#include <sys/cdefs.h>
|
|
|
|
|
1996-12-18 21:42:38 +00:00
|
|
|
/*
|
|
|
|
* Ethernet address conversion/parsing routines.
|
|
|
|
*/
|
1996-12-19 18:12:06 +00:00
|
|
|
__BEGIN_DECLS
|
2000-07-18 22:44:52 +00:00
|
|
|
struct ether_addr *ether_aton __P((const char *));
|
|
|
|
int ether_hostton __P((const char *, struct ether_addr *));
|
|
|
|
int ether_line __P((const char *, struct ether_addr *, char *));
|
|
|
|
char *ether_ntoa __P((const struct ether_addr *));
|
|
|
|
int ether_ntohost __P((char *, const struct ether_addr *));
|
1996-12-19 18:12:06 +00:00
|
|
|
__END_DECLS
|
2000-06-26 23:34:54 +00:00
|
|
|
|
|
|
|
#endif /* !_KERNEL */
|
1996-12-19 18:12:06 +00:00
|
|
|
|
|
|
|
#endif /* !_NET_ETHERNET_H_ */
|