summaryrefslogtreecommitdiff
path: root/monitor/avdtp.c
diff options
context:
space:
mode:
Diffstat (limited to 'monitor/avdtp.c')
-rw-r--r--monitor/avdtp.c29
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);