Diff between 89eedbfde5e6f9bb5a1b7afe363f112e5f161df9 and c86793ceb7833d6c1a5516a3000cadd9603ab4e8

Changed Files

File Additions Deletions Status
monitor/avdtp.c +33 -0 modified

Full Patch

diff --git a/monitor/avdtp.c b/monitor/avdtp.c
index 6e2bb25..8051fee 100644
--- a/monitor/avdtp.c
+++ b/monitor/avdtp.c
@@ -465,6 +465,37 @@ static bool avdtp_close(struct avdtp_frame *avdtp_frame)
 	return false;
 }
 
+static bool avdtp_suspend(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)
 {
 	struct l2cap_frame *frame = &avdtp_frame->l2cap_frame;
@@ -536,6 +567,8 @@ static bool avdtp_signalling_packet(struct avdtp_frame *avdtp_frame)
 		return avdtp_start(avdtp_frame);
 	case AVDTP_CLOSE:
 		return avdtp_close(avdtp_frame);
+	case AVDTP_SUSPEND:
+		return avdtp_suspend(avdtp_frame);
 	}
 
 	packet_hexdump(frame->data, frame->size);