X-Git-Url: http://git.archive.openwrt.org/?p=project%2Fnetifd.git;a=blobdiff_plain;f=interface-ip.h;h=df5545d5fde60c1cf689f25f6e8afbe626663498;hp=6ad9b427800b8c935e14c5741c087302cfd9b680;hb=1aa37f77cd92a6aee0c512ca6e3f56f388ed2922;hpb=52c36d741c05db2350ad1d240f6bd5d72237d8fd diff --git a/interface-ip.h b/interface-ip.h index 6ad9b42..df5545d 100644 --- a/interface-ip.h +++ b/interface-ip.h @@ -1,17 +1,19 @@ #ifndef __INTERFACE_IP_H #define __INTERFACE_IP_H +#include "interface.h" + enum device_addr_flags { /* address family for routes and addresses */ DEVADDR_INET4 = (0 << 0), 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,6 +25,10 @@ struct device_addr { struct vlist_node node; enum device_addr_flags flags; + bool enabled; + + /* ipv4 only */ + uint32_t broadcast; /* must be last */ unsigned int mask; @@ -33,10 +39,12 @@ struct device_route { struct vlist_node node; enum device_addr_flags flags; + bool enabled; bool keep; union if_addr nexthop; - struct device *device; + int metric; + int mtu; /* must be last */ unsigned int mask; @@ -44,25 +52,30 @@ struct device_route { }; struct dns_server { - struct list_head list; + struct vlist_simple_node node; int af; union if_addr addr; }; struct dns_search_domain { - struct list_head list; + struct vlist_simple_node node; char name[]; }; -void interface_ip_init(struct interface *iface); -void interface_add_dns_server(struct interface *iface, const char *str); -void interface_add_dns_server_list(struct interface *iface, struct blob_attr *list); -void interface_add_dns_search_list(struct interface *iface, struct blob_attr *list); -void interface_clear_dns(struct interface *iface); +extern const struct config_param_list route_attr_list; + +void interface_ip_init(struct interface_ip_settings *ip, struct interface *iface); +void interface_add_dns_server(struct interface_ip_settings *ip, const char *str); +void interface_add_dns_server_list(struct interface_ip_settings *ip, struct blob_attr *list); +void interface_add_dns_search_list(struct interface_ip_settings *ip, struct blob_attr *list); void interface_write_resolv_conf(void); -void interface_ip_update_start(struct interface *iface); -void interface_ip_update_complete(struct interface *iface); +void interface_ip_add_route(struct interface *iface, struct blob_attr *attr, bool v6); +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