1*53ee8cc1Swenshuai.xi /* 2*53ee8cc1Swenshuai.xi * INET An implementation of the TCP/IP protocol suite for the LINUX 3*53ee8cc1Swenshuai.xi * operating system. INET is implemented using the BSD Socket 4*53ee8cc1Swenshuai.xi * interface as the means of communication with the user level. 5*53ee8cc1Swenshuai.xi * 6*53ee8cc1Swenshuai.xi * Global definitions for the ARCnet interface. 7*53ee8cc1Swenshuai.xi * 8*53ee8cc1Swenshuai.xi * Authors: David Woodhouse and Avery Pennarun 9*53ee8cc1Swenshuai.xi * 10*53ee8cc1Swenshuai.xi * This program is free software; you can redistribute it and/or 11*53ee8cc1Swenshuai.xi * modify it under the terms of the GNU General Public License 12*53ee8cc1Swenshuai.xi * as published by the Free Software Foundation; either version 13*53ee8cc1Swenshuai.xi * 2 of the License, or (at your option) any later version. 14*53ee8cc1Swenshuai.xi */ 15*53ee8cc1Swenshuai.xi 16*53ee8cc1Swenshuai.xi #ifndef _LINUX_IF_ARCNET_H 17*53ee8cc1Swenshuai.xi #define _LINUX_IF_ARCNET_H 18*53ee8cc1Swenshuai.xi 19*53ee8cc1Swenshuai.xi #include <linux/if_ether.h> 20*53ee8cc1Swenshuai.xi 21*53ee8cc1Swenshuai.xi 22*53ee8cc1Swenshuai.xi /* 23*53ee8cc1Swenshuai.xi * These are the defined ARCnet Protocol ID's. 24*53ee8cc1Swenshuai.xi */ 25*53ee8cc1Swenshuai.xi 26*53ee8cc1Swenshuai.xi /* CAP mode */ 27*53ee8cc1Swenshuai.xi /* No macro but uses 1-8 */ 28*53ee8cc1Swenshuai.xi 29*53ee8cc1Swenshuai.xi /* RFC1201 Protocol ID's */ 30*53ee8cc1Swenshuai.xi #define ARC_P_IP 212 /* 0xD4 */ 31*53ee8cc1Swenshuai.xi #define ARC_P_IPV6 196 /* 0xC4: RFC2497 */ 32*53ee8cc1Swenshuai.xi #define ARC_P_ARP 213 /* 0xD5 */ 33*53ee8cc1Swenshuai.xi #define ARC_P_RARP 214 /* 0xD6 */ 34*53ee8cc1Swenshuai.xi #define ARC_P_IPX 250 /* 0xFA */ 35*53ee8cc1Swenshuai.xi #define ARC_P_NOVELL_EC 236 /* 0xEC */ 36*53ee8cc1Swenshuai.xi 37*53ee8cc1Swenshuai.xi /* Old RFC1051 Protocol ID's */ 38*53ee8cc1Swenshuai.xi #define ARC_P_IP_RFC1051 240 /* 0xF0 */ 39*53ee8cc1Swenshuai.xi #define ARC_P_ARP_RFC1051 241 /* 0xF1 */ 40*53ee8cc1Swenshuai.xi 41*53ee8cc1Swenshuai.xi /* MS LanMan/WfWg "NDIS" encapsulation */ 42*53ee8cc1Swenshuai.xi #define ARC_P_ETHER 232 /* 0xE8 */ 43*53ee8cc1Swenshuai.xi 44*53ee8cc1Swenshuai.xi /* Unsupported/indirectly supported protocols */ 45*53ee8cc1Swenshuai.xi #define ARC_P_DATAPOINT_BOOT 0 /* very old Datapoint equipment */ 46*53ee8cc1Swenshuai.xi #define ARC_P_DATAPOINT_MOUNT 1 47*53ee8cc1Swenshuai.xi #define ARC_P_POWERLAN_BEACON 8 /* Probably ATA-Netbios related */ 48*53ee8cc1Swenshuai.xi #define ARC_P_POWERLAN_BEACON2 243 /* 0xF3 */ 49*53ee8cc1Swenshuai.xi #define ARC_P_LANSOFT 251 /* 0xFB - what is this? */ 50*53ee8cc1Swenshuai.xi #define ARC_P_ATALK 0xDD 51*53ee8cc1Swenshuai.xi 52*53ee8cc1Swenshuai.xi /* Hardware address length */ 53*53ee8cc1Swenshuai.xi #define ARCNET_ALEN 1 54*53ee8cc1Swenshuai.xi 55*53ee8cc1Swenshuai.xi /* 56*53ee8cc1Swenshuai.xi * The RFC1201-specific components of an arcnet packet header. 57*53ee8cc1Swenshuai.xi */ 58*53ee8cc1Swenshuai.xi struct arc_rfc1201 59*53ee8cc1Swenshuai.xi { 60*53ee8cc1Swenshuai.xi uint8_t proto; /* protocol ID field - varies */ 61*53ee8cc1Swenshuai.xi uint8_t split_flag; /* for use with split packets */ 62*53ee8cc1Swenshuai.xi __be16 sequence; /* sequence number */ 63*53ee8cc1Swenshuai.xi uint8_t payload[0]; /* space remaining in packet (504 bytes)*/ 64*53ee8cc1Swenshuai.xi }; 65*53ee8cc1Swenshuai.xi #define RFC1201_HDR_SIZE 4 66*53ee8cc1Swenshuai.xi 67*53ee8cc1Swenshuai.xi 68*53ee8cc1Swenshuai.xi /* 69*53ee8cc1Swenshuai.xi * The RFC1051-specific components. 70*53ee8cc1Swenshuai.xi */ 71*53ee8cc1Swenshuai.xi struct arc_rfc1051 72*53ee8cc1Swenshuai.xi { 73*53ee8cc1Swenshuai.xi uint8_t proto; /* ARC_P_RFC1051_ARP/RFC1051_IP */ 74*53ee8cc1Swenshuai.xi uint8_t payload[0]; /* 507 bytes */ 75*53ee8cc1Swenshuai.xi }; 76*53ee8cc1Swenshuai.xi #define RFC1051_HDR_SIZE 1 77*53ee8cc1Swenshuai.xi 78*53ee8cc1Swenshuai.xi 79*53ee8cc1Swenshuai.xi /* 80*53ee8cc1Swenshuai.xi * The ethernet-encap-specific components. We have a real ethernet header 81*53ee8cc1Swenshuai.xi * and some data. 82*53ee8cc1Swenshuai.xi */ 83*53ee8cc1Swenshuai.xi struct arc_eth_encap 84*53ee8cc1Swenshuai.xi { 85*53ee8cc1Swenshuai.xi uint8_t proto; /* Always ARC_P_ETHER */ 86*53ee8cc1Swenshuai.xi struct ethhdr eth; /* standard ethernet header (yuck!) */ 87*53ee8cc1Swenshuai.xi uint8_t payload[0]; /* 493 bytes */ 88*53ee8cc1Swenshuai.xi }; 89*53ee8cc1Swenshuai.xi #define ETH_ENCAP_HDR_SIZE 14 90*53ee8cc1Swenshuai.xi 91*53ee8cc1Swenshuai.xi 92*53ee8cc1Swenshuai.xi struct arc_cap 93*53ee8cc1Swenshuai.xi { 94*53ee8cc1Swenshuai.xi uint8_t proto; 95*53ee8cc1Swenshuai.xi uint8_t cookie[sizeof(int)]; /* Actually NOT sent over the network */ 96*53ee8cc1Swenshuai.xi union { 97*53ee8cc1Swenshuai.xi uint8_t ack; 98*53ee8cc1Swenshuai.xi uint8_t raw[0]; /* 507 bytes */ 99*53ee8cc1Swenshuai.xi } mes; 100*53ee8cc1Swenshuai.xi }; 101*53ee8cc1Swenshuai.xi 102*53ee8cc1Swenshuai.xi /* 103*53ee8cc1Swenshuai.xi * The data needed by the actual arcnet hardware. 104*53ee8cc1Swenshuai.xi * 105*53ee8cc1Swenshuai.xi * Now, in the real arcnet hardware, the third and fourth bytes are the 106*53ee8cc1Swenshuai.xi * 'offset' specification instead of the length, and the soft data is at 107*53ee8cc1Swenshuai.xi * the _end_ of the 512-byte buffer. We hide this complexity inside the 108*53ee8cc1Swenshuai.xi * driver. 109*53ee8cc1Swenshuai.xi */ 110*53ee8cc1Swenshuai.xi struct arc_hardware 111*53ee8cc1Swenshuai.xi { 112*53ee8cc1Swenshuai.xi uint8_t source, /* source ARCnet - filled in automagically */ 113*53ee8cc1Swenshuai.xi dest, /* destination ARCnet - 0 for broadcast */ 114*53ee8cc1Swenshuai.xi offset[2]; /* offset bytes (some weird semantics) */ 115*53ee8cc1Swenshuai.xi }; 116*53ee8cc1Swenshuai.xi #define ARC_HDR_SIZE 4 117*53ee8cc1Swenshuai.xi 118*53ee8cc1Swenshuai.xi /* 119*53ee8cc1Swenshuai.xi * This is an ARCnet frame header, as seen by the kernel (and userspace, 120*53ee8cc1Swenshuai.xi * when you do a raw packet capture). 121*53ee8cc1Swenshuai.xi */ 122*53ee8cc1Swenshuai.xi struct archdr 123*53ee8cc1Swenshuai.xi { 124*53ee8cc1Swenshuai.xi /* hardware requirements */ 125*53ee8cc1Swenshuai.xi struct arc_hardware hard; 126*53ee8cc1Swenshuai.xi 127*53ee8cc1Swenshuai.xi /* arcnet encapsulation-specific bits */ 128*53ee8cc1Swenshuai.xi union { 129*53ee8cc1Swenshuai.xi struct arc_rfc1201 rfc1201; 130*53ee8cc1Swenshuai.xi struct arc_rfc1051 rfc1051; 131*53ee8cc1Swenshuai.xi struct arc_eth_encap eth_encap; 132*53ee8cc1Swenshuai.xi struct arc_cap cap; 133*53ee8cc1Swenshuai.xi uint8_t raw[0]; /* 508 bytes */ 134*53ee8cc1Swenshuai.xi } soft; 135*53ee8cc1Swenshuai.xi }; 136*53ee8cc1Swenshuai.xi 137*53ee8cc1Swenshuai.xi #endif /* _LINUX_IF_ARCNET_H */ 138