[ SYSTEM ]: Linux srv.persadacompanies.com 4.18.0-553.56.1.el8_10.x86_64 #1 SMP Tue Jun 10 05:00:59 EDT 2025 x86_64
[ SERVER ]: Apache | PHP: 8.4.19
[ USER ]: persadamedika | IP: 45.64.1.108
GEFORCE FILE MANAGER
/
usr
/
src
/
kernels
/
4.18.0-553.64.1.el8_10.x86_64
/
include
/
net
/
UPLOAD:
NAME
SIZE
QUICK PERMS
ACTIONS
📁 9p
SET
[ DEL ]
📁 bluetooth
SET
[ DEL ]
📁 caif
SET
[ DEL ]
📁 iucv
SET
[ DEL ]
📁 mana
SET
[ DEL ]
📁 netfilter
SET
[ DEL ]
📁 netns
SET
[ DEL ]
📁 nfc
SET
[ DEL ]
📁 phonet
SET
[ DEL ]
📁 sctp
SET
[ DEL ]
📁 tc_act
SET
[ DEL ]
📄 6lowpan.h
10,271 B
SET
[ EDIT ]
|
[ DEL ]
📄 Space.h
1,094 B
SET
[ EDIT ]
|
[ DEL ]
📄 act_api.h
9,478 B
SET
[ EDIT ]
|
[ DEL ]
📄 addrconf.h
13,826 B
SET
[ EDIT ]
|
[ DEL ]
📄 af_ieee802154.h
1,591 B
SET
[ EDIT ]
|
[ DEL ]
📄 af_rxrpc.h
2,976 B
SET
[ EDIT ]
|
[ DEL ]
📄 af_unix.h
2,272 B
SET
[ EDIT ]
|
[ DEL ]
📄 af_vsock.h
7,295 B
SET
[ EDIT ]
|
[ DEL ]
📄 ah.h
382 B
SET
[ EDIT ]
|
[ DEL ]
📄 arp.h
2,052 B
SET
[ EDIT ]
|
[ DEL ]
📄 atmclip.h
1,515 B
SET
[ EDIT ]
|
[ DEL ]
📄 ax25.h
14,999 B
SET
[ EDIT ]
|
[ DEL ]
📄 ax88796.h
1,488 B
SET
[ EDIT ]
|
[ DEL ]
📄 bareudp.h
333 B
SET
[ EDIT ]
|
[ DEL ]
📄 bond_3ad.h
9,629 B
SET
[ EDIT ]
|
[ DEL ]
📄 bond_alb.h
6,251 B
SET
[ EDIT ]
|
[ DEL ]
📄 bond_options.h
3,916 B
SET
[ EDIT ]
|
[ DEL ]
📄 bonding.h
20,225 B
SET
[ EDIT ]
|
[ DEL ]
📄 bpf_sk_storage.h
1,802 B
SET
[ EDIT ]
|
[ DEL ]
📄 busy_poll.h
4,973 B
SET
[ EDIT ]
|
[ DEL ]
📄 calipso.h
2,199 B
SET
[ EDIT ]
|
[ DEL ]
📄 cfg80211-wext.h
1,900 B
SET
[ EDIT ]
|
[ DEL ]
📄 cfg80211.h
325,844 B
SET
[ EDIT ]
|
[ DEL ]
📄 cfg802154.h
11,175 B
SET
[ EDIT ]
|
[ DEL ]
📄 checksum.h
4,850 B
SET
[ EDIT ]
|
[ DEL ]
📄 cipso_ipv4.h
8,399 B
SET
[ EDIT ]
|
[ DEL ]
📄 cls_cgroup.h
2,301 B
SET
[ EDIT ]
|
[ DEL ]
📄 codel.h
6,000 B
SET
[ EDIT ]
|
[ DEL ]
📄 codel_impl.h
8,500 B
SET
[ EDIT ]
|
[ DEL ]
📄 codel_qdisc.h
3,001 B
SET
[ EDIT ]
|
[ DEL ]
📄 compat.h
1,711 B
SET
[ EDIT ]
|
[ DEL ]
📄 datalink.h
619 B
SET
[ EDIT ]
|
[ DEL ]
📄 dcbevent.h
1,293 B
SET
[ EDIT ]
|
[ DEL ]
📄 dcbnl.h
5,267 B
SET
[ EDIT ]
|
[ DEL ]
📄 devlink.h
64,711 B
SET
[ EDIT ]
|
[ DEL ]
📄 dn.h
7,046 B
SET
[ EDIT ]
|
[ DEL ]
📄 dn_dev.h
5,488 B
SET
[ EDIT ]
|
[ DEL ]
📄 dn_fib.h
4,077 B
SET
[ EDIT ]
|
[ DEL ]
📄 dn_neigh.h
968 B
SET
[ EDIT ]
|
[ DEL ]
📄 dn_nsp.h
5,966 B
SET
[ EDIT ]
|
[ DEL ]
📄 dn_route.h
4,500 B
SET
[ EDIT ]
|
[ DEL ]
📄 drop_monitor.h
901 B
SET
[ EDIT ]
|
[ DEL ]
📄 dropreason-core.h
12,063 B
SET
[ EDIT ]
|
[ DEL ]
📄 dsa.h
16,605 B
SET
[ EDIT ]
|
[ DEL ]
📄 dsfield.h
1,139 B
SET
[ EDIT ]
|
[ DEL ]
📄 dst.h
13,989 B
SET
[ EDIT ]
|
[ DEL ]
📄 dst_cache.h
2,596 B
SET
[ EDIT ]
|
[ DEL ]
📄 dst_metadata.h
5,521 B
SET
[ EDIT ]
|
[ DEL ]
📄 dst_ops.h
2,564 B
SET
[ EDIT ]
|
[ DEL ]
📄 erspan.h
8,527 B
SET
[ EDIT ]
|
[ DEL ]
📄 esp.h
1,190 B
SET
[ EDIT ]
|
[ DEL ]
📄 espintcp.h
966 B
SET
[ EDIT ]
|
[ DEL ]
📄 ethoc.h
537 B
SET
[ EDIT ]
|
[ DEL ]
📄 failover.h
1,178 B
SET
[ EDIT ]
|
[ DEL ]
📄 fib_notifier.h
1,476 B
SET
[ EDIT ]
|
[ DEL ]
📄 fib_rules.h
5,728 B
SET
[ EDIT ]
|
[ DEL ]
📄 firewire.h
636 B
SET
[ EDIT ]
|
[ DEL ]
📄 flow.h
6,353 B
SET
[ EDIT ]
|
[ DEL ]
📄 flow_dissector.h
11,284 B
SET
[ EDIT ]
|
[ DEL ]
📄 flow_offload.h
17,797 B
SET
[ EDIT ]
|
[ DEL ]
📄 fou.h
549 B
SET
[ EDIT ]
|
[ DEL ]
📄 fq.h
2,497 B
SET
[ EDIT ]
|
[ DEL ]
📄 fq_impl.h
8,144 B
SET
[ EDIT ]
|
[ DEL ]
📄 garp.h
2,678 B
SET
[ EDIT ]
|
[ DEL ]
📄 gen_stats.h
3,034 B
SET
[ EDIT ]
|
[ DEL ]
📄 genetlink.h
14,647 B
SET
[ EDIT ]
|
[ DEL ]
📄 geneve.h
1,898 B
SET
[ EDIT ]
|
[ DEL ]
📄 gre.h
3,377 B
SET
[ EDIT ]
|
[ DEL ]
📄 gro_cells.h
443 B
SET
[ EDIT ]
|
[ DEL ]
📄 gtp.h
633 B
SET
[ EDIT ]
|
[ DEL ]
📄 gue.h
3,311 B
SET
[ EDIT ]
|
[ DEL ]
📄 hwbm.h
937 B
SET
[ EDIT ]
|
[ DEL ]
📄 icmp.h
1,765 B
SET
[ EDIT ]
|
[ DEL ]
📄 ieee80211_radiotap.h
23,017 B
SET
[ EDIT ]
|
[ DEL ]
📄 ieee802154_netdev.h
9,358 B
SET
[ EDIT ]
|
[ DEL ]
📄 if_inet6.h
6,591 B
SET
[ EDIT ]
|
[ DEL ]
📄 ife.h
1,057 B
SET
[ EDIT ]
|
[ DEL ]
📄 ila.h
498 B
SET
[ EDIT ]
|
[ DEL ]
📄 inet6_connection_sock.h
976 B
SET
[ EDIT ]
|
[ DEL ]
📄 inet6_hashtables.h
3,746 B
SET
[ EDIT ]
|
[ DEL ]
📄 inet_common.h
2,614 B
SET
[ EDIT ]
|
[ DEL ]
📄 inet_connection_sock.h
11,981 B
SET
[ EDIT ]
|
[ DEL ]
📄 inet_ecn.h
8,071 B
SET
[ EDIT ]
|
[ DEL ]
📄 inet_frag.h
4,816 B
SET
[ EDIT ]
|
[ DEL ]
📄 inet_hashtables.h
13,847 B
SET
[ EDIT ]
|
[ DEL ]
📄 inet_sock.h
9,828 B
SET
[ EDIT ]
|
[ DEL ]
📄 inet_timewait_sock.h
3,926 B
SET
[ EDIT ]
|
[ DEL ]
📄 inetpeer.h
3,372 B
SET
[ EDIT ]
|
[ DEL ]
📄 ip.h
21,221 B
SET
[ EDIT ]
|
[ DEL ]
📄 ip6_checksum.h
2,981 B
SET
[ EDIT ]
|
[ DEL ]
📄 ip6_fib.h
13,766 B
SET
[ EDIT ]
|
[ DEL ]
📄 ip6_route.h
9,220 B
SET
[ EDIT ]
|
[ DEL ]
📄 ip6_tunnel.h
5,096 B
SET
[ EDIT ]
|
[ DEL ]
📄 ip_fib.h
14,290 B
SET
[ EDIT ]
|
[ DEL ]
📄 ip_tunnels.h
14,697 B
SET
[ EDIT ]
|
[ DEL ]
📄 ip_vs.h
49,407 B
SET
[ EDIT ]
|
[ DEL ]
📄 ipcomp.h
659 B
SET
[ EDIT ]
|
[ DEL ]
📄 ipconfig.h
811 B
SET
[ EDIT ]
|
[ DEL ]
📄 ipv6.h
32,741 B
SET
[ EDIT ]
|
[ DEL ]
📄 ipv6_frag.h
3,321 B
SET
[ EDIT ]
|
[ DEL ]
📄 ipv6_stubs.h
2,671 B
SET
[ EDIT ]
|
[ DEL ]
📄 ipx.h
4,386 B
SET
[ EDIT ]
|
[ DEL ]
📄 iw_handler.h
21,413 B
SET
[ EDIT ]
|
[ DEL ]
📄 kcm.h
5,083 B
SET
[ EDIT ]
|
[ DEL ]
📄 l3mdev.h
6,743 B
SET
[ EDIT ]
|
[ DEL ]
📄 lag.h
409 B
SET
[ EDIT ]
|
[ DEL ]
📄 lapb.h
4,869 B
SET
[ EDIT ]
|
[ DEL ]
📄 lib80211.h
4,017 B
SET
[ EDIT ]
|
[ DEL ]
📄 llc.h
4,464 B
SET
[ EDIT ]
|
[ DEL ]
📄 llc_c_ac.h
9,537 B
SET
[ EDIT ]
|
[ DEL ]
📄 llc_c_ev.h
10,940 B
SET
[ EDIT ]
|
[ DEL ]
📄 llc_c_st.h
1,762 B
SET
[ EDIT ]
|
[ DEL ]
📄 llc_conn.h
4,155 B
SET
[ EDIT ]
|
[ DEL ]
📄 llc_if.h
2,210 B
SET
[ EDIT ]
|
[ DEL ]
📄 llc_pdu.h
14,783 B
SET
[ EDIT ]
|
[ DEL ]
📄 llc_s_ac.h
1,591 B
SET
[ EDIT ]
|
[ DEL ]
📄 llc_s_ev.h
2,255 B
SET
[ EDIT ]
|
[ DEL ]
📄 llc_s_st.h
947 B
SET
[ EDIT ]
|
[ DEL ]
📄 llc_sap.h
1,108 B
SET
[ EDIT ]
|
[ DEL ]
📄 lwtunnel.h
6,563 B
SET
[ EDIT ]
|
[ DEL ]
📄 mac80211.h
294,437 B
SET
[ EDIT ]
|
[ DEL ]
📄 mac802154.h
15,633 B
SET
[ EDIT ]
|
[ DEL ]
📄 mip6.h
1,617 B
SET
[ EDIT ]
|
[ DEL ]
📄 mld.h
2,870 B
SET
[ EDIT ]
|
[ DEL ]
📄 mpls.h
1,340 B
SET
[ EDIT ]
|
[ DEL ]
📄 mpls_iptunnel.h
827 B
SET
[ EDIT ]
|
[ DEL ]
📄 mptcp.h
6,242 B
SET
[ EDIT ]
|
[ DEL ]
📄 mrp.h
3,103 B
SET
[ EDIT ]
|
[ DEL ]
📄 ncsi.h
1,964 B
SET
[ EDIT ]
|
[ DEL ]
📄 ndisc.h
15,095 B
SET
[ EDIT ]
|
[ DEL ]
📄 neighbour.h
16,289 B
SET
[ EDIT ]
|
[ DEL ]
📄 net_failover.h
1,023 B
SET
[ EDIT ]
|
[ DEL ]
📄 net_namespace.h
14,177 B
SET
[ EDIT ]
|
[ DEL ]
📄 net_ratelimit.h
220 B
SET
[ EDIT ]
|
[ DEL ]
📄 netdev_queues.h
5,609 B
SET
[ EDIT ]
|
[ DEL ]
📄 netevent.h
1,044 B
SET
[ EDIT ]
|
[ DEL ]
📄 netlabel.h
21,236 B
SET
[ EDIT ]
|
[ DEL ]
📄 netlink.h
63,253 B
SET
[ EDIT ]
|
[ DEL ]
📄 netprio_cgroup.h
1,260 B
SET
[ EDIT ]
|
[ DEL ]
📄 netrom.h
7,896 B
SET
[ EDIT ]
|
[ DEL ]
📄 nexthop.h
865 B
SET
[ EDIT ]
|
[ DEL ]
📄 nl802154.h
12,385 B
SET
[ EDIT ]
|
[ DEL ]
📄 nsh.h
12,602 B
SET
[ EDIT ]
|
[ DEL ]
📄 p8022.h
447 B
SET
[ EDIT ]
|
[ DEL ]
📄 page_pool.h
6,985 B
SET
[ EDIT ]
|
[ DEL ]
📄 pie.h
3,684 B
SET
[ EDIT ]
|
[ DEL ]
📄 ping.h
3,197 B
SET
[ EDIT ]
|
[ DEL ]
📄 pkt_cls.h
26,178 B
SET
[ EDIT ]
|
[ DEL ]
📄 pkt_sched.h
6,543 B
SET
[ EDIT ]
|
[ DEL ]
📄 pptp.h
557 B
SET
[ EDIT ]
|
[ DEL ]
📄 protocol.h
4,320 B
SET
[ EDIT ]
|
[ DEL ]
📄 psample.h
1,083 B
SET
[ EDIT ]
|
[ DEL ]
📄 psnap.h
351 B
SET
[ EDIT ]
|
[ DEL ]
📄 raw.h
2,161 B
SET
[ EDIT ]
|
[ DEL ]
📄 rawv6.h
856 B
SET
[ EDIT ]
|
[ DEL ]
📄 red.h
11,600 B
SET
[ EDIT ]
|
[ DEL ]
📄 regulatory.h
10,961 B
SET
[ EDIT ]
|
[ DEL ]
📄 request_sock.h
6,871 B
SET
[ EDIT ]
|
[ DEL ]
📄 rose.h
7,802 B
SET
[ EDIT ]
|
[ DEL ]
📄 route.h
11,327 B
SET
[ EDIT ]
|
[ DEL ]
📄 rsi_91x.h
1,710 B
SET
[ EDIT ]
|
[ DEL ]
📄 rtnetlink.h
7,212 B
SET
[ EDIT ]
|
[ DEL ]
📄 sch_generic.h
33,841 B
SET
[ EDIT ]
|
[ DEL ]
📄 scm.h
3,671 B
SET
[ EDIT ]
|
[ DEL ]
📄 secure_seq.h
855 B
SET
[ EDIT ]
|
[ DEL ]
📄 seg6.h
1,874 B
SET
[ EDIT ]
|
[ DEL ]
📄 seg6_hmac.h
1,699 B
SET
[ EDIT ]
|
[ DEL ]
📄 seg6_local.h
870 B
SET
[ EDIT ]
|
[ DEL ]
📄 slhc_vj.h
6,831 B
SET
[ EDIT ]
|
[ DEL ]
📄 smc.h
2,155 B
SET
[ EDIT ]
|
[ DEL ]
📄 snmp.h
5,482 B
SET
[ EDIT ]
|
[ DEL ]
📄 sock.h
79,182 B
SET
[ EDIT ]
|
[ DEL ]
📄 sock_reuseport.h
1,565 B
SET
[ EDIT ]
|
[ DEL ]
📄 stp.h
383 B
SET
[ EDIT ]
|
[ DEL ]
📄 strparser.h
4,340 B
SET
[ EDIT ]
|
[ DEL ]
📄 switchdev.h
17,812 B
SET
[ EDIT ]
|
[ DEL ]
📄 tc_wrapper.h
7,033 B
SET
[ EDIT ]
|
[ DEL ]
📄 tcp.h
73,125 B
SET
[ EDIT ]
|
[ DEL ]
📄 tcp_states.h
1,540 B
SET
[ EDIT ]
|
[ DEL ]
📄 timewait_sock.h
1,136 B
SET
[ EDIT ]
|
[ DEL ]
📄 tipc.h
2,405 B
SET
[ EDIT ]
|
[ DEL ]
📄 tls.h
21,363 B
SET
[ EDIT ]
|
[ DEL ]
📄 tls_toe.h
3,006 B
SET
[ EDIT ]
|
[ DEL ]
📄 transp_v6.h
1,996 B
SET
[ EDIT ]
|
[ DEL ]
📄 tso.h
515 B
SET
[ EDIT ]
|
[ DEL ]
📄 tun_proto.h
988 B
SET
[ EDIT ]
|
[ DEL ]
📄 udp.h
16,481 B
SET
[ EDIT ]
|
[ DEL ]
📄 udp_tunnel.h
13,376 B
SET
[ EDIT ]
|
[ DEL ]
📄 udplite.h
3,762 B
SET
[ EDIT ]
|
[ DEL ]
📄 vsock_addr.h
662 B
SET
[ EDIT ]
|
[ DEL ]
📄 vxlan.h
13,541 B
SET
[ EDIT ]
|
[ DEL ]
📄 wext.h
1,510 B
SET
[ EDIT ]
|
[ DEL ]
📄 wimax.h
20,445 B
SET
[ EDIT ]
|
[ DEL ]
📄 x25.h
9,658 B
SET
[ EDIT ]
|
[ DEL ]
📄 x25device.h
387 B
SET
[ EDIT ]
|
[ DEL ]
📄 xdp.h
9,436 B
SET
[ EDIT ]
|
[ DEL ]
📄 xdp_priv.h
446 B
SET
[ EDIT ]
|
[ DEL ]
📄 xdp_sock.h
2,094 B
SET
[ EDIT ]
|
[ DEL ]
📄 xdp_sock_drv.h
6,423 B
SET
[ EDIT ]
|
[ DEL ]
📄 xfrm.h
59,628 B
SET
[ EDIT ]
|
[ DEL ]
📄 xsk_buff_pool.h
6,550 B
SET
[ EDIT ]
|
[ DEL ]
DELETE SELECTED
[ CLOSE ]
EDIT: xdp.h
/* include/net/xdp.h * * Copyright (c) 2017 Jesper Dangaard Brouer, Red Hat Inc. * Released under terms in GPL version 2. See COPYING. */ #ifndef __LINUX_NET_XDP_H__ #define __LINUX_NET_XDP_H__ #include <linux/skbuff.h> /* skb_shared_info */ #include <linux/rh_kabi.h> /** * DOC: XDP RX-queue information * * The XDP RX-queue info (xdp_rxq_info) is associated with the driver * level RX-ring queues. It is information that is specific to how * the driver have configured a given RX-ring queue. * * Each xdp_buff frame received in the driver carry a (pointer) * reference to this xdp_rxq_info structure. This provides the XDP * data-path read-access to RX-info for both kernel and bpf-side * (limited subset). * * For now, direct access is only safe while running in NAPI/softirq * context. Contents is read-mostly and must not be updated during * driver NAPI/softirq poll. * * The driver usage API is a register and unregister API. * * The struct is not directly tied to the XDP prog. A new XDP prog * can be attached as long as it doesn't change the underlying * RX-ring. If the RX-ring does change significantly, the NIC driver * naturally need to stop the RX-ring before purging and reallocating * memory. In that process the driver MUST call unregistor (which * also apply for driver shutdown and unload). The register API is * also mandatory during RX-ring setup. */ enum xdp_mem_type { MEM_TYPE_PAGE_SHARED = 0, /* Split-page refcnt based model */ MEM_TYPE_PAGE_ORDER0, /* Orig XDP full page model */ MEM_TYPE_PAGE_POOL, MEM_TYPE_XSK_BUFF_POOL, MEM_TYPE_MAX, }; /* XDP flags for ndo_xdp_xmit */ #define XDP_XMIT_FLUSH (1U << 0) /* doorbell signal consumer */ #define XDP_XMIT_FLAGS_MASK XDP_XMIT_FLUSH struct xdp_mem_info { u32 type; /* enum xdp_mem_type, but known size type */ u32 id; }; struct page_pool; struct xdp_rxq_info { struct net_device *dev; u32 queue_index; u32 reg_state; struct xdp_mem_info mem; /* RHEL: This structure is not considered part of the kABI * whitelist. However, it is embedded in struct netdev_rx_queue * which is referenced from struct net_device::_rx as an array. * Therefore, we need to protect the size of struct xdp_rxq_info. */ RH_KABI_USE(1, unsigned int napi_id) RH_KABI_RESERVE(2) RH_KABI_RESERVE(3) RH_KABI_RESERVE(4) RH_KABI_RESERVE(5) RH_KABI_RESERVE(6) /* Note that there is more space available after the reserved fields * due to the cache alignment of this structure. Be sure to verify * the result with pahole on all supported archs before using the * padding, though. */ } ____cacheline_aligned; /* perf critical, avoid false-sharing */ struct xdp_txq_info { struct net_device *dev; }; struct xdp_buff { void *data; void *data_end; void *data_meta; void *data_hard_start; struct xdp_rxq_info *rxq; struct xdp_txq_info *txq; u32 frame_sz; /* frame size to deduce data_hard_end/reserved tailroom*/ }; static __always_inline void xdp_init_buff(struct xdp_buff *xdp, u32 frame_sz, struct xdp_rxq_info *rxq) { xdp->frame_sz = frame_sz; xdp->rxq = rxq; } static __always_inline void xdp_prepare_buff(struct xdp_buff *xdp, unsigned char *hard_start, int headroom, int data_len, const bool meta_valid) { unsigned char *data = hard_start + headroom; xdp->data_hard_start = hard_start; xdp->data = data; xdp->data_end = data + data_len; xdp->data_meta = meta_valid ? data : data + 1; } /* Reserve memory area at end-of data area. * * This macro reserves tailroom in the XDP buffer by limiting the * XDP/BPF data access to data_hard_end. Notice same area (and size) * is used for XDP_PASS, when constructing the SKB via build_skb(). */ #define xdp_data_hard_end(xdp) \ ((xdp)->data_hard_start + (xdp)->frame_sz - \ SKB_DATA_ALIGN(sizeof(struct skb_shared_info))) static inline struct skb_shared_info * xdp_get_shared_info_from_buff(struct xdp_buff *xdp) { return (struct skb_shared_info *)xdp_data_hard_end(xdp); } struct xdp_frame { void *data; u16 len; u16 headroom; u32 metasize:8; u32 frame_sz:24; /* Lifetime of xdp_rxq_info is limited to NAPI/enqueue time, * while mem info is valid on remote CPU. */ struct xdp_mem_info mem; struct net_device *dev_rx; /* used by cpumap */ }; #define XDP_BULK_QUEUE_SIZE 16 struct xdp_frame_bulk { int count; void *xa; void *q[XDP_BULK_QUEUE_SIZE]; }; static __always_inline void xdp_frame_bulk_init(struct xdp_frame_bulk *bq) { /* bq->count will be zero'ed when bq->xa gets updated */ bq->xa = NULL; } static inline struct skb_shared_info * xdp_get_shared_info_from_frame(struct xdp_frame *frame) { void *data_hard_start = frame->data - frame->headroom - sizeof(*frame); return (struct skb_shared_info *)(data_hard_start + frame->frame_sz - SKB_DATA_ALIGN(sizeof(struct skb_shared_info))); } struct xdp_cpumap_stats { unsigned int redirect; unsigned int pass; unsigned int drop; }; /* Clear kernel pointers in xdp_frame */ static inline void xdp_scrub_frame(struct xdp_frame *frame) { frame->data = NULL; frame->dev_rx = NULL; } /* Avoids inlining WARN macro in fast-path */ void xdp_warn(const char *msg, const char *func, const int line); #define XDP_WARN(msg) xdp_warn(msg, __func__, __LINE__) struct xdp_frame *xdp_convert_zc_to_xdp_frame(struct xdp_buff *xdp); struct sk_buff *__xdp_build_skb_from_frame(struct xdp_frame *xdpf, struct sk_buff *skb, struct net_device *dev); struct sk_buff *xdp_build_skb_from_frame(struct xdp_frame *xdpf, struct net_device *dev); int xdp_alloc_skb_bulk(void **skbs, int n_skb, gfp_t gfp); struct xdp_frame *xdpf_clone(struct xdp_frame *xdpf); static inline void xdp_convert_frame_to_buff(struct xdp_frame *frame, struct xdp_buff *xdp) { xdp->data_hard_start = frame->data - frame->headroom - sizeof(*frame); xdp->data = frame->data; xdp->data_end = frame->data + frame->len; xdp->data_meta = frame->data - frame->metasize; xdp->frame_sz = frame->frame_sz; } static inline int xdp_update_frame_from_buff(struct xdp_buff *xdp, struct xdp_frame *xdp_frame) { int metasize, headroom; /* Assure headroom is available for storing info */ headroom = xdp->data - xdp->data_hard_start; metasize = xdp->data - xdp->data_meta; metasize = metasize > 0 ? metasize : 0; if (unlikely((headroom - metasize) < sizeof(*xdp_frame))) return -ENOSPC; /* Catch if driver didn't reserve tailroom for skb_shared_info */ if (unlikely(xdp->data_end > xdp_data_hard_end(xdp))) { XDP_WARN("Driver BUG: missing reserved tailroom"); return -ENOSPC; } xdp_frame->data = xdp->data; xdp_frame->len = xdp->data_end - xdp->data; xdp_frame->headroom = headroom - sizeof(*xdp_frame); xdp_frame->metasize = metasize; xdp_frame->frame_sz = xdp->frame_sz; return 0; } /* Convert xdp_buff to xdp_frame */ static inline struct xdp_frame *xdp_convert_buff_to_frame(struct xdp_buff *xdp) { struct xdp_frame *xdp_frame; if (xdp->rxq->mem.type == MEM_TYPE_XSK_BUFF_POOL) return xdp_convert_zc_to_xdp_frame(xdp); /* Store info in top of packet */ xdp_frame = xdp->data_hard_start; if (unlikely(xdp_update_frame_from_buff(xdp, xdp_frame) < 0)) return NULL; /* rxq only valid until napi_schedule ends, convert to xdp_mem_info */ xdp_frame->mem = xdp->rxq->mem; return xdp_frame; } void xdp_return_frame(struct xdp_frame *xdpf); void xdp_return_frame_rx_napi(struct xdp_frame *xdpf); void xdp_return_buff(struct xdp_buff *xdp); void xdp_flush_frame_bulk(struct xdp_frame_bulk *bq); void xdp_return_frame_bulk(struct xdp_frame *xdpf, struct xdp_frame_bulk *bq); /* When sending xdp_frame into the network stack, then there is no * return point callback, which is needed to release e.g. DMA-mapping * resources with page_pool. Thus, have explicit function to release * frame resources. */ void __xdp_release_frame(void *data, struct xdp_mem_info *mem); static inline void xdp_release_frame(struct xdp_frame *xdpf) { struct xdp_mem_info *mem = &xdpf->mem; /* Curr only page_pool needs this */ if (mem->type == MEM_TYPE_PAGE_POOL) __xdp_release_frame(xdpf->data, mem); } /* RHEL: increase the version of xdp_rxq_info_reg kABI whenever XDP is * changed in a kABI incompatible way. That includes changes to ndo_xdp* and * ndo_bpf ops, inline function changes and XDP struct changes. */ RH_KABI_FORCE_CHANGE(3) int xdp_rxq_info_reg(struct xdp_rxq_info *xdp_rxq, struct net_device *dev, u32 queue_index, unsigned int napi_id); void xdp_rxq_info_unreg(struct xdp_rxq_info *xdp_rxq); void xdp_rxq_info_unused(struct xdp_rxq_info *xdp_rxq); bool xdp_rxq_info_is_reg(struct xdp_rxq_info *xdp_rxq); int xdp_rxq_info_reg_mem_model(struct xdp_rxq_info *xdp_rxq, enum xdp_mem_type type, void *allocator); void xdp_rxq_info_unreg_mem_model(struct xdp_rxq_info *xdp_rxq); /* Drivers not supporting XDP metadata can use this helper, which * rejects any room expansion for metadata as a result. */ static __always_inline void xdp_set_data_meta_invalid(struct xdp_buff *xdp) { xdp->data_meta = xdp->data + 1; } static __always_inline bool xdp_data_meta_unsupported(const struct xdp_buff *xdp) { return unlikely(xdp->data_meta > xdp->data); } struct xdp_attachment_info { struct bpf_prog *prog; u32 flags; }; struct netdev_bpf; void xdp_attachment_setup(struct xdp_attachment_info *info, struct netdev_bpf *bpf); #define DEV_MAP_BULK_SIZE XDP_BULK_QUEUE_SIZE #endif /* __LINUX_NET_XDP_H__ */