From e173ce45728226d19c4ce4c54d0b7aa80150f395 Mon Sep 17 00:00:00 2001 From: Luiz Augusto von Dentz Date: Sun, 9 Mar 2014 13:17:42 +0200 Subject: [PATCH] android/avrcp: Fix not handling SetAbsoluteVolume response This follow what is stated in AVRCP specification 1.5 page 83: " When the volume is changed on the TG by this command the Volume Change notification shall not be completed." Therefore the only option is to treat the response and self generate changed notification. --- android/avrcp.c | 33 ++++++++++++++++++++++++++++++++- 1 file changed, 32 insertions(+), 1 deletion(-) diff --git a/android/avrcp.c b/android/avrcp.c index 70266f782..eab519ae1 100644 --- a/android/avrcp.c +++ b/android/avrcp.c @@ -330,6 +330,36 @@ done: HAL_OP_AVRCP_REGISTER_NOTIFICATION, status); } +static gboolean set_volume_rsp(struct avctp *conn, + uint8_t code, uint8_t subunit, + uint8_t *operands, size_t operand_count, + void *user_data) +{ + struct hal_ev_avrcp_volume_changed ev; + uint8_t *params; + + if (code != AVC_CTYPE_ACCEPTED) { + ev.volume = 0; + ev.type = code; + goto done; + } + + if (operands == NULL || operand_count < 7) + return FALSE; + + params = &operands[7]; + + ev.volume = params[0] & 0x7F; + ev.type = code; + +done: + ipc_send_notif(hal_ipc, HAL_SERVICE_ID_AVRCP, + HAL_EV_AVRCP_VOLUME_CHANGED, + sizeof(ev), &ev); + + return FALSE; +} + static void handle_set_volume(const void *buf, uint16_t len) { struct hal_cmd_avrcp_set_volume *cmd = (void *) buf; @@ -350,7 +380,8 @@ static void handle_set_volume(const void *buf, uint16_t len) */ dev = devices->data; - ret = avrcp_set_volume(dev->session, cmd->value & 0x7f, NULL, NULL); + ret = avrcp_set_volume(dev->session, cmd->value & 0x7f, set_volume_rsp, + dev); if (ret < 0) { status = HAL_STATUS_FAILED; goto done; -- 2.47.3