Fix bridge and WiMAX device detection
[connman] / plugins / rtnllink.c
index 094547d..b0ed247 100644 (file)
@@ -48,7 +48,7 @@ static void rtnllink_newlink(unsigned short type, int index,
        struct connman_element *device;
        GSList *list;
        gboolean exists = FALSE;
-       gchar *name;
+       gchar *name, *devname;
 
        DBG("index %d", index);
 
@@ -64,7 +64,8 @@ static void rtnllink_newlink(unsigned short type, int index,
        if (exists == TRUE)
                return;
 
-       name = inet_index2name(index);
+       name = inet_index2ident(index, "dev_");
+       devname = inet_index2name(index);
 
        if (type == ARPHRD_ETHER) {
                char bridge_path[PATH_MAX], wimax_path[PATH_MAX];
@@ -73,12 +74,12 @@ static void rtnllink_newlink(unsigned short type, int index,
                int sk;
 
                snprintf(bridge_path, PATH_MAX,
-                                       "/sys/class/net/%s/bridge", name);
+                                       "/sys/class/net/%s/bridge", devname);
                snprintf(wimax_path, PATH_MAX,
-                                       "/sys/class/net/%s/wimax", name);
+                                       "/sys/class/net/%s/wimax", devname);
 
                memset(&iwr, 0, sizeof(iwr));
-               strncpy(iwr.ifr_ifrn.ifrn_name, name, IFNAMSIZ);
+               strncpy(iwr.ifr_ifrn.ifrn_name, devname, IFNAMSIZ);
 
                sk = socket(PF_INET, SOCK_DGRAM, 0);
 
@@ -107,6 +108,7 @@ static void rtnllink_newlink(unsigned short type, int index,
 
        device->index = index;
        device->name = name;
+       device->devname = devname;
 
        connman_element_register(device, NULL);
        device_list = g_slist_append(device_list, device);
@@ -167,5 +169,5 @@ static void rtnllink_exit(void)
        device_list = NULL;
 }
 
-CONNMAN_PLUGIN_DEFINE("rtnllink", "RTNL link detection plugin", VERSION,
+CONNMAN_PLUGIN_DEFINE(rtnllink, "RTNL link detection plugin", VERSION,
                                                rtnllink_init, rtnllink_exit)