monitor/avdtp: Decode AVDTP_START

< ACL Data TX: Handle 256 flags 0x00 dlen 7
      Channel: 258 len 3 [PSM 25 mode 0] {chan 2}
      AVDTP: Start (0x07) Command (0x00) type 0x00 label 7 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: Start (0x07) Response Accept (0x02) type 0x00 label 7 nosp 0
This commit is contained in:
Andrzej Kaczmarek 2015-11-22 21:20:21 +01:00 committed by Luiz Augusto von Dentz
parent 004c180013
commit 0c7b69cdb9

View File

@ -411,6 +411,37 @@ static bool avdtp_open(struct avdtp_frame *avdtp_frame)
return false; return false;
} }
static bool avdtp_start(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) static bool avdtp_signalling_packet(struct avdtp_frame *avdtp_frame)
{ {
struct l2cap_frame *frame = &avdtp_frame->l2cap_frame; struct l2cap_frame *frame = &avdtp_frame->l2cap_frame;
@ -478,6 +509,8 @@ static bool avdtp_signalling_packet(struct avdtp_frame *avdtp_frame)
return avdtp_reconfigure(avdtp_frame); return avdtp_reconfigure(avdtp_frame);
case AVDTP_OPEN: case AVDTP_OPEN:
return avdtp_open(avdtp_frame); return avdtp_open(avdtp_frame);
case AVDTP_START:
return avdtp_start(avdtp_frame);
} }
packet_hexdump(frame->data, frame->size); packet_hexdump(frame->data, frame->size);