From 6094417533d97662f693d134ab04595a292de30c Mon Sep 17 00:00:00 2001 From: Felix Fietkau Date: Thu, 5 Jul 2012 14:18:04 +0200 Subject: fix ifname for alias+vlan chains --- device.c | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) (limited to 'device.c') diff --git a/device.c b/device.c index 017fe03..cc41b20 100644 --- a/device.c +++ b/device.c @@ -163,6 +163,7 @@ alias_device_create(const char *name, struct blob_attr *attr) alias = calloc(1, sizeof(*alias) + strlen(name) + 1); strcpy(alias->name, name); alias->dev.set_state = alias_device_set_state; + alias->dev.hidden = true; device_init_virtual(&alias->dev, &alias_device_type, NULL); alias->avl.key = alias->name; avl_insert(&aliases, &alias->avl); @@ -269,13 +270,19 @@ alias_notify_device(const char *name, struct device *dev) device_remove_user(&alias->dep); strcpy(alias->dev.ifname, dev->ifname); device_add_user(&alias->dep, dev); + alias->dev.hidden = false; + device_broadcast_event(&alias->dev, DEV_EVENT_UPDATE_IFNAME); } } device_set_present(&alias->dev, !!dev); - if (!dev && alias->dep.dev && !alias->dep.dev->active) + if (!dev && alias->dep.dev && !alias->dep.dev->active) { device_remove_user(&alias->dep); + alias->dev.hidden = true; + alias->dev.ifname[0] = 0; + device_broadcast_event(&alias->dev, DEV_EVENT_UPDATE_IFNAME); + } device_unlock(); } -- cgit v1.2.1