X-Git-Url: http://git.archive.openwrt.org/?p=project%2Fnetifd.git;a=blobdiff_plain;f=interface-ip.h;h=7c4a8aeacf3b506f66e2570237bf72fb2ce8777d;hp=c78a076293cd0dcffdcd60330f3238c8bbfd00ac;hb=3eea8576d48d9b20cc1c6b46f54c7345a39d13aa;hpb=d095bf24cf7879150d008c23998676bfedebbde6 diff --git a/interface-ip.h b/interface-ip.h index c78a076..7c4a8ae 100644 --- a/interface-ip.h +++ b/interface-ip.h @@ -42,6 +42,12 @@ enum device_addr_flags { /* route resides in default source-route table */ DEVROUTE_SRCTABLE = (1 << 8), + + /* route is on-link */ + DEVROUTE_ONLINK = (1 << 9), + + /* route overrides the default route type */ + DEVROUTE_TYPE = (1 << 10), }; union if_addr { @@ -53,6 +59,7 @@ struct device_prefix_assignment { struct list_head head; int32_t assigned; uint8_t length; + struct in6_addr addr; bool enabled; char name[]; }; @@ -77,6 +84,7 @@ struct device_prefix { struct device_addr { struct vlist_node node; bool enabled; + bool failed; /* ipv4 only */ uint32_t broadcast; @@ -85,6 +93,7 @@ struct device_addr { /* ipv6 only */ time_t valid_until; time_t preferred_until; + char *pclass; /* must be last */ enum device_addr_flags flags; @@ -98,9 +107,11 @@ struct device_route { bool enabled; bool keep; + bool failed; union if_addr nexthop; int mtu; + unsigned int type; time_t valid_until; /* must be last */ @@ -108,6 +119,17 @@ struct device_route { int metric; // there can be multiple routes to the same target unsigned int table; unsigned int mask; + unsigned int sourcemask; + union if_addr addr; + union if_addr source; +}; + +struct device_source_table { + struct list_head head; + uint32_t table; + uint16_t refcount; + uint8_t v6; + uint8_t mask; union if_addr addr; };