blob: e7e7a33135b629126eb88bd337f5b68c7060c063 [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;
35 unsigned char sll_addr[8];
Ben Cheng655a7c02013-10-16 16:09:24 -070036};
37#define PACKET_HOST 0
38#define PACKET_BROADCAST 1
39#define PACKET_MULTICAST 2
Ben Cheng655a7c02013-10-16 16:09:24 -070040#define PACKET_OTHERHOST 3
41#define PACKET_OUTGOING 4
42#define PACKET_LOOPBACK 5
Christopher Ferris38062f92014-07-09 15:33:25 -070043#define PACKET_USER 6
Christopher Ferris38062f92014-07-09 15:33:25 -070044#define PACKET_KERNEL 7
45#define PACKET_FASTROUTE 6
Ben Cheng655a7c02013-10-16 16:09:24 -070046#define PACKET_ADD_MEMBERSHIP 1
47#define PACKET_DROP_MEMBERSHIP 2
48#define PACKET_RECV_OUTPUT 3
49#define PACKET_RX_RING 5
Ben Cheng655a7c02013-10-16 16:09:24 -070050#define PACKET_STATISTICS 6
51#define PACKET_COPY_THRESH 7
52#define PACKET_AUXDATA 8
53#define PACKET_ORIGDEV 9
Ben Cheng655a7c02013-10-16 16:09:24 -070054#define PACKET_VERSION 10
55#define PACKET_HDRLEN 11
56#define PACKET_RESERVE 12
57#define PACKET_TX_RING 13
Ben Cheng655a7c02013-10-16 16:09:24 -070058#define PACKET_LOSS 14
59#define PACKET_VNET_HDR 15
60#define PACKET_TX_TIMESTAMP 16
61#define PACKET_TIMESTAMP 17
Ben Cheng655a7c02013-10-16 16:09:24 -070062#define PACKET_FANOUT 18
63#define PACKET_TX_HAS_OFF 19
Christopher Ferris38062f92014-07-09 15:33:25 -070064#define PACKET_QDISC_BYPASS 20
Christopher Ferris05d08e92016-02-04 13:16:38 -080065#define PACKET_ROLLOVER_STATS 21
66#define PACKET_FANOUT_DATA 22
Christopher Ferris86a48372019-01-10 14:14:59 -080067#define PACKET_IGNORE_OUTGOING 23
Ben Cheng655a7c02013-10-16 16:09:24 -070068#define PACKET_FANOUT_HASH 0
69#define PACKET_FANOUT_LB 1
Ben Cheng655a7c02013-10-16 16:09:24 -070070#define PACKET_FANOUT_CPU 2
Christopher Ferris38062f92014-07-09 15:33:25 -070071#define PACKET_FANOUT_ROLLOVER 3
72#define PACKET_FANOUT_RND 4
73#define PACKET_FANOUT_QM 5
Christopher Ferris05d08e92016-02-04 13:16:38 -080074#define PACKET_FANOUT_CBPF 6
75#define PACKET_FANOUT_EBPF 7
Christopher Ferris38062f92014-07-09 15:33:25 -070076#define PACKET_FANOUT_FLAG_ROLLOVER 0x1000
Christopher Ferris525ce912017-07-26 13:12:53 -070077#define PACKET_FANOUT_FLAG_UNIQUEID 0x2000
Christopher Ferris38062f92014-07-09 15:33:25 -070078#define PACKET_FANOUT_FLAG_DEFRAG 0x8000
Ben Cheng655a7c02013-10-16 16:09:24 -070079struct tpacket_stats {
Tao Baod7db5942015-01-28 10:07:51 -080080 unsigned int tp_packets;
81 unsigned int tp_drops;
Christopher Ferris38062f92014-07-09 15:33:25 -070082};
Ben Cheng655a7c02013-10-16 16:09:24 -070083struct tpacket_stats_v3 {
Tao Baod7db5942015-01-28 10:07:51 -080084 unsigned int tp_packets;
85 unsigned int tp_drops;
Tao Baod7db5942015-01-28 10:07:51 -080086 unsigned int tp_freeze_q_cnt;
Ben Cheng655a7c02013-10-16 16:09:24 -070087};
Christopher Ferris05d08e92016-02-04 13:16:38 -080088struct tpacket_rollover_stats {
89 __aligned_u64 tp_all;
Christopher Ferris05d08e92016-02-04 13:16:38 -080090 __aligned_u64 tp_huge;
91 __aligned_u64 tp_failed;
92};
93union tpacket_stats_u {
Christopher Ferris05d08e92016-02-04 13:16:38 -080094 struct tpacket_stats stats1;
Tao Baod7db5942015-01-28 10:07:51 -080095 struct tpacket_stats_v3 stats3;
Ben Cheng655a7c02013-10-16 16:09:24 -070096};
97struct tpacket_auxdata {
Christopher Ferris05d08e92016-02-04 13:16:38 -080098 __u32 tp_status;
Tao Baod7db5942015-01-28 10:07:51 -080099 __u32 tp_len;
100 __u32 tp_snaplen;
101 __u16 tp_mac;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800102 __u16 tp_net;
Tao Baod7db5942015-01-28 10:07:51 -0800103 __u16 tp_vlan_tci;
104 __u16 tp_vlan_tpid;
Ben Cheng655a7c02013-10-16 16:09:24 -0700105};
Christopher Ferris05d08e92016-02-04 13:16:38 -0800106#define TP_STATUS_KERNEL 0
Christopher Ferris38062f92014-07-09 15:33:25 -0700107#define TP_STATUS_USER (1 << 0)
Ben Cheng655a7c02013-10-16 16:09:24 -0700108#define TP_STATUS_COPY (1 << 1)
109#define TP_STATUS_LOSING (1 << 2)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800110#define TP_STATUS_CSUMNOTREADY (1 << 3)
Christopher Ferris38062f92014-07-09 15:33:25 -0700111#define TP_STATUS_VLAN_VALID (1 << 4)
Ben Cheng655a7c02013-10-16 16:09:24 -0700112#define TP_STATUS_BLK_TMO (1 << 5)
Christopher Ferris38062f92014-07-09 15:33:25 -0700113#define TP_STATUS_VLAN_TPID_VALID (1 << 6)
Christopher Ferris05d08e92016-02-04 13:16:38 -0800114#define TP_STATUS_CSUM_VALID (1 << 7)
115#define TP_STATUS_AVAILABLE 0
Ben Cheng655a7c02013-10-16 16:09:24 -0700116#define TP_STATUS_SEND_REQUEST (1 << 0)
117#define TP_STATUS_SENDING (1 << 1)
Ben Cheng655a7c02013-10-16 16:09:24 -0700118#define TP_STATUS_WRONG_FORMAT (1 << 2)
119#define TP_STATUS_TS_SOFTWARE (1 << 29)
120#define TP_STATUS_TS_SYS_HARDWARE (1 << 30)
Christopher Ferrisb8a95e22019-10-02 18:29:20 -0700121#define TP_STATUS_TS_RAW_HARDWARE (1U << 31)
Ben Cheng655a7c02013-10-16 16:09:24 -0700122#define TP_FT_REQ_FILL_RXHASH 0x1
123struct tpacket_hdr {
Tao Baod7db5942015-01-28 10:07:51 -0800124 unsigned long tp_status;
125 unsigned int tp_len;
126 unsigned int tp_snaplen;
127 unsigned short tp_mac;
Tao Baod7db5942015-01-28 10:07:51 -0800128 unsigned short tp_net;
129 unsigned int tp_sec;
130 unsigned int tp_usec;
Ben Cheng655a7c02013-10-16 16:09:24 -0700131};
132#define TPACKET_ALIGNMENT 16
Tao Baod7db5942015-01-28 10:07:51 -0800133#define TPACKET_ALIGN(x) (((x) + TPACKET_ALIGNMENT - 1) & ~(TPACKET_ALIGNMENT - 1))
Ben Cheng655a7c02013-10-16 16:09:24 -0700134#define TPACKET_HDRLEN (TPACKET_ALIGN(sizeof(struct tpacket_hdr)) + sizeof(struct sockaddr_ll))
135struct tpacket2_hdr {
Tao Baod7db5942015-01-28 10:07:51 -0800136 __u32 tp_status;
137 __u32 tp_len;
138 __u32 tp_snaplen;
139 __u16 tp_mac;
Tao Baod7db5942015-01-28 10:07:51 -0800140 __u16 tp_net;
141 __u32 tp_sec;
142 __u32 tp_nsec;
143 __u16 tp_vlan_tci;
Tao Baod7db5942015-01-28 10:07:51 -0800144 __u16 tp_vlan_tpid;
145 __u8 tp_padding[4];
Christopher Ferris38062f92014-07-09 15:33:25 -0700146};
Ben Cheng655a7c02013-10-16 16:09:24 -0700147struct tpacket_hdr_variant1 {
Tao Baod7db5942015-01-28 10:07:51 -0800148 __u32 tp_rxhash;
149 __u32 tp_vlan_tci;
150 __u16 tp_vlan_tpid;
151 __u16 tp_padding;
Christopher Ferris38062f92014-07-09 15:33:25 -0700152};
Ben Cheng655a7c02013-10-16 16:09:24 -0700153struct tpacket3_hdr {
Tao Baod7db5942015-01-28 10:07:51 -0800154 __u32 tp_next_offset;
155 __u32 tp_sec;
Tao Baod7db5942015-01-28 10:07:51 -0800156 __u32 tp_nsec;
157 __u32 tp_snaplen;
158 __u32 tp_len;
159 __u32 tp_status;
Tao Baod7db5942015-01-28 10:07:51 -0800160 __u16 tp_mac;
161 __u16 tp_net;
162 union {
163 struct tpacket_hdr_variant1 hv1;
Tao Baod7db5942015-01-28 10:07:51 -0800164 };
165 __u8 tp_padding[8];
Ben Cheng655a7c02013-10-16 16:09:24 -0700166};
167struct tpacket_bd_ts {
Tao Baod7db5942015-01-28 10:07:51 -0800168 unsigned int ts_sec;
169 union {
170 unsigned int ts_usec;
171 unsigned int ts_nsec;
Tao Baod7db5942015-01-28 10:07:51 -0800172 };
Ben Cheng655a7c02013-10-16 16:09:24 -0700173};
Ben Cheng655a7c02013-10-16 16:09:24 -0700174struct tpacket_hdr_v1 {
Tao Baod7db5942015-01-28 10:07:51 -0800175 __u32 block_status;
Tao Baod7db5942015-01-28 10:07:51 -0800176 __u32 num_pkts;
177 __u32 offset_to_first_pkt;
178 __u32 blk_len;
179 __aligned_u64 seq_num;
Tao Baod7db5942015-01-28 10:07:51 -0800180 struct tpacket_bd_ts ts_first_pkt, ts_last_pkt;
Ben Cheng655a7c02013-10-16 16:09:24 -0700181};
Ben Cheng655a7c02013-10-16 16:09:24 -0700182union tpacket_bd_header_u {
Tao Baod7db5942015-01-28 10:07:51 -0800183 struct tpacket_hdr_v1 bh1;
Ben Cheng655a7c02013-10-16 16:09:24 -0700184};
185struct tpacket_block_desc {
Tao Baod7db5942015-01-28 10:07:51 -0800186 __u32 version;
187 __u32 offset_to_priv;
Tao Baod7db5942015-01-28 10:07:51 -0800188 union tpacket_bd_header_u hdr;
Ben Cheng655a7c02013-10-16 16:09:24 -0700189};
Ben Cheng655a7c02013-10-16 16:09:24 -0700190#define TPACKET2_HDRLEN (TPACKET_ALIGN(sizeof(struct tpacket2_hdr)) + sizeof(struct sockaddr_ll))
191#define TPACKET3_HDRLEN (TPACKET_ALIGN(sizeof(struct tpacket3_hdr)) + sizeof(struct sockaddr_ll))
192enum tpacket_versions {
Tao Baod7db5942015-01-28 10:07:51 -0800193 TPACKET_V1,
194 TPACKET_V2,
195 TPACKET_V3
Ben Cheng655a7c02013-10-16 16:09:24 -0700196};
197struct tpacket_req {
Tao Baod7db5942015-01-28 10:07:51 -0800198 unsigned int tp_block_size;
199 unsigned int tp_block_nr;
Tao Baod7db5942015-01-28 10:07:51 -0800200 unsigned int tp_frame_size;
201 unsigned int tp_frame_nr;
Ben Cheng655a7c02013-10-16 16:09:24 -0700202};
203struct tpacket_req3 {
Tao Baod7db5942015-01-28 10:07:51 -0800204 unsigned int tp_block_size;
205 unsigned int tp_block_nr;
206 unsigned int tp_frame_size;
207 unsigned int tp_frame_nr;
Tao Baod7db5942015-01-28 10:07:51 -0800208 unsigned int tp_retire_blk_tov;
209 unsigned int tp_sizeof_priv;
210 unsigned int tp_feature_req_word;
Ben Cheng655a7c02013-10-16 16:09:24 -0700211};
212union tpacket_req_u {
Tao Baod7db5942015-01-28 10:07:51 -0800213 struct tpacket_req req;
214 struct tpacket_req3 req3;
Ben Cheng655a7c02013-10-16 16:09:24 -0700215};
216struct packet_mreq {
Tao Baod7db5942015-01-28 10:07:51 -0800217 int mr_ifindex;
218 unsigned short mr_type;
219 unsigned short mr_alen;
Tao Baod7db5942015-01-28 10:07:51 -0800220 unsigned char mr_address[8];
Ben Cheng655a7c02013-10-16 16:09:24 -0700221};
Christopher Ferris05667cd2021-02-16 16:01:34 -0800222struct fanout_args {
223#ifdef __LITTLE_ENDIAN_BITFIELD
224 __u16 id;
225 __u16 type_flags;
226#else
227 __u16 type_flags;
228 __u16 id;
229#endif
230 __u32 max_num_members;
231};
Ben Cheng655a7c02013-10-16 16:09:24 -0700232#define PACKET_MR_MULTICAST 0
233#define PACKET_MR_PROMISC 1
234#define PACKET_MR_ALLMULTI 2
235#define PACKET_MR_UNICAST 3
Ben Cheng655a7c02013-10-16 16:09:24 -0700236#endif