16983e65eSMilanka Ringwald /* 26983e65eSMilanka Ringwald * Copyright (C) 2016 BlueKitchen GmbH 36983e65eSMilanka Ringwald * 46983e65eSMilanka Ringwald * Redistribution and use in source and binary forms, with or without 56983e65eSMilanka Ringwald * modification, are permitted provided that the following conditions 66983e65eSMilanka Ringwald * are met: 76983e65eSMilanka Ringwald * 86983e65eSMilanka Ringwald * 1. Redistributions of source code must retain the above copyright 96983e65eSMilanka Ringwald * notice, this list of conditions and the following disclaimer. 106983e65eSMilanka Ringwald * 2. Redistributions in binary form must reproduce the above copyright 116983e65eSMilanka Ringwald * notice, this list of conditions and the following disclaimer in the 126983e65eSMilanka Ringwald * documentation and/or other materials provided with the distribution. 136983e65eSMilanka Ringwald * 3. Neither the name of the copyright holders nor the names of 146983e65eSMilanka Ringwald * contributors may be used to endorse or promote products derived 156983e65eSMilanka Ringwald * from this software without specific prior written permission. 166983e65eSMilanka Ringwald * 4. Any redistribution, use, or modification is done solely for 176983e65eSMilanka Ringwald * personal benefit and not for any commercial purpose or for 186983e65eSMilanka Ringwald * monetary gain. 196983e65eSMilanka Ringwald * 206983e65eSMilanka Ringwald * THIS SOFTWARE IS PROVIDED BY BLUEKITCHEN GMBH AND CONTRIBUTORS 216983e65eSMilanka Ringwald * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 226983e65eSMilanka Ringwald * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS 232fca4dadSMilanka Ringwald * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL BLUEKITCHEN 242fca4dadSMilanka Ringwald * GMBH OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, 256983e65eSMilanka Ringwald * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, 266983e65eSMilanka Ringwald * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS 276983e65eSMilanka Ringwald * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED 286983e65eSMilanka Ringwald * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, 296983e65eSMilanka Ringwald * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF 306983e65eSMilanka Ringwald * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 316983e65eSMilanka Ringwald * SUCH DAMAGE. 326983e65eSMilanka Ringwald * 336983e65eSMilanka Ringwald * Please inquire about commercial licensing options at 346983e65eSMilanka Ringwald * [email protected] 356983e65eSMilanka Ringwald * 366983e65eSMilanka Ringwald */ 376983e65eSMilanka Ringwald 38fe5a6c4eSMilanka Ringwald /** 39fe5a6c4eSMilanka Ringwald * @title AVRCP Controller 406983e65eSMilanka Ringwald * 416983e65eSMilanka Ringwald */ 426983e65eSMilanka Ringwald 4380e33422SMatthias Ringwald #ifndef AVRCP_CONTROLLER_H 4480e33422SMatthias Ringwald #define AVRCP_CONTROLLER_H 456983e65eSMilanka Ringwald 466983e65eSMilanka Ringwald #include <stdint.h> 476983e65eSMilanka Ringwald #include "btstack_run_loop.h" 486983e65eSMilanka Ringwald #include "btstack_linked_list.h" 493311c2d5SMatthias Ringwald #include "classic/avrcp.h" 506983e65eSMilanka Ringwald 516983e65eSMilanka Ringwald #if defined __cplusplus 526983e65eSMilanka Ringwald extern "C" { 536983e65eSMilanka Ringwald #endif 546983e65eSMilanka Ringwald 556983e65eSMilanka Ringwald /* API_START */ 5611014891SMilanka Ringwald 5711014891SMilanka Ringwald typedef enum { 5811014891SMilanka Ringwald AVRCP_CONTROLLER_SUPPORTED_FEATURE_CATEGORY_PLAYER_OR_RECORDER = 0, 5911014891SMilanka Ringwald AVRCP_CONTROLLER_SUPPORTED_FEATURE_CATEGORY_MONITOR_OR_AMPLIFIER, 6011014891SMilanka Ringwald AVRCP_CONTROLLER_SUPPORTED_FEATURE_CATEGORY_TUNER, 6111014891SMilanka Ringwald AVRCP_CONTROLLER_SUPPORTED_FEATURE_CATEGORY_MENU, 6211014891SMilanka Ringwald AVRCP_CONTROLLER_SUPPORTED_FEATURE_RESERVED_4, 6311014891SMilanka Ringwald AVRCP_CONTROLLER_SUPPORTED_FEATURE_RESERVED_5, 64c4a41e65SMilanka Ringwald AVRCP_CONTROLLER_SUPPORTED_FEATURE_BROWSING, 65c4a41e65SMilanka Ringwald AVRCP_CONTROLLER_SUPPORTED_FEATURE_COVER_ART_GET_IMAGE_PROPERTIES, 66c4a41e65SMilanka Ringwald AVRCP_CONTROLLER_SUPPORTED_FEATURE_COVER_ART_GET_IMAGE, 67c4a41e65SMilanka Ringwald AVRCP_CONTROLLER_SUPPORTED_FEATURE_COVER_ART_GET_LINKED_THUMBNAIL 6811014891SMilanka Ringwald } avrcp_controller_supported_feature_t; 6911014891SMilanka Ringwald 706983e65eSMilanka Ringwald /** 71f65a5459SMilanka Ringwald * @brief AVRCP Controller service record. 726983e65eSMilanka Ringwald * @param service 736983e65eSMilanka Ringwald * @param service_record_handle 74e2f25417SMilanka Ringwald * @param supported_features 16-bit bitmap, see AVRCP_FEATURE_MASK_* in avrcp.h 75*141dff40SMatthias Ringwald * @param service_name or NULL for default value. Provide "" (empty string) to skip attribute 76*141dff40SMatthias Ringwald * @param service_provider_name or NULL for default value. Provide "" (empty string) to skip attribute 776983e65eSMilanka Ringwald */ 784f0111ebSMilanka Ringwald void avrcp_controller_create_sdp_record(uint8_t * service, uint32_t service_record_handle, uint16_t supported_features, const char * service_name, const char * service_provider_name); 796983e65eSMilanka Ringwald 806983e65eSMilanka Ringwald /** 813734adacSMilanka Ringwald * @brief Set up AVRCP Controller service. 826983e65eSMilanka Ringwald */ 836983e65eSMilanka Ringwald void avrcp_controller_init(void); 846983e65eSMilanka Ringwald 856983e65eSMilanka Ringwald /** 86e30788a3SMilanka Ringwald * @brief Register callback for the AVRCP Controller client. 876983e65eSMilanka Ringwald * @param callback 886983e65eSMilanka Ringwald */ 896983e65eSMilanka Ringwald void avrcp_controller_register_packet_handler(btstack_packet_handler_t callback); 906983e65eSMilanka Ringwald 916983e65eSMilanka Ringwald /** 928b2b4034SMilanka Ringwald * @brief Set max num fragments in whuch message can be transmited. 938b2b4034SMilanka Ringwald * @param avrcp_cid 948b2b4034SMilanka Ringwald * @param max_num_fragments 956b65794dSMilanka Ringwald * @return status 968b2b4034SMilanka Ringwald */ 978b2b4034SMilanka Ringwald uint8_t avrcp_controller_set_max_num_fragments(uint16_t avrcp_cid, uint8_t max_num_fragments); 988b2b4034SMilanka Ringwald 998b2b4034SMilanka Ringwald 1008b2b4034SMilanka Ringwald /** 1016983e65eSMilanka Ringwald * @brief Unit info. 1026983e65eSMilanka Ringwald * @param avrcp_cid 1036b65794dSMilanka Ringwald * @return status 1046983e65eSMilanka Ringwald */ 1056983e65eSMilanka Ringwald uint8_t avrcp_controller_unit_info(uint16_t avrcp_cid); 1066983e65eSMilanka Ringwald 1076983e65eSMilanka Ringwald /** 108ad75da14SMilanka Ringwald * @brief Subunit info. 109ad75da14SMilanka Ringwald * @param avrcp_cid 1106b65794dSMilanka Ringwald * @return status 111ad75da14SMilanka Ringwald */ 112ad75da14SMilanka Ringwald uint8_t avrcp_controller_subunit_info(uint16_t avrcp_cid); 113ad75da14SMilanka Ringwald 114ad75da14SMilanka Ringwald /** 1156983e65eSMilanka Ringwald * @brief Get capabilities. 1166983e65eSMilanka Ringwald * @param avrcp_cid 1176b65794dSMilanka Ringwald * @return status 1186983e65eSMilanka Ringwald */ 1196983e65eSMilanka Ringwald uint8_t avrcp_controller_get_supported_company_ids(uint16_t avrcp_cid); 1206983e65eSMilanka Ringwald 1216983e65eSMilanka Ringwald /** 1226983e65eSMilanka Ringwald * @brief Get supported Events. 1236983e65eSMilanka Ringwald * @param avrcp_cid 1246b65794dSMilanka Ringwald * @return status 1256983e65eSMilanka Ringwald */ 1266983e65eSMilanka Ringwald uint8_t avrcp_controller_get_supported_events(uint16_t avrcp_cid); 1276983e65eSMilanka Ringwald 1288c79e168SMilanka Ringwald 12937a7ced0SMatthias Ringwald /** 13037a7ced0SMatthias Ringwald * @brief Start continuous cmd (play, pause, volume up, ...). Event AVRCP_SUBEVENT_OPERATION_COMPLETE returns operation id and status. 13137a7ced0SMatthias Ringwald * @param avrcp_cid 1326b65794dSMilanka Ringwald * @return status 13337a7ced0SMatthias Ringwald */ 13437a7ced0SMatthias Ringwald uint8_t avrcp_controller_start_press_and_hold_cmd(uint16_t avrcp_cid, avrcp_operation_id_t operation_id); 1358c79e168SMilanka Ringwald 1368c79e168SMilanka Ringwald /** 1378c79e168SMilanka Ringwald * @brief Stops continuous cmd (play, pause, volume up, ...). Event AVRCP_SUBEVENT_OPERATION_COMPLETE returns operation id and status. 1388c79e168SMilanka Ringwald * @param avrcp_cid 1396b65794dSMilanka Ringwald * @return status 1408c79e168SMilanka Ringwald */ 1418c79e168SMilanka Ringwald uint8_t avrcp_controller_release_press_and_hold_cmd(uint16_t avrcp_cid); 1428c79e168SMilanka Ringwald 1436983e65eSMilanka Ringwald /** 1446983e65eSMilanka Ringwald * @brief Play. Event AVRCP_SUBEVENT_OPERATION_COMPLETE returns operation id and status. 1456983e65eSMilanka Ringwald * @param avrcp_cid 1466b65794dSMilanka Ringwald * @return status 1476983e65eSMilanka Ringwald */ 1486983e65eSMilanka Ringwald uint8_t avrcp_controller_play(uint16_t avrcp_cid); 1498c79e168SMilanka Ringwald uint8_t avrcp_controller_press_and_hold_play(uint16_t avrcp_cid); 1506983e65eSMilanka Ringwald 1516983e65eSMilanka Ringwald /** 1526983e65eSMilanka Ringwald * @brief Stop. Event AVRCP_SUBEVENT_OPERATION_COMPLETE returns operation id and status. 1536983e65eSMilanka Ringwald * @param avrcp_cid 1546b65794dSMilanka Ringwald * @return status 1556983e65eSMilanka Ringwald */ 1566983e65eSMilanka Ringwald uint8_t avrcp_controller_stop(uint16_t avrcp_cid); 1578c79e168SMilanka Ringwald uint8_t avrcp_controller_press_and_hold_stop(uint16_t avrcp_cid); 1586983e65eSMilanka Ringwald 1596983e65eSMilanka Ringwald /** 1606983e65eSMilanka Ringwald * @brief Pause. Event AVRCP_SUBEVENT_OPERATION_COMPLETE returns operation id and status. 1616983e65eSMilanka Ringwald * @param avrcp_cid 1626b65794dSMilanka Ringwald * @return status 1636983e65eSMilanka Ringwald */ 1646983e65eSMilanka Ringwald uint8_t avrcp_controller_pause(uint16_t avrcp_cid); 1658c79e168SMilanka Ringwald uint8_t avrcp_controller_press_and_hold_pause(uint16_t avrcp_cid); 1666983e65eSMilanka Ringwald 1676983e65eSMilanka Ringwald /** 1686983e65eSMilanka Ringwald * @brief Single step - fast forward. Event AVRCP_SUBEVENT_OPERATION_COMPLETE returns operation id and status. 1696983e65eSMilanka Ringwald * @param avrcp_cid 1706b65794dSMilanka Ringwald * @return status 1716983e65eSMilanka Ringwald */ 1726983e65eSMilanka Ringwald uint8_t avrcp_controller_fast_forward(uint16_t avrcp_cid); 1738c79e168SMilanka Ringwald uint8_t avrcp_controller_press_and_hold_fast_forward(uint16_t avrcp_cid); 1746983e65eSMilanka Ringwald 1756983e65eSMilanka Ringwald 1766983e65eSMilanka Ringwald /** 1776983e65eSMilanka Ringwald * @brief Single step rewind. Event AVRCP_SUBEVENT_OPERATION_COMPLETE returns operation id and status. 1786983e65eSMilanka Ringwald * @param avrcp_cid 1796b65794dSMilanka Ringwald * @return status 1806983e65eSMilanka Ringwald */ 1816983e65eSMilanka Ringwald uint8_t avrcp_controller_rewind(uint16_t avrcp_cid); 1828c79e168SMilanka Ringwald uint8_t avrcp_controller_press_and_hold_rewind(uint16_t avrcp_cid); 1836983e65eSMilanka Ringwald 1846983e65eSMilanka Ringwald /** 1856983e65eSMilanka Ringwald * @brief Forward. Event AVRCP_SUBEVENT_OPERATION_COMPLETE returns operation id and status. 1866983e65eSMilanka Ringwald * @param avrcp_cid 1876b65794dSMilanka Ringwald * @return status 1886983e65eSMilanka Ringwald */ 1896983e65eSMilanka Ringwald uint8_t avrcp_controller_forward(uint16_t avrcp_cid); 1908c79e168SMilanka Ringwald uint8_t avrcp_controller_press_and_hold_forward(uint16_t avrcp_cid); 1916983e65eSMilanka Ringwald 1926983e65eSMilanka Ringwald /** 1936983e65eSMilanka Ringwald * @brief Backward. Event AVRCP_SUBEVENT_OPERATION_COMPLETE returns operation id and status. 1946983e65eSMilanka Ringwald * @param avrcp_cid 1956b65794dSMilanka Ringwald * @return status 1966983e65eSMilanka Ringwald */ 1976983e65eSMilanka Ringwald uint8_t avrcp_controller_backward(uint16_t avrcp_cid); 1988c79e168SMilanka Ringwald uint8_t avrcp_controller_press_and_hold_backward(uint16_t avrcp_cid); 1996983e65eSMilanka Ringwald 2008c79e168SMilanka Ringwald /** 2018c79e168SMilanka Ringwald * @brief Turns the volume to high. Event AVRCP_SUBEVENT_OPERATION_COMPLETE returns operation id and status. 2028c79e168SMilanka Ringwald * @param avrcp_cid 2036b65794dSMilanka Ringwald * @return status 2048c79e168SMilanka Ringwald */ 2058c79e168SMilanka Ringwald uint8_t avrcp_controller_volume_up(uint16_t avrcp_cid); 2068c79e168SMilanka Ringwald uint8_t avrcp_controller_press_and_hold_volume_up(uint16_t avrcp_cid); 2078c79e168SMilanka Ringwald /** 2088c79e168SMilanka Ringwald * @brief Turns the volume to low. Event AVRCP_SUBEVENT_OPERATION_COMPLETE returns operation id and status. 2098c79e168SMilanka Ringwald * @param avrcp_cid 2106b65794dSMilanka Ringwald * @return status 2118c79e168SMilanka Ringwald */ 2128c79e168SMilanka Ringwald uint8_t avrcp_controller_volume_down(uint16_t avrcp_cid); 2138c79e168SMilanka Ringwald uint8_t avrcp_controller_press_and_hold_volume_down(uint16_t avrcp_cid); 2148c79e168SMilanka Ringwald 2158c79e168SMilanka Ringwald /** 2168c79e168SMilanka Ringwald * @brief Puts the sound out. Event AVRCP_SUBEVENT_OPERATION_COMPLETE returns operation id and status. 2178c79e168SMilanka Ringwald * @param avrcp_cid 2186b65794dSMilanka Ringwald * @return status 2198c79e168SMilanka Ringwald */ 2208c79e168SMilanka Ringwald uint8_t avrcp_controller_mute(uint16_t avrcp_cid); 2218c79e168SMilanka Ringwald uint8_t avrcp_controller_press_and_hold_mute(uint16_t avrcp_cid); 2226983e65eSMilanka Ringwald 2236983e65eSMilanka Ringwald /** 2246983e65eSMilanka Ringwald * @brief Get play status. Returns event of type AVRCP_SUBEVENT_PLAY_STATUS (length, position, play_status). 2256983e65eSMilanka Ringwald * If TG does not support SongLength And SongPosition on TG, then TG shall return 0xFFFFFFFF. 2266983e65eSMilanka Ringwald * @param avrcp_cid 2276b65794dSMilanka Ringwald * @return status 2286983e65eSMilanka Ringwald */ 2296983e65eSMilanka Ringwald uint8_t avrcp_controller_get_play_status(uint16_t avrcp_cid); 2306983e65eSMilanka Ringwald 2316983e65eSMilanka Ringwald /** 232b2e02b8dSMilanka Ringwald * @brief Enable notification. Response via AVRCP_SUBEVENT_NOTIFICATION_STATE. 2336983e65eSMilanka Ringwald * @param avrcp_cid 2346983e65eSMilanka Ringwald * @param event_id 2356b65794dSMilanka Ringwald * @return status 2366983e65eSMilanka Ringwald */ 2376983e65eSMilanka Ringwald uint8_t avrcp_controller_enable_notification(uint16_t avrcp_cid, avrcp_notification_event_id_t event_id); 2386983e65eSMilanka Ringwald 2396983e65eSMilanka Ringwald /** 240b2e02b8dSMilanka Ringwald * @brief Disable notification. Response via AVRCP_SUBEVENT_NOTIFICATION_STATE. 2416983e65eSMilanka Ringwald * @param avrcp_cid 2426983e65eSMilanka Ringwald * @param event_id 2436b65794dSMilanka Ringwald * @return status 2446983e65eSMilanka Ringwald */ 2456983e65eSMilanka Ringwald uint8_t avrcp_controller_disable_notification(uint16_t avrcp_cid, avrcp_notification_event_id_t event_id); 2466983e65eSMilanka Ringwald 2476983e65eSMilanka Ringwald /** 24861920526SMilanka Ringwald * @brief Get info on now playing media using subset of attribute IDs 24961920526SMilanka Ringwald * @param avrcp_cid 2506b65794dSMilanka Ringwald * @return status 25161920526SMilanka Ringwald */ 25261920526SMilanka Ringwald uint8_t avrcp_controller_get_element_attributes(uint16_t avrcp_cid, uint8_t num_attributes, avrcp_media_attribute_id_t * attributes); 25361920526SMilanka Ringwald 25461920526SMilanka Ringwald /** 25561920526SMilanka Ringwald * @brief Get info on now playing media using all IDs. 2566983e65eSMilanka Ringwald * @param avrcp_cid 2576b65794dSMilanka Ringwald * @return status 2586983e65eSMilanka Ringwald */ 2596983e65eSMilanka Ringwald uint8_t avrcp_controller_get_now_playing_info(uint16_t avrcp_cid); 2606983e65eSMilanka Ringwald 2616983e65eSMilanka Ringwald /** 26266e22952SMilanka Ringwald * @brief Get info on now playing media using specific media attribute ID. 26366e22952SMilanka Ringwald * @param media_attribute_id 26466e22952SMilanka Ringwald * @param avrcp_cid 26566e22952SMilanka Ringwald * @return status 26666e22952SMilanka Ringwald */ 26766e22952SMilanka Ringwald uint8_t avrcp_controller_get_now_playing_info_for_media_attribute_id(uint16_t avrcp_cid, avrcp_media_attribute_id_t media_attribute_id); 26866e22952SMilanka Ringwald 26966e22952SMilanka Ringwald /** 2706983e65eSMilanka Ringwald * @brief Set absolute volume 0-127 (corresponds to 0-100%). Response via AVRCP_SUBEVENT_SET_ABSOLUTE_VOLUME_RESPONSE 2716983e65eSMilanka Ringwald * @param avrcp_cid 2726b65794dSMilanka Ringwald * @return status 2736983e65eSMilanka Ringwald */ 2746983e65eSMilanka Ringwald uint8_t avrcp_controller_set_absolute_volume(uint16_t avrcp_cid, uint8_t volume); 2756983e65eSMilanka Ringwald 2766983e65eSMilanka Ringwald 2776983e65eSMilanka Ringwald /** 2786983e65eSMilanka Ringwald * @brief Skip to next playing media. Event AVRCP_SUBEVENT_OPERATION_COMPLETE returns operation id and status. 2796983e65eSMilanka Ringwald * @param avrcp_cid 2806b65794dSMilanka Ringwald * @return status 2816983e65eSMilanka Ringwald */ 2826983e65eSMilanka Ringwald uint8_t avrcp_controller_skip(uint16_t avrcp_cid); 2836983e65eSMilanka Ringwald 2846983e65eSMilanka Ringwald /** 2856983e65eSMilanka Ringwald * @brief Query repeat and shuffle mode. Response via AVRCP_SUBEVENT_SHUFFLE_AND_REPEAT_MODE. 2866983e65eSMilanka Ringwald * @param avrcp_cid 2876b65794dSMilanka Ringwald * @return status 2886983e65eSMilanka Ringwald */ 2896983e65eSMilanka Ringwald uint8_t avrcp_controller_query_shuffle_and_repeat_modes(uint16_t avrcp_cid); 2906983e65eSMilanka Ringwald 2916983e65eSMilanka Ringwald /** 2926983e65eSMilanka Ringwald * @brief Set shuffle mode. Event AVRCP_SUBEVENT_OPERATION_COMPLETE returns operation id and status. 2936983e65eSMilanka Ringwald * @param avrcp_cid 2946b65794dSMilanka Ringwald * @return status 2956983e65eSMilanka Ringwald */ 2966983e65eSMilanka Ringwald uint8_t avrcp_controller_set_shuffle_mode(uint16_t avrcp_cid, avrcp_shuffle_mode_t mode); 2976983e65eSMilanka Ringwald 2986983e65eSMilanka Ringwald /** 2996983e65eSMilanka Ringwald * @brief Set repeat mode. Event AVRCP_SUBEVENT_OPERATION_COMPLETE returns operation id and status. 3006983e65eSMilanka Ringwald * @param avrcp_cid 3016b65794dSMilanka Ringwald * @return status 3026983e65eSMilanka Ringwald */ 3036983e65eSMilanka Ringwald uint8_t avrcp_controller_set_repeat_mode(uint16_t avrcp_cid, avrcp_repeat_mode_t mode); 304be65baf4SMilanka Ringwald 305be65baf4SMilanka Ringwald /** 306be65baf4SMilanka Ringwald * @brief The PlayItem command starts playing an item indicated by the UID. It is routed to the Addressed Player. 307be65baf4SMilanka Ringwald * @param avrcp_cid 308be65baf4SMilanka Ringwald * @param uid 309be65baf4SMilanka Ringwald * @param uid_counter 3104614c049SMilanka Ringwald * @param scope 311be65baf4SMilanka Ringwald **/ 3124614c049SMilanka Ringwald uint8_t avrcp_controller_play_item_for_scope(uint16_t avrcp_cid, uint8_t * uid, uint16_t uid_counter, avrcp_browsing_scope_t scope); 313864d08b0SMilanka Ringwald 314864d08b0SMilanka Ringwald /** 3154931e24aSMilanka Ringwald * @brief Adds an item indicated by the UID to the Now Playing queue. 3164931e24aSMilanka Ringwald * @param avrcp_cid 3174931e24aSMilanka Ringwald * @param uid 3184931e24aSMilanka Ringwald * @param uid_counter 3194931e24aSMilanka Ringwald * @param scope 3204931e24aSMilanka Ringwald **/ 3214931e24aSMilanka Ringwald uint8_t avrcp_controller_add_item_from_scope_to_now_playing_list(uint16_t avrcp_cid, uint8_t * uid, uint16_t uid_counter, avrcp_browsing_scope_t scope); 3224931e24aSMilanka Ringwald 3234931e24aSMilanka Ringwald /** 324864d08b0SMilanka Ringwald * @brief Set addressed player. 325864d08b0SMilanka Ringwald * @param avrcp_cid 326864d08b0SMilanka Ringwald * @param addressed_player_id 327864d08b0SMilanka Ringwald */ 328864d08b0SMilanka Ringwald uint8_t avrcp_controller_set_addressed_player(uint16_t avrcp_cid, uint16_t addressed_player_id); 329864d08b0SMilanka Ringwald 330c4b5c3d5SMatthias Ringwald /** 331c4b5c3d5SMatthias Ringwald * @brief Send custom command 332c4b5c3d5SMatthias Ringwald * @param avrcp_cid 333c4b5c3d5SMatthias Ringwald * @param command_type 334c4b5c3d5SMatthias Ringwald * @param subunit_type 3355d3671d9SMilanka Ringwald * @param subunit_id 3365d3671d9SMilanka Ringwald * @param pdu_id 3375d3671d9SMilanka Ringwald * @param company_id 3385d3671d9SMilanka Ringwald * @param data 3395d3671d9SMilanka Ringwald * @param data_len 340c4b5c3d5SMatthias Ringwald */ 3415d3671d9SMilanka Ringwald uint8_t avrcp_controller_send_custom_command(uint16_t avrcp_cid, 3425d3671d9SMilanka Ringwald avrcp_command_type_t command_type, 3435d3671d9SMilanka Ringwald avrcp_subunit_type_t subunit_type, avrcp_subunit_id_t subunit_id, 3445d3671d9SMilanka Ringwald avrcp_pdu_id_t pdu_id, uint32_t company_id, 3455d3671d9SMilanka Ringwald const uint8_t * data, uint16_t data_len); 346c4b5c3d5SMatthias Ringwald 347680af5dcSMatthias Ringwald /** 348680af5dcSMatthias Ringwald * @brief De-Init AVRCP Controller 349680af5dcSMatthias Ringwald */ 350680af5dcSMatthias Ringwald void avrcp_controller_deinit(void); 351680af5dcSMatthias Ringwald 352680af5dcSMatthias Ringwald /* API_END */ 353680af5dcSMatthias Ringwald 35439b456a8SMatthias Ringwald // send press command if connection is open. use with great care and only if there's no other option 35539b456a8SMatthias Ringwald uint8_t avrcp_controller_force_send_press_cmd(uint16_t avrcp_cid, avrcp_operation_id_t operation_id); 35639b456a8SMatthias Ringwald 3574adb0765SMatthias Ringwald // Used by AVRCP controller and AVRCP browsing controller 3584adb0765SMatthias Ringwald extern avrcp_context_t avrcp_controller_context; 359247956eaSMilanka Ringwald 3606983e65eSMilanka Ringwald #if defined __cplusplus 3616983e65eSMilanka Ringwald } 3626983e65eSMilanka Ringwald #endif 3636983e65eSMilanka Ringwald 36480e33422SMatthias Ringwald #endif // AVRCP_CONTROLLER_H 365