xref: /linux-6.15/include/uapi/linux/nexthop.h (revision b72a6a7a)
165ee00a9SDavid Ahern /* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
265ee00a9SDavid Ahern #ifndef _UAPI_LINUX_NEXTHOP_H
365ee00a9SDavid Ahern #define _UAPI_LINUX_NEXTHOP_H
465ee00a9SDavid Ahern 
565ee00a9SDavid Ahern #include <linux/types.h>
665ee00a9SDavid Ahern 
765ee00a9SDavid Ahern struct nhmsg {
865ee00a9SDavid Ahern 	unsigned char	nh_family;
965ee00a9SDavid Ahern 	unsigned char	nh_scope;     /* return only */
1065ee00a9SDavid Ahern 	unsigned char	nh_protocol;  /* Routing protocol that installed nh */
1165ee00a9SDavid Ahern 	unsigned char	resvd;
1265ee00a9SDavid Ahern 	unsigned int	nh_flags;     /* RTNH_F flags */
1365ee00a9SDavid Ahern };
1465ee00a9SDavid Ahern 
1565ee00a9SDavid Ahern /* entry in a nexthop group */
1665ee00a9SDavid Ahern struct nexthop_grp {
1765ee00a9SDavid Ahern 	__u32	id;	  /* nexthop id - must exist */
1865ee00a9SDavid Ahern 	__u8	weight;   /* weight of this nexthop */
19*b72a6a7aSPetr Machata 	__u8	weight_high;	/* high order bits of weight */
2065ee00a9SDavid Ahern 	__u16	resvd2;
2165ee00a9SDavid Ahern };
2265ee00a9SDavid Ahern 
nexthop_grp_weight(const struct nexthop_grp * entry)23*b72a6a7aSPetr Machata static inline __u16 nexthop_grp_weight(const struct nexthop_grp *entry)
24*b72a6a7aSPetr Machata {
25*b72a6a7aSPetr Machata 	return ((entry->weight_high << 8) | entry->weight) + 1;
26*b72a6a7aSPetr Machata }
27*b72a6a7aSPetr Machata 
2865ee00a9SDavid Ahern enum {
29710ec562SIdo Schimmel 	NEXTHOP_GRP_TYPE_MPATH,  /* hash-threshold nexthop group
30710ec562SIdo Schimmel 				  * default type if not specified
31710ec562SIdo Schimmel 				  */
32710ec562SIdo Schimmel 	NEXTHOP_GRP_TYPE_RES,    /* resilient nexthop group */
3365ee00a9SDavid Ahern 	__NEXTHOP_GRP_TYPE_MAX,
3465ee00a9SDavid Ahern };
3565ee00a9SDavid Ahern 
3665ee00a9SDavid Ahern #define NEXTHOP_GRP_TYPE_MAX (__NEXTHOP_GRP_TYPE_MAX - 1)
3765ee00a9SDavid Ahern 
3895fedd76SIdo Schimmel #define NHA_OP_FLAG_DUMP_STATS		BIT(0)
395072ae00SIdo Schimmel #define NHA_OP_FLAG_DUMP_HW_STATS	BIT(1)
4095fedd76SIdo Schimmel 
4175bab45eSPetr Machata /* Response OP_FLAGS. */
4275bab45eSPetr Machata #define NHA_OP_FLAG_RESP_GRP_RESVD_0	BIT(31)	/* Dump clears resvd fields. */
4375bab45eSPetr Machata 
4465ee00a9SDavid Ahern enum {
4565ee00a9SDavid Ahern 	NHA_UNSPEC,
4665ee00a9SDavid Ahern 	NHA_ID,		/* u32; id for nexthop. id == 0 means auto-assign */
4765ee00a9SDavid Ahern 
4865ee00a9SDavid Ahern 	NHA_GROUP,	/* array of nexthop_grp */
4965ee00a9SDavid Ahern 	NHA_GROUP_TYPE,	/* u16 one of NEXTHOP_GRP_TYPE */
5065ee00a9SDavid Ahern 	/* if NHA_GROUP attribute is added, no other attributes can be set */
5165ee00a9SDavid Ahern 
5265ee00a9SDavid Ahern 	NHA_BLACKHOLE,	/* flag; nexthop used to blackhole packets */
5365ee00a9SDavid Ahern 	/* if NHA_BLACKHOLE is added, OIF, GATEWAY, ENCAP can not be set */
5465ee00a9SDavid Ahern 
5565ee00a9SDavid Ahern 	NHA_OIF,	/* u32; nexthop device */
5665ee00a9SDavid Ahern 	NHA_GATEWAY,	/* be32 (IPv4) or in6_addr (IPv6) gw address */
5765ee00a9SDavid Ahern 	NHA_ENCAP_TYPE, /* u16; lwt encap type */
5865ee00a9SDavid Ahern 	NHA_ENCAP,	/* lwt encap data */
5965ee00a9SDavid Ahern 
6065ee00a9SDavid Ahern 	/* NHA_OIF can be appended to dump request to return only
6165ee00a9SDavid Ahern 	 * nexthops using given device
6265ee00a9SDavid Ahern 	 */
6365ee00a9SDavid Ahern 	NHA_GROUPS,	/* flag; only return nexthop groups in dump */
6465ee00a9SDavid Ahern 	NHA_MASTER,	/* u32;  only return nexthops with given master dev */
6565ee00a9SDavid Ahern 
6638428d68SRoopa Prabhu 	NHA_FDB,	/* flag; nexthop belongs to a bridge fdb */
6738428d68SRoopa Prabhu 	/* if NHA_FDB is added, OIF, BLACKHOLE, ENCAP cannot be set */
6838428d68SRoopa Prabhu 
69710ec562SIdo Schimmel 	/* nested; resilient nexthop group attributes */
70710ec562SIdo Schimmel 	NHA_RES_GROUP,
71710ec562SIdo Schimmel 	/* nested; nexthop bucket attributes */
72710ec562SIdo Schimmel 	NHA_RES_BUCKET,
73710ec562SIdo Schimmel 
74a207eab1SPetr Machata 	/* u32; operation-specific flags */
75a207eab1SPetr Machata 	NHA_OP_FLAGS,
76a207eab1SPetr Machata 
7795fedd76SIdo Schimmel 	/* nested; nexthop group stats */
7895fedd76SIdo Schimmel 	NHA_GROUP_STATS,
7995fedd76SIdo Schimmel 
80746c19a5SIdo Schimmel 	/* u32; nexthop hardware stats enable */
81746c19a5SIdo Schimmel 	NHA_HW_STATS_ENABLE,
82746c19a5SIdo Schimmel 
835072ae00SIdo Schimmel 	/* u32; read-only; whether any driver collects HW stats */
845072ae00SIdo Schimmel 	NHA_HW_STATS_USED,
855072ae00SIdo Schimmel 
8665ee00a9SDavid Ahern 	__NHA_MAX,
8765ee00a9SDavid Ahern };
8865ee00a9SDavid Ahern 
8965ee00a9SDavid Ahern #define NHA_MAX	(__NHA_MAX - 1)
90710ec562SIdo Schimmel 
91710ec562SIdo Schimmel enum {
92710ec562SIdo Schimmel 	NHA_RES_GROUP_UNSPEC,
93710ec562SIdo Schimmel 	/* Pad attribute for 64-bit alignment. */
94710ec562SIdo Schimmel 	NHA_RES_GROUP_PAD = NHA_RES_GROUP_UNSPEC,
95710ec562SIdo Schimmel 
96710ec562SIdo Schimmel 	/* u16; number of nexthop buckets in a resilient nexthop group */
97710ec562SIdo Schimmel 	NHA_RES_GROUP_BUCKETS,
98710ec562SIdo Schimmel 	/* clock_t as u32; nexthop bucket idle timer (per-group) */
99710ec562SIdo Schimmel 	NHA_RES_GROUP_IDLE_TIMER,
100710ec562SIdo Schimmel 	/* clock_t as u32; nexthop unbalanced timer */
101710ec562SIdo Schimmel 	NHA_RES_GROUP_UNBALANCED_TIMER,
102710ec562SIdo Schimmel 	/* clock_t as u64; nexthop unbalanced time */
103710ec562SIdo Schimmel 	NHA_RES_GROUP_UNBALANCED_TIME,
104710ec562SIdo Schimmel 
105710ec562SIdo Schimmel 	__NHA_RES_GROUP_MAX,
106710ec562SIdo Schimmel };
107710ec562SIdo Schimmel 
108710ec562SIdo Schimmel #define NHA_RES_GROUP_MAX	(__NHA_RES_GROUP_MAX - 1)
109710ec562SIdo Schimmel 
110710ec562SIdo Schimmel enum {
111710ec562SIdo Schimmel 	NHA_RES_BUCKET_UNSPEC,
112710ec562SIdo Schimmel 	/* Pad attribute for 64-bit alignment. */
113710ec562SIdo Schimmel 	NHA_RES_BUCKET_PAD = NHA_RES_BUCKET_UNSPEC,
114710ec562SIdo Schimmel 
115710ec562SIdo Schimmel 	/* u16; nexthop bucket index */
116710ec562SIdo Schimmel 	NHA_RES_BUCKET_INDEX,
117710ec562SIdo Schimmel 	/* clock_t as u64; nexthop bucket idle time */
118710ec562SIdo Schimmel 	NHA_RES_BUCKET_IDLE_TIME,
119710ec562SIdo Schimmel 	/* u32; nexthop id assigned to the nexthop bucket */
120710ec562SIdo Schimmel 	NHA_RES_BUCKET_NH_ID,
121710ec562SIdo Schimmel 
122710ec562SIdo Schimmel 	__NHA_RES_BUCKET_MAX,
123710ec562SIdo Schimmel };
124710ec562SIdo Schimmel 
125710ec562SIdo Schimmel #define NHA_RES_BUCKET_MAX	(__NHA_RES_BUCKET_MAX - 1)
126710ec562SIdo Schimmel 
12795fedd76SIdo Schimmel enum {
12895fedd76SIdo Schimmel 	NHA_GROUP_STATS_UNSPEC,
12995fedd76SIdo Schimmel 
13095fedd76SIdo Schimmel 	/* nested; nexthop group entry stats */
13195fedd76SIdo Schimmel 	NHA_GROUP_STATS_ENTRY,
13295fedd76SIdo Schimmel 
13395fedd76SIdo Schimmel 	__NHA_GROUP_STATS_MAX,
13495fedd76SIdo Schimmel };
13595fedd76SIdo Schimmel 
13695fedd76SIdo Schimmel #define NHA_GROUP_STATS_MAX	(__NHA_GROUP_STATS_MAX - 1)
13795fedd76SIdo Schimmel 
13895fedd76SIdo Schimmel enum {
13995fedd76SIdo Schimmel 	NHA_GROUP_STATS_ENTRY_UNSPEC,
14095fedd76SIdo Schimmel 
14195fedd76SIdo Schimmel 	/* u32; nexthop id of the nexthop group entry */
14295fedd76SIdo Schimmel 	NHA_GROUP_STATS_ENTRY_ID,
14395fedd76SIdo Schimmel 
14495fedd76SIdo Schimmel 	/* uint; number of packets forwarded via the nexthop group entry */
14595fedd76SIdo Schimmel 	NHA_GROUP_STATS_ENTRY_PACKETS,
14695fedd76SIdo Schimmel 
1475072ae00SIdo Schimmel 	/* uint; number of packets forwarded via the nexthop group entry in
1485072ae00SIdo Schimmel 	 * hardware
1495072ae00SIdo Schimmel 	 */
1505072ae00SIdo Schimmel 	NHA_GROUP_STATS_ENTRY_PACKETS_HW,
1515072ae00SIdo Schimmel 
15295fedd76SIdo Schimmel 	__NHA_GROUP_STATS_ENTRY_MAX,
15395fedd76SIdo Schimmel };
15495fedd76SIdo Schimmel 
15595fedd76SIdo Schimmel #define NHA_GROUP_STATS_ENTRY_MAX	(__NHA_GROUP_STATS_ENTRY_MAX - 1)
15695fedd76SIdo Schimmel 
15765ee00a9SDavid Ahern #endif
158