From: Florian Eckert Date: Tue, 24 Nov 2020 07:18:00 +0000 (+0100) Subject: netifd: add possibility to switch off route config X-Git-Url: http://git.openwrt.org/?a=commitdiff_plain;h=327da9895327bc56b23413ee91a6e6b6e0e4329d;p=project%2Fnetifd.git netifd: add possibility to switch off route config This change adds the new configuration option `disabled` for the route section, which can be used to temporarily disable the section so that the route is not set. The advantage is that we do not have to delete this route configuration section to achieve this. config route option disabled '1 Signed-off-by: Florian Eckert --- diff --git a/interface-ip.c b/interface-ip.c index 1444fbf..648f521 100644 --- a/interface-ip.c +++ b/interface-ip.c @@ -43,6 +43,7 @@ enum { ROUTE_ONLINK, ROUTE_TYPE, ROUTE_PROTO, + ROUTE_DISABLED, __ROUTE_MAX }; @@ -59,6 +60,7 @@ static const struct blobmsg_policy route_attr[__ROUTE_MAX] = { [ROUTE_ONLINK] = { .name = "onlink", .type = BLOBMSG_TYPE_BOOL }, [ROUTE_TYPE] = { .name = "type", .type = BLOBMSG_TYPE_STRING }, [ROUTE_PROTO] = { .name = "proto", .type = BLOBMSG_TYPE_STRING }, + [ROUTE_DISABLED] = { .name = "disabled", .type = BLOBMSG_TYPE_BOOL }, }; const struct uci_blob_param_list route_attr_list = { @@ -394,6 +396,9 @@ interface_ip_add_route(struct interface *iface, struct blob_attr *attr, bool v6) blobmsg_parse(route_attr, __ROUTE_MAX, tb, blobmsg_data(attr), blobmsg_data_len(attr)); + if ((cur = tb[ROUTE_DISABLED]) != NULL && blobmsg_get_bool(cur)) + return; + if (!iface) { if ((cur = tb[ROUTE_INTERFACE]) == NULL) return;