Home | History | Annotate | Download | only in linux
      1 /****************************************************************************
      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 _UAPI__LINUX_BPF_H__
     20 #define _UAPI__LINUX_BPF_H__
     21 #include <linux/types.h>
     22 #include <linux/bpf_common.h>
     23 #define BPF_ALU64 0x07
     24 #define BPF_DW 0x18
     25 #define BPF_XADD 0xc0
     26 #define BPF_MOV 0xb0
     27 #define BPF_ARSH 0xc0
     28 #define BPF_END 0xd0
     29 #define BPF_TO_LE 0x00
     30 #define BPF_TO_BE 0x08
     31 #define BPF_FROM_LE BPF_TO_LE
     32 #define BPF_FROM_BE BPF_TO_BE
     33 #define BPF_JNE 0x50
     34 #define BPF_JSGT 0x60
     35 #define BPF_JSGE 0x70
     36 #define BPF_CALL 0x80
     37 #define BPF_EXIT 0x90
     38 enum {
     39   BPF_REG_0 = 0,
     40   BPF_REG_1,
     41   BPF_REG_2,
     42   BPF_REG_3,
     43   BPF_REG_4,
     44   BPF_REG_5,
     45   BPF_REG_6,
     46   BPF_REG_7,
     47   BPF_REG_8,
     48   BPF_REG_9,
     49   BPF_REG_10,
     50   __MAX_BPF_REG,
     51 };
     52 #define MAX_BPF_REG __MAX_BPF_REG
     53 struct bpf_insn {
     54   __u8 code;
     55   __u8 dst_reg : 4;
     56   __u8 src_reg : 4;
     57   __s16 off;
     58   __s32 imm;
     59 };
     60 enum bpf_cmd {
     61   BPF_MAP_CREATE,
     62   BPF_MAP_LOOKUP_ELEM,
     63   BPF_MAP_UPDATE_ELEM,
     64   BPF_MAP_DELETE_ELEM,
     65   BPF_MAP_GET_NEXT_KEY,
     66   BPF_PROG_LOAD,
     67   BPF_OBJ_PIN,
     68   BPF_OBJ_GET,
     69   BPF_PROG_ATTACH,
     70   BPF_PROG_DETACH,
     71 };
     72 enum bpf_map_type {
     73   BPF_MAP_TYPE_UNSPEC,
     74   BPF_MAP_TYPE_HASH,
     75   BPF_MAP_TYPE_ARRAY,
     76   BPF_MAP_TYPE_PROG_ARRAY,
     77   BPF_MAP_TYPE_PERF_EVENT_ARRAY,
     78   BPF_MAP_TYPE_PERCPU_HASH,
     79   BPF_MAP_TYPE_PERCPU_ARRAY,
     80   BPF_MAP_TYPE_STACK_TRACE,
     81   BPF_MAP_TYPE_CGROUP_ARRAY,
     82   BPF_MAP_TYPE_LRU_HASH,
     83   BPF_MAP_TYPE_LRU_PERCPU_HASH,
     84 };
     85 enum bpf_prog_type {
     86   BPF_PROG_TYPE_UNSPEC,
     87   BPF_PROG_TYPE_SOCKET_FILTER,
     88   BPF_PROG_TYPE_KPROBE,
     89   BPF_PROG_TYPE_SCHED_CLS,
     90   BPF_PROG_TYPE_SCHED_ACT,
     91   BPF_PROG_TYPE_TRACEPOINT,
     92   BPF_PROG_TYPE_XDP,
     93   BPF_PROG_TYPE_PERF_EVENT,
     94   BPF_PROG_TYPE_CGROUP_SKB,
     95   BPF_PROG_TYPE_CGROUP_SOCK,
     96   BPF_PROG_TYPE_LWT_IN,
     97   BPF_PROG_TYPE_LWT_OUT,
     98   BPF_PROG_TYPE_LWT_XMIT,
     99 };
    100 enum bpf_attach_type {
    101   BPF_CGROUP_INET_INGRESS,
    102   BPF_CGROUP_INET_EGRESS,
    103   BPF_CGROUP_INET_SOCK_CREATE,
    104   __MAX_BPF_ATTACH_TYPE
    105 };
    106 #define MAX_BPF_ATTACH_TYPE __MAX_BPF_ATTACH_TYPE
    107 #define BPF_F_ALLOW_OVERRIDE (1U << 0)
    108 #define BPF_PSEUDO_MAP_FD 1
    109 #define BPF_ANY 0
    110 #define BPF_NOEXIST 1
    111 #define BPF_EXIST 2
    112 #define BPF_F_NO_PREALLOC (1U << 0)
    113 #define BPF_F_NO_COMMON_LRU (1U << 1)
    114 union bpf_attr {
    115   struct {
    116     __u32 map_type;
    117     __u32 key_size;
    118     __u32 value_size;
    119     __u32 max_entries;
    120     __u32 map_flags;
    121   };
    122   struct {
    123     __u32 map_fd;
    124     __aligned_u64 key;
    125     union {
    126       __aligned_u64 value;
    127       __aligned_u64 next_key;
    128     };
    129     __u64 flags;
    130   };
    131   struct {
    132     __u32 prog_type;
    133     __u32 insn_cnt;
    134     __aligned_u64 insns;
    135     __aligned_u64 license;
    136     __u32 log_level;
    137     __u32 log_size;
    138     __aligned_u64 log_buf;
    139     __u32 kern_version;
    140   };
    141   struct {
    142     __aligned_u64 pathname;
    143     __u32 bpf_fd;
    144   };
    145   struct {
    146     __u32 target_fd;
    147     __u32 attach_bpf_fd;
    148     __u32 attach_type;
    149     __u32 attach_flags;
    150   };
    151 } __attribute__((aligned(8)));
    152 #define __BPF_FUNC_MAPPER(FN) FN(unspec), FN(map_lookup_elem), FN(map_update_elem), FN(map_delete_elem), FN(probe_read), FN(ktime_get_ns), FN(trace_printk), FN(get_prandom_u32), FN(get_smp_processor_id), FN(skb_store_bytes), FN(l3_csum_replace), FN(l4_csum_replace), FN(tail_call), FN(clone_redirect), FN(get_current_pid_tgid), FN(get_current_uid_gid), FN(get_current_comm), FN(get_cgroup_classid), FN(skb_vlan_push), FN(skb_vlan_pop), FN(skb_get_tunnel_key), FN(skb_set_tunnel_key), FN(perf_event_read), FN(redirect), FN(get_route_realm), FN(perf_event_output), FN(skb_load_bytes), FN(get_stackid), FN(csum_diff), FN(skb_get_tunnel_opt), FN(skb_set_tunnel_opt), FN(skb_change_proto), FN(skb_change_type), FN(skb_under_cgroup), FN(get_hash_recalc), FN(get_current_task), FN(probe_write_user), FN(current_task_under_cgroup), FN(skb_change_tail), FN(skb_pull_data), FN(csum_update), FN(set_hash_invalid), FN(get_numa_node_id), FN(skb_change_head), FN(xdp_adjust_head),
    153 #define __BPF_ENUM_FN(x) BPF_FUNC_ ##x
    154 enum bpf_func_id {
    155   __BPF_FUNC_MAPPER(__BPF_ENUM_FN) __BPF_FUNC_MAX_ID,
    156 };
    157 #undef __BPF_ENUM_FN
    158 #define BPF_F_RECOMPUTE_CSUM (1ULL << 0)
    159 #define BPF_F_INVALIDATE_HASH (1ULL << 1)
    160 #define BPF_F_HDR_FIELD_MASK 0xfULL
    161 #define BPF_F_PSEUDO_HDR (1ULL << 4)
    162 #define BPF_F_MARK_MANGLED_0 (1ULL << 5)
    163 #define BPF_F_INGRESS (1ULL << 0)
    164 #define BPF_F_TUNINFO_IPV6 (1ULL << 0)
    165 #define BPF_F_SKIP_FIELD_MASK 0xffULL
    166 #define BPF_F_USER_STACK (1ULL << 8)
    167 #define BPF_F_FAST_STACK_CMP (1ULL << 9)
    168 #define BPF_F_REUSE_STACKID (1ULL << 10)
    169 #define BPF_F_ZERO_CSUM_TX (1ULL << 1)
    170 #define BPF_F_DONT_FRAGMENT (1ULL << 2)
    171 #define BPF_F_INDEX_MASK 0xffffffffULL
    172 #define BPF_F_CURRENT_CPU BPF_F_INDEX_MASK
    173 #define BPF_F_CTXLEN_MASK (0xfffffULL << 32)
    174 struct __sk_buff {
    175   __u32 len;
    176   __u32 pkt_type;
    177   __u32 mark;
    178   __u32 queue_mapping;
    179   __u32 protocol;
    180   __u32 vlan_present;
    181   __u32 vlan_tci;
    182   __u32 vlan_proto;
    183   __u32 priority;
    184   __u32 ingress_ifindex;
    185   __u32 ifindex;
    186   __u32 tc_index;
    187   __u32 cb[5];
    188   __u32 hash;
    189   __u32 tc_classid;
    190   __u32 data;
    191   __u32 data_end;
    192 };
    193 struct bpf_tunnel_key {
    194   __u32 tunnel_id;
    195   union {
    196     __u32 remote_ipv4;
    197     __u32 remote_ipv6[4];
    198   };
    199   __u8 tunnel_tos;
    200   __u8 tunnel_ttl;
    201   __u16 tunnel_ext;
    202   __u32 tunnel_label;
    203 };
    204 enum bpf_ret_code {
    205   BPF_OK = 0,
    206   BPF_DROP = 2,
    207   BPF_REDIRECT = 7,
    208 };
    209 struct bpf_sock {
    210   __u32 bound_dev_if;
    211   __u32 family;
    212   __u32 type;
    213   __u32 protocol;
    214 };
    215 #define XDP_PACKET_HEADROOM 256
    216 enum xdp_action {
    217   XDP_ABORTED = 0,
    218   XDP_DROP,
    219   XDP_PASS,
    220   XDP_TX,
    221 };
    222 struct xdp_md {
    223   __u32 data;
    224   __u32 data_end;
    225 };
    226 #endif
    227