• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 #ifndef __LINUX_FIB_RULES_H
2 #define __LINUX_FIB_RULES_H
3 
4 #include <linux/types.h>
5 #include <linux/rtnetlink.h>
6 
7 /* rule is permanent, and cannot be deleted */
8 #define FIB_RULE_PERMANENT	0x00000001
9 #define FIB_RULE_INVERT		0x00000002
10 #define FIB_RULE_UNRESOLVED	0x00000004
11 #define FIB_RULE_IIF_DETACHED	0x00000008
12 #define FIB_RULE_DEV_DETACHED	FIB_RULE_IIF_DETACHED
13 #define FIB_RULE_OIF_DETACHED	0x00000010
14 
15 /* try to find source address in routing lookups */
16 #define FIB_RULE_FIND_SADDR	0x00010000
17 
18 struct fib_rule_hdr {
19 	__u8		family;
20 	__u8		dst_len;
21 	__u8		src_len;
22 	__u8		tos;
23 
24 	__u8		table;
25 	__u8		res1;	/* reserved */
26 	__u8		res2;	/* reserved */
27 	__u8		action;
28 
29 	__u32		flags;
30 };
31 
32 enum {
33 	FRA_UNSPEC,
34 	FRA_DST,	/* destination address */
35 	FRA_SRC,	/* source address */
36 	FRA_IIFNAME,	/* interface name */
37 #define FRA_IFNAME	FRA_IIFNAME
38 	FRA_GOTO,	/* target to jump to (FR_ACT_GOTO) */
39 	FRA_UNUSED2,
40 	FRA_PRIORITY,	/* priority/preference */
41 	FRA_UNUSED3,
42 	FRA_UNUSED4,
43 	FRA_UNUSED5,
44 	FRA_FWMARK,	/* mark */
45 	FRA_FLOW,	/* flow/class id */
46 	FRA_UNUSED6,
47 	FRA_UNUSED7,
48 	FRA_UNUSED8,
49 	FRA_TABLE,	/* Extended table id */
50 	FRA_FWMASK,	/* mask for netfilter mark */
51 	FRA_OIFNAME,
52 	FRA_UID_START,	/* UID range */
53 	FRA_UID_END,
54 	__FRA_MAX
55 };
56 
57 #define FRA_MAX (__FRA_MAX - 1)
58 
59 enum {
60 	FR_ACT_UNSPEC,
61 	FR_ACT_TO_TBL,		/* Pass to fixed table */
62 	FR_ACT_GOTO,		/* Jump to another rule */
63 	FR_ACT_NOP,		/* No operation */
64 	FR_ACT_RES3,
65 	FR_ACT_RES4,
66 	FR_ACT_BLACKHOLE,	/* Drop without notification */
67 	FR_ACT_UNREACHABLE,	/* Drop with ENETUNREACH */
68 	FR_ACT_PROHIBIT,	/* Drop with EACCES */
69 	__FR_ACT_MAX,
70 };
71 
72 #define FR_ACT_MAX (__FR_ACT_MAX - 1)
73 
74 #endif
75