blob: cb0c80414f7bb68f2558aceb721d6729243406e6 [file] [log] [blame]
Ben Cheng655a7c02013-10-16 16:09:24 -07001/****************************************************************************
2 ****************************************************************************
3 ***
4 *** This header was automatically generated from a Linux kernel header
5 *** of the same name, to make information necessary for userspace to
6 *** call into the kernel available to libc. It contains only constants,
7 *** structures, and macros generated from the original header, and thus,
8 *** contains no copyrightable information.
9 ***
10 *** To edit the content of this header, modify the corresponding
11 *** source file (e.g. under external/kernel-headers/original/) then
12 *** run bionic/libc/kernel/tools/update_all.py
13 ***
14 *** Any manual change here will be lost the next time this script will
15 *** be run. You've been warned!
16 ***
17 ****************************************************************************
18 ****************************************************************************/
19#ifndef __LINUX_IF_PACKET_H
20#define __LINUX_IF_PACKET_H
Christopher Ferris05667cd2021-02-16 16:01:34 -080021#include <asm/byteorder.h>
Ben Cheng655a7c02013-10-16 16:09:24 -070022#include <linux/types.h>
23struct sockaddr_pkt {
Tao Baod7db5942015-01-28 10:07:51 -080024 unsigned short spkt_family;
25 unsigned char spkt_device[14];
26 __be16 spkt_protocol;
Ben Cheng655a7c02013-10-16 16:09:24 -070027};
Ben Cheng655a7c02013-10-16 16:09:24 -070028struct sockaddr_ll {
Tao Baod7db5942015-01-28 10:07:51 -080029 unsigned short sll_family;
30 __be16 sll_protocol;
31 int sll_ifindex;
Tao Baod7db5942015-01-28 10:07:51 -080032 unsigned short sll_hatype;
33 unsigned char sll_pkttype;
34 unsigned char sll_halen;
Christopher Ferris8666d042023-09-06 14:55:31 -070035 union {
36 unsigned char sll_addr[8];
37 __DECLARE_FLEX_ARRAY(unsigned char, sll_addr_flex);
38 };
Ben Cheng655a7c02013-10-16 16:09:24 -070039};
40#define PACKET_HOST 0
41#define PACKET_BROADCAST 1
42#define PACKET_MULTICAST 2
Ben Cheng655a7c02013-10-16 16:09:24 -070043#define PACKET_OTHERHOST 3
44#define PACKET_OUTGOING 4
45#define PACKET_LOOPBACK 5
Christopher Ferris38062f92014-07-09 15:33:25 -070046#define PACKET_USER 6
Christopher Ferris38062f92014-07-09 15:33:25 -070047#define PACKET_KERNEL 7
48#define PACKET_FASTROUTE 6
Ben Cheng655a7c02013-10-16 16:09:24 -070049#define PACKET_ADD_MEMBERSHIP 1
50#define PACKET_DROP_MEMBERSHIP 2
51#define PACKET_RECV_OUTPUT 3
52#define PACKET_RX_RING 5
Ben Cheng655a7c02013-10-16 16:09:24 -070053#define PACKET_STATISTICS 6
54#define PACKET_COPY_THRESH 7
55#define PACKET_AUXDATA 8
56#define PACKET_ORIGDEV 9
Ben Cheng655a7c02013-10-16 16:09:24 -070057#define PACKET_VERSION 10
58#define PACKET_HDRLEN 11
59#define PACKET_RESERVE 12
60#define PACKET_TX_RING 13
Ben Cheng655a7c02013-10-16 16:09:24 -070061#define PACKET_LOSS 14
62#define PACKET_VNET_HDR 15
63#define PACKET_TX_TIMESTAMP 16
64#define PACKET_TIMESTAMP 17
Ben Cheng655a7c02013-10-16 16:09:24 -070065#define PACKET_FANOUT 18
66#define PACKET_TX_HAS_OFF 19
Christopher Ferris38062f92014-07-09 15:33:25 -070067#define PACKET_QDISC_BYPASS 20
Christopher Ferris05d08e92016-02-04 13:16:38 -080068#define PACKET_ROLLOVER_STATS 21
69#define PACKET_FANOUT_DATA 22
Christopher Ferris86a48372019-01-10 14:14:59 -080070#define PACKET_IGNORE_OUTGOING 23
Christopher Ferris37c3f3c2023-07-10 10:59:05 -070071#define PACKET_VNET_HDR_SZ 24
Ben Cheng655a7c02013-10-16 16:09:24 -070072#define PACKET_FANOUT_HASH 0
73#define PACKET_FANOUT_LB 1
Ben Cheng655a7c02013-10-16 16:09:24 -070074#define PACKET_FANOUT_CPU 2
Christopher Ferris38062f92014-07-09 15:33:25 -070075#define PACKET_FANOUT_ROLLOVER 3
76#define PACKET_FANOUT_RND 4
77#define PACKET_FANOUT_QM 5
Christopher Ferris05d08e92016-02-04 13:16:38 -080078#define PACKET_FANOUT_CBPF 6
79#define PACKET_FANOUT_EBPF 7
Christopher Ferris38062f92014-07-09 15:33:25 -070080#define PACKET_FANOUT_FLAG_ROLLOVER 0x1000
Christopher Ferris525ce912017-07-26 13:12:53 -070081#define PACKET_FANOUT_FLAG_UNIQUEID 0x2000
Christopher Ferris8b7fdc92023-02-21 13:36:32 -080082#define PACKET_FANOUT_FLAG_IGNORE_OUTGOING 0x4000
Christopher Ferris38062f92014-07-09 15:33:25 -070083#define PACKET_FANOUT_FLAG_DEFRAG 0x8000
Ben Cheng655a7c02013-10-16 16:09:24 -070084struct tpacket_stats {
Tao Baod7db5942015-01-28 10:07:51 -080085 unsigned int tp_packets;
86 unsigned int tp_drops;
Christopher Ferris38062f92014-07-09 15:33:25 -070087};
Ben Cheng655a7c02013-10-16 16:09:24 -070088struct tpacket_stats_v3 {
Tao Baod7db5942015-01-28 10:07:51 -080089 unsigned int tp_packets;
90 unsigned int tp_drops;
Tao Baod7db5942015-01-28 10:07:51 -080091 unsigned int tp_freeze_q_cnt;
Ben Cheng655a7c02013-10-16 16:09:24 -070092};
Christopher Ferris05d08e92016-02-04 13:16:38 -080093struct tpacket_rollover_stats {
94 __aligned_u64 tp_all;
Christopher Ferris05d08e92016-02-04 13:16:38 -080095 __aligned_u64 tp_huge;
96 __aligned_u64 tp_failed;
97};
98union tpacket_stats_u {
Christopher Ferris05d08e92016-02-04 13:16:38 -080099 struct tpacket_stats stats1;
Tao Baod7db5942015-01-28 10:07:51 -0800100 struct tpacket_stats_v3 stats3;
Ben Cheng655a7c02013-10-16 16:09:24 -0700101};
102struct tpacket_auxdata {
Christopher Ferris05d08e92016-02-04 13:16:38 -0800103 __u32 tp_status;
Tao Baod7db5942015-01-28 10:07:51 -0800104 __u32 tp_len;
105 __u32 tp_snaplen;
106 __u16 tp_mac;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800107 __u16 tp_net;
Tao Baod7db5942015-01-28 10:07:51 -0800108 __u16 tp_vlan_tci;
109 __u16 tp_vlan_tpid;
Ben Cheng655a7c02013-10-16 16:09:24 -0700110};
Christopher Ferris05d08e92016-02-04 13:16:38 -0800111#define TP_STATUS_KERNEL 0
Christopher Ferris38062f92014-07-09 15:33:25 -0700112#define TP_STATUS_USER (1 << 0)
Ben Cheng655a7c02013-10-16 16:09:24 -0700113#define TP_STATUS_COPY (1 << 1)
114#define TP_STATUS_LOSING (1 << 2)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800115#define TP_STATUS_CSUMNOTREADY (1 << 3)
Christopher Ferris38062f92014-07-09 15:33:25 -0700116#define TP_STATUS_VLAN_VALID (1 << 4)
Ben Cheng655a7c02013-10-16 16:09:24 -0700117#define TP_STATUS_BLK_TMO (1 << 5)
Christopher Ferris38062f92014-07-09 15:33:25 -0700118#define TP_STATUS_VLAN_TPID_VALID (1 << 6)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800119#define TP_STATUS_CSUM_VALID (1 << 7)
Christopher Ferrisb7cef6d2023-05-09 19:04:15 +0000120#define TP_STATUS_GSO_TCP (1 << 8)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800121#define TP_STATUS_AVAILABLE 0
Ben Cheng655a7c02013-10-16 16:09:24 -0700122#define TP_STATUS_SEND_REQUEST (1 << 0)
123#define TP_STATUS_SENDING (1 << 1)
Ben Cheng655a7c02013-10-16 16:09:24 -0700124#define TP_STATUS_WRONG_FORMAT (1 << 2)
125#define TP_STATUS_TS_SOFTWARE (1 << 29)
126#define TP_STATUS_TS_SYS_HARDWARE (1 << 30)
Christopher Ferrisb8a95e22019-10-02 18:29:20 -0700127#define TP_STATUS_TS_RAW_HARDWARE (1U << 31)
Ben Cheng655a7c02013-10-16 16:09:24 -0700128#define TP_FT_REQ_FILL_RXHASH 0x1
129struct tpacket_hdr {
Tao Baod7db5942015-01-28 10:07:51 -0800130 unsigned long tp_status;
131 unsigned int tp_len;
132 unsigned int tp_snaplen;
133 unsigned short tp_mac;
Tao Baod7db5942015-01-28 10:07:51 -0800134 unsigned short tp_net;
135 unsigned int tp_sec;
136 unsigned int tp_usec;
Ben Cheng655a7c02013-10-16 16:09:24 -0700137};
138#define TPACKET_ALIGNMENT 16
Tao Baod7db5942015-01-28 10:07:51 -0800139#define TPACKET_ALIGN(x) (((x) + TPACKET_ALIGNMENT - 1) & ~(TPACKET_ALIGNMENT - 1))
Ben Cheng655a7c02013-10-16 16:09:24 -0700140#define TPACKET_HDRLEN (TPACKET_ALIGN(sizeof(struct tpacket_hdr)) + sizeof(struct sockaddr_ll))
141struct tpacket2_hdr {
Tao Baod7db5942015-01-28 10:07:51 -0800142 __u32 tp_status;
143 __u32 tp_len;
144 __u32 tp_snaplen;
145 __u16 tp_mac;
Tao Baod7db5942015-01-28 10:07:51 -0800146 __u16 tp_net;
147 __u32 tp_sec;
148 __u32 tp_nsec;
149 __u16 tp_vlan_tci;
Tao Baod7db5942015-01-28 10:07:51 -0800150 __u16 tp_vlan_tpid;
151 __u8 tp_padding[4];
Christopher Ferris38062f92014-07-09 15:33:25 -0700152};
Ben Cheng655a7c02013-10-16 16:09:24 -0700153struct tpacket_hdr_variant1 {
Tao Baod7db5942015-01-28 10:07:51 -0800154 __u32 tp_rxhash;
155 __u32 tp_vlan_tci;
156 __u16 tp_vlan_tpid;
157 __u16 tp_padding;
Christopher Ferris38062f92014-07-09 15:33:25 -0700158};
Ben Cheng655a7c02013-10-16 16:09:24 -0700159struct tpacket3_hdr {
Tao Baod7db5942015-01-28 10:07:51 -0800160 __u32 tp_next_offset;
161 __u32 tp_sec;
Tao Baod7db5942015-01-28 10:07:51 -0800162 __u32 tp_nsec;
163 __u32 tp_snaplen;
164 __u32 tp_len;
165 __u32 tp_status;
Tao Baod7db5942015-01-28 10:07:51 -0800166 __u16 tp_mac;
167 __u16 tp_net;
168 union {
169 struct tpacket_hdr_variant1 hv1;
Tao Baod7db5942015-01-28 10:07:51 -0800170 };
171 __u8 tp_padding[8];
Ben Cheng655a7c02013-10-16 16:09:24 -0700172};
173struct tpacket_bd_ts {
Tao Baod7db5942015-01-28 10:07:51 -0800174 unsigned int ts_sec;
175 union {
176 unsigned int ts_usec;
177 unsigned int ts_nsec;
Tao Baod7db5942015-01-28 10:07:51 -0800178 };
Ben Cheng655a7c02013-10-16 16:09:24 -0700179};
Ben Cheng655a7c02013-10-16 16:09:24 -0700180struct tpacket_hdr_v1 {
Tao Baod7db5942015-01-28 10:07:51 -0800181 __u32 block_status;
Tao Baod7db5942015-01-28 10:07:51 -0800182 __u32 num_pkts;
183 __u32 offset_to_first_pkt;
184 __u32 blk_len;
185 __aligned_u64 seq_num;
Tao Baod7db5942015-01-28 10:07:51 -0800186 struct tpacket_bd_ts ts_first_pkt, ts_last_pkt;
Ben Cheng655a7c02013-10-16 16:09:24 -0700187};
Ben Cheng655a7c02013-10-16 16:09:24 -0700188union tpacket_bd_header_u {
Tao Baod7db5942015-01-28 10:07:51 -0800189 struct tpacket_hdr_v1 bh1;
Ben Cheng655a7c02013-10-16 16:09:24 -0700190};
191struct tpacket_block_desc {
Tao Baod7db5942015-01-28 10:07:51 -0800192 __u32 version;
193 __u32 offset_to_priv;
Tao Baod7db5942015-01-28 10:07:51 -0800194 union tpacket_bd_header_u hdr;
Ben Cheng655a7c02013-10-16 16:09:24 -0700195};
Ben Cheng655a7c02013-10-16 16:09:24 -0700196#define TPACKET2_HDRLEN (TPACKET_ALIGN(sizeof(struct tpacket2_hdr)) + sizeof(struct sockaddr_ll))
197#define TPACKET3_HDRLEN (TPACKET_ALIGN(sizeof(struct tpacket3_hdr)) + sizeof(struct sockaddr_ll))
198enum tpacket_versions {
Tao Baod7db5942015-01-28 10:07:51 -0800199 TPACKET_V1,
200 TPACKET_V2,
201 TPACKET_V3
Ben Cheng655a7c02013-10-16 16:09:24 -0700202};
203struct tpacket_req {
Tao Baod7db5942015-01-28 10:07:51 -0800204 unsigned int tp_block_size;
205 unsigned int tp_block_nr;
Tao Baod7db5942015-01-28 10:07:51 -0800206 unsigned int tp_frame_size;
207 unsigned int tp_frame_nr;
Ben Cheng655a7c02013-10-16 16:09:24 -0700208};
209struct tpacket_req3 {
Tao Baod7db5942015-01-28 10:07:51 -0800210 unsigned int tp_block_size;
211 unsigned int tp_block_nr;
212 unsigned int tp_frame_size;
213 unsigned int tp_frame_nr;
Tao Baod7db5942015-01-28 10:07:51 -0800214 unsigned int tp_retire_blk_tov;
215 unsigned int tp_sizeof_priv;
216 unsigned int tp_feature_req_word;
Ben Cheng655a7c02013-10-16 16:09:24 -0700217};
218union tpacket_req_u {
Tao Baod7db5942015-01-28 10:07:51 -0800219 struct tpacket_req req;
220 struct tpacket_req3 req3;
Ben Cheng655a7c02013-10-16 16:09:24 -0700221};
222struct packet_mreq {
Tao Baod7db5942015-01-28 10:07:51 -0800223 int mr_ifindex;
224 unsigned short mr_type;
225 unsigned short mr_alen;
Tao Baod7db5942015-01-28 10:07:51 -0800226 unsigned char mr_address[8];
Ben Cheng655a7c02013-10-16 16:09:24 -0700227};
Christopher Ferris05667cd2021-02-16 16:01:34 -0800228struct fanout_args {
229#ifdef __LITTLE_ENDIAN_BITFIELD
230 __u16 id;
231 __u16 type_flags;
232#else
233 __u16 type_flags;
234 __u16 id;
235#endif
236 __u32 max_num_members;
237};
Ben Cheng655a7c02013-10-16 16:09:24 -0700238#define PACKET_MR_MULTICAST 0
239#define PACKET_MR_PROMISC 1
240#define PACKET_MR_ALLMULTI 2
241#define PACKET_MR_UNICAST 3
Ben Cheng655a7c02013-10-16 16:09:24 -0700242#endif