xref: /linux/include/uapi/linux/fib_rules.h (revision 71e2f4dd5a65bd8dbca0b77661e75eea471168f8)
1 /* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
2 #ifndef __LINUX_FIB_RULES_H
3 #define __LINUX_FIB_RULES_H
4 
5 #include <linux/types.h>
6 #include <linux/rtnetlink.h>
7 
8 /* rule is permanent, and cannot be deleted */
9 #define FIB_RULE_PERMANENT	0x00000001
10 #define FIB_RULE_INVERT		0x00000002
11 #define FIB_RULE_UNRESOLVED	0x00000004
12 #define FIB_RULE_IIF_DETACHED	0x00000008
13 #define FIB_RULE_DEV_DETACHED	FIB_RULE_IIF_DETACHED
14 #define FIB_RULE_OIF_DETACHED	0x00000010
15 
16 /* try to find source address in routing lookups */
17 #define FIB_RULE_FIND_SADDR	0x00010000
18 
19 struct fib_rule_hdr {
20 	__u8		family;
21 	__u8		dst_len;
22 	__u8		src_len;
23 	__u8		tos;
24 
25 	__u8		table;
26 	__u8		res1;   /* reserved */
27 	__u8		res2;	/* reserved */
28 	__u8		action;
29 
30 	__u32		flags;
31 };
32 
33 struct fib_rule_uid_range {
34 	__u32		start;
35 	__u32		end;
36 };
37 
38 struct fib_rule_port_range {
39 	__u16		start;
40 	__u16		end;
41 };
42 
43 enum {
44 	FRA_UNSPEC,
45 	FRA_DST,	/* destination address */
46 	FRA_SRC,	/* source address */
47 	FRA_IIFNAME,	/* interface name */
48 #define FRA_IFNAME	FRA_IIFNAME
49 	FRA_GOTO,	/* target to jump to (FR_ACT_GOTO) */
50 	FRA_UNUSED2,
51 	FRA_PRIORITY,	/* priority/preference */
52 	FRA_UNUSED3,
53 	FRA_UNUSED4,
54 	FRA_UNUSED5,
55 	FRA_FWMARK,	/* mark */
56 	FRA_FLOW,	/* flow/class id */
57 	FRA_TUN_ID,
58 	FRA_SUPPRESS_IFGROUP,
59 	FRA_SUPPRESS_PREFIXLEN,
60 	FRA_TABLE,	/* Extended table id */
61 	FRA_FWMASK,	/* mask for netfilter mark */
62 	FRA_OIFNAME,
63 	FRA_PAD,
64 	FRA_L3MDEV,	/* iif or oif is l3mdev goto its table */
65 	FRA_UID_RANGE,	/* UID range */
66 	FRA_PROTOCOL,   /* Originator of the rule */
67 	FRA_IP_PROTO,	/* ip proto */
68 	FRA_SPORT_RANGE, /* sport */
69 	FRA_DPORT_RANGE, /* dport */
70 	__FRA_MAX
71 };
72 
73 #define FRA_MAX (__FRA_MAX - 1)
74 
75 enum {
76 	FR_ACT_UNSPEC,
77 	FR_ACT_TO_TBL,		/* Pass to fixed table */
78 	FR_ACT_GOTO,		/* Jump to another rule */
79 	FR_ACT_NOP,		/* No operation */
80 	FR_ACT_RES3,
81 	FR_ACT_RES4,
82 	FR_ACT_BLACKHOLE,	/* Drop without notification */
83 	FR_ACT_UNREACHABLE,	/* Drop with ENETUNREACH */
84 	FR_ACT_PROHIBIT,	/* Drop with EACCES */
85 	__FR_ACT_MAX,
86 };
87 
88 #define FR_ACT_MAX (__FR_ACT_MAX - 1)
89 
90 #endif
91