Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | #ifndef __LINUX_IF_PACKET_H |
| 2 | #define __LINUX_IF_PACKET_H |
| 3 | |
Al Viro | 0e11c91 | 2006-11-08 00:26:29 -0800 | [diff] [blame] | 4 | #include <linux/types.h> |
| 5 | |
Eric Dumazet | d94d9fe | 2009-11-04 09:50:58 -0800 | [diff] [blame] | 6 | struct sockaddr_pkt { |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 7 | unsigned short spkt_family; |
| 8 | unsigned char spkt_device[14]; |
Al Viro | 0e11c91 | 2006-11-08 00:26:29 -0800 | [diff] [blame] | 9 | __be16 spkt_protocol; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 10 | }; |
| 11 | |
Eric Dumazet | d94d9fe | 2009-11-04 09:50:58 -0800 | [diff] [blame] | 12 | struct sockaddr_ll { |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 13 | unsigned short sll_family; |
Al Viro | 0e11c91 | 2006-11-08 00:26:29 -0800 | [diff] [blame] | 14 | __be16 sll_protocol; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 15 | int sll_ifindex; |
| 16 | unsigned short sll_hatype; |
| 17 | unsigned char sll_pkttype; |
| 18 | unsigned char sll_halen; |
| 19 | unsigned char sll_addr[8]; |
| 20 | }; |
| 21 | |
| 22 | /* Packet types */ |
| 23 | |
| 24 | #define PACKET_HOST 0 /* To us */ |
| 25 | #define PACKET_BROADCAST 1 /* To all */ |
| 26 | #define PACKET_MULTICAST 2 /* To group */ |
| 27 | #define PACKET_OTHERHOST 3 /* To someone else */ |
| 28 | #define PACKET_OUTGOING 4 /* Outgoing of any type */ |
| 29 | /* These ones are invisible by user level */ |
| 30 | #define PACKET_LOOPBACK 5 /* MC/BRD frame looped back */ |
| 31 | #define PACKET_FASTROUTE 6 /* Fastrouted frame */ |
| 32 | |
| 33 | /* Packet socket options */ |
| 34 | |
| 35 | #define PACKET_ADD_MEMBERSHIP 1 |
| 36 | #define PACKET_DROP_MEMBERSHIP 2 |
| 37 | #define PACKET_RECV_OUTPUT 3 |
| 38 | /* Value 4 is still used by obsolete turbo-packet. */ |
| 39 | #define PACKET_RX_RING 5 |
| 40 | #define PACKET_STATISTICS 6 |
| 41 | #define PACKET_COPY_THRESH 7 |
Herbert Xu | 8dc4194 | 2007-02-04 23:31:32 -0800 | [diff] [blame] | 42 | #define PACKET_AUXDATA 8 |
Peter P. Waskiewicz Jr | 80feaac | 2007-04-20 16:05:39 -0700 | [diff] [blame] | 43 | #define PACKET_ORIGDEV 9 |
Patrick McHardy | bbd6ef8 | 2008-07-14 22:50:15 -0700 | [diff] [blame] | 44 | #define PACKET_VERSION 10 |
| 45 | #define PACKET_HDRLEN 11 |
Patrick McHardy | 8913336 | 2008-07-18 18:05:19 -0700 | [diff] [blame] | 46 | #define PACKET_RESERVE 12 |
Johann Baudy | 69e3c75 | 2009-05-18 22:11:22 -0700 | [diff] [blame] | 47 | #define PACKET_TX_RING 13 |
| 48 | #define PACKET_LOSS 14 |
Sridhar Samudrala | bfd5f4a | 2010-02-04 20:24:10 -0800 | [diff] [blame] | 49 | #define PACKET_VNET_HDR 15 |
Richard Cochran | ed85b56 | 2010-04-07 22:41:28 +0000 | [diff] [blame] | 50 | #define PACKET_TX_TIMESTAMP 16 |
Scott McMillan | 614f60f | 2010-06-02 05:53:56 -0700 | [diff] [blame] | 51 | #define PACKET_TIMESTAMP 17 |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 52 | |
Eric Dumazet | d94d9fe | 2009-11-04 09:50:58 -0800 | [diff] [blame] | 53 | struct tpacket_stats { |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 54 | unsigned int tp_packets; |
| 55 | unsigned int tp_drops; |
| 56 | }; |
| 57 | |
Eric Dumazet | d94d9fe | 2009-11-04 09:50:58 -0800 | [diff] [blame] | 58 | struct tpacket_auxdata { |
Herbert Xu | 8dc4194 | 2007-02-04 23:31:32 -0800 | [diff] [blame] | 59 | __u32 tp_status; |
| 60 | __u32 tp_len; |
| 61 | __u32 tp_snaplen; |
| 62 | __u16 tp_mac; |
| 63 | __u16 tp_net; |
Patrick McHardy | 393e52e | 2008-07-14 22:50:39 -0700 | [diff] [blame] | 64 | __u16 tp_vlan_tci; |
Eric Dumazet | 13fcb7b | 2011-06-06 22:42:06 -0700 | [diff] [blame] | 65 | __u16 tp_padding; |
Herbert Xu | 8dc4194 | 2007-02-04 23:31:32 -0800 | [diff] [blame] | 66 | }; |
| 67 | |
Johann Baudy | 69e3c75 | 2009-05-18 22:11:22 -0700 | [diff] [blame] | 68 | /* Rx ring - header status */ |
| 69 | #define TP_STATUS_KERNEL 0x0 |
| 70 | #define TP_STATUS_USER 0x1 |
| 71 | #define TP_STATUS_COPY 0x2 |
| 72 | #define TP_STATUS_LOSING 0x4 |
| 73 | #define TP_STATUS_CSUMNOTREADY 0x8 |
Ben Greear | a3bcc23 | 2011-06-01 06:49:10 +0000 | [diff] [blame] | 74 | #define TP_STATUS_VLAN_VALID 0x10 /* auxdata has valid tp_vlan_tci */ |
Johann Baudy | 69e3c75 | 2009-05-18 22:11:22 -0700 | [diff] [blame] | 75 | |
| 76 | /* Tx ring - header status */ |
| 77 | #define TP_STATUS_AVAILABLE 0x0 |
| 78 | #define TP_STATUS_SEND_REQUEST 0x1 |
| 79 | #define TP_STATUS_SENDING 0x2 |
| 80 | #define TP_STATUS_WRONG_FORMAT 0x4 |
| 81 | |
Eric Dumazet | d94d9fe | 2009-11-04 09:50:58 -0800 | [diff] [blame] | 82 | struct tpacket_hdr { |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 83 | unsigned long tp_status; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 84 | unsigned int tp_len; |
| 85 | unsigned int tp_snaplen; |
| 86 | unsigned short tp_mac; |
| 87 | unsigned short tp_net; |
| 88 | unsigned int tp_sec; |
| 89 | unsigned int tp_usec; |
| 90 | }; |
| 91 | |
| 92 | #define TPACKET_ALIGNMENT 16 |
| 93 | #define TPACKET_ALIGN(x) (((x)+TPACKET_ALIGNMENT-1)&~(TPACKET_ALIGNMENT-1)) |
| 94 | #define TPACKET_HDRLEN (TPACKET_ALIGN(sizeof(struct tpacket_hdr)) + sizeof(struct sockaddr_ll)) |
| 95 | |
Eric Dumazet | d94d9fe | 2009-11-04 09:50:58 -0800 | [diff] [blame] | 96 | struct tpacket2_hdr { |
Patrick McHardy | bbd6ef8 | 2008-07-14 22:50:15 -0700 | [diff] [blame] | 97 | __u32 tp_status; |
| 98 | __u32 tp_len; |
| 99 | __u32 tp_snaplen; |
| 100 | __u16 tp_mac; |
| 101 | __u16 tp_net; |
| 102 | __u32 tp_sec; |
| 103 | __u32 tp_nsec; |
Patrick McHardy | 393e52e | 2008-07-14 22:50:39 -0700 | [diff] [blame] | 104 | __u16 tp_vlan_tci; |
Eric Dumazet | 13fcb7b | 2011-06-06 22:42:06 -0700 | [diff] [blame] | 105 | __u16 tp_padding; |
Patrick McHardy | bbd6ef8 | 2008-07-14 22:50:15 -0700 | [diff] [blame] | 106 | }; |
| 107 | |
| 108 | #define TPACKET2_HDRLEN (TPACKET_ALIGN(sizeof(struct tpacket2_hdr)) + sizeof(struct sockaddr_ll)) |
| 109 | |
Eric Dumazet | d94d9fe | 2009-11-04 09:50:58 -0800 | [diff] [blame] | 110 | enum tpacket_versions { |
Patrick McHardy | bbd6ef8 | 2008-07-14 22:50:15 -0700 | [diff] [blame] | 111 | TPACKET_V1, |
| 112 | TPACKET_V2, |
| 113 | }; |
| 114 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 115 | /* |
| 116 | Frame structure: |
| 117 | |
| 118 | - Start. Frame must be aligned to TPACKET_ALIGNMENT=16 |
| 119 | - struct tpacket_hdr |
| 120 | - pad to TPACKET_ALIGNMENT=16 |
| 121 | - struct sockaddr_ll |
| 122 | - Gap, chosen so that packet data (Start+tp_net) alignes to TPACKET_ALIGNMENT=16 |
| 123 | - Start+tp_mac: [ Optional MAC header ] |
| 124 | - Start+tp_net: Packet data, aligned to TPACKET_ALIGNMENT=16. |
| 125 | - Pad to align to TPACKET_ALIGNMENT=16 |
| 126 | */ |
| 127 | |
Eric Dumazet | d94d9fe | 2009-11-04 09:50:58 -0800 | [diff] [blame] | 128 | struct tpacket_req { |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 129 | unsigned int tp_block_size; /* Minimal size of contiguous block */ |
| 130 | unsigned int tp_block_nr; /* Number of blocks */ |
| 131 | unsigned int tp_frame_size; /* Size of frame */ |
| 132 | unsigned int tp_frame_nr; /* Total number of frames */ |
| 133 | }; |
| 134 | |
Eric Dumazet | d94d9fe | 2009-11-04 09:50:58 -0800 | [diff] [blame] | 135 | struct packet_mreq { |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 136 | int mr_ifindex; |
| 137 | unsigned short mr_type; |
| 138 | unsigned short mr_alen; |
| 139 | unsigned char mr_address[8]; |
| 140 | }; |
| 141 | |
| 142 | #define PACKET_MR_MULTICAST 0 |
| 143 | #define PACKET_MR_PROMISC 1 |
| 144 | #define PACKET_MR_ALLMULTI 2 |
Eric W. Biederman | d95ed92 | 2009-05-19 18:27:17 +0000 | [diff] [blame] | 145 | #define PACKET_MR_UNICAST 3 |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 146 | |
| 147 | #endif |