X-Git-Url: http://git.archive.openwrt.org/?p=project%2Fnetifd.git;a=blobdiff_plain;f=interface-ip.h;h=28df0938dd830ed5e993eb060513cf63bc405a46;hp=f6413ee016fe60a170179e407bb206675403a2e0;hb=0cd5498ea51d681124d713130aef7a964b30ef25;hpb=58d36928da0e3099e17309bd7a44ee442b5f5153 diff --git a/interface-ip.h b/interface-ip.h index f6413ee..28df093 100644 --- a/interface-ip.h +++ b/interface-ip.h @@ -9,11 +9,11 @@ enum device_addr_flags { DEVADDR_INET6 = (1 << 0), DEVADDR_FAMILY = DEVADDR_INET4 | DEVADDR_INET6, - /* device route (no gateway) */ - DEVADDR_DEVICE = (1 << 1), - /* externally added address */ DEVADDR_EXTERNAL = (1 << 2), + + /* route overrides the default interface metric */ + DEVROUTE_METRIC = (1 << 3) }; union if_addr { @@ -23,19 +23,21 @@ union if_addr { struct device_addr { struct vlist_node node; - - enum device_addr_flags flags; bool enabled; + /* ipv4 only */ + uint32_t broadcast; + /* must be last */ + enum device_addr_flags flags; unsigned int mask; union if_addr addr; }; struct device_route { struct vlist_node node; + struct interface *iface; - enum device_addr_flags flags; bool enabled; bool keep; @@ -44,6 +46,7 @@ struct device_route { int mtu; /* must be last */ + enum device_addr_flags flags; unsigned int mask; union if_addr addr; }; @@ -73,6 +76,6 @@ void interface_ip_update_start(struct interface_ip_settings *ip); void interface_ip_update_complete(struct interface_ip_settings *ip); void interface_ip_flush(struct interface_ip_settings *ip); void interface_ip_set_enabled(struct interface_ip_settings *ip, bool enabled); - +void interface_ip_update_metric(struct interface_ip_settings *ip, int metric); #endif