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
18struct 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
32enum {
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,
53	FRA_UID_END,
54	__FRA_MAX
55};
56
57#define FRA_MAX (__FRA_MAX - 1)
58
59enum {
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