From: Andrei Emeltchenko <andrei.emeltchenko@xxxxxxxxx> Test verifies that the get current player application setting value response issued from the Target. --- unit/test-avrcp.c | 38 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 38 insertions(+) diff --git a/unit/test-avrcp.c b/unit/test-avrcp.c index f297efd..0206e19 100644 --- a/unit/test-avrcp.c +++ b/unit/test-avrcp.c @@ -387,6 +387,28 @@ static uint8_t avrcp_handle_get_player_value_text(struct avrcp *session, return AVC_CTYPE_STABLE; } +static uint8_t avrcp_handle_get_current_player_value(struct avrcp *session, + uint8_t transaction, uint16_t *params_len, + uint8_t *params, void *user_data) +{ + uint8_t *attributes; + int i; + + DBG("num attributes %d", params[0]); + + attributes = g_memdup(¶ms[1], params[0]); + + for (i = 0; i < params[0]; i++) { + params[i * 2 + 1] = attributes[i]; + params[i * 2 + 2] = 0; /* value */ + } + + params[0] = i; + *params_len = params[0] * 2 + 1; + + return AVC_CTYPE_STABLE; +} + static const struct avrcp_control_handler control_handlers[] = { { AVRCP_GET_CAPABILITIES, AVC_CTYPE_STATUS, avrcp_handle_get_capabilities }, @@ -396,6 +418,8 @@ static const struct avrcp_control_handler control_handlers[] = { avrcp_handle_get_player_attr_text }, { AVRCP_LIST_PLAYER_VALUES, AVC_CTYPE_STATUS, avrcp_handle_list_player_values }, + { AVRCP_GET_CURRENT_PLAYER_VALUE, AVC_CTYPE_STATUS, + avrcp_handle_get_current_player_value }, { AVRCP_GET_PLAYER_VALUE_TEXT, AVC_CTYPE_STATUS, avrcp_handle_get_player_value_text }, { }, @@ -590,5 +614,19 @@ int main(int argc, char *argv[]) AVRCP_ATTRIBUTE_EQUALIZER, AVRCP_ATTRIBUTE_REPEAT_MODE)); + define_test("/TP/PAS/BV-10-C", test_server, + raw_pdu(0x00, 0x11, 0x0e, 0x01, 0x48, 0x00, + 0x00, 0x19, 0x58, + AVRCP_GET_CURRENT_PLAYER_VALUE, + 0x00, 0x00, 0x03, 0x02, + AVRCP_ATTRIBUTE_EQUALIZER, + AVRCP_ATTRIBUTE_REPEAT_MODE), + raw_pdu(0x02, 0x11, 0x0e, 0x0c, 0x48, 0x00, + 0x00, 0x19, 0x58, + AVRCP_GET_CURRENT_PLAYER_VALUE, + 0x00, 0x00, 0x05, 0x02, + AVRCP_ATTRIBUTE_EQUALIZER, 0x00, + AVRCP_ATTRIBUTE_REPEAT_MODE, 0x00)); + return g_test_run(); } -- 1.8.3.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