mirror of
				https://git.proxmox.com/git/mirror_iproute2
				synced 2025-11-04 07:37:05 +00:00 
			
		
		
		
	AF_XDP is an address family that is optimized for high performance
packet processing.
This patch adds AF_XDP support to ss(8) so that sockets can be queried
and monitored.
Example:
$ sudo ss --xdp -e -p -m
Recv-Q      Send-Q           Local Address:Port             Peer Address:Port
0           0                   enp134s0f0:q20                          *
 users:(("xdpsock",pid=17787,fd=3)) ino:39424 sk:4
        rx(entries:2048)
        tx(entries:2048)
        umem(id:1,size:8388608,num_pages:2048,chunk_size:2048,headroom:0,ifindex:7,
qid:20,zc:0,refs:1)
        fr(entries:2048)
        cr(entries:2048) skmem:(r0,rb212992,t0,tb212992,f0,w0,o0,bl0,d0)
0           0                    enp24s0f0:q0                           *
 users:(("xdpsock",pid=17780,fd=3)) ino:37384 sk:5
        rx(entries:2048)
        tx(entries:2048)
        umem(id:0,size:8388608,num_pages:2048,chunk_size:2048,headroom:0,ifindex:6,
qid:0,zc:1,refs:1)
        fr(entries:2048)
        cr(entries:2048) skmem:(r0,rb212992,t0,tb212992,f0,w0,o0,bl0,d0)
Signed-off-by: Björn Töpel <bjorn.topel@intel.com>
Signed-off-by: David Ahern <dsahern@gmail.com>
		
	
			
		
			
				
	
	
		
			325 lines
		
	
	
		
			8.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			325 lines
		
	
	
		
			8.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/* SPDX-License-Identifier: GPL-2.0 */
 | 
						|
#ifndef __UTILS_H__
 | 
						|
#define __UTILS_H__ 1
 | 
						|
 | 
						|
#include <sys/types.h>
 | 
						|
#include <asm/types.h>
 | 
						|
#include <resolv.h>
 | 
						|
#include <stdlib.h>
 | 
						|
#include <stdbool.h>
 | 
						|
#include <time.h>
 | 
						|
 | 
						|
#ifdef HAVE_LIBBSD
 | 
						|
#include <bsd/string.h>
 | 
						|
#endif
 | 
						|
 | 
						|
#include "libnetlink.h"
 | 
						|
#include "ll_map.h"
 | 
						|
#include "rtm_map.h"
 | 
						|
#include "json_print.h"
 | 
						|
 | 
						|
extern int preferred_family;
 | 
						|
extern int human_readable;
 | 
						|
extern int use_iec;
 | 
						|
extern int show_stats;
 | 
						|
extern int show_details;
 | 
						|
extern int show_raw;
 | 
						|
extern int resolve_hosts;
 | 
						|
extern int oneline;
 | 
						|
extern int brief;
 | 
						|
extern int json;
 | 
						|
extern int pretty;
 | 
						|
extern int timestamp;
 | 
						|
extern int timestamp_short;
 | 
						|
extern const char * _SL_;
 | 
						|
extern int max_flush_loops;
 | 
						|
extern int batch_mode;
 | 
						|
extern bool do_all;
 | 
						|
 | 
						|
#ifndef CONFDIR
 | 
						|
#define CONFDIR		"/etc/iproute2"
 | 
						|
#endif
 | 
						|
 | 
						|
#define SPRINT_BSIZE 64
 | 
						|
#define SPRINT_BUF(x)	char x[SPRINT_BSIZE]
 | 
						|
 | 
						|
void incomplete_command(void) __attribute__((noreturn));
 | 
						|
 | 
						|
#define NEXT_ARG() do { argv++; if (--argc <= 0) incomplete_command(); } while(0)
 | 
						|
#define NEXT_ARG_OK() (argc - 1 > 0)
 | 
						|
#define NEXT_ARG_FWD() do { argv++; argc--; } while(0)
 | 
						|
#define PREV_ARG() do { argv--; argc++; } while(0)
 | 
						|
 | 
						|
#define TIME_UNITS_PER_SEC	1000000
 | 
						|
#define NSEC_PER_USEC 1000
 | 
						|
#define NSEC_PER_MSEC 1000000
 | 
						|
#define NSEC_PER_SEC 1000000000LL
 | 
						|
 | 
						|
typedef struct
 | 
						|
{
 | 
						|
	__u16 flags;
 | 
						|
	__u16 bytelen;
 | 
						|
	__s16 bitlen;
 | 
						|
	/* These next two fields match rtvia */
 | 
						|
	__u16 family;
 | 
						|
	__u32 data[64];
 | 
						|
} inet_prefix;
 | 
						|
 | 
						|
enum {
 | 
						|
	PREFIXLEN_SPECIFIED	= (1 << 0),
 | 
						|
	ADDRTYPE_INET		= (1 << 1),
 | 
						|
	ADDRTYPE_UNSPEC		= (1 << 2),
 | 
						|
	ADDRTYPE_MULTI		= (1 << 3),
 | 
						|
 | 
						|
	ADDRTYPE_INET_UNSPEC	= ADDRTYPE_INET | ADDRTYPE_UNSPEC,
 | 
						|
	ADDRTYPE_INET_MULTI	= ADDRTYPE_INET | ADDRTYPE_MULTI
 | 
						|
};
 | 
						|
 | 
						|
static inline void inet_prefix_reset(inet_prefix *p)
 | 
						|
{
 | 
						|
	p->flags = 0;
 | 
						|
}
 | 
						|
 | 
						|
static inline bool is_addrtype_inet(const inet_prefix *p)
 | 
						|
{
 | 
						|
	return p->flags & ADDRTYPE_INET;
 | 
						|
}
 | 
						|
 | 
						|
static inline bool is_addrtype_inet_unspec(const inet_prefix *p)
 | 
						|
{
 | 
						|
	return (p->flags & ADDRTYPE_INET_UNSPEC) == ADDRTYPE_INET_UNSPEC;
 | 
						|
}
 | 
						|
 | 
						|
static inline bool is_addrtype_inet_multi(const inet_prefix *p)
 | 
						|
{
 | 
						|
	return (p->flags & ADDRTYPE_INET_MULTI) == ADDRTYPE_INET_MULTI;
 | 
						|
}
 | 
						|
 | 
						|
static inline bool is_addrtype_inet_not_unspec(const inet_prefix *p)
 | 
						|
{
 | 
						|
	return (p->flags & ADDRTYPE_INET_UNSPEC) == ADDRTYPE_INET;
 | 
						|
}
 | 
						|
 | 
						|
static inline bool is_addrtype_inet_not_multi(const inet_prefix *p)
 | 
						|
{
 | 
						|
	return (p->flags & ADDRTYPE_INET_MULTI) == ADDRTYPE_INET;
 | 
						|
}
 | 
						|
 | 
						|
#define DN_MAXADDL 20
 | 
						|
#ifndef AF_DECnet
 | 
						|
#define AF_DECnet 12
 | 
						|
#endif
 | 
						|
 | 
						|
struct dn_naddr
 | 
						|
{
 | 
						|
        unsigned short          a_len;
 | 
						|
        unsigned char a_addr[DN_MAXADDL];
 | 
						|
};
 | 
						|
 | 
						|
#ifndef AF_MPLS
 | 
						|
# define AF_MPLS 28
 | 
						|
#endif
 | 
						|
#ifndef IPPROTO_MPLS
 | 
						|
#define IPPROTO_MPLS	137
 | 
						|
#endif
 | 
						|
 | 
						|
#ifndef CLOCK_TAI
 | 
						|
# define CLOCK_TAI 11
 | 
						|
#endif
 | 
						|
 | 
						|
#ifndef AF_XDP
 | 
						|
# define AF_XDP 44
 | 
						|
# if AF_MAX < 45
 | 
						|
#  undef AF_MAX
 | 
						|
#  define AF_MAX 45
 | 
						|
# endif
 | 
						|
#endif
 | 
						|
 | 
						|
__u32 get_addr32(const char *name);
 | 
						|
int get_addr_1(inet_prefix *dst, const char *arg, int family);
 | 
						|
int get_prefix_1(inet_prefix *dst, char *arg, int family);
 | 
						|
int get_addr(inet_prefix *dst, const char *arg, int family);
 | 
						|
int get_prefix(inet_prefix *dst, char *arg, int family);
 | 
						|
int mask2bits(__u32 netmask);
 | 
						|
int get_addr_rta(inet_prefix *dst, const struct rtattr *rta, int family);
 | 
						|
int get_addr_ila(__u64 *val, const char *arg);
 | 
						|
 | 
						|
int read_prop(const char *dev, char *prop, long *value);
 | 
						|
int parse_percent(double *val, const char *str);
 | 
						|
int get_hex(char c);
 | 
						|
int get_integer(int *val, const char *arg, int base);
 | 
						|
int get_unsigned(unsigned *val, const char *arg, int base);
 | 
						|
int get_time_rtt(unsigned *val, const char *arg, int *raw);
 | 
						|
#define get_byte get_u8
 | 
						|
#define get_ushort get_u16
 | 
						|
#define get_short get_s16
 | 
						|
int get_s64(__s64 *val, const char *arg, int base);
 | 
						|
int get_u64(__u64 *val, const char *arg, int base);
 | 
						|
int get_u32(__u32 *val, const char *arg, int base);
 | 
						|
int get_s32(__s32 *val, const char *arg, int base);
 | 
						|
int get_u16(__u16 *val, const char *arg, int base);
 | 
						|
int get_u8(__u8 *val, const char *arg, int base);
 | 
						|
int get_be64(__be64 *val, const char *arg, int base);
 | 
						|
int get_be32(__be32 *val, const char *arg, int base);
 | 
						|
int get_be16(__be16 *val, const char *arg, int base);
 | 
						|
int get_addr64(__u64 *ap, const char *cp);
 | 
						|
 | 
						|
int hex2mem(const char *buf, uint8_t *mem, int count);
 | 
						|
char *hexstring_n2a(const __u8 *str, int len, char *buf, int blen);
 | 
						|
__u8 *hexstring_a2n(const char *str, __u8 *buf, int blen, unsigned int *len);
 | 
						|
#define ADDR64_BUF_SIZE sizeof("xxxx:xxxx:xxxx:xxxx")
 | 
						|
int addr64_n2a(__u64 addr, char *buff, size_t len);
 | 
						|
 | 
						|
int af_bit_len(int af);
 | 
						|
 | 
						|
const char *format_host_r(int af, int len, const void *addr,
 | 
						|
			       char *buf, int buflen);
 | 
						|
#define format_host_rta_r(af, rta, buf, buflen)	\
 | 
						|
	format_host_r(af, RTA_PAYLOAD(rta), RTA_DATA(rta), \
 | 
						|
		      buf, buflen)
 | 
						|
 | 
						|
const char *format_host(int af, int lne, const void *addr);
 | 
						|
#define format_host_rta(af, rta) \
 | 
						|
	format_host(af, RTA_PAYLOAD(rta), RTA_DATA(rta))
 | 
						|
const char *rt_addr_n2a_r(int af, int len, const void *addr,
 | 
						|
			       char *buf, int buflen);
 | 
						|
const char *rt_addr_n2a(int af, int len, const void *addr);
 | 
						|
#define rt_addr_n2a_rta(af, rta) \
 | 
						|
	rt_addr_n2a(af, RTA_PAYLOAD(rta), RTA_DATA(rta))
 | 
						|
 | 
						|
int read_family(const char *name);
 | 
						|
const char *family_name(int family);
 | 
						|
 | 
						|
void missarg(const char *) __attribute__((noreturn));
 | 
						|
void invarg(const char *, const char *) __attribute__((noreturn));
 | 
						|
void duparg(const char *, const char *) __attribute__((noreturn));
 | 
						|
void duparg2(const char *, const char *) __attribute__((noreturn));
 | 
						|
int nodev(const char *dev);
 | 
						|
int check_ifname(const char *);
 | 
						|
int get_ifname(char *, const char *);
 | 
						|
const char *get_ifname_rta(int ifindex, const struct rtattr *rta);
 | 
						|
int matches(const char *arg, const char *pattern);
 | 
						|
int inet_addr_match(const inet_prefix *a, const inet_prefix *b, int bits);
 | 
						|
int inet_addr_match_rta(const inet_prefix *m, const struct rtattr *rta);
 | 
						|
 | 
						|
const char *mpls_ntop(int af, const void *addr, char *str, size_t len);
 | 
						|
int mpls_pton(int af, const char *src, void *addr, size_t alen);
 | 
						|
 | 
						|
extern int __iproute2_hz_internal;
 | 
						|
int __get_hz(void);
 | 
						|
 | 
						|
static __inline__ int get_hz(void)
 | 
						|
{
 | 
						|
	if (__iproute2_hz_internal == 0)
 | 
						|
		__iproute2_hz_internal = __get_hz();
 | 
						|
	return __iproute2_hz_internal;
 | 
						|
}
 | 
						|
 | 
						|
extern int __iproute2_user_hz_internal;
 | 
						|
int __get_user_hz(void);
 | 
						|
 | 
						|
static __inline__ int get_user_hz(void)
 | 
						|
{
 | 
						|
	if (__iproute2_user_hz_internal == 0)
 | 
						|
		__iproute2_user_hz_internal = __get_user_hz();
 | 
						|
	return __iproute2_user_hz_internal;
 | 
						|
}
 | 
						|
 | 
						|
static inline __u32 nl_mgrp(__u32 group)
 | 
						|
{
 | 
						|
	if (group > 31 ) {
 | 
						|
		fprintf(stderr, "Use setsockopt for this group %d\n", group);
 | 
						|
		exit(-1);
 | 
						|
	}
 | 
						|
	return group ? (1 << (group - 1)) : 0;
 | 
						|
}
 | 
						|
 | 
						|
/* courtesy of bridge-utils */
 | 
						|
static inline unsigned long __tv_to_jiffies(const struct timeval *tv)
 | 
						|
{
 | 
						|
	unsigned long long jif;
 | 
						|
 | 
						|
	jif = 1000000ULL * tv->tv_sec + tv->tv_usec;
 | 
						|
 | 
						|
	return jif/10000;
 | 
						|
}
 | 
						|
 | 
						|
static inline void __jiffies_to_tv(struct timeval *tv, unsigned long jiffies)
 | 
						|
{
 | 
						|
	unsigned long long tvusec;
 | 
						|
 | 
						|
	tvusec = 10000ULL*jiffies;
 | 
						|
	tv->tv_sec = tvusec/1000000;
 | 
						|
	tv->tv_usec = tvusec - 1000000 * tv->tv_sec;
 | 
						|
}
 | 
						|
 | 
						|
void print_escape_buf(const __u8 *buf, size_t len, const char *escape);
 | 
						|
 | 
						|
int print_timestamp(FILE *fp);
 | 
						|
void print_nlmsg_timestamp(FILE *fp, const struct nlmsghdr *n);
 | 
						|
 | 
						|
unsigned int print_name_and_link(const char *fmt,
 | 
						|
				 const char *name, struct rtattr *tb[]);
 | 
						|
 | 
						|
#define BIT(nr)                 (1UL << (nr))
 | 
						|
 | 
						|
#define ARRAY_SIZE(x) (sizeof(x) / sizeof((x)[0]))
 | 
						|
 | 
						|
#define BUILD_BUG_ON(cond) ((void)sizeof(char[1 - 2 * !!(cond)]))
 | 
						|
 | 
						|
#ifndef offsetof
 | 
						|
# define offsetof(type, member) ((size_t) &((type *)0)->member)
 | 
						|
#endif
 | 
						|
 | 
						|
#ifndef min
 | 
						|
# define min(x, y) ({			\
 | 
						|
	typeof(x) _min1 = (x);		\
 | 
						|
	typeof(y) _min2 = (y);		\
 | 
						|
	(void) (&_min1 == &_min2);	\
 | 
						|
	_min1 < _min2 ? _min1 : _min2; })
 | 
						|
#endif
 | 
						|
 | 
						|
#ifndef __check_format_string
 | 
						|
# define __check_format_string(pos_str, pos_args) \
 | 
						|
	__attribute__ ((format (printf, (pos_str), (pos_args))))
 | 
						|
#endif
 | 
						|
 | 
						|
#define _textify(x)	#x
 | 
						|
#define textify(x)	_textify(x)
 | 
						|
 | 
						|
#define htonll(x) ((1==htonl(1)) ? (x) : ((uint64_t)htonl((x) & 0xFFFFFFFF) << 32) | htonl((x) >> 32))
 | 
						|
#define ntohll(x) ((1==ntohl(1)) ? (x) : ((uint64_t)ntohl((x) & 0xFFFFFFFF) << 32) | ntohl((x) >> 32))
 | 
						|
 | 
						|
extern int cmdlineno;
 | 
						|
ssize_t getcmdline(char **line, size_t *len, FILE *in);
 | 
						|
int makeargs(char *line, char *argv[], int maxargs);
 | 
						|
 | 
						|
int do_each_netns(int (*func)(char *nsname, void *arg), void *arg,
 | 
						|
		bool show_label);
 | 
						|
 | 
						|
char *int_to_str(int val, char *buf);
 | 
						|
int get_guid(__u64 *guid, const char *arg);
 | 
						|
int get_real_family(int rtm_type, int rtm_family);
 | 
						|
 | 
						|
int cmd_exec(const char *cmd, char **argv, bool do_fork);
 | 
						|
int make_path(const char *path, mode_t mode);
 | 
						|
char *find_cgroup2_mount(void);
 | 
						|
int get_command_name(const char *pid, char *comm, size_t len);
 | 
						|
 | 
						|
int get_rtnl_link_stats_rta(struct rtnl_link_stats64 *stats64,
 | 
						|
			    struct rtattr *tb[]);
 | 
						|
 | 
						|
#ifdef NEED_STRLCPY
 | 
						|
size_t strlcpy(char *dst, const char *src, size_t size);
 | 
						|
size_t strlcat(char *dst, const char *src, size_t size);
 | 
						|
#endif
 | 
						|
 | 
						|
void drop_cap(void);
 | 
						|
 | 
						|
int get_time(unsigned int *time, const char *str);
 | 
						|
int get_time64(__s64 *time, const char *str);
 | 
						|
char *sprint_time(__u32 time, char *buf);
 | 
						|
char *sprint_time64(__s64 time, char *buf);
 | 
						|
 | 
						|
#endif /* __UTILS_H__ */
 |