xref: /btstack/src/classic/avrcp_target.h (revision 6e735d0a1ba2a458816705bea310c2f29d85e178)
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
72e2f25417SMilanka Ringwald  * @param supported_features 16-bit bitmap, see AVRCP_FEATURE_MASK_* in avrcp.h
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 
783734adacSMilanka Ringwald /**
793734adacSMilanka Ringwald  * @brief Set up AVRCP Target service.
803734adacSMilanka Ringwald  */
8101dc6e35SMilanka Ringwald void    avrcp_target_init(void);
8201dc6e35SMilanka Ringwald 
833734adacSMilanka Ringwald /**
843734adacSMilanka Ringwald  * @brief Register callback for the AVRCP Target client.
853734adacSMilanka Ringwald  * @param callback
863734adacSMilanka Ringwald  */
8701dc6e35SMilanka Ringwald void    avrcp_target_register_packet_handler(btstack_packet_handler_t callback);
8801dc6e35SMilanka Ringwald 
893734adacSMilanka Ringwald /**
90d1cf25b1SMatthias Ringwald  * @brief Select Player that is controlled by Controller
91d1cf25b1SMatthias Ringwald  * @param callback
92d1cf25b1SMatthias Ringwald  * @note Callback should return if selected player is valid
93d1cf25b1SMatthias Ringwald  */
94d1cf25b1SMatthias Ringwald void avrcp_target_register_set_addressed_player_handler(bool (*callback)(uint16_t player_id));
95d1cf25b1SMatthias Ringwald 
96d1cf25b1SMatthias Ringwald /**
973734adacSMilanka Ringwald  * @brief Send a list of Company IDs supported by target.
983734adacSMilanka Ringwald  * @note  The avrcp_target_packet_handler will receive AVRCP_SUBEVENT_COMPANY_IDS_QUERY event. Use this function to respond.
993734adacSMilanka Ringwald  * @param avrcp_cid
1003734adacSMilanka Ringwald  * @param num_company_ids
1013734adacSMilanka Ringwald  * @param company_ids
1023734adacSMilanka Ringwald  * @param company_ids_size
1033734adacSMilanka Ringwald  * @returns status ERROR_CODE_UNKNOWN_CONNECTION_IDENTIFIER if connection is not found, otherwise ERROR_CODE_SUCCESS
1043734adacSMilanka Ringwald  */
105*6e735d0aSMatthias Ringwald uint8_t avrcp_target_supported_companies(uint16_t avrcp_cid, uint8_t num_company_ids, const uint8_t *company_ids, uint8_t company_ids_size);
10601dc6e35SMilanka Ringwald 
1073734adacSMilanka Ringwald /**
1083734adacSMilanka Ringwald  * @brief Send a list of Events supported by target.
1093734adacSMilanka Ringwald  * @note  The avrcp_target_packet_handler will receive AVRCP_SUBEVENT_EVENT_IDS_QUERY event. Use this function to respond.
1103734adacSMilanka Ringwald  * @param avrcp_cid
1113734adacSMilanka Ringwald  * @param num_event_ids
1123734adacSMilanka Ringwald  * @param event_ids
1133734adacSMilanka Ringwald  * @param event_ids_size
1143734adacSMilanka Ringwald  * @returns status ERROR_CODE_UNKNOWN_CONNECTION_IDENTIFIER if connection is not found, otherwise ERROR_CODE_SUCCESS
1153734adacSMilanka Ringwald  */
116*6e735d0aSMatthias Ringwald uint8_t avrcp_target_supported_events(uint16_t avrcp_cid, uint8_t num_event_ids, const uint8_t *event_ids, uint8_t event_ids_size);
1173734adacSMilanka Ringwald 
1183734adacSMilanka Ringwald /**
1193734adacSMilanka Ringwald  * @brief Send a play status.
1203734adacSMilanka Ringwald  * @note  The avrcp_target_packet_handler will receive AVRCP_SUBEVENT_PLAY_STATUS_QUERY event. Use this function to respond.
1213734adacSMilanka Ringwald  * @param avrcp_cid
1223734adacSMilanka Ringwald  * @param song_length_ms
1233734adacSMilanka Ringwald  * @param song_position_ms
1243734adacSMilanka Ringwald  * @returns status ERROR_CODE_UNKNOWN_CONNECTION_IDENTIFIER if connection is not found, otherwise ERROR_CODE_SUCCESS
1253734adacSMilanka Ringwald  */
126d1207cd8SMilanka 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);
127c045af99SMilanka Ringwald 
128fe9491e7SMatthias Ringwald /**
129fe9491e7SMatthias Ringwald  * @param Set Now Playing Info that is send to Controller if notifications are enabled
130fe9491e7SMatthias Ringwald  * @param avrcp_cid
131fe9491e7SMatthias Ringwald  * @param current_track
132fe9491e7SMatthias Ringwald  * @param total_tracks
133fe9491e7SMatthias Ringwald  */
134d1207cd8SMilanka Ringwald void avrcp_target_set_now_playing_info(uint16_t avrcp_cid, const avrcp_track_t * current_track, uint16_t total_tracks);
135fe9491e7SMatthias Ringwald 
136fe9491e7SMatthias Ringwald /**
137fe9491e7SMatthias Ringwald  * @param Set Playing status and send to Controller
138fe9491e7SMatthias Ringwald  * @param avrcp_cid
139fe9491e7SMatthias Ringwald  * @param playback_status
140fe9491e7SMatthias Ringwald  * @return
141fe9491e7SMatthias Ringwald  */
142d1207cd8SMilanka Ringwald uint8_t avrcp_target_set_playback_status(uint16_t avrcp_cid, avrcp_playback_status_t playback_status);
143fe9491e7SMatthias Ringwald 
144fe9491e7SMatthias Ringwald /**
145fe9491e7SMatthias Ringwald  * @param Set Unit Info
146fe9491e7SMatthias Ringwald  * @param avrcp_cid
147fe9491e7SMatthias Ringwald  * @param unit_type
148fe9491e7SMatthias Ringwald  * @param company_id
149fe9491e7SMatthias Ringwald  */
150d1207cd8SMilanka Ringwald void avrcp_target_set_unit_info(uint16_t avrcp_cid, avrcp_subunit_type_t unit_type, uint32_t company_id);
151fe9491e7SMatthias Ringwald 
152fe9491e7SMatthias Ringwald /**
153fe9491e7SMatthias Ringwald  * @param Set Subunit Info
154fe9491e7SMatthias Ringwald  * @param avrcp_cid
155fe9491e7SMatthias Ringwald  * @param subunit_type
156fe9491e7SMatthias Ringwald  * @param subunit_info_data
157fe9491e7SMatthias Ringwald  * @param subunit_info_data_size
158fe9491e7SMatthias Ringwald  */
159d1207cd8SMilanka 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);
160d1207cd8SMilanka Ringwald 
161fe9491e7SMatthias Ringwald /**
162fe9491e7SMatthias Ringwald  * @param Send Playing Content Changed Notification if enabled
163fe9491e7SMatthias Ringwald  * @param avrcp_cid
164fe9491e7SMatthias Ringwald  * @return
165fe9491e7SMatthias Ringwald  */
166d1207cd8SMilanka Ringwald uint8_t avrcp_target_playing_content_changed(uint16_t avrcp_cid);
167fe9491e7SMatthias Ringwald 
168fe9491e7SMatthias Ringwald /**
169fe9491e7SMatthias Ringwald  * @param Send Addressed Player Changed Notification if enabled
170fe9491e7SMatthias Ringwald  * @param avrcp_cid
171fe9491e7SMatthias Ringwald  * @param player_id
172fe9491e7SMatthias Ringwald  * @param uid_counter
173fe9491e7SMatthias Ringwald  * @return
174fe9491e7SMatthias Ringwald  */
1756568eb54SMilanka Ringwald uint8_t avrcp_target_addressed_player_changed(uint16_t avrcp_cid, uint16_t player_id, uint16_t uid_counter);
1766568eb54SMilanka Ringwald 
177fe9491e7SMatthias Ringwald /**
178fe9491e7SMatthias Ringwald  * @param Set Battery Status Changed and send notification if enabled
179fe9491e7SMatthias Ringwald  * @param avrcp_cid
180fe9491e7SMatthias Ringwald  * @param battery_status
181fe9491e7SMatthias Ringwald  * @return
182fe9491e7SMatthias Ringwald  */
183d1207cd8SMilanka Ringwald uint8_t avrcp_target_battery_status_changed(uint16_t avrcp_cid, avrcp_battery_status_t battery_status);
184fe9491e7SMatthias Ringwald 
185fe9491e7SMatthias Ringwald /**
186fe9491e7SMatthias Ringwald  * @param Set Volume and send notification if enabled
187fe9491e7SMatthias Ringwald  * @param avrcp_cid
188fe9491e7SMatthias Ringwald  * @param volume_percentage
189fe9491e7SMatthias Ringwald  * @return
190fe9491e7SMatthias Ringwald  */
191d1207cd8SMilanka Ringwald uint8_t avrcp_target_volume_changed(uint16_t avrcp_cid, uint8_t volume_percentage);
192fe9491e7SMatthias Ringwald 
193fe9491e7SMatthias Ringwald /**
194fe9491e7SMatthias Ringwald  * @param Set Track and send notification if enabled
195fe9491e7SMatthias Ringwald  * @param avrcp_cid
196fe9491e7SMatthias Ringwald  * @param trackID
197fe9491e7SMatthias Ringwald  * @return
198fe9491e7SMatthias Ringwald  */
19912b7c8ecSMilanka Ringwald uint8_t avrcp_target_track_changed(uint16_t avrcp_cid, uint8_t * trackID);
20012b7c8ecSMilanka Ringwald 
201fe9491e7SMatthias Ringwald /**
202fe9491e7SMatthias Ringwald  * @param Send Operation Rejected message
203fe9491e7SMatthias Ringwald  * @param avrcp_cid
204fe9491e7SMatthias Ringwald  * @param opid
205fe9491e7SMatthias Ringwald  * @param operands_length
206fe9491e7SMatthias Ringwald  * @param operand
207fe9491e7SMatthias Ringwald  * @return
208fe9491e7SMatthias Ringwald  */
209831d3fd5SMilanka Ringwald uint8_t avrcp_target_operation_rejected(uint16_t avrcp_cid, avrcp_operation_id_t opid, uint8_t operands_length, uint8_t operand);
210fe9491e7SMatthias Ringwald 
211fe9491e7SMatthias Ringwald /**
212fe9491e7SMatthias Ringwald  * @param Send Operation Accepted message
213fe9491e7SMatthias Ringwald  * @param avrcp_cid
214fe9491e7SMatthias Ringwald  * @param opid
215fe9491e7SMatthias Ringwald  * @param operands_length
216fe9491e7SMatthias Ringwald  * @param operand
217fe9491e7SMatthias Ringwald  * @return
218fe9491e7SMatthias Ringwald  */
219831d3fd5SMilanka Ringwald uint8_t avrcp_target_operation_accepted(uint16_t avrcp_cid, avrcp_operation_id_t opid, uint8_t operands_length, uint8_t operand);
220fe9491e7SMatthias Ringwald 
221fe9491e7SMatthias Ringwald /**
222fe9491e7SMatthias Ringwald  * @param Send Operation Not Implemented message
223fe9491e7SMatthias Ringwald  * @param avrcp_cid
224fe9491e7SMatthias Ringwald  * @param opid
225fe9491e7SMatthias Ringwald  * @param operands_length
226fe9491e7SMatthias Ringwald  * @param operand
227fe9491e7SMatthias Ringwald  * @return
228fe9491e7SMatthias Ringwald  */
229831d3fd5SMilanka Ringwald uint8_t avrcp_target_operation_not_implemented(uint16_t avrcp_cid, avrcp_operation_id_t opid, uint8_t operands_length, uint8_t operand);
230831d3fd5SMilanka Ringwald 
231680af5dcSMatthias Ringwald /**
232680af5dcSMatthias Ringwald  * @brief De-Init AVRCP Browsing Target
233680af5dcSMatthias Ringwald  */
234680af5dcSMatthias Ringwald void avrcp_target_deinit(void);
235680af5dcSMatthias Ringwald 
2366983e65eSMilanka Ringwald /* API_END */
237654724deSMilanka Ringwald 
238654724deSMilanka Ringwald  // Used by AVRCP target and AVRCP browsing target
239654724deSMilanka Ringwald extern avrcp_context_t avrcp_target_context;
240654724deSMilanka Ringwald 
2416983e65eSMilanka Ringwald #if defined __cplusplus
2426983e65eSMilanka Ringwald }
2436983e65eSMilanka Ringwald #endif
2446983e65eSMilanka Ringwald 
24580e33422SMatthias Ringwald #endif // AVRCP_TARGET_H
246