From 89eedbfde5e6f9bb5a1b7afe363f112e5f161df9 Mon Sep 17 00:00:00 2001 From: Andrzej Kaczmarek Date: Sun, 22 Nov 2015 21:20:22 +0100 Subject: [PATCH] monitor/avdtp: Decode AVDTP_CLOSE < ACL Data TX: Handle 12 flags 0x02 dlen 7 Channel: 2753 len 3 [PSM 25 mode 0] {chan 1} AVDTP: Close (0x08) Command (0x00) type 0x00 label 8 nosp 0 ACP SEID: 5 > ACL Data RX: Handle 12 flags 0x02 dlen 6 Channel: 67 len 2 [PSM 25 mode 0] {chan 1} AVDTP: Close (0x08) Response Accept (0x02) type 0x00 label 8 nosp 0 --- monitor/avdtp.c | 25 +++++++++++++++++++++++++ 1 file changed, 25 insertions(+) diff --git a/monitor/avdtp.c b/monitor/avdtp.c index c8213fae6..6e2bb256e 100644 --- a/monitor/avdtp.c +++ b/monitor/avdtp.c @@ -442,6 +442,29 @@ static bool avdtp_start(struct avdtp_frame *avdtp_frame) return false; } +static bool avdtp_close(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); + + return true; + case AVDTP_MSG_TYPE_RESPONSE_ACCEPT: + return true; + case AVDTP_MSG_TYPE_RESPONSE_REJECT: + 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; @@ -511,6 +534,8 @@ static bool avdtp_signalling_packet(struct avdtp_frame *avdtp_frame) return avdtp_open(avdtp_frame); case AVDTP_START: return avdtp_start(avdtp_frame); + case AVDTP_CLOSE: + return avdtp_close(avdtp_frame); } packet_hexdump(frame->data, frame->size); -- 2.11.0