From: Andrei Emeltchenko <andrei.emeltchenko@xxxxxxxxx> Handle events from Android framework. Write everything to real RFCOMM socket. --- android/socket.c | 29 +++++++++++++++++++++++++++++ 1 file changed, 29 insertions(+) diff --git a/android/socket.c b/android/socket.c index 0ee53ba..dfad9da 100644 --- a/android/socket.c +++ b/android/socket.c @@ -94,6 +94,35 @@ static int get_rfcomm_chan(const uint8_t *uuid) static gboolean sock_stack_event_cb(GIOChannel *io, GIOCondition cond, gpointer data) { + struct rfcomm_slot *rfslot = data; + unsigned char buf[1024] = { 0 }; + int len; + + DBG("rfslot: fd %d hal_fd %d real_sock %d chan %u sock %d", + rfslot->fd, rfslot->hal_fd, rfslot->real_sock, rfslot->channel, + g_io_channel_unix_get_fd(io)); + + if (cond & (G_IO_ERR | G_IO_HUP | G_IO_NVAL)) { + error("Socket error: sock %d cond %d", + g_io_channel_unix_get_fd(io), cond); + g_io_channel_shutdown(io, TRUE, NULL); + return FALSE; + } + + /* FIXME check fd vs sock(io) */ + len = recv(rfslot->fd, buf, sizeof(buf), 0); + if (len <= 0) { + error("recv(): %s", strerror(errno)); + return FALSE; + } + + DBG("read %d bytes write to %d", len, rfslot->real_sock); + + if (send(rfslot->real_sock, buf, len, 0) < 0) { + error("send(): %s", strerror(errno)); + return FALSE; + } + return TRUE; } -- 1.7.10.4 -- To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html