diff options
Diffstat (limited to 'tools/include/uapi/linux')
| -rw-r--r-- | tools/include/uapi/linux/bpf.h | 132 | ||||
| -rw-r--r-- | tools/include/uapi/linux/btf.h | 2 | ||||
| -rw-r--r-- | tools/include/uapi/linux/if_link.h | 2 | ||||
| -rw-r--r-- | tools/include/uapi/linux/in.h | 301 | ||||
| -rw-r--r-- | tools/include/uapi/linux/kvm.h | 1 | ||||
| -rw-r--r-- | tools/include/uapi/linux/perf_event.h | 2 | 
6 files changed, 429 insertions, 11 deletions
| diff --git a/tools/include/uapi/linux/bpf.h b/tools/include/uapi/linux/bpf.h index e0b06784f227..66917a4eba27 100644 --- a/tools/include/uapi/linux/bpf.h +++ b/tools/include/uapi/linux/bpf.h @@ -75,6 +75,11 @@ struct bpf_lpm_trie_key {  	__u8	data[0];	/* Arbitrary size */  }; +struct bpf_cgroup_storage_key { +	__u64	cgroup_inode_id;	/* cgroup inode id */ +	__u32	attach_type;		/* program attach type */ +}; +  /* BPF syscall commands, see bpf(2) man-page for details. */  enum bpf_cmd {  	BPF_MAP_CREATE, @@ -120,6 +125,8 @@ enum bpf_map_type {  	BPF_MAP_TYPE_CPUMAP,  	BPF_MAP_TYPE_XSKMAP,  	BPF_MAP_TYPE_SOCKHASH, +	BPF_MAP_TYPE_CGROUP_STORAGE, +	BPF_MAP_TYPE_REUSEPORT_SOCKARRAY,  };  enum bpf_prog_type { @@ -144,6 +151,7 @@ enum bpf_prog_type {  	BPF_PROG_TYPE_CGROUP_SOCK_ADDR,  	BPF_PROG_TYPE_LWT_SEG6LOCAL,  	BPF_PROG_TYPE_LIRC_MODE2, +	BPF_PROG_TYPE_SK_REUSEPORT,  };  enum bpf_attach_type { @@ -1371,6 +1379,20 @@ union bpf_attr {   * 		A 8-byte long non-decreasing number on success, or 0 if the   * 		socket field is missing inside *skb*.   * + * u64 bpf_get_socket_cookie(struct bpf_sock_addr *ctx) + * 	Description + * 		Equivalent to bpf_get_socket_cookie() helper that accepts + * 		*skb*, but gets socket from **struct bpf_sock_addr** contex. + * 	Return + * 		A 8-byte long non-decreasing number. + * + * u64 bpf_get_socket_cookie(struct bpf_sock_ops *ctx) + * 	Description + * 		Equivalent to bpf_get_socket_cookie() helper that accepts + * 		*skb*, but gets socket from **struct bpf_sock_ops** contex. + * 	Return + * 		A 8-byte long non-decreasing number. + *   * u32 bpf_get_socket_uid(struct sk_buff *skb)   * 	Return   * 		The owner UID of the socket associated to *skb*. If the socket @@ -1826,7 +1848,7 @@ union bpf_attr {   * 		A non-negative value equal to or less than *size* on success,   * 		or a negative error in case of failure.   * - * int skb_load_bytes_relative(const struct sk_buff *skb, u32 offset, void *to, u32 len, u32 start_header) + * int bpf_skb_load_bytes_relative(const struct sk_buff *skb, u32 offset, void *to, u32 len, u32 start_header)   * 	Description   * 		This helper is similar to **bpf_skb_load_bytes**\ () in that   * 		it provides an easy way to load *len* bytes from *offset* @@ -1857,7 +1879,8 @@ union bpf_attr {   *		is resolved), the nexthop address is returned in ipv4_dst   *		or ipv6_dst based on family, smac is set to mac address of   *		egress device, dmac is set to nexthop mac address, rt_metric - *		is set to metric from route (IPv4/IPv6 only). + *		is set to metric from route (IPv4/IPv6 only), and ifindex + *		is set to the device index of the nexthop from the FIB lookup.   *   *             *plen* argument is the size of the passed in struct.   *             *flags* argument can be a combination of one or more of the @@ -1873,9 +1896,10 @@ union bpf_attr {   *             *ctx* is either **struct xdp_md** for XDP programs or   *             **struct sk_buff** tc cls_act programs.   *     Return - *             Egress device index on success, 0 if packet needs to continue - *             up the stack for further processing or a negative error in case - *             of failure. + *		* < 0 if any input argument is invalid + *		*   0 on success (packet is forwarded, nexthop neighbor exists) + *		* > 0 one of **BPF_FIB_LKUP_RET_** codes explaining why the + *		  packet is not forwarded or needs assist from full stack   *   * int bpf_sock_hash_update(struct bpf_sock_ops_kern *skops, struct bpf_map *map, void *key, u64 flags)   *	Description @@ -2031,7 +2055,6 @@ union bpf_attr {   *		This helper is only available is the kernel was compiled with   *		the **CONFIG_BPF_LIRC_MODE2** configuration option set to   *		"**y**". - *   *	Return   *		0   * @@ -2051,7 +2074,6 @@ union bpf_attr {   *		This helper is only available is the kernel was compiled with   *		the **CONFIG_BPF_LIRC_MODE2** configuration option set to   *		"**y**". - *   *	Return   *		0   * @@ -2071,10 +2093,54 @@ union bpf_attr {   * 	Return   * 		The id is returned or 0 in case the id could not be retrieved.   * + * u64 bpf_skb_ancestor_cgroup_id(struct sk_buff *skb, int ancestor_level) + *	Description + *		Return id of cgroup v2 that is ancestor of cgroup associated + *		with the *skb* at the *ancestor_level*.  The root cgroup is at + *		*ancestor_level* zero and each step down the hierarchy + *		increments the level. If *ancestor_level* == level of cgroup + *		associated with *skb*, then return value will be same as that + *		of **bpf_skb_cgroup_id**\ (). + * + *		The helper is useful to implement policies based on cgroups + *		that are upper in hierarchy than immediate cgroup associated + *		with *skb*. + * + *		The format of returned id and helper limitations are same as in + *		**bpf_skb_cgroup_id**\ (). + *	Return + *		The id is returned or 0 in case the id could not be retrieved. + *   * u64 bpf_get_current_cgroup_id(void)   * 	Return   * 		A 64-bit integer containing the current cgroup id based   * 		on the cgroup within which the current task is running. + * + * void* get_local_storage(void *map, u64 flags) + *	Description + *		Get the pointer to the local storage area. + *		The type and the size of the local storage is defined + *		by the *map* argument. + *		The *flags* meaning is specific for each map type, + *		and has to be 0 for cgroup local storage. + * + *		Depending on the bpf program type, a local storage area + *		can be shared between multiple instances of the bpf program, + *		running simultaneously. + * + *		A user should care about the synchronization by himself. + *		For example, by using the BPF_STX_XADD instruction to alter + *		the shared data. + *	Return + *		Pointer to the local storage area. + * + * int bpf_sk_select_reuseport(struct sk_reuseport_md *reuse, struct bpf_map *map, void *key, u64 flags) + *	Description + *		Select a SO_REUSEPORT sk from a	BPF_MAP_TYPE_REUSEPORT_ARRAY map + *		It checks the selected sk is matching the incoming + *		request in the skb. + *	Return + *		0 on success, or a negative error in case of failure.   */  #define __BPF_FUNC_MAPPER(FN)		\  	FN(unspec),			\ @@ -2157,7 +2223,10 @@ union bpf_attr {  	FN(rc_repeat),			\  	FN(rc_keydown),			\  	FN(skb_cgroup_id),		\ -	FN(get_current_cgroup_id), +	FN(get_current_cgroup_id),	\ +	FN(get_local_storage),		\ +	FN(sk_select_reuseport),	\ +	FN(skb_ancestor_cgroup_id),  /* integer value in 'imm' field of BPF_CALL instruction selects which helper   * function eBPF program intends to call @@ -2374,6 +2443,30 @@ struct sk_msg_md {  	__u32 local_port;	/* stored in host byte order */  }; +struct sk_reuseport_md { +	/* +	 * Start of directly accessible data. It begins from +	 * the tcp/udp header. +	 */ +	void *data; +	void *data_end;		/* End of directly accessible data */ +	/* +	 * Total length of packet (starting from the tcp/udp header). +	 * Note that the directly accessible bytes (data_end - data) +	 * could be less than this "len".  Those bytes could be +	 * indirectly read by a helper "bpf_skb_load_bytes()". +	 */ +	__u32 len; +	/* +	 * Eth protocol in the mac header (network byte order). e.g. +	 * ETH_P_IP(0x0800) and ETH_P_IPV6(0x86DD) +	 */ +	__u32 eth_protocol; +	__u32 ip_protocol;	/* IP protocol. e.g. IPPROTO_TCP, IPPROTO_UDP */ +	__u32 bind_inany;	/* Is sock bound to an INANY address? */ +	__u32 hash;		/* A hash of the packet 4 tuples */ +}; +  #define BPF_TAG_SIZE	8  struct bpf_prog_info { @@ -2555,6 +2648,9 @@ enum {  					 * Arg1: old_state  					 * Arg2: new_state  					 */ +	BPF_SOCK_OPS_TCP_LISTEN_CB,	/* Called on listen(2), right after +					 * socket transition to LISTEN state. +					 */  };  /* List of TCP states. There is a build check in net/ipv4/tcp.c to detect @@ -2612,6 +2708,18 @@ struct bpf_raw_tracepoint_args {  #define BPF_FIB_LOOKUP_DIRECT  BIT(0)  #define BPF_FIB_LOOKUP_OUTPUT  BIT(1) +enum { +	BPF_FIB_LKUP_RET_SUCCESS,      /* lookup successful */ +	BPF_FIB_LKUP_RET_BLACKHOLE,    /* dest is blackholed; can be dropped */ +	BPF_FIB_LKUP_RET_UNREACHABLE,  /* dest is unreachable; can be dropped */ +	BPF_FIB_LKUP_RET_PROHIBIT,     /* dest not allowed; can be dropped */ +	BPF_FIB_LKUP_RET_NOT_FWDED,    /* packet is not forwarded */ +	BPF_FIB_LKUP_RET_FWD_DISABLED, /* fwding is not enabled on ingress */ +	BPF_FIB_LKUP_RET_UNSUPP_LWT,   /* fwd requires encapsulation */ +	BPF_FIB_LKUP_RET_NO_NEIGH,     /* no neighbor entry for nh */ +	BPF_FIB_LKUP_RET_FRAG_NEEDED,  /* fragmentation required to fwd */ +}; +  struct bpf_fib_lookup {  	/* input:  network family for lookup (AF_INET, AF_INET6)  	 * output: network family of egress nexthop @@ -2625,12 +2733,16 @@ struct bpf_fib_lookup {  	/* total length of packet from network header - used for MTU check */  	__u16	tot_len; -	__u32	ifindex;  /* L3 device index for lookup */ + +	/* input: L3 device index for lookup +	 * output: device index from FIB lookup +	 */ +	__u32	ifindex;  	union {  		/* inputs to lookup */  		__u8	tos;		/* AF_INET  */ -		__be32	flowlabel;	/* AF_INET6 */ +		__be32	flowinfo;	/* AF_INET6, flow_label + priority */  		/* output: metric of fib result (IPv4/IPv6 only) */  		__u32	rt_metric; diff --git a/tools/include/uapi/linux/btf.h b/tools/include/uapi/linux/btf.h index 0b5ddbe135a4..972265f32871 100644 --- a/tools/include/uapi/linux/btf.h +++ b/tools/include/uapi/linux/btf.h @@ -76,7 +76,7 @@ struct btf_type {   */  #define BTF_INT_ENCODING(VAL)	(((VAL) & 0x0f000000) >> 24)  #define BTF_INT_OFFSET(VAL)	(((VAL  & 0x00ff0000)) >> 16) -#define BTF_INT_BITS(VAL)	((VAL)  & 0x0000ffff) +#define BTF_INT_BITS(VAL)	((VAL)  & 0x000000ff)  /* Attributes stored in the BTF_INT_ENCODING */  #define BTF_INT_SIGNED	(1 << 0) diff --git a/tools/include/uapi/linux/if_link.h b/tools/include/uapi/linux/if_link.h index 68699f654118..cf01b6824244 100644 --- a/tools/include/uapi/linux/if_link.h +++ b/tools/include/uapi/linux/if_link.h @@ -333,6 +333,7 @@ enum {  	IFLA_BRPORT_BCAST_FLOOD,  	IFLA_BRPORT_GROUP_FWD_MASK,  	IFLA_BRPORT_NEIGH_SUPPRESS, +	IFLA_BRPORT_ISOLATED,  	__IFLA_BRPORT_MAX  };  #define IFLA_BRPORT_MAX (__IFLA_BRPORT_MAX - 1) @@ -516,6 +517,7 @@ enum {  	IFLA_VXLAN_COLLECT_METADATA,  	IFLA_VXLAN_LABEL,  	IFLA_VXLAN_GPE, +	IFLA_VXLAN_TTL_INHERIT,  	__IFLA_VXLAN_MAX  };  #define IFLA_VXLAN_MAX	(__IFLA_VXLAN_MAX - 1) diff --git a/tools/include/uapi/linux/in.h b/tools/include/uapi/linux/in.h new file mode 100644 index 000000000000..48e8a225b985 --- /dev/null +++ b/tools/include/uapi/linux/in.h @@ -0,0 +1,301 @@ +/* SPDX-License-Identifier: GPL-2.0+ WITH Linux-syscall-note */ +/* + * INET		An implementation of the TCP/IP protocol suite for the LINUX + *		operating system.  INET is implemented using the  BSD Socket + *		interface as the means of communication with the user level. + * + *		Definitions of the Internet Protocol. + * + * Version:	@(#)in.h	1.0.1	04/21/93 + * + * Authors:	Original taken from the GNU Project <netinet/in.h> file. + *		Fred N. van Kempen, <[email protected]> + * + *		This program is free software; you can redistribute it and/or + *		modify it under the terms of the GNU General Public License + *		as published by the Free Software Foundation; either version + *		2 of the License, or (at your option) any later version. + */ +#ifndef _UAPI_LINUX_IN_H +#define _UAPI_LINUX_IN_H + +#include <linux/types.h> +#include <linux/libc-compat.h> +#include <linux/socket.h> + +#if __UAPI_DEF_IN_IPPROTO +/* Standard well-defined IP protocols.  */ +enum { +  IPPROTO_IP = 0,		/* Dummy protocol for TCP		*/ +#define IPPROTO_IP		IPPROTO_IP +  IPPROTO_ICMP = 1,		/* Internet Control Message Protocol	*/ +#define IPPROTO_ICMP		IPPROTO_ICMP +  IPPROTO_IGMP = 2,		/* Internet Group Management Protocol	*/ +#define IPPROTO_IGMP		IPPROTO_IGMP +  IPPROTO_IPIP = 4,		/* IPIP tunnels (older KA9Q tunnels use 94) */ +#define IPPROTO_IPIP		IPPROTO_IPIP +  IPPROTO_TCP = 6,		/* Transmission Control Protocol	*/ +#define IPPROTO_TCP		IPPROTO_TCP +  IPPROTO_EGP = 8,		/* Exterior Gateway Protocol		*/ +#define IPPROTO_EGP		IPPROTO_EGP +  IPPROTO_PUP = 12,		/* PUP protocol				*/ +#define IPPROTO_PUP		IPPROTO_PUP +  IPPROTO_UDP = 17,		/* User Datagram Protocol		*/ +#define IPPROTO_UDP		IPPROTO_UDP +  IPPROTO_IDP = 22,		/* XNS IDP protocol			*/ +#define IPPROTO_IDP		IPPROTO_IDP +  IPPROTO_TP = 29,		/* SO Transport Protocol Class 4	*/ +#define IPPROTO_TP		IPPROTO_TP +  IPPROTO_DCCP = 33,		/* Datagram Congestion Control Protocol */ +#define IPPROTO_DCCP		IPPROTO_DCCP +  IPPROTO_IPV6 = 41,		/* IPv6-in-IPv4 tunnelling		*/ +#define IPPROTO_IPV6		IPPROTO_IPV6 +  IPPROTO_RSVP = 46,		/* RSVP Protocol			*/ +#define IPPROTO_RSVP		IPPROTO_RSVP +  IPPROTO_GRE = 47,		/* Cisco GRE tunnels (rfc 1701,1702)	*/ +#define IPPROTO_GRE		IPPROTO_GRE +  IPPROTO_ESP = 50,		/* Encapsulation Security Payload protocol */ +#define IPPROTO_ESP		IPPROTO_ESP +  IPPROTO_AH = 51,		/* Authentication Header protocol	*/ +#define IPPROTO_AH		IPPROTO_AH +  IPPROTO_MTP = 92,		/* Multicast Transport Protocol		*/ +#define IPPROTO_MTP		IPPROTO_MTP +  IPPROTO_BEETPH = 94,		/* IP option pseudo header for BEET	*/ +#define IPPROTO_BEETPH		IPPROTO_BEETPH +  IPPROTO_ENCAP = 98,		/* Encapsulation Header			*/ +#define IPPROTO_ENCAP		IPPROTO_ENCAP +  IPPROTO_PIM = 103,		/* Protocol Independent Multicast	*/ +#define IPPROTO_PIM		IPPROTO_PIM +  IPPROTO_COMP = 108,		/* Compression Header Protocol		*/ +#define IPPROTO_COMP		IPPROTO_COMP +  IPPROTO_SCTP = 132,		/* Stream Control Transport Protocol	*/ +#define IPPROTO_SCTP		IPPROTO_SCTP +  IPPROTO_UDPLITE = 136,	/* UDP-Lite (RFC 3828)			*/ +#define IPPROTO_UDPLITE		IPPROTO_UDPLITE +  IPPROTO_MPLS = 137,		/* MPLS in IP (RFC 4023)		*/ +#define IPPROTO_MPLS		IPPROTO_MPLS +  IPPROTO_RAW = 255,		/* Raw IP packets			*/ +#define IPPROTO_RAW		IPPROTO_RAW +  IPPROTO_MAX +}; +#endif + +#if __UAPI_DEF_IN_ADDR +/* Internet address. */ +struct in_addr { +	__be32	s_addr; +}; +#endif + +#define IP_TOS		1 +#define IP_TTL		2 +#define IP_HDRINCL	3 +#define IP_OPTIONS	4 +#define IP_ROUTER_ALERT	5 +#define IP_RECVOPTS	6 +#define IP_RETOPTS	7 +#define IP_PKTINFO	8 +#define IP_PKTOPTIONS	9 +#define IP_MTU_DISCOVER	10 +#define IP_RECVERR	11 +#define IP_RECVTTL	12 +#define	IP_RECVTOS	13 +#define IP_MTU		14 +#define IP_FREEBIND	15 +#define IP_IPSEC_POLICY	16 +#define IP_XFRM_POLICY	17 +#define IP_PASSSEC	18 +#define IP_TRANSPARENT	19 + +/* BSD compatibility */ +#define IP_RECVRETOPTS	IP_RETOPTS + +/* TProxy original addresses */ +#define IP_ORIGDSTADDR       20 +#define IP_RECVORIGDSTADDR   IP_ORIGDSTADDR + +#define IP_MINTTL       21 +#define IP_NODEFRAG     22 +#define IP_CHECKSUM	23 +#define IP_BIND_ADDRESS_NO_PORT	24 +#define IP_RECVFRAGSIZE	25 + +/* IP_MTU_DISCOVER values */ +#define IP_PMTUDISC_DONT		0	/* Never send DF frames */ +#define IP_PMTUDISC_WANT		1	/* Use per route hints	*/ +#define IP_PMTUDISC_DO			2	/* Always DF		*/ +#define IP_PMTUDISC_PROBE		3       /* Ignore dst pmtu      */ +/* Always use interface mtu (ignores dst pmtu) but don't set DF flag. + * Also incoming ICMP frag_needed notifications will be ignored on + * this socket to prevent accepting spoofed ones. + */ +#define IP_PMTUDISC_INTERFACE		4 +/* weaker version of IP_PMTUDISC_INTERFACE, which allos packets to get + * fragmented if they exeed the interface mtu + */ +#define IP_PMTUDISC_OMIT		5 + +#define IP_MULTICAST_IF			32 +#define IP_MULTICAST_TTL 		33 +#define IP_MULTICAST_LOOP 		34 +#define IP_ADD_MEMBERSHIP		35 +#define IP_DROP_MEMBERSHIP		36 +#define IP_UNBLOCK_SOURCE		37 +#define IP_BLOCK_SOURCE			38 +#define IP_ADD_SOURCE_MEMBERSHIP	39 +#define IP_DROP_SOURCE_MEMBERSHIP	40 +#define IP_MSFILTER			41 +#define MCAST_JOIN_GROUP		42 +#define MCAST_BLOCK_SOURCE		43 +#define MCAST_UNBLOCK_SOURCE		44 +#define MCAST_LEAVE_GROUP		45 +#define MCAST_JOIN_SOURCE_GROUP		46 +#define MCAST_LEAVE_SOURCE_GROUP	47 +#define MCAST_MSFILTER			48 +#define IP_MULTICAST_ALL		49 +#define IP_UNICAST_IF			50 + +#define MCAST_EXCLUDE	0 +#define MCAST_INCLUDE	1 + +/* These need to appear somewhere around here */ +#define IP_DEFAULT_MULTICAST_TTL        1 +#define IP_DEFAULT_MULTICAST_LOOP       1 + +/* Request struct for multicast socket ops */ + +#if __UAPI_DEF_IP_MREQ +struct ip_mreq  { +	struct in_addr imr_multiaddr;	/* IP multicast address of group */ +	struct in_addr imr_interface;	/* local IP address of interface */ +}; + +struct ip_mreqn { +	struct in_addr	imr_multiaddr;		/* IP multicast address of group */ +	struct in_addr	imr_address;		/* local IP address of interface */ +	int		imr_ifindex;		/* Interface index */ +}; + +struct ip_mreq_source { +	__be32		imr_multiaddr; +	__be32		imr_interface; +	__be32		imr_sourceaddr; +}; + +struct ip_msfilter { +	__be32		imsf_multiaddr; +	__be32		imsf_interface; +	__u32		imsf_fmode; +	__u32		imsf_numsrc; +	__be32		imsf_slist[1]; +}; + +#define IP_MSFILTER_SIZE(numsrc) \ +	(sizeof(struct ip_msfilter) - sizeof(__u32) \ +	+ (numsrc) * sizeof(__u32)) + +struct group_req { +	__u32				 gr_interface;	/* interface index */ +	struct __kernel_sockaddr_storage gr_group;	/* group address */ +}; + +struct group_source_req { +	__u32				 gsr_interface;	/* interface index */ +	struct __kernel_sockaddr_storage gsr_group;	/* group address */ +	struct __kernel_sockaddr_storage gsr_source;	/* source address */ +}; + +struct group_filter { +	__u32				 gf_interface;	/* interface index */ +	struct __kernel_sockaddr_storage gf_group;	/* multicast address */ +	__u32				 gf_fmode;	/* filter mode */ +	__u32				 gf_numsrc;	/* number of sources */ +	struct __kernel_sockaddr_storage gf_slist[1];	/* interface index */ +}; + +#define GROUP_FILTER_SIZE(numsrc) \ +	(sizeof(struct group_filter) - sizeof(struct __kernel_sockaddr_storage) \ +	+ (numsrc) * sizeof(struct __kernel_sockaddr_storage)) +#endif + +#if __UAPI_DEF_IN_PKTINFO +struct in_pktinfo { +	int		ipi_ifindex; +	struct in_addr	ipi_spec_dst; +	struct in_addr	ipi_addr; +}; +#endif + +/* Structure describing an Internet (IP) socket address. */ +#if  __UAPI_DEF_SOCKADDR_IN +#define __SOCK_SIZE__	16		/* sizeof(struct sockaddr)	*/ +struct sockaddr_in { +  __kernel_sa_family_t	sin_family;	/* Address family		*/ +  __be16		sin_port;	/* Port number			*/ +  struct in_addr	sin_addr;	/* Internet address		*/ + +  /* Pad to size of `struct sockaddr'. */ +  unsigned char		__pad[__SOCK_SIZE__ - sizeof(short int) - +			sizeof(unsigned short int) - sizeof(struct in_addr)]; +}; +#define sin_zero	__pad		/* for BSD UNIX comp. -FvK	*/ +#endif + +#if __UAPI_DEF_IN_CLASS +/* + * Definitions of the bits in an Internet address integer. + * On subnets, host and network parts are found according + * to the subnet mask, not these masks. + */ +#define	IN_CLASSA(a)		((((long int) (a)) & 0x80000000) == 0) +#define	IN_CLASSA_NET		0xff000000 +#define	IN_CLASSA_NSHIFT	24 +#define	IN_CLASSA_HOST		(0xffffffff & ~IN_CLASSA_NET) +#define	IN_CLASSA_MAX		128 + +#define	IN_CLASSB(a)		((((long int) (a)) & 0xc0000000) == 0x80000000) +#define	IN_CLASSB_NET		0xffff0000 +#define	IN_CLASSB_NSHIFT	16 +#define	IN_CLASSB_HOST		(0xffffffff & ~IN_CLASSB_NET) +#define	IN_CLASSB_MAX		65536 + +#define	IN_CLASSC(a)		((((long int) (a)) & 0xe0000000) == 0xc0000000) +#define	IN_CLASSC_NET		0xffffff00 +#define	IN_CLASSC_NSHIFT	8 +#define	IN_CLASSC_HOST		(0xffffffff & ~IN_CLASSC_NET) + +#define	IN_CLASSD(a)		((((long int) (a)) & 0xf0000000) == 0xe0000000) +#define	IN_MULTICAST(a)		IN_CLASSD(a) +#define IN_MULTICAST_NET	0xF0000000 + +#define	IN_EXPERIMENTAL(a)	((((long int) (a)) & 0xf0000000) == 0xf0000000) +#define	IN_BADCLASS(a)		IN_EXPERIMENTAL((a)) + +/* Address to accept any incoming messages. */ +#define	INADDR_ANY		((unsigned long int) 0x00000000) + +/* Address to send to all hosts. */ +#define	INADDR_BROADCAST	((unsigned long int) 0xffffffff) + +/* Address indicating an error return. */ +#define	INADDR_NONE		((unsigned long int) 0xffffffff) + +/* Network number for local host loopback. */ +#define	IN_LOOPBACKNET		127 + +/* Address to loopback in software to local host.  */ +#define	INADDR_LOOPBACK		0x7f000001	/* 127.0.0.1   */ +#define	IN_LOOPBACK(a)		((((long int) (a)) & 0xff000000) == 0x7f000000) + +/* Defines for Multicast INADDR */ +#define INADDR_UNSPEC_GROUP   	0xe0000000U	/* 224.0.0.0   */ +#define INADDR_ALLHOSTS_GROUP 	0xe0000001U	/* 224.0.0.1   */ +#define INADDR_ALLRTRS_GROUP    0xe0000002U	/* 224.0.0.2 */ +#define INADDR_MAX_LOCAL_GROUP  0xe00000ffU	/* 224.0.0.255 */ +#endif + +/* <asm/byteorder.h> contains the htonl type stuff.. */ +#include <asm/byteorder.h>  + + +#endif /* _UAPI_LINUX_IN_H */ diff --git a/tools/include/uapi/linux/kvm.h b/tools/include/uapi/linux/kvm.h index 39e364c70caf..b6270a3b38e9 100644 --- a/tools/include/uapi/linux/kvm.h +++ b/tools/include/uapi/linux/kvm.h @@ -948,6 +948,7 @@ struct kvm_ppc_resize_hpt {  #define KVM_CAP_S390_BPB 152  #define KVM_CAP_GET_MSR_FEATURES 153  #define KVM_CAP_HYPERV_EVENTFD 154 +#define KVM_CAP_HYPERV_TLBFLUSH 155  #ifdef KVM_CAP_IRQ_ROUTING diff --git a/tools/include/uapi/linux/perf_event.h b/tools/include/uapi/linux/perf_event.h index b8e288a1f740..eeb787b1c53c 100644 --- a/tools/include/uapi/linux/perf_event.h +++ b/tools/include/uapi/linux/perf_event.h @@ -143,6 +143,8 @@ enum perf_event_sample_format {  	PERF_SAMPLE_PHYS_ADDR			= 1U << 19,  	PERF_SAMPLE_MAX = 1U << 20,		/* non-ABI */ + +	__PERF_SAMPLE_CALLCHAIN_EARLY		= 1ULL << 63,  };  /* |