fib_rules.h 1.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. #ifndef __LINUX_FIB_RULES_H
  2. #define __LINUX_FIB_RULES_H
  3. #include <linux/types.h>
  4. #include <linux/rtnetlink.h>
  5. /* rule is permanent, and cannot be deleted */
  6. #define FIB_RULE_PERMANENT 1
  7. struct fib_rule_hdr
  8. {
  9. __u8 family;
  10. __u8 dst_len;
  11. __u8 src_len;
  12. __u8 tos;
  13. __u8 table;
  14. __u8 res1; /* reserved */
  15. __u8 res2; /* reserved */
  16. __u8 action;
  17. __u32 flags;
  18. };
  19. enum
  20. {
  21. FRA_UNSPEC,
  22. FRA_DST, /* destination address */
  23. FRA_SRC, /* source address */
  24. FRA_IFNAME, /* interface name */
  25. FRA_UNUSED1,
  26. FRA_UNUSED2,
  27. FRA_PRIORITY, /* priority/preference */
  28. FRA_UNUSED3,
  29. FRA_UNUSED4,
  30. FRA_UNUSED5,
  31. FRA_FWMARK, /* netfilter mark */
  32. FRA_FLOW, /* flow/class id */
  33. FRA_UNUSED6,
  34. FRA_UNUSED7,
  35. FRA_UNUSED8,
  36. FRA_TABLE, /* Extended table id */
  37. FRA_FWMASK, /* mask for netfilter mark */
  38. __FRA_MAX
  39. };
  40. #define FRA_MAX (__FRA_MAX - 1)
  41. enum
  42. {
  43. FR_ACT_UNSPEC,
  44. FR_ACT_TO_TBL, /* Pass to fixed table */
  45. FR_ACT_RES1,
  46. FR_ACT_RES2,
  47. FR_ACT_RES3,
  48. FR_ACT_RES4,
  49. FR_ACT_BLACKHOLE, /* Drop without notification */
  50. FR_ACT_UNREACHABLE, /* Drop with ENETUNREACH */
  51. FR_ACT_PROHIBIT, /* Drop with EACCES */
  52. __FR_ACT_MAX,
  53. };
  54. #define FR_ACT_MAX (__FR_ACT_MAX - 1)
  55. #endif