From: Martin Xu <[email protected]>
The device is created and attach technology at rtnl->newlink(), so
__connman_technology_add_interface() nees to be called after rtnl->newlink()
---
src/rtnl.c | 15 +++++++--------
1 files changed, 7 insertions(+), 8 deletions(-)
diff --git a/src/rtnl.c b/src/rtnl.c
index 8fea094..4029b40 100644
--- a/src/rtnl.c
+++ b/src/rtnl.c
@@ -406,6 +406,7 @@ static void process_newlink(unsigned short type, int index,
unsigned flags,
struct ether_addr compare = {{ 0, 0, 0, 0, 0, 0 }};
struct rtnl_link_stats stats;
unsigned char operstate = 0xff;
+ struct interface_data *interface;
const char *ifname = NULL;
unsigned int mtu = 0;
char ident[13], str[18];
@@ -449,10 +450,9 @@ static void process_newlink(unsigned short type, int
index, unsigned flags,
ifname, index, operstate,
operstate2str(operstate));
- if (g_hash_table_lookup(interface_list,
- GINT_TO_POINTER(index)) == NULL) {
- struct interface_data *interface;
-
+ interface = g_hash_table_lookup(interface_list,
+ GINT_TO_POINTER(index));
+ if (interface == NULL) {
interface = g_new0(struct interface_data, 1);
interface->index = index;
interface->name = g_strdup(ifname);
@@ -460,12 +460,8 @@ static void process_newlink(unsigned short type, int
index, unsigned flags,
g_hash_table_insert(interface_list,
GINT_TO_POINTER(index), interface);
-
if (type == ARPHRD_ETHER)
read_uevent(interface);
-
- __connman_technology_add_interface(interface->service_type,
- interface->index, interface->name, interface->ident);
}
for (list = rtnl_list; list; list = list->next) {
@@ -475,6 +471,9 @@ static void process_newlink(unsigned short type, int index,
unsigned flags,
rtnl->newlink(type, index, flags, change);
}
+ __connman_technology_add_interface(interface->service_type,
+ interface->index, interface->name, interface->ident);
+
for (list = watch_list; list; list = list->next) {
struct watch_data *watch = list->data;
--
1.6.1.3
_______________________________________________
connman mailing list
[email protected]
http://lists.connman.net/listinfo/connman