--- tools/scotest.c | 36 ++++++++++++++++++++++++++++++++++-- 1 file changed, 34 insertions(+), 2 deletions(-) diff --git a/tools/scotest.c b/tools/scotest.c index a40e395..ea71c41 100644 --- a/tools/scotest.c +++ b/tools/scotest.c @@ -58,6 +58,7 @@ static long data_size = 672; static bdaddr_t bdaddr; static int defer_setup = 0; +static int mode = 0; static float tv2fl(struct timeval tv) { @@ -68,6 +69,7 @@ static int do_connect(char *svr) { struct sockaddr_sco addr; struct sco_conninfo conn; + struct sco_options opts; socklen_t optlen; int sk; @@ -90,6 +92,15 @@ static int do_connect(char *svr) goto error; } + /* Add SCO options */ + memset(&opts, 0, sizeof(opts)); + opts.mode = mode; + if (setsockopt(sk, SOL_SCO, SCO_OPTIONS, &opts, sizeof(opts)) < 0) { + syslog(LOG_ERR, "Can't set socket options: %s (%d)", + strerror(errno), errno); + goto error; + } + /* Connect to remote device */ memset(&addr, 0, sizeof(addr)); addr.sco_family = AF_BLUETOOTH; @@ -229,8 +240,16 @@ error: static void dump_mode(int sk) { + struct sco_options opts; int len; + /* Add SCO options */ + memset(&opts, 0, sizeof(opts)); + opts.mode = mode; + if (setsockopt(sk, SOL_SCO, SCO_OPTIONS, &opts, sizeof(opts)) < 0) + syslog(LOG_ERR, "Can't set socket options: %s (%d)", + strerror(errno), errno); + if (defer_setup) { len = read(sk, buf, sizeof(buf)); if (len < 0) @@ -248,9 +267,17 @@ static void dump_mode(int sk) static void recv_mode(int sk) { struct timeval tv_beg,tv_end,tv_diff; + struct sco_options opts; long total; int len; + /* Add SCO options */ + memset(&opts, 0, sizeof(opts)); + opts.mode = mode; + if (setsockopt(sk, SOL_SCO, SCO_OPTIONS, &opts, sizeof(opts)) < 0) + syslog(LOG_ERR, "Can't set socket options: %s (%d)", + strerror(errno), errno); + if (defer_setup) { len = read(sk, buf, sizeof(buf)); if (len < 0) @@ -381,7 +408,8 @@ static void usage(void) "\t-n connect and be silent (client)\n" "Options:\n" "\t[-b bytes]\n" - "\t[-W seconds] enable deferred setup\n"); + "\t[-W seconds] enable deferred setup\n" + "\t[-M mode] select mode (sco only: 0 cvsd, 1 transparent)\n"); } int main(int argc ,char *argv[]) @@ -389,7 +417,7 @@ int main(int argc ,char *argv[]) struct sigaction sa; int opt, sk, mode = RECV; - while ((opt = getopt(argc, argv, "rdscmnb:W:")) != EOF) { + while ((opt = getopt(argc, argv, "rdscmnb:W:M:")) != EOF) { switch(opt) { case 'r': mode = RECV; @@ -423,6 +451,10 @@ int main(int argc ,char *argv[]) defer_setup = atoi(optarg); break; + case 'M': + mode = atoi(optarg); + break; + default: usage(); exit(1); -- 1.7.9.5 -- 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