blob: 8270aac2aa5d95a9ada6f9ff1b5234362ca1d285 [file] [log] [blame]
Thomas Graf14c0b972006-08-04 03:38:38 -07001#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 1
Thomas Graf3dfbcc42006-11-09 15:23:20 -08009#define FIB_RULE_INVERT 2
Thomas Graf14c0b972006-08-04 03:38:38 -070010
11struct fib_rule_hdr
12{
13 __u8 family;
14 __u8 dst_len;
15 __u8 src_len;
16 __u8 tos;
17
18 __u8 table;
19 __u8 res1; /* reserved */
20 __u8 res2; /* reserved */
21 __u8 action;
22
23 __u32 flags;
24};
25
26enum
27{
28 FRA_UNSPEC,
29 FRA_DST, /* destination address */
30 FRA_SRC, /* source address */
31 FRA_IFNAME, /* interface name */
32 FRA_UNUSED1,
33 FRA_UNUSED2,
34 FRA_PRIORITY, /* priority/preference */
35 FRA_UNUSED3,
36 FRA_UNUSED4,
37 FRA_UNUSED5,
Thomas Grafb8964ed2006-11-09 15:22:18 -080038 FRA_FWMARK, /* mark */
Thomas Graf14c0b972006-08-04 03:38:38 -070039 FRA_FLOW, /* flow/class id */
Patrick McHardy9e762a42006-08-10 23:09:48 -070040 FRA_UNUSED6,
41 FRA_UNUSED7,
42 FRA_UNUSED8,
43 FRA_TABLE, /* Extended table id */
Patrick McHardybbfb39c2006-08-25 16:10:14 -070044 FRA_FWMASK, /* mask for netfilter mark */
Thomas Graf14c0b972006-08-04 03:38:38 -070045 __FRA_MAX
46};
47
48#define FRA_MAX (__FRA_MAX - 1)
49
50enum
51{
52 FR_ACT_UNSPEC,
53 FR_ACT_TO_TBL, /* Pass to fixed table */
54 FR_ACT_RES1,
55 FR_ACT_RES2,
56 FR_ACT_RES3,
57 FR_ACT_RES4,
58 FR_ACT_BLACKHOLE, /* Drop without notification */
59 FR_ACT_UNREACHABLE, /* Drop with ENETUNREACH */
60 FR_ACT_PROHIBIT, /* Drop with EACCES */
61 __FR_ACT_MAX,
62};
63
64#define FR_ACT_MAX (__FR_ACT_MAX - 1)
65
66#endif