--- monitor/avdtp.c | 41 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 41 insertions(+) diff --git a/monitor/avdtp.c b/monitor/avdtp.c index e065d8b..e48e507 100644 --- a/monitor/avdtp.c +++ b/monitor/avdtp.c @@ -488,6 +488,44 @@ response: return true; } +static bool avdtp_suspend(struct avdtp_frame *avdtp_frame) +{ + struct l2cap_frame *frame = &avdtp_frame->l2cap_frame; + uint8_t seid; + + if (avdtp_frame->hdr & 0x01) + goto reject; + + if (avdtp_frame->hdr & 0x02) + goto response; + + if (!l2cap_frame_get_u8(frame, &seid)) + return false; + + print_field("ACP SEID: %d", seid >> 2); + + for (;;) { + if (!l2cap_frame_get_u8(frame, &seid)) + break; + + print_field("ACP SEID: %d", seid >> 2); + } + + return true; + +reject: + if (!l2cap_frame_get_u8(frame, &seid)) + return false; + + print_field("ACP SEID: %d", seid >> 2); + + return avdtp_reject_common(avdtp_frame); + +response: + /* no extra parameters */ + return true; +} + static bool avdtp_signalling_packet(struct avdtp_frame *avdtp_frame) { struct l2cap_frame *frame = &avdtp_frame->l2cap_frame; @@ -566,6 +604,9 @@ static bool avdtp_signalling_packet(struct avdtp_frame *avdtp_frame) case AVDTP_CLOSE: ret = avdtp_close(avdtp_frame); break; + case AVDTP_SUSPEND: + ret = avdtp_suspend(avdtp_frame); + break; default: packet_hexdump(frame->data, frame->size); ret = true; -- 2.6.2 -- To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html