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.
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)