summaryrefslogtreecommitdiff
path: root/interface.c
diff options
context:
space:
mode:
authorFelix Fietkau <nbd@openwrt.org>2011-09-04 14:33:31 +0200
committerFelix Fietkau <nbd@openwrt.org>2011-09-04 14:33:31 +0200
commitdca8c7133b1db463f6ae71ccc6d34cd12735daef (patch)
tree320d30e5213288f9cca0946153f2f17ddfcf163b /interface.c
parent07a47add60b567f65dd2051fe45ac49e1ae97524 (diff)
downloadnetifd-dca8c7133b1db463f6ae71ccc6d34cd12735daef.tar.gz
trigger proto attach from config.c
Diffstat (limited to 'interface.c')
-rw-r--r--interface.c14
1 files changed, 9 insertions, 5 deletions
diff --git a/interface.c b/interface.c
index 20956be..f08fee0 100644
--- a/interface.c
+++ b/interface.c
@@ -201,12 +201,13 @@ void interface_set_proto_state(struct interface *iface, struct interface_proto_s
}
struct interface *
-interface_alloc(const char *name, struct uci_section *s, struct blob_attr *attr)
+interface_alloc(const char *name, struct blob_attr *attr)
{
struct interface *iface;
struct blob_attr *tb[IFACE_ATTR_MAX];
struct blob_attr *cur;
struct device *dev;
+ const char *proto_name = NULL;
iface = interface_get(name);
if (iface)
@@ -221,19 +222,22 @@ interface_alloc(const char *name, struct uci_section *s, struct blob_attr *attr)
INIT_LIST_HEAD(&iface->address);
INIT_LIST_HEAD(&iface->routes);
- proto_attach_interface(iface, s);
-
- netifd_ubus_add_interface(iface);
-
blobmsg_parse(iface_attrs, IFACE_ATTR_MAX, tb,
blob_data(attr), blob_len(attr));
+ if ((cur = tb[IFACE_ATTR_PROTO]))
+ proto_name = blobmsg_data(cur);
+
+ proto_attach_interface(iface, proto_name);
+
if ((cur = tb[IFACE_ATTR_IFNAME])) {
dev = device_get(blobmsg_data(cur), true);
if (dev)
device_add_user(&iface->main_dev, dev);
}
+ netifd_ubus_add_interface(iface);
+
return iface;
}