From: Andrei Emeltchenko <Andrei.Emeltchenko.news@gmail.com>
To: linux-bluetooth@vger.kernel.org
Subject: [PATCHv8 01/15] android/socket: Parse SDP response and connect
Date: Mon, 25 Nov 2013 11:44:44 +0200 [thread overview]
Message-ID: <1385372698-16212-2-git-send-email-Andrei.Emeltchenko.news@gmail.com> (raw)
In-Reply-To: <1385372698-16212-1-git-send-email-Andrei.Emeltchenko.news@gmail.com>
From: Andrei Emeltchenko <andrei.emeltchenko@intel.com>
Parse SDP response, find RFCOMM channel and connect.
---
android/socket.c | 68 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 68 insertions(+)
diff --git a/android/socket.c b/android/socket.c
index 1815367..cd958d9 100644
--- a/android/socket.c
+++ b/android/socket.c
@@ -424,9 +424,77 @@ static int handle_listen(void *buf)
return hal_fd;
}
+static void connect_cb(GIOChannel *io, GError *err, gpointer user_data)
+{
+}
+
static void sdp_search_cb(sdp_list_t *recs, int err, gpointer data)
{
+ struct rfcomm_sock *rfsock = data;
+ GError *gerr = NULL;
+ sdp_list_t *list;
+ GIOChannel *io;
+ int chan;
+
DBG("");
+
+ if (err < 0) {
+ error("Unable to get SDP record: %s", strerror(-err));
+ goto fail;
+ }
+
+ if (!recs || !recs->data) {
+ error("No SDP records found");
+ goto fail;
+ }
+
+ for (list = recs; list != NULL; list = list->next) {
+ sdp_record_t *rec = list->data;
+ sdp_list_t *protos;
+
+ if (sdp_get_access_protos(rec, &protos) < 0) {
+ error("Unable to get proto list");
+ goto fail;
+ }
+
+ chan = sdp_get_proto_port(protos, RFCOMM_UUID);
+
+ sdp_list_foreach(protos, (sdp_list_func_t) sdp_list_free,
+ NULL);
+ sdp_list_free(protos, NULL);
+
+ if (chan)
+ break;
+ }
+
+ if (chan <= 0) {
+ error("Could not get RFCOMM channel %d", chan);
+ goto fail;
+ }
+
+ DBG("Got RFCOMM channel %d", chan);
+
+ io = bt_io_connect(connect_cb, rfsock, NULL, &gerr,
+ BT_IO_OPT_SOURCE_BDADDR, &adapter_addr,
+ BT_IO_OPT_DEST_BDADDR, &rfsock->dst,
+ BT_IO_OPT_CHANNEL, chan,
+ BT_IO_OPT_SEC_LEVEL, BT_IO_SEC_LOW,
+ BT_IO_OPT_INVALID);
+ if (!io) {
+ error("Failed connect: %s", gerr->message);
+ g_error_free(gerr);
+ goto fail;
+ }
+
+ rfsock->real_sock = g_io_channel_unix_get_fd(io);
+ rfsock->channel = chan;
+ connections = g_list_append(connections, rfsock);
+
+ g_io_channel_unref(io);
+
+ return;
+fail:
+ cleanup_rfsock(rfsock);
}
static int handle_connect(void *buf)
--
1.8.3.2
next prev parent reply other threads:[~2013-11-25 9:44 UTC|newest]
Thread overview: 16+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-11-25 9:44 [PATCHv8 00/15] Socket HAL Andrei Emeltchenko
2013-11-25 9:44 ` Andrei Emeltchenko [this message]
2013-11-25 9:44 ` [PATCHv8 02/15] android/socket: Implement HAL connect call Andrei Emeltchenko
2013-11-25 9:44 ` [PATCHv8 03/15] android/socket: Send RFCOMM channel to framework Andrei Emeltchenko
2013-11-25 9:44 ` [PATCHv8 04/15] android/socket: Send connect signal to Android framework Andrei Emeltchenko
2013-11-25 9:44 ` [PATCHv8 05/15] android/socket: Close file descriptor after sending Andrei Emeltchenko
2013-11-25 9:44 ` [PATCHv8 06/15] android/socket: Add general service create/remove function Andrei Emeltchenko
2013-11-25 9:44 ` [PATCHv8 07/15] android/socket: Add OPP SDP record Andrei Emeltchenko
2013-11-25 9:44 ` [PATCHv8 08/15] android/socket: Add MAS uuid to profile table Andrei Emeltchenko
2013-11-25 9:44 ` [PATCHv8 09/15] android/socket: Add SPP " Andrei Emeltchenko
2013-11-25 9:44 ` [PATCHv8 10/15] android/socket: Add PBAP SDP record Andrei Emeltchenko
2013-11-25 9:44 ` [PATCHv8 11/15] android/socket: Add SPP " Andrei Emeltchenko
2013-11-25 9:44 ` [PATCHv8 12/15] android/socket: Support listen() with supplied chan number Andrei Emeltchenko
2013-11-25 9:44 ` [PATCHv8 13/15] android/hal-sock: Print bdaddr on connect Andrei Emeltchenko
2013-11-25 9:44 ` [PATCHv8 14/15] android/socket: Refactor socket send_fd function Andrei Emeltchenko
2013-11-25 9:44 ` [PATCHv8 15/15] android/hal-utils: Fix possible NULL pointer dereference Andrei Emeltchenko
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1385372698-16212-2-git-send-email-Andrei.Emeltchenko.news@gmail.com \
--to=andrei.emeltchenko.news@gmail.com \
--cc=linux-bluetooth@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).