X-Git-Url: http://git.archive.openwrt.org/?p=project%2Fnetifd.git;a=blobdiff_plain;f=config.c;h=9fb9c010d8bceac8487881e1ef2253ef04f3c258;hp=515e6467df57e1068eff7914e057f60904667e5a;hb=26cb3b2a0aebb1b9dc07daf7b54bd8400d6d659b;hpb=59217785704fca27d2c7a19e279d27c384a452cd diff --git a/config.c b/config.c index 515e646..9fb9c01 100644 --- a/config.c +++ b/config.c @@ -33,6 +33,25 @@ static struct uci_package *uci_wireless; static struct blob_buf b; static int +config_section_idx(struct uci_section *s) +{ + struct uci_element *e; + int idx = 0; + + uci_foreach_element(&uci_wireless->sections, e) { + struct uci_section *cur = uci_to_section(e); + + if (s == cur) + return idx; + + if (!strcmp(cur->type, s->type)) + idx++; + } + + return -1; +} + +static int config_parse_bridge_interface(struct uci_section *s) { char *name; @@ -167,16 +186,16 @@ config_init_devices(void) type = uci_lookup_option_string(uci_ctx, s, "type"); if (type) { - if (!strcmp(type, "bridge")) + if (!strcmp(type, "8021ad")) + devtype = &vlandev_device_type; + else if (!strcmp(type, "8021q")) + devtype = &vlandev_device_type; + else if (!strcmp(type, "bridge")) devtype = &bridge_device_type; - else if (!strcmp(type, "tunnel")) - devtype = &tunnel_device_type; else if (!strcmp(type, "macvlan")) devtype = &macvlan_device_type; - else if (!strcmp(type, "8021ad")) - devtype = &vlandev_device_type; - else if (!strcmp(type, "8021q")) - devtype = &vlandev_device_type; + else if (!strcmp(type, "tunnel")) + devtype = &tunnel_device_type; } if (!devtype) @@ -313,9 +332,16 @@ config_parse_wireless_device(struct uci_section *s) static void config_parse_wireless_interface(struct wireless_device *wdev, struct uci_section *s) { + char *name = NULL; + + if (s->anonymous) { + name = alloca(strlen(s->type) + 16); + asprintf(&name, "@%s[%d]", s->type, config_section_idx(s)); + } + blob_buf_init(&b, 0); uci_to_blob(&b, s, wdev->drv->interface.config); - wireless_interface_create(wdev, b.head, s->e.name); + wireless_interface_create(wdev, b.head, name ? name : s->e.name); } static void