diff options
author | Andrzej Kaczmarek <andrzej.kaczmarek@codecoup.pl> | 2015-11-22 21:20:23 +0100 |
---|---|---|
committer | Luiz Augusto von Dentz <luiz.von.dentz@intel.com> | 2015-12-01 10:42:27 +0200 |
commit | c86793ceb7833d6c1a5516a3000cadd9603ab4e8 (patch) | |
tree | f7272581e28edb6147ec6cfbd7c95b82abccdf8f | |
parent | 89eedbfde5e6f9bb5a1b7afe363f112e5f161df9 (diff) | |
download | bluez-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.c | 33 |
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); |