From: Alok Barsode <[email protected]>
If a technology was rfkilled before connman ran, we need to register
it. If such tech was enabled, technology->device_list will be empty.
We save the state, rfkill unblock the type and exit. When the devices
get unblocked, they are automatically enabled since we saved the enable
state.
---
src/technology.c | 9 +++++++++
1 files changed, 9 insertions(+), 0 deletions(-)
diff --git a/src/technology.c b/src/technology.c
index 8214617..2b1763a 100644
--- a/src/technology.c
+++ b/src/technology.c
@@ -859,6 +859,13 @@ int __connman_technology_enable(enum connman_service_type
type, DBusMessage *msg
__connman_rfkill_block(technology->type, FALSE);
+ /*
+ * An empty device list means that devices in the technology
+ * were rfkill blocked. The unblock above will enable the devs.
+ */
+ if (technology->device_list == NULL)
+ return 0;
+
for (list = technology->device_list; list; list = list->next) {
struct connman_device *device = list->data;
@@ -1031,6 +1038,8 @@ int __connman_technology_add_rfkill(unsigned int index,
if (rfkill == NULL)
return -ENOMEM;
+ __connman_notifier_register(type);
+
rfkill->index = index;
rfkill->type = type;
rfkill->softblock = softblock;
--
1.7.4.1
_______________________________________________
connman mailing list
[email protected]
http://lists.connman.net/listinfo/connman