From b8cb072358e4c839b0a6062248103a54a22c460f Mon Sep 17 00:00:00 2001 From: Luiz Augusto von Dentz Date: Mon, 1 Aug 2011 11:42:15 +0300 Subject: [PATCH] hcidump: Add parsing for AVRCP InformBatteryStatusOfCT PDU --- tools/parser/avrcp.c | 35 +++++++++++++++++++++++++++++++++++ 1 file changed, 35 insertions(+) diff --git a/tools/parser/avrcp.c b/tools/parser/avrcp.c index 53d8be247..e4d227f09 100644 --- a/tools/parser/avrcp.c +++ b/tools/parser/avrcp.c @@ -847,6 +847,38 @@ static void avrcp_displayable_charset(int level, struct frame *frm, } } +static const char *status2str(uint8_t status) +{ + switch (status) { + case 0x0: + return "NORMAL"; + case 0x1: + return "WARNING"; + case 0x2: + return "CRITICAL"; + case 0x3: + return "EXTERNAL"; + case 0x4: + return "FULL_CHARGE"; + default: + return "Reserved"; + } +} + +static void avrcp_ct_battery_status_dump(int level, struct frame *frm, + uint8_t ctype, uint16_t len) +{ + uint8_t status; + + if (ctype > AVC_CTYPE_GENERAL_INQUIRY) + return; + + p_indent(level, frm); + + status = get_u8(frm); + printf("BatteryStatus: 0x%02x (%s)\n", status, status2str(status)); +} + static void avrcp_pdu_dump(int level, struct frame *frm, uint8_t ctype) { uint8_t pduid, pt; @@ -899,6 +931,9 @@ static void avrcp_pdu_dump(int level, struct frame *frm, uint8_t ctype) case AVRCP_DISPLAYABLE_CHARSET: avrcp_displayable_charset(level + 1, frm, ctype, len); break; + case AVRCP_CT_BATTERY_STATUS: + avrcp_ct_battery_status_dump(level + 1, frm, ctype, len); + break; default: raw_dump(level, frm); } -- 2.47.3