diff --git a/android/avdtp.c b/android/avdtp.c
index b2d77a4..7d3cb18 100644
--- a/android/avdtp.c
+++ b/android/avdtp.c
return FALSE;
}
+void avdtp_shutdown(struct avdtp *session)
+{
+ GSList *l;
+ int sock;
+
+ if (!session->io)
+ return;
+
+ for (l = session->streams; l; l = g_slist_next(l)) {
+ struct avdtp_stream *stream = l->data;
+
+ avdtp_close(session, stream, TRUE);
+ }
+
+ sock = g_io_channel_unix_get_fd(session->io);
+
+ shutdown(sock, SHUT_RDWR);
+}
+
static void queue_request(struct avdtp *session, struct pending_req *req,
gboolean priority)
{
diff --git a/android/avdtp.h b/android/avdtp.h
index 1619029..d371653 100644
--- a/android/avdtp.h
+++ b/android/avdtp.h
void *user_data);
gboolean avdtp_remove_disconnect_cb(struct avdtp *session, unsigned int id);
+void avdtp_shutdown(struct avdtp *session);
+
void avdtp_unref(struct avdtp *session);
struct avdtp *avdtp_ref(struct avdtp *session);