* [PATCH 0/1 v3] Add release all sessions when adapter is switched off
@ 2011-03-22 12:29 Dmitriy Paliy
2011-03-22 12:29 ` [PATCH " Dmitriy Paliy
0 siblings, 1 reply; 3+ messages in thread
From: Dmitriy Paliy @ 2011-03-22 12:29 UTC (permalink / raw)
To: linux-bluetooth, johan.hedberg
Hi,
This proposal includes also comment in the code on why g_slist_free is not
used after g_slist_foreach.
Br,
Dmitriy
^ permalink raw reply [flat|nested] 3+ messages in thread
* [PATCH v3] Add release all sessions when adapter is switched off
2011-03-22 12:29 [PATCH 0/1 v3] Add release all sessions when adapter is switched off Dmitriy Paliy
@ 2011-03-22 12:29 ` Dmitriy Paliy
2011-03-23 13:09 ` Johan Hedberg
0 siblings, 1 reply; 3+ messages in thread
From: Dmitriy Paliy @ 2011-03-22 12:29 UTC (permalink / raw)
To: linux-bluetooth, johan.hedberg; +Cc: Dmitriy Paliy
All sessions should be released when adapter is switched off. Then a new
RequestSession method call always results in change from power off to power
on such ensuring operational mode. Otherwise, it is possible to end up in
adapter state being powered off after RequestSession succeded.
g_slist_free is not called after g_slist_foreach because the list is updated
using g_slist_remove inside of session_free, which is called for each element
by g_slist_foreach.
---
src/adapter.c | 9 +++++++++
1 files changed, 9 insertions(+), 0 deletions(-)
diff --git a/src/adapter.c b/src/adapter.c
index cc4f43e..691b963 100644
--- a/src/adapter.c
+++ b/src/adapter.c
@@ -2507,6 +2507,15 @@ static void set_mode_complete(struct btd_adapter *adapter)
DBG("");
+ /*
+ * g_slist_free is not called after g_slist_foreach because the list is
+ * updated using g_slist_remove in session_remove which is called by
+ * session_free, which is called for each element by g_slist_foreach.
+ */
+ if (adapter->mode == MODE_OFF)
+ g_slist_foreach(adapter->mode_sessions, (GFunc) session_free,
+ NULL);
+
if (adapter->pending_mode == NULL)
return;
--
1.7.1
^ permalink raw reply related [flat|nested] 3+ messages in thread* Re: [PATCH v3] Add release all sessions when adapter is switched off
2011-03-22 12:29 ` [PATCH " Dmitriy Paliy
@ 2011-03-23 13:09 ` Johan Hedberg
0 siblings, 0 replies; 3+ messages in thread
From: Johan Hedberg @ 2011-03-23 13:09 UTC (permalink / raw)
To: Dmitriy Paliy; +Cc: linux-bluetooth
Hi Dmitriy,
On Tue, Mar 22, 2011, Dmitriy Paliy wrote:
> All sessions should be released when adapter is switched off. Then a new
> RequestSession method call always results in change from power off to power
> on such ensuring operational mode. Otherwise, it is possible to end up in
> adapter state being powered off after RequestSession succeded.
>
> g_slist_free is not called after g_slist_foreach because the list is updated
> using g_slist_remove inside of session_free, which is called for each element
> by g_slist_foreach.
> ---
> src/adapter.c | 9 +++++++++
> 1 files changed, 9 insertions(+), 0 deletions(-)
Pushed upstream. Thanks.
Johan
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2011-03-23 13:09 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2011-03-22 12:29 [PATCH 0/1 v3] Add release all sessions when adapter is switched off Dmitriy Paliy
2011-03-22 12:29 ` [PATCH " Dmitriy Paliy
2011-03-23 13:09 ` Johan Hedberg
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox