diff --git a/android/avdtptest.c b/android/avdtptest.c
index cbdcb3a..424deda 100644
--- a/android/avdtptest.c
+++ b/android/avdtptest.c
static guint media_player = 0;
static guint idle_id = 0;
+static bool fragment = false;
+
static const char sbc_codec[] = {0x00, 0x00, 0x11, 0x15, 0x02, 0x40};
static const char sbc_media_frame[] = {
0x00, 0x60, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01,
return;
}
+ printf("Connected (imtu=%d omtu=%d)\n", imtu, omtu);
+
fd = g_io_channel_unix_get_fd(chan);
if (avdtp && avdtp_stream) {
}
}
+static GIOChannel *do_connect(GError **err)
+{
+ if (fragment)
+ return bt_io_connect(connect_cb, NULL, NULL, err,
+ BT_IO_OPT_SOURCE_BDADDR, &src,
+ BT_IO_OPT_DEST_BDADDR, &dst,
+ BT_IO_OPT_SEC_LEVEL, BT_IO_SEC_LOW,
+ BT_IO_OPT_PSM, AVDTP_PSM,
+ BT_IO_OPT_MTU, 48,
+ BT_IO_OPT_INVALID);
+
+ return bt_io_connect(connect_cb, NULL, NULL, err,
+ BT_IO_OPT_SOURCE_BDADDR, &src,
+ BT_IO_OPT_DEST_BDADDR, &dst,
+ BT_IO_OPT_SEC_LEVEL, BT_IO_SEC_LOW,
+ BT_IO_OPT_PSM, AVDTP_PSM,
+ BT_IO_OPT_INVALID);
+}
+
static void open_cfm(struct avdtp *session, struct avdtp_local_sep *lsep,
struct avdtp_stream *stream, struct avdtp_error *err,
void *user_data)
if (!initiator)
return;
- bt_io_connect(connect_cb, NULL, NULL, &gerr,
- BT_IO_OPT_SOURCE_BDADDR, &src,
- BT_IO_OPT_DEST_BDADDR, &dst,
- BT_IO_OPT_SEC_LEVEL, BT_IO_SEC_LOW,
- BT_IO_OPT_PSM, AVDTP_PSM,
- BT_IO_OPT_INVALID);
+ do_connect(&gerr);
if (gerr) {
printf("connect failed: %s\n", gerr->message);
g_error_free(gerr);
void *user_data)
{
struct avdtp_service_capability *service;
+ int i;
printf("%s\n", __func__);
*caps = g_slist_append(*caps, service);
service = avdtp_service_cap_new(AVDTP_MEDIA_CODEC, sbc_codec,
- sizeof(sbc_codec));
+ sizeof(sbc_codec));
*caps = g_slist_append(*caps, service);
+ if (fragment)
+ for (i = 0; i < 10; i++) {
+ service = avdtp_service_cap_new(AVDTP_MEDIA_CODEC,
+ sbc_codec,
+ sizeof(sbc_codec));
+ *caps = g_slist_append(*caps, service);
+ }
+
return TRUE;
}
"\t-i <hcidev> HCI adapter\n"
"\t-c <bdaddr> connect\n"
"\t-l listen\n"
- "\t-r reject commands\n");
+ "\t-r reject commands\n"
+ "\t-f fragment\n");
}
static struct option main_options[] = {
{ "connect", 1, 0, 'c' },
{ "listen", 0, 0, 'l' },
{ "reject", 0, 0, 'r' },
+ { "fragment", 0, 0, 'f' },
{ 0, 0, 0, 0 }
};
+static GIOChannel *do_listen(GError **err)
+{
+ if (fragment)
+ return bt_io_listen(connect_cb, NULL, NULL, NULL, err,
+ BT_IO_OPT_SOURCE_BDADDR, &src,
+ BT_IO_OPT_PSM, AVDTP_PSM,
+ BT_IO_OPT_SEC_LEVEL, BT_IO_SEC_LOW,
+ BT_IO_OPT_MTU, 48,
+ BT_IO_OPT_INVALID);
+
+ return bt_io_listen(connect_cb, NULL, NULL, NULL, err,
+ BT_IO_OPT_SOURCE_BDADDR, &src,
+ BT_IO_OPT_PSM, AVDTP_PSM,
+ BT_IO_OPT_SEC_LEVEL, BT_IO_SEC_LOW,
+ BT_IO_OPT_INVALID);
+}
+
int main(int argc, char *argv[])
{
GError *err = NULL;
exit(1);
}
- while ((opt = getopt_long(argc, argv, "d:hi:s:c:lr",
+ while ((opt = getopt_long(argc, argv, "d:hi:s:c:lrf",
main_options, NULL)) != EOF) {
switch (opt) {
case 'i':
case 'r':
reject = true;
break;
+ case 'f':
+ fragment = true;
+ break;
case 'h':
default:
usage();
if (!bacmp(&dst, BDADDR_ANY)) {
printf("Listening...\n");
- io = bt_io_listen(connect_cb, NULL, NULL, NULL, &err,
- BT_IO_OPT_SOURCE_BDADDR, &src,
- BT_IO_OPT_PSM, AVDTP_PSM,
- BT_IO_OPT_SEC_LEVEL, BT_IO_SEC_LOW,
- BT_IO_OPT_INVALID);
+ io = do_listen(&err);
} else {
printf("Connecting...\n");
- io = bt_io_connect(connect_cb, NULL, NULL, &err,
- BT_IO_OPT_SOURCE_BDADDR, &src,
- BT_IO_OPT_DEST_BDADDR, &dst,
- BT_IO_OPT_SEC_LEVEL, BT_IO_SEC_LOW,
- BT_IO_OPT_PSM, AVDTP_PSM,
- BT_IO_OPT_INVALID);
+ io = do_connect(&err);
}
if (!io) {