diff options
-rw-r--r-- | monitor/avdtp.c | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/monitor/avdtp.c b/monitor/avdtp.c index a69ddbeba..28ddb2072 100644 --- a/monitor/avdtp.c +++ b/monitor/avdtp.c @@ -517,6 +517,33 @@ static bool avdtp_abort(struct avdtp_frame *avdtp_frame) return false; } +static bool avdtp_security_control(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); + + /* TODO: decode more information */ + packet_hexdump(frame->data, frame->size); + return true; + case AVDTP_MSG_TYPE_RESPONSE_ACCEPT: + /* TODO: decode more information */ + packet_hexdump(frame->data, frame->size); + 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; @@ -592,6 +619,8 @@ static bool avdtp_signalling_packet(struct avdtp_frame *avdtp_frame) return avdtp_suspend(avdtp_frame); case AVDTP_ABORT: return avdtp_abort(avdtp_frame); + case AVDTP_SECURITY_CONTROL: + return avdtp_security_control(avdtp_frame); } packet_hexdump(frame->data, frame->size); |