From ba977186fea2680207e4253a979d3d53d2f63d3b Mon Sep 17 00:00:00 2001 From: Andrzej Kaczmarek Date: Sun, 22 Nov 2015 21:20:19 +0100 Subject: [PATCH] monitor/avdtp: Decode AVDTP_RECONFIGURE --- monitor/avdtp.c | 32 ++++++++++++++++++++++++++++++++ 1 file changed, 32 insertions(+) diff --git a/monitor/avdtp.c b/monitor/avdtp.c index 8377afe18..413d966ed 100644 --- a/monitor/avdtp.c +++ b/monitor/avdtp.c @@ -358,6 +358,36 @@ static bool avdtp_get_configuration(struct avdtp_frame *avdtp_frame) return false; } +static bool avdtp_reconfigure(struct avdtp_frame *avdtp_frame) +{ + struct l2cap_frame *frame = &avdtp_frame->l2cap_frame; + uint8_t type = avdtp_frame->hdr & 0x03; + uint8_t seid; + uint8_t service_cat; + + switch (type) { + case AVDTP_MSG_TYPE_COMMAND: + if (!l2cap_frame_get_u8(frame, &seid)) + return false; + + print_field("ACP SEID: %d", seid >> 2); + + return decode_capabilities(avdtp_frame); + case AVDTP_MSG_TYPE_RESPONSE_ACCEPT: + return true; + case AVDTP_MSG_TYPE_RESPONSE_REJECT: + if (!l2cap_frame_get_u8(frame, &service_cat)) + return false; + + print_field("Service Category: %s (0x%02x)", + servicecat2str(service_cat), service_cat); + + 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; @@ -421,6 +451,8 @@ static bool avdtp_signalling_packet(struct avdtp_frame *avdtp_frame) return avdtp_set_configuration(avdtp_frame); case AVDTP_GET_CONFIGURATION: return avdtp_get_configuration(avdtp_frame); + case AVDTP_RECONFIGURE: + return avdtp_reconfigure(avdtp_frame); } packet_hexdump(frame->data, frame->size); -- 2.47.3