add support for multiple config_param_list::next pointers
[project/netifd.git] / config.c
index 18efe96..1e465c5 100644 (file)
--- a/config.c
+++ b/config.c
@@ -69,8 +69,8 @@ static void uci_array_to_blob(struct blob_buf *b, struct uci_option *o,
        free(str);
 }
 
-static void uci_to_blob(struct blob_buf *b, struct uci_section *s,
-                       const struct config_param_list *p)
+static void __uci_to_blob(struct blob_buf *b, struct uci_section *s,
+                         const struct config_param_list *p)
 {
        const struct blobmsg_policy *attr;
        struct uci_element *e;
@@ -107,6 +107,16 @@ static void uci_to_blob(struct blob_buf *b, struct uci_section *s,
        }
 }
 
+static void uci_to_blob(struct blob_buf *b, struct uci_section *s,
+                       const struct config_param_list *p)
+{
+       int i;
+
+       __uci_to_blob(b, s, p);
+       for (i = 0; i < p->n_next; i++)
+               uci_to_blob(b, s, p->next[i]);
+}
+
 static void
 config_parse_interface(struct uci_section *s)
 {
@@ -114,7 +124,7 @@ config_parse_interface(struct uci_section *s)
 
        blob_buf_init(&b, 0);
        uci_to_blob(&b, s, &interface_attr_list);
-       alloc_interface(s->e.name, s, b.head);
+       interface_alloc(s->e.name, s, b.head);
 }
 
 void
@@ -165,8 +175,8 @@ config_init_interfaces(const char *name)
                if (!strcmp(s->type, "interface"))
                        config_parse_interface(s);
        }
-       cleanup_devices();
+       device_free_all();
        config_init = false;
 
-       start_pending_interfaces();
+       interface_start_pending();
 }