From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: From: Luiz Augusto von Dentz To: linux-bluetooth@vger.kernel.org Subject: [PATCH BlueZ 02/12] audio/A2DP: Add implemention of SEP close indication Date: Mon, 13 Jan 2014 19:32:03 +0200 Message-Id: <1389634333-25870-2-git-send-email-luiz.dentz@gmail.com> In-Reply-To: <1389634333-25870-1-git-send-email-luiz.dentz@gmail.com> References: <1389634333-25870-1-git-send-email-luiz.dentz@gmail.com> Sender: linux-bluetooth-owner@vger.kernel.org List-ID: From: Luiz Augusto von Dentz --- android/a2dp.c | 31 +++++++++++++++++++++++++++++++ 1 file changed, 31 insertions(+) diff --git a/android/a2dp.c b/android/a2dp.c index 1a9adb8..9aebc9d 100644 --- a/android/a2dp.c +++ b/android/a2dp.c @@ -514,6 +514,12 @@ static void setup_free(void *data) g_free(setup); } +static void setup_remove(struct a2dp_setup *setup) +{ + setups = g_slist_remove(setups, setup); + setup_free(setup); +} + static void setup_add(struct a2dp_device *dev, struct a2dp_endpoint *endpoint, struct a2dp_preset *preset, struct avdtp_stream *stream) { @@ -615,10 +621,35 @@ static gboolean sep_open_ind(struct avdtp *session, struct avdtp_local_sep *sep, return TRUE; } +static gboolean sep_close_ind(struct avdtp *session, + struct avdtp_local_sep *sep, + struct avdtp_stream *stream, + uint8_t *err, + void *user_data) +{ + struct a2dp_endpoint *endpoint = user_data; + struct a2dp_setup *setup; + + DBG(""); + + setup = find_setup(endpoint->id); + if (!setup) { + error("Unable to find stream setup for endpoint %u", + endpoint->id); + *err = AVDTP_SEP_NOT_IN_USE; + return FALSE; + } + + setup_remove(setup); + + return TRUE; +} + static struct avdtp_sep_ind sep_ind = { .get_capability = sep_getcap_ind, .set_configuration = sep_setconf_ind, .open = sep_open_ind, + .close = sep_close_ind, }; static uint8_t register_endpoint(const uint8_t *uuid, uint8_t codec, -- 1.8.4.2