OSDN Git Service

btiotest: Add option for SCO voice setting
authorFrédéric Dalleau <frederic.dalleau@linux.intel.com>
Fri, 5 Jul 2013 15:46:44 +0000 (17:46 +0200)
committerJohan Hedberg <johan.hedberg@intel.com>
Thu, 1 Aug 2013 09:37:38 +0000 (12:37 +0300)
tools/btiotest.c

index 2c77fb3..580e7a5 100644 (file)
@@ -445,7 +445,7 @@ static void rfcomm_listen(const char *src, uint8_t ch, gboolean defer,
        g_io_channel_unref(rc_srv);
 }
 
-static void sco_connect(const char *src, const char *dst, int disconn)
+static void sco_connect(const char *src, const char *dst, int disconn, int voice)
 {
        struct io_data *data;
        GError *err = NULL;
@@ -460,12 +460,14 @@ static void sco_connect(const char *src, const char *dst, int disconn)
                                                &err,
                                                BT_IO_OPT_SOURCE, src,
                                                BT_IO_OPT_DEST, dst,
+                                               BT_IO_OPT_VOICE, voice,
                                                BT_IO_OPT_INVALID);
        else
                data->io = bt_io_connect(connect_cb, data,
                                                (GDestroyNotify) io_data_unref,
                                                &err,
                                                BT_IO_OPT_DEST, dst,
+                                               BT_IO_OPT_VOICE, voice,
                                                BT_IO_OPT_INVALID);
 
        if (!data->io) {
@@ -476,7 +478,7 @@ static void sco_connect(const char *src, const char *dst, int disconn)
 }
 
 static void sco_listen(const char *src, gboolean defer, int reject,
-                               int disconn, int accept)
+                               int disconn, int accept, int voice)
 {
        struct io_data *data;
        BtIOConnect conn;
@@ -501,11 +503,14 @@ static void sco_listen(const char *src, gboolean defer, int reject,
                                        (GDestroyNotify) io_data_unref,
                                        &err,
                                        BT_IO_OPT_SOURCE, src,
+                                       BT_IO_OPT_VOICE, voice,
                                        BT_IO_OPT_INVALID);
        else
                sco_srv = bt_io_listen(conn, cfm, data,
                                        (GDestroyNotify) io_data_unref,
-                                       &err, BT_IO_OPT_INVALID);
+                                       &err,
+                                       BT_IO_OPT_VOICE, voice,
+                                       BT_IO_OPT_INVALID);
 
        if (!sco_srv) {
                printf("Listening failed: %s\n", err->message);
@@ -520,6 +525,7 @@ static int opt_channel = -1;
 static int opt_psm = 0;
 static gboolean opt_sco = FALSE;
 static gboolean opt_defer = FALSE;
+static gint opt_voice = 0;
 static char *opt_dev = NULL;
 static int opt_reject = -1;
 static int opt_disconn = -1;
@@ -546,6 +552,9 @@ static GOptionEntry options[] = {
                                "Use SCO" },
        { "defer", 'd', 0, G_OPTION_ARG_NONE, &opt_defer,
                                "Use DEFER_SETUP for incoming connections" },
+       { "voice", 'V', 0, G_OPTION_ARG_INT, &opt_voice,
+                               "Voice setting "
+                               "(0x0060 CVSD, 0x0003 Transparent)" },
        { "sec-level", 'S', 0, G_OPTION_ARG_INT, &opt_sec,
                                "Security level" },
        { "update-sec-level", 'U', 0, G_OPTION_ARG_INT, &opt_update_sec,
@@ -611,10 +620,10 @@ int main(int argc, char *argv[])
 
        if (opt_sco) {
                if (argc > 1)
-                       sco_connect(opt_dev, argv[1], opt_disconn);
+                       sco_connect(opt_dev, argv[1], opt_disconn, opt_voice);
                else
                        sco_listen(opt_dev, opt_defer, opt_reject,
-                                       opt_disconn, opt_accept);
+                                       opt_disconn, opt_accept, opt_voice);
        }
 
        signal(SIGTERM, sig_term);