bluetooth: Release transport when the pa_rtpoll_run loop finishes.
authorJarkko Suontausta <jarkko.suontausta@digia.com>
Tue, 22 May 2012 12:58:33 +0000 (15:58 +0300)
committerArun Raghavan <arun.raghavan@collabora.co.uk>
Tue, 29 May 2012 03:54:27 +0000 (09:24 +0530)
Based on a patch by Marko Ollonen.

src/modules/bluetooth/module-bluetooth-device.c

index 0b12cc7b622394609f701729299803824eb700b0..68c4efc70da2397f1087243f1d878ba328d90b54 100644 (file)
@@ -1731,11 +1731,18 @@ static void thread_func(void *userdata) {
             pollfd->events = (short) (((u->sink && PA_SINK_IS_LINKED(u->sink->thread_info.state) && !writable) ? POLLOUT : 0) |
                                       (u->source && PA_SOURCE_IS_LINKED(u->source->thread_info.state) ? POLLIN : 0));
 
-        if ((ret = pa_rtpoll_run(u->rtpoll, TRUE)) < 0)
+        if ((ret = pa_rtpoll_run(u->rtpoll, TRUE)) < 0) {
+            pa_log_debug("pa_rtpoll_run failed with: %d", ret);
             goto fail;
-
-        if (ret == 0)
+        }
+        if (ret == 0) {
+            pa_log_debug("IO thread shutdown requested, stopping cleanly");
+            if (u->transport)
+                bt_transport_release(u);
+            else
+                stop_stream_fd(u);
             goto finish;
+        }
 
         pollfd = u->rtpoll_item ? pa_rtpoll_item_get_pollfd(u->rtpoll_item, NULL) : NULL;