Return-Path: From: =?UTF-8?q?Jo=C3=A3o=20Paulo=20Rechi=20Vita?= To: linux-bluetooth@vger.kernel.org Cc: Claudio Takahasi Subject: [PATCH BlueZ v6 01/11] core: Control connections based on adapter state Date: Tue, 11 Sep 2012 10:32:57 -0300 Message-Id: <1347370387-17670-1-git-send-email-jprvita@openbossa.org> Sender: linux-bluetooth-owner@vger.kernel.org List-ID: From: Claudio Takahasi This patch disable automatic ATTIO connections when the adapter is powered down and enable automatic connection when the adapter is powered on. --- src/adapter.c | 23 ++++++++++++++--------- 1 file changed, 14 insertions(+), 9 deletions(-) diff --git a/src/adapter.c b/src/adapter.c index 4b675e8..6b8435e 100644 --- a/src/adapter.c +++ b/src/adapter.c @@ -2113,6 +2113,14 @@ static int get_pairable_timeout(const char *src) return main_opts.pairto; } +static void set_auto_connect(gpointer data, gpointer user_data) +{ + struct btd_device *device = data; + gboolean *enable = user_data; + + device_set_auto_connect(device, *enable); +} + static void call_adapter_powered_callbacks(struct btd_adapter *adapter, gboolean powered) { @@ -2122,7 +2130,9 @@ static void call_adapter_powered_callbacks(struct btd_adapter *adapter, btd_adapter_powered_cb cb = l->data; cb(adapter, powered); - } + } + + g_slist_foreach(adapter->devices, set_auto_connect, &powered); } static void emit_device_disappeared(gpointer data, gpointer user_data) @@ -3401,15 +3411,10 @@ static gboolean disable_auto(gpointer user_data) return FALSE; } -static void set_auto_connect(gpointer data, gpointer user_data) -{ - struct btd_device *device = data; - - device_set_auto_connect(device, TRUE); -} - void btd_adapter_enable_auto_connect(struct btd_adapter *adapter) { + gboolean enable = TRUE; + if (!adapter->up) return; @@ -3418,7 +3423,7 @@ void btd_adapter_enable_auto_connect(struct btd_adapter *adapter) if (adapter->auto_timeout_id) return; - g_slist_foreach(adapter->devices, set_auto_connect, NULL); + g_slist_foreach(adapter->devices, set_auto_connect, &enable); adapter->auto_timeout_id = g_timeout_add_seconds(main_opts.autoto, disable_auto, adapter); -- 1.7.11.4