Hi, On Tue, Jul 22, 2014 at 1:57 PM, Vikrampal Yadav <vikram.pal@xxxxxxxxxxx> wrote: > Support for decoding AVCTP packets added in Bluetooth monitor. > --- > monitor/l2cap.c | 64 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++ > 1 file changed, 64 insertions(+) > > diff --git a/monitor/l2cap.c b/monitor/l2cap.c > index 993aa8b..3475263 100644 > --- a/monitor/l2cap.c > +++ b/monitor/l2cap.c > @@ -2220,6 +2220,66 @@ static void att_packet(uint16_t index, bool in, uint16_t handle, > opcode_data->func(&frame); > } > > +static void avrcp_control_packet(const struct l2cap_frame *frame) > +{ > +} > + > +static void avrcp_browsing_packet(const struct l2cap_frame *frame, uint8_t hdr) > +{ > +} Please use avctp prefix while processing AVCTP part of the packets. > +static void avrcp_packet(const struct l2cap_frame *frame, uint8_t hdr, > + uint16_t psm) > +{ > + switch (psm) { > + case 0x17: > + avrcp_control_packet(frame); > + break; > + case 0x1B: > + avrcp_browsing_packet(frame, hdr); > + break; > + default: > + packet_hexdump(frame->data, frame->size); > + } > +} Here as well. > +static void avctp_packet(const struct l2cap_frame *frame, uint16_t psm) > +{ > + uint8_t hdr; > + uint16_t pid; > + struct l2cap_frame avctp_frame; > + const char *pdu_color; > + > + if (frame->size < 3) { > + print_text(COLOR_ERROR, "frame too short"); > + packet_hexdump(frame->data, frame->size); > + return; > + } > + > + hdr = *((uint8_t *) frame->data); > + > + pid = get_be16(frame->data + 1); > + > + if (frame->in) > + pdu_color = COLOR_MAGENTA; > + else > + pdu_color = COLOR_BLUE; > + > + print_indent(6, pdu_color, "AVCTP", "", COLOR_OFF, > + " %s: %s: Packet_type 0x%02x Transaction label %d " > + "PID 0x%04x", > + psm == 23 ? "Control" : "Browsing", > + hdr & 0x02 ? "Response" : "Command", > + hdr & 0x0c, hdr >> 4, pid); > + > + l2cap_frame_pull(&avctp_frame, frame, 3); > + > + if (pid == 0x110e || pid == 0x110c) > + avrcp_packet(&avctp_frame, hdr, psm); > + else > + packet_hexdump(frame->data + 3, frame->size - 3); > +} > + > static void print_addr(const uint8_t *addr, uint8_t addr_type) > { > const char *str; > @@ -2634,6 +2694,10 @@ static void l2cap_frame(uint16_t index, bool in, uint16_t handle, > case 0x001f: > att_packet(index, in, handle, cid, data, size); > break; > + case 0x0017: > + case 0x001B: > + avctp_packet(&frame, psm); > + break; > default: > packet_hexdump(data, size); > break; Perhaps we should split this into avctp.c to keep l2cap.c just for L2CAP layer, otherwise this file will grow quite big. > -- > 1.9.1 > > -- > 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 -- Luiz Augusto von Dentz -- 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