xref: /btstack/src/classic/avrcp_target.h (revision 3734adac224a0f087ebb71b5a90c5dd558ba9e25)
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
236983e65eSMilanka Ringwald  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL MATTHIAS
246983e65eSMilanka Ringwald  * RINGWALD 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 
386983e65eSMilanka Ringwald /*
39f65a5459SMilanka Ringwald  * avrcp_target.h
406983e65eSMilanka Ringwald  *
416983e65eSMilanka Ringwald  * Audio/Video Remote Control Profile
426983e65eSMilanka Ringwald  *
436983e65eSMilanka Ringwald  */
446983e65eSMilanka Ringwald 
4580e33422SMatthias Ringwald #ifndef AVRCP_TARGET_H
4680e33422SMatthias Ringwald #define AVRCP_TARGET_H
476983e65eSMilanka Ringwald 
486983e65eSMilanka Ringwald #include <stdint.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 */
566983e65eSMilanka Ringwald 
5711014891SMilanka Ringwald typedef enum {
5811014891SMilanka Ringwald     AVRCP_TARGET_SUPPORTED_FEATURE_CATEGORY_PLAYER_OR_RECORDER = 0,
5911014891SMilanka Ringwald     AVRCP_TARGET_SUPPORTED_FEATURE_CATEGORY_MONITOR_OR_AMPLIFIER,
6011014891SMilanka Ringwald     AVRCP_TARGET_SUPPORTED_FEATURE_CATEGORY_TUNER,
6111014891SMilanka Ringwald     AVRCP_TARGET_SUPPORTED_FEATURE_CATEGORY_MENU,
6211014891SMilanka Ringwald     AVRCP_TARGET_SUPPORTED_FEATURE_PLAYER_APPLICATION_SETTINGS, // AVRCP_TARGET_SUPPORTED_FEATURE_CATEGORY_PLAYER_OR_RECORDER must be 1 for this feature to be set
6311014891SMilanka Ringwald     AVRCP_TARGET_SUPPORTED_FEATURE_RESERVED_GROUP_NAVIGATION,   // AVRCP_TARGET_SUPPORTED_FEATURE_CATEGORY_PLAYER_OR_RECORDER must be 1 for this feature to be set
6411014891SMilanka Ringwald     AVRCP_TARGET_SUPPORTED_FEATURE_BROWSING,
6511014891SMilanka Ringwald     AVRCP_TARGET_SUPPORTED_FEATURE_MULTIPLE_MEDIA_PLAYE_APPLICATIONS
6611014891SMilanka Ringwald } avrcp_target_supported_feature_t;
676983e65eSMilanka Ringwald 
686983e65eSMilanka Ringwald /**
69f65a5459SMilanka Ringwald  * @brief AVRCP Target service record.
706983e65eSMilanka Ringwald  * @param service
716983e65eSMilanka Ringwald  * @param service_record_handle
724f0111ebSMilanka Ringwald  * @param supported_features 16-bit bitmap, see avrcp_target_supported_feature_t
736983e65eSMilanka Ringwald  * @param service_name
746983e65eSMilanka Ringwald  * @param service_provider_name
756983e65eSMilanka Ringwald  */
764f0111ebSMilanka Ringwald void    avrcp_target_create_sdp_record(uint8_t * service, uint32_t service_record_handle, uint16_t supported_features, const char * service_name, const char * service_provider_name);
776983e65eSMilanka Ringwald 
78*3734adacSMilanka Ringwald /**
79*3734adacSMilanka Ringwald  * @brief Set up AVRCP Target service.
80*3734adacSMilanka Ringwald  */
8101dc6e35SMilanka Ringwald void    avrcp_target_init(void);
8201dc6e35SMilanka Ringwald 
83*3734adacSMilanka Ringwald /**
84*3734adacSMilanka Ringwald  * @brief Register callback for the AVRCP Target client.
85*3734adacSMilanka Ringwald  * @param callback
86*3734adacSMilanka Ringwald  */
8701dc6e35SMilanka Ringwald void    avrcp_target_register_packet_handler(btstack_packet_handler_t callback);
8801dc6e35SMilanka Ringwald 
89*3734adacSMilanka Ringwald /**
90*3734adacSMilanka Ringwald  * @brief Send a list of Company IDs supported by target.
91*3734adacSMilanka Ringwald  * @note  The avrcp_target_packet_handler will receive AVRCP_SUBEVENT_COMPANY_IDS_QUERY event. Use this function to respond.
92*3734adacSMilanka Ringwald  * @param avrcp_cid
93*3734adacSMilanka Ringwald  * @param num_company_ids
94*3734adacSMilanka Ringwald  * @param company_ids
95*3734adacSMilanka Ringwald  * @param company_ids_size
96*3734adacSMilanka Ringwald  * @returns status ERROR_CODE_UNKNOWN_CONNECTION_IDENTIFIER if connection is not found, otherwise ERROR_CODE_SUCCESS
97*3734adacSMilanka Ringwald  */
98*3734adacSMilanka Ringwald uint8_t avrcp_target_supported_companies(uint16_t avrcp_cid, uint8_t num_company_ids, uint8_t * company_ids, uint8_t company_ids_size);
9901dc6e35SMilanka Ringwald 
100*3734adacSMilanka Ringwald /**
101*3734adacSMilanka Ringwald  * @brief Send a list of Events supported by target.
102*3734adacSMilanka Ringwald  * @note  The avrcp_target_packet_handler will receive AVRCP_SUBEVENT_EVENT_IDS_QUERY event. Use this function to respond.
103*3734adacSMilanka Ringwald  * @param avrcp_cid
104*3734adacSMilanka Ringwald  * @param num_event_ids
105*3734adacSMilanka Ringwald  * @param event_ids
106*3734adacSMilanka Ringwald  * @param event_ids_size
107*3734adacSMilanka Ringwald  * @returns status ERROR_CODE_UNKNOWN_CONNECTION_IDENTIFIER if connection is not found, otherwise ERROR_CODE_SUCCESS
108*3734adacSMilanka Ringwald  */
109*3734adacSMilanka Ringwald uint8_t avrcp_target_supported_events(uint16_t avrcp_cid, uint8_t num_event_ids, uint8_t * event_ids, uint8_t event_ids_size);
110*3734adacSMilanka Ringwald 
111*3734adacSMilanka Ringwald /**
112*3734adacSMilanka Ringwald  * @brief Send a play status.
113*3734adacSMilanka Ringwald  * @note  The avrcp_target_packet_handler will receive AVRCP_SUBEVENT_PLAY_STATUS_QUERY event. Use this function to respond.
114*3734adacSMilanka Ringwald  * @param avrcp_cid
115*3734adacSMilanka Ringwald  * @param song_length_ms
116*3734adacSMilanka Ringwald  * @param song_position_ms
117*3734adacSMilanka Ringwald  * @returns status ERROR_CODE_UNKNOWN_CONNECTION_IDENTIFIER if connection is not found, otherwise ERROR_CODE_SUCCESS
118*3734adacSMilanka Ringwald  */
119d1207cd8SMilanka Ringwald uint8_t avrcp_target_play_status(uint16_t avrcp_cid, uint32_t song_length_ms, uint32_t song_position_ms, avrcp_playback_status_t status);
120c045af99SMilanka Ringwald 
121*3734adacSMilanka Ringwald 
122d1207cd8SMilanka Ringwald void avrcp_target_set_now_playing_info(uint16_t avrcp_cid, const avrcp_track_t * current_track, uint16_t total_tracks);
123d1207cd8SMilanka Ringwald uint8_t avrcp_target_set_playback_status(uint16_t avrcp_cid, avrcp_playback_status_t playback_status);
124d1207cd8SMilanka Ringwald void avrcp_target_set_unit_info(uint16_t avrcp_cid, avrcp_subunit_type_t unit_type, uint32_t company_id);
125d1207cd8SMilanka Ringwald void avrcp_target_set_subunit_info(uint16_t avrcp_cid, avrcp_subunit_type_t subunit_type, const uint8_t * subunit_info_data, uint16_t subunit_info_data_size);
126d1207cd8SMilanka Ringwald 
127d1207cd8SMilanka Ringwald uint8_t avrcp_target_playing_content_changed(uint16_t avrcp_cid);
1286568eb54SMilanka Ringwald uint8_t avrcp_target_addressed_player_changed(uint16_t avrcp_cid, uint16_t player_id, uint16_t uid_counter);
1296568eb54SMilanka Ringwald 
130d1207cd8SMilanka Ringwald uint8_t avrcp_target_battery_status_changed(uint16_t avrcp_cid, avrcp_battery_status_t battery_status);
131d1207cd8SMilanka Ringwald uint8_t avrcp_target_volume_changed(uint16_t avrcp_cid, uint8_t volume_percentage);
13212b7c8ecSMilanka Ringwald uint8_t avrcp_target_track_changed(uint16_t avrcp_cid, uint8_t * trackID);
13312b7c8ecSMilanka Ringwald 
134831d3fd5SMilanka Ringwald uint8_t avrcp_target_operation_rejected(uint16_t avrcp_cid, avrcp_operation_id_t opid, uint8_t operands_length, uint8_t operand);
135831d3fd5SMilanka Ringwald uint8_t avrcp_target_operation_accepted(uint16_t avrcp_cid, avrcp_operation_id_t opid, uint8_t operands_length, uint8_t operand);
136831d3fd5SMilanka Ringwald uint8_t avrcp_target_operation_not_implemented(uint16_t avrcp_cid, avrcp_operation_id_t opid, uint8_t operands_length, uint8_t operand);
137831d3fd5SMilanka Ringwald 
1386983e65eSMilanka Ringwald /* API_END */
139654724deSMilanka Ringwald 
140654724deSMilanka Ringwald  // Used by AVRCP target and AVRCP browsing target
141654724deSMilanka Ringwald extern avrcp_context_t avrcp_target_context;
142654724deSMilanka Ringwald 
1436983e65eSMilanka Ringwald #if defined __cplusplus
1446983e65eSMilanka Ringwald }
1456983e65eSMilanka Ringwald #endif
1466983e65eSMilanka Ringwald 
14780e33422SMatthias Ringwald #endif // AVRCP_TARGET_H
148