xref: /btstack/src/classic/avrcp_target.h (revision 61a3437b34352703a9ebc6eb1246c9d86553e99e)
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 /*
39fe5a6c4eSMilanka Ringwald  * @title AVRCP Target
406983e65eSMilanka Ringwald  *
416983e65eSMilanka Ringwald  */
426983e65eSMilanka Ringwald 
4380e33422SMatthias Ringwald #ifndef AVRCP_TARGET_H
4480e33422SMatthias Ringwald #define AVRCP_TARGET_H
456983e65eSMilanka Ringwald 
466983e65eSMilanka Ringwald #include <stdint.h>
473311c2d5SMatthias Ringwald #include "classic/avrcp.h"
486983e65eSMilanka Ringwald 
496983e65eSMilanka Ringwald #if defined __cplusplus
506983e65eSMilanka Ringwald extern "C" {
516983e65eSMilanka Ringwald #endif
526983e65eSMilanka Ringwald 
536983e65eSMilanka Ringwald /* API_START */
546983e65eSMilanka Ringwald 
5511014891SMilanka Ringwald typedef enum {
5611014891SMilanka Ringwald     AVRCP_TARGET_SUPPORTED_FEATURE_CATEGORY_PLAYER_OR_RECORDER = 0,
5711014891SMilanka Ringwald     AVRCP_TARGET_SUPPORTED_FEATURE_CATEGORY_MONITOR_OR_AMPLIFIER,
5811014891SMilanka Ringwald     AVRCP_TARGET_SUPPORTED_FEATURE_CATEGORY_TUNER,
5911014891SMilanka Ringwald     AVRCP_TARGET_SUPPORTED_FEATURE_CATEGORY_MENU,
6011014891SMilanka 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
6111014891SMilanka 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
6211014891SMilanka Ringwald     AVRCP_TARGET_SUPPORTED_FEATURE_BROWSING,
6311014891SMilanka Ringwald     AVRCP_TARGET_SUPPORTED_FEATURE_MULTIPLE_MEDIA_PLAYE_APPLICATIONS
6411014891SMilanka Ringwald } avrcp_target_supported_feature_t;
656983e65eSMilanka Ringwald 
666983e65eSMilanka Ringwald /**
67f65a5459SMilanka Ringwald  * @brief AVRCP Target service record.
686983e65eSMilanka Ringwald  * @param service
696983e65eSMilanka Ringwald  * @param service_record_handle
70e2f25417SMilanka Ringwald  * @param supported_features 16-bit bitmap, see AVRCP_FEATURE_MASK_* in avrcp.h
716983e65eSMilanka Ringwald  * @param service_name
726983e65eSMilanka Ringwald  * @param service_provider_name
736983e65eSMilanka Ringwald  */
744f0111ebSMilanka 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);
756983e65eSMilanka Ringwald 
763734adacSMilanka Ringwald /**
773734adacSMilanka Ringwald  * @brief Set up AVRCP Target service.
783734adacSMilanka Ringwald  */
7901dc6e35SMilanka Ringwald void    avrcp_target_init(void);
8001dc6e35SMilanka Ringwald 
813734adacSMilanka Ringwald /**
823734adacSMilanka Ringwald  * @brief Register callback for the AVRCP Target client.
833734adacSMilanka Ringwald  * @param callback
843734adacSMilanka Ringwald  */
8501dc6e35SMilanka Ringwald void    avrcp_target_register_packet_handler(btstack_packet_handler_t callback);
8601dc6e35SMilanka Ringwald 
873734adacSMilanka Ringwald /**
88d1cf25b1SMatthias Ringwald  * @brief Select Player that is controlled by Controller
89d1cf25b1SMatthias Ringwald  * @param callback
90d1cf25b1SMatthias Ringwald  * @note Callback should return if selected player is valid
91d1cf25b1SMatthias Ringwald  */
92d1cf25b1SMatthias Ringwald void avrcp_target_register_set_addressed_player_handler(bool (*callback)(uint16_t player_id));
93d1cf25b1SMatthias Ringwald 
94d1cf25b1SMatthias Ringwald /**
953734adacSMilanka Ringwald  * @brief Send a list of Company IDs supported by target.
963734adacSMilanka Ringwald  * @note  The avrcp_target_packet_handler will receive AVRCP_SUBEVENT_COMPANY_IDS_QUERY event. Use this function to respond.
973734adacSMilanka Ringwald  * @param avrcp_cid
983734adacSMilanka Ringwald  * @param num_company_ids
993734adacSMilanka Ringwald  * @param company_ids
1003734adacSMilanka Ringwald  * @param company_ids_size
1013734adacSMilanka Ringwald  * @returns status ERROR_CODE_UNKNOWN_CONNECTION_IDENTIFIER if connection is not found, otherwise ERROR_CODE_SUCCESS
1023734adacSMilanka Ringwald  */
1036e735d0aSMatthias 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);
10401dc6e35SMilanka Ringwald 
1053734adacSMilanka Ringwald /**
1063734adacSMilanka Ringwald  * @brief Send a list of Events supported by target.
1073734adacSMilanka Ringwald  * @note  The avrcp_target_packet_handler will receive AVRCP_SUBEVENT_EVENT_IDS_QUERY event. Use this function to respond.
1083734adacSMilanka Ringwald  * @param avrcp_cid
1093734adacSMilanka Ringwald  * @param num_event_ids
1103734adacSMilanka Ringwald  * @param event_ids
1113734adacSMilanka Ringwald  * @param event_ids_size
1123734adacSMilanka Ringwald  * @returns status ERROR_CODE_UNKNOWN_CONNECTION_IDENTIFIER if connection is not found, otherwise ERROR_CODE_SUCCESS
1133734adacSMilanka Ringwald  */
1146e735d0aSMatthias 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);
1153734adacSMilanka Ringwald 
1163734adacSMilanka Ringwald /**
1173734adacSMilanka Ringwald  * @brief Send a play status.
1183734adacSMilanka Ringwald  * @note  The avrcp_target_packet_handler will receive AVRCP_SUBEVENT_PLAY_STATUS_QUERY event. Use this function to respond.
1193734adacSMilanka Ringwald  * @param avrcp_cid
1203734adacSMilanka Ringwald  * @param song_length_ms
1213734adacSMilanka Ringwald  * @param song_position_ms
1223734adacSMilanka Ringwald  * @returns status ERROR_CODE_UNKNOWN_CONNECTION_IDENTIFIER if connection is not found, otherwise ERROR_CODE_SUCCESS
1233734adacSMilanka Ringwald  */
124d1207cd8SMilanka 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);
125c045af99SMilanka Ringwald 
126fe9491e7SMatthias Ringwald /**
127fe9491e7SMatthias Ringwald  * @param Set Now Playing Info that is send to Controller if notifications are enabled
128fe9491e7SMatthias Ringwald  * @param avrcp_cid
129fe9491e7SMatthias Ringwald  * @param current_track
130fe9491e7SMatthias Ringwald  * @param total_tracks
131fe9491e7SMatthias Ringwald  */
132*61a3437bSMilanka Ringwald uint8_t avrcp_target_set_now_playing_info(uint16_t avrcp_cid, const avrcp_track_t * current_track, uint16_t total_tracks);
133fe9491e7SMatthias Ringwald 
134fe9491e7SMatthias Ringwald /**
135fe9491e7SMatthias Ringwald  * @param Set Playing status and send to Controller
136fe9491e7SMatthias Ringwald  * @param avrcp_cid
137fe9491e7SMatthias Ringwald  * @param playback_status
138fe9491e7SMatthias Ringwald  * @return
139fe9491e7SMatthias Ringwald  */
140d1207cd8SMilanka Ringwald uint8_t avrcp_target_set_playback_status(uint16_t avrcp_cid, avrcp_playback_status_t playback_status);
141fe9491e7SMatthias Ringwald 
142fe9491e7SMatthias Ringwald /**
143fe9491e7SMatthias Ringwald  * @param Set Unit Info
144fe9491e7SMatthias Ringwald  * @param avrcp_cid
145fe9491e7SMatthias Ringwald  * @param unit_type
146fe9491e7SMatthias Ringwald  * @param company_id
147fe9491e7SMatthias Ringwald  */
148*61a3437bSMilanka Ringwald uint8_t avrcp_target_set_unit_info(uint16_t avrcp_cid, avrcp_subunit_type_t unit_type, uint32_t company_id);
149fe9491e7SMatthias Ringwald 
150fe9491e7SMatthias Ringwald /**
151fe9491e7SMatthias Ringwald  * @param Set Subunit Info
152fe9491e7SMatthias Ringwald  * @param avrcp_cid
153fe9491e7SMatthias Ringwald  * @param subunit_type
154fe9491e7SMatthias Ringwald  * @param subunit_info_data
155fe9491e7SMatthias Ringwald  * @param subunit_info_data_size
156fe9491e7SMatthias Ringwald  */
157*61a3437bSMilanka Ringwald uint8_t 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);
158d1207cd8SMilanka Ringwald 
159fe9491e7SMatthias Ringwald /**
160fe9491e7SMatthias Ringwald  * @param Send Playing Content Changed Notification if enabled
161fe9491e7SMatthias Ringwald  * @param avrcp_cid
162fe9491e7SMatthias Ringwald  * @return
163fe9491e7SMatthias Ringwald  */
164d1207cd8SMilanka Ringwald uint8_t avrcp_target_playing_content_changed(uint16_t avrcp_cid);
165fe9491e7SMatthias Ringwald 
166fe9491e7SMatthias Ringwald /**
167fe9491e7SMatthias Ringwald  * @param Send Addressed Player Changed Notification if enabled
168fe9491e7SMatthias Ringwald  * @param avrcp_cid
169fe9491e7SMatthias Ringwald  * @param player_id
170fe9491e7SMatthias Ringwald  * @param uid_counter
171fe9491e7SMatthias Ringwald  * @return
172fe9491e7SMatthias Ringwald  */
1736568eb54SMilanka Ringwald uint8_t avrcp_target_addressed_player_changed(uint16_t avrcp_cid, uint16_t player_id, uint16_t uid_counter);
1746568eb54SMilanka Ringwald 
175fe9491e7SMatthias Ringwald /**
176fe9491e7SMatthias Ringwald  * @param Set Battery Status Changed and send notification if enabled
177fe9491e7SMatthias Ringwald  * @param avrcp_cid
178fe9491e7SMatthias Ringwald  * @param battery_status
179fe9491e7SMatthias Ringwald  * @return
180fe9491e7SMatthias Ringwald  */
181d1207cd8SMilanka Ringwald uint8_t avrcp_target_battery_status_changed(uint16_t avrcp_cid, avrcp_battery_status_t battery_status);
182fe9491e7SMatthias Ringwald 
183fe9491e7SMatthias Ringwald /**
184fe9491e7SMatthias Ringwald  * @param Set Volume and send notification if enabled
185fe9491e7SMatthias Ringwald  * @param avrcp_cid
186fe9491e7SMatthias Ringwald  * @param volume_percentage
187fe9491e7SMatthias Ringwald  * @return
188fe9491e7SMatthias Ringwald  */
189d1207cd8SMilanka Ringwald uint8_t avrcp_target_volume_changed(uint16_t avrcp_cid, uint8_t volume_percentage);
190fe9491e7SMatthias Ringwald 
191fe9491e7SMatthias Ringwald /**
192fe9491e7SMatthias Ringwald  * @param Set Track and send notification if enabled
193fe9491e7SMatthias Ringwald  * @param avrcp_cid
194fe9491e7SMatthias Ringwald  * @param trackID
195fe9491e7SMatthias Ringwald  * @return
196fe9491e7SMatthias Ringwald  */
19712b7c8ecSMilanka Ringwald uint8_t avrcp_target_track_changed(uint16_t avrcp_cid, uint8_t * trackID);
19812b7c8ecSMilanka Ringwald 
199fe9491e7SMatthias Ringwald /**
200fe9491e7SMatthias Ringwald  * @param Send Operation Rejected message
201fe9491e7SMatthias Ringwald  * @param avrcp_cid
202fe9491e7SMatthias Ringwald  * @param opid
203fe9491e7SMatthias Ringwald  * @param operands_length
204fe9491e7SMatthias Ringwald  * @param operand
205fe9491e7SMatthias Ringwald  * @return
206fe9491e7SMatthias Ringwald  */
207831d3fd5SMilanka Ringwald uint8_t avrcp_target_operation_rejected(uint16_t avrcp_cid, avrcp_operation_id_t opid, uint8_t operands_length, uint8_t operand);
208fe9491e7SMatthias Ringwald 
209fe9491e7SMatthias Ringwald /**
210fe9491e7SMatthias Ringwald  * @param Send Operation Accepted message
211fe9491e7SMatthias Ringwald  * @param avrcp_cid
212fe9491e7SMatthias Ringwald  * @param opid
213fe9491e7SMatthias Ringwald  * @param operands_length
214fe9491e7SMatthias Ringwald  * @param operand
215fe9491e7SMatthias Ringwald  * @return
216fe9491e7SMatthias Ringwald  */
217831d3fd5SMilanka Ringwald uint8_t avrcp_target_operation_accepted(uint16_t avrcp_cid, avrcp_operation_id_t opid, uint8_t operands_length, uint8_t operand);
218fe9491e7SMatthias Ringwald 
219fe9491e7SMatthias Ringwald /**
220fe9491e7SMatthias Ringwald  * @param Send Operation Not Implemented message
221fe9491e7SMatthias Ringwald  * @param avrcp_cid
222fe9491e7SMatthias Ringwald  * @param opid
223fe9491e7SMatthias Ringwald  * @param operands_length
224fe9491e7SMatthias Ringwald  * @param operand
225fe9491e7SMatthias Ringwald  * @return
226fe9491e7SMatthias Ringwald  */
227831d3fd5SMilanka Ringwald uint8_t avrcp_target_operation_not_implemented(uint16_t avrcp_cid, avrcp_operation_id_t opid, uint8_t operands_length, uint8_t operand);
228831d3fd5SMilanka Ringwald 
229680af5dcSMatthias Ringwald /**
230680af5dcSMatthias Ringwald  * @brief De-Init AVRCP Browsing Target
231680af5dcSMatthias Ringwald  */
232680af5dcSMatthias Ringwald void avrcp_target_deinit(void);
233680af5dcSMatthias Ringwald 
2346983e65eSMilanka Ringwald /* API_END */
235654724deSMilanka Ringwald 
236654724deSMilanka Ringwald  // Used by AVRCP target and AVRCP browsing target
237654724deSMilanka Ringwald extern avrcp_context_t avrcp_target_context;
238654724deSMilanka Ringwald 
2396983e65eSMilanka Ringwald #if defined __cplusplus
2406983e65eSMilanka Ringwald }
2416983e65eSMilanka Ringwald #endif
2426983e65eSMilanka Ringwald 
24380e33422SMatthias Ringwald #endif // AVRCP_TARGET_H
244