summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndrzej Kaczmarek <andrzej.kaczmarek@codecoup.pl>2015-11-22 21:20:23 +0100
committerLuiz Augusto von Dentz <luiz.von.dentz@intel.com>2015-12-01 10:42:27 +0200
commitc86793ceb7833d6c1a5516a3000cadd9603ab4e8 (patch)
treef7272581e28edb6147ec6cfbd7c95b82abccdf8f
parent89eedbfde5e6f9bb5a1b7afe363f112e5f161df9 (diff)
downloadbluez-c86793ceb7833d6c1a5516a3000cadd9603ab4e8.tar.gz
monitor/avdtp: Decode AVDTP_SUSPEND
< ACL Data TX: Handle 256 flags 0x00 dlen 7 Channel: 258 len 3 [PSM 25 mode 0] {chan 2} AVDTP: Suspend (0x09) Command (0x00) type 0x00 label 8 nosp 0 ACP SEID: 1 > ACL Data RX: Handle 256 flags 0x02 dlen 6 Channel: 66 len 2 [PSM 25 mode 0] {chan 2} AVDTP: Suspend (0x09) Response Accept (0x02) type 0x00 label 8 nosp 0
-rw-r--r--monitor/avdtp.c33
1 files changed, 33 insertions, 0 deletions
diff --git a/monitor/avdtp.c b/monitor/avdtp.c
index 6e2bb256e..8051fee23 100644
--- a/monitor/avdtp.c
+++ b/monitor/avdtp.c
@@ -465,6 +465,37 @@ static bool avdtp_close(struct avdtp_frame *avdtp_frame)
return false;
}
+static bool avdtp_suspend(struct avdtp_frame *avdtp_frame)
+{
+ struct l2cap_frame *frame = &avdtp_frame->l2cap_frame;
+ uint8_t type = avdtp_frame->hdr & 0x03;
+ uint8_t seid;
+
+ switch (type) {
+ case AVDTP_MSG_TYPE_COMMAND:
+ if (!l2cap_frame_get_u8(frame, &seid))
+ return false;
+
+ print_field("ACP SEID: %d", seid >> 2);
+
+ while (l2cap_frame_get_u8(frame, &seid))
+ print_field("ACP SEID: %d", seid >> 2);
+
+ return true;
+ case AVDTP_MSG_TYPE_RESPONSE_ACCEPT:
+ return true;
+ case AVDTP_MSG_TYPE_RESPONSE_REJECT:
+ if (!l2cap_frame_get_u8(frame, &seid))
+ return false;
+
+ print_field("ACP SEID: %d", seid >> 2);
+
+ return avdtp_reject_common(avdtp_frame);
+ }
+
+ return false;
+}
+
static bool avdtp_signalling_packet(struct avdtp_frame *avdtp_frame)
{
struct l2cap_frame *frame = &avdtp_frame->l2cap_frame;
@@ -536,6 +567,8 @@ static bool avdtp_signalling_packet(struct avdtp_frame *avdtp_frame)
return avdtp_start(avdtp_frame);
case AVDTP_CLOSE:
return avdtp_close(avdtp_frame);
+ case AVDTP_SUSPEND:
+ return avdtp_suspend(avdtp_frame);
}
packet_hexdump(frame->data, frame->size);