From c57192242574cb314883c4837af0823aca6d435f Mon Sep 17 00:00:00 2001 From: Tomasz Bursztyka Date: Tue, 2 Oct 2012 12:27:11 +0300 Subject: [PATCH] technology: Handle harblock if all of them have identical type On some hardware, there exist two rfkill entities for the same type with a cascading issue: if one is soft blocked, the other one is hardblocked. But if the hardblock switch is set, all are hardblocked. This patch figures out that a technology is hardblocked only if all related rkill events get the same hardblock value. --- src/technology.c | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) diff --git a/src/technology.c b/src/technology.c index 14861222..e9598aa5 100644 --- a/src/technology.c +++ b/src/technology.c @@ -1290,9 +1290,28 @@ void __connman_technology_set_connected(enum connman_service_type type, static void technology_apply_hardblock_change(struct connman_technology *technology, connman_bool_t hardblock) { + gboolean apply = TRUE; + GList *start, *list; + if (technology->hardblocked == hardblock) return; + start = g_hash_table_get_values(rfkill_list); + for (list = start; list != NULL; list = list->next) { + struct connman_rfkill *rfkill = list->data; + + if (rfkill->type != technology->type) + continue; + + if (rfkill->hardblock != hardblock) + apply = FALSE; + } + + g_list_free(start); + + if (apply == FALSE) + return; + technology->hardblocked = hardblock; if (hardblock == TRUE) -- 2.34.1