1b442c9e6SMilanka Ringwald /* 2b442c9e6SMilanka Ringwald * Copyright (C) 2016 BlueKitchen GmbH 3b442c9e6SMilanka Ringwald * 4b442c9e6SMilanka Ringwald * Redistribution and use in source and binary forms, with or without 5b442c9e6SMilanka Ringwald * modification, are permitted provided that the following conditions 6b442c9e6SMilanka Ringwald * are met: 7b442c9e6SMilanka Ringwald * 8b442c9e6SMilanka Ringwald * 1. Redistributions of source code must retain the above copyright 9b442c9e6SMilanka Ringwald * notice, this list of conditions and the following disclaimer. 10b442c9e6SMilanka Ringwald * 2. Redistributions in binary form must reproduce the above copyright 11b442c9e6SMilanka Ringwald * notice, this list of conditions and the following disclaimer in the 12b442c9e6SMilanka Ringwald * documentation and/or other materials provided with the distribution. 13b442c9e6SMilanka Ringwald * 3. Neither the name of the copyright holders nor the names of 14b442c9e6SMilanka Ringwald * contributors may be used to endorse or promote products derived 15b442c9e6SMilanka Ringwald * from this software without specific prior written permission. 16b442c9e6SMilanka Ringwald * 4. Any redistribution, use, or modification is done solely for 17b442c9e6SMilanka Ringwald * personal benefit and not for any commercial purpose or for 18b442c9e6SMilanka Ringwald * monetary gain. 19b442c9e6SMilanka Ringwald * 20b442c9e6SMilanka Ringwald * THIS SOFTWARE IS PROVIDED BY BLUEKITCHEN GMBH AND CONTRIBUTORS 21b442c9e6SMilanka Ringwald * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 22b442c9e6SMilanka 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, 25b442c9e6SMilanka Ringwald * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, 26b442c9e6SMilanka Ringwald * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS 27b442c9e6SMilanka Ringwald * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED 28b442c9e6SMilanka Ringwald * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, 29b442c9e6SMilanka Ringwald * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF 30b442c9e6SMilanka Ringwald * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 31b442c9e6SMilanka Ringwald * SUCH DAMAGE. 32b442c9e6SMilanka Ringwald * 33b442c9e6SMilanka Ringwald * Please inquire about commercial licensing options at 34b442c9e6SMilanka Ringwald * [email protected] 35b442c9e6SMilanka Ringwald * 36b442c9e6SMilanka Ringwald */ 37b442c9e6SMilanka Ringwald 38fe5a6c4eSMilanka Ringwald /** 39fe5a6c4eSMilanka Ringwald * @title A2DP Sink 40b442c9e6SMilanka Ringwald * 41fe5a6c4eSMilanka Ringwald * Audio/Video Distribution Transport Protocol A2DP Sink is a device that accepts streamed media data. 42b442c9e6SMilanka Ringwald * 43b442c9e6SMilanka Ringwald */ 44b442c9e6SMilanka Ringwald 4580e33422SMatthias Ringwald #ifndef A2DP_SINK_H 4680e33422SMatthias Ringwald #define A2DP_SINK_H 47b442c9e6SMilanka Ringwald 48b442c9e6SMilanka Ringwald #include <stdint.h> 49ac881096SMatthias Ringwald #include "classic/avdtp.h" 50b442c9e6SMilanka Ringwald 51b442c9e6SMilanka Ringwald #if defined __cplusplus 52b442c9e6SMilanka Ringwald extern "C" { 53b442c9e6SMilanka Ringwald #endif 54b442c9e6SMilanka Ringwald 55b442c9e6SMilanka Ringwald /* API_START */ 56b442c9e6SMilanka Ringwald 57b442c9e6SMilanka Ringwald /** 58fd58c900SMilanka Ringwald * @brief Create A2DP Sink service record. 59b442c9e6SMilanka Ringwald * @param service 60b442c9e6SMilanka Ringwald * @param service_record_handle 61fd58c900SMilanka Ringwald * @param supported_features 16-bit bitmap, see AVDTP_SINK_SF_* values in avdtp.h 62*1041da4bSMatthias Ringwald * @param service_name or NULL for default value. Provide "" (empty string) to skip attribute 63*1041da4bSMatthias Ringwald * @param service_provider_name or NULL for default value. Provide "" (empty string) to skip attribute 64b442c9e6SMilanka Ringwald */ 65b442c9e6SMilanka Ringwald void a2dp_sink_create_sdp_record(uint8_t * service, uint32_t service_record_handle, uint16_t supported_features, const char * service_name, const char * service_provider_name); 66b442c9e6SMilanka Ringwald 677050d2caSMilanka Ringwald /** 68fd58c900SMilanka Ringwald * @brief Initialize up A2DP Sink device. 697050d2caSMilanka Ringwald */ 707050d2caSMilanka Ringwald void a2dp_sink_init(void); 717050d2caSMilanka Ringwald 72fd58c900SMilanka Ringwald /** 73fd58c900SMilanka Ringwald * @brief Create a stream endpoint of type SINK, and register media codec by specifying its capabilities and the default configuration. 74fd58c900SMilanka Ringwald * @param media_type see avdtp_media_type_t values in avdtp.h (audio, video or multimedia) 75fd58c900SMilanka Ringwald * @param media_codec_type see avdtp_media_codec_type_t values in avdtp.h 76fd58c900SMilanka Ringwald * @param codec_capabilities media codec capabilities as defined in A2DP spec, section 4 - Audio Codec Interoperability Requirements. 77fd58c900SMilanka Ringwald * @param codec_capabilities_len media codec capabilities length 78fd58c900SMilanka Ringwald * @param codec_configuration default media codec configuration 79fd58c900SMilanka Ringwald * @param codec_configuration_len media codec configuration length 8088132161SMilanka Ringwald * 818b94010eSMilanka Ringwald * @return local_stream_endpoint 82fd58c900SMilanka Ringwald */ 838b94010eSMilanka Ringwald avdtp_stream_endpoint_t * a2dp_sink_create_stream_endpoint(avdtp_media_type_t media_type, avdtp_media_codec_type_t media_codec_type, 843e6cf581SMatthias Ringwald const uint8_t *codec_capabilities, uint16_t codec_capabilities_len, 858b94010eSMilanka Ringwald uint8_t * codec_configuration, uint16_t codec_configuration_len); 867050d2caSMilanka Ringwald 877050d2caSMilanka Ringwald /** 8817ddf501SMatthias Ringwald * @brief Unregister stream endpoint and free it's memory 8917ddf501SMatthias Ringwald * @param stream_endpoint created by a2dp_sink_create_stream_endpoint 9017ddf501SMatthias Ringwald */ 9117ddf501SMatthias Ringwald void a2dp_sink_finalize_stream_endpoint(avdtp_stream_endpoint_t * stream_endpoint); 9217ddf501SMatthias Ringwald 9317ddf501SMatthias Ringwald /** 94fd58c900SMilanka Ringwald * @brief Register callback for the A2DP Sink client. It will receive following subevents of HCI_EVENT_A2DP_META HCI event type: 95fd58c900SMilanka Ringwald * - A2DP_SUBEVENT_SIGNALING_MEDIA_CODEC_SBC_CONFIGURATION: indicates from remote chosen SBC media codec configuration 96fd58c900SMilanka Ringwald * - A2DP_SUBEVENT_SIGNALING_MEDIA_CODEC_OTHER_CONFIGURATION: indicates from remote chosen other then SBC media codec configuration 97fd58c900SMilanka Ringwald * - A2DP_SUBEVENT_STREAM_ESTABLISHED: received when stream to a remote device is established 98fd58c900SMilanka Ringwald * - A2DP_SUBEVENT_STREAM_STARTED: received when stream is started 99fd58c900SMilanka Ringwald * - A2DP_SUBEVENT_STREAM_SUSPENDED: received when stream is paused 100133bececSMilanka Ringwald * - A2DP_SUBEVENT_STREAM_STOPED: received when stream is aborted or stopped 101fd58c900SMilanka Ringwald * - A2DP_SUBEVENT_STREAM_RELEASED: received when stream is released 102a466d508SMilanka Ringwald * - A2DP_SUBEVENT_SIGNALING_CONNECTION_RELEASED: received when signaling channel is disconnected 103fd58c900SMilanka Ringwald * 1047050d2caSMilanka Ringwald * @param callback 1057050d2caSMilanka Ringwald */ 1067050d2caSMilanka Ringwald void a2dp_sink_register_packet_handler(btstack_packet_handler_t callback); 1077050d2caSMilanka Ringwald 1087050d2caSMilanka Ringwald /** 1097050d2caSMilanka Ringwald * @brief Register media handler for the A2DP Sink client. 1107050d2caSMilanka Ringwald * @param callback 111fd58c900SMilanka Ringwald * @param packet 112fd58c900SMilanka Ringwald * @param size 1137050d2caSMilanka Ringwald */ 114fd58c900SMilanka Ringwald void a2dp_sink_register_media_handler(void (*callback)(uint8_t local_seid, uint8_t *packet, uint16_t size)); 1157050d2caSMilanka Ringwald 1167050d2caSMilanka Ringwald /** 117fd58c900SMilanka Ringwald * @brief Establish stream. 118fd58c900SMilanka Ringwald * @param remote 11948ce193cSMilanka Ringwald * @param out_a2dp_cid Assigned A2DP channel identifier used for furhter A2DP commands. 1207050d2caSMilanka Ringwald */ 121d3f12e45SMatthias Ringwald uint8_t a2dp_sink_establish_stream(bd_addr_t remote, uint16_t * out_a2dp_cid); 1227050d2caSMilanka Ringwald 12348ce193cSMilanka Ringwald #ifdef ENABLE_AVDTP_ACCEPTOR_EXPLICIT_START_STREAM_CONFIRMATION 12448ce193cSMilanka Ringwald /** 12548ce193cSMilanka Ringwald * @brief Accept starting the stream on A2DP_SUBEVENT_START_STREAM_REQUESTED event. 12648ce193cSMilanka Ringwald * @param a2dp_cid A2DP channel identifier. 12748ce193cSMilanka Ringwald * @param local_seid ID of a local stream endpoint. 12848ce193cSMilanka Ringwald */ 12948ce193cSMilanka Ringwald uint8_t a2dp_sink_start_stream_accept(uint16_t a2dp_cid, uint8_t local_seid); 13048ce193cSMilanka Ringwald 13148ce193cSMilanka Ringwald /** 13248ce193cSMilanka Ringwald * @brief Reject starting the stream on A2DP_SUBEVENT_START_STREAM_REQUESTED event. 13348ce193cSMilanka Ringwald * @param a2dp_cid A2DP channel identifier. 13448ce193cSMilanka Ringwald * @param local_seid ID of a local stream endpoint. 13548ce193cSMilanka Ringwald */ 13648ce193cSMilanka Ringwald uint8_t a2dp_sink_start_stream_reject(uint16_t a2dp_cid, uint8_t local_seid); 13748ce193cSMilanka Ringwald #endif 13848ce193cSMilanka Ringwald 1397050d2caSMilanka Ringwald /** 14088132161SMilanka Ringwald * @brief Release stream and disconnect from remote. 14148ce193cSMilanka Ringwald * @param a2dp_cid A2DP channel identifier. 1427050d2caSMilanka Ringwald */ 1437050d2caSMilanka Ringwald void a2dp_sink_disconnect(uint16_t a2dp_cid); 144fd58c900SMilanka Ringwald 1457569dc61SMatthias Ringwald /** 1465d2ab254SMatthias Ringwald * @brief Select and configure SBC endpoint 1475d2ab254SMatthias Ringwald * @param a2dp_cid A2DP channel identifier. 1485d2ab254SMatthias Ringwald * @param local_seid ID of a local stream endpoint. 1495d2ab254SMatthias Ringwald * @param remote_seid ID of a remote stream endpoint. 1505d2ab254SMatthias Ringwald * @param configuration SBC Configuration 1515d2ab254SMatthias Ringwald * @return status 1525d2ab254SMatthias Ringwald */ 1535d2ab254SMatthias Ringwald uint8_t a2dp_sink_set_config_sbc(uint16_t a2dp_cid, uint8_t local_seid, uint8_t remote_seid, const avdtp_configuration_sbc_t * configuration); 1545d2ab254SMatthias Ringwald 1555d2ab254SMatthias Ringwald /** 1565d2ab254SMatthias Ringwald * @brief Select and configure MPEG AUDIO endpoint 1575d2ab254SMatthias Ringwald * @param a2dp_cid A2DP channel identifier. 1585d2ab254SMatthias Ringwald * @param local_seid ID of a local stream endpoint. 1595d2ab254SMatthias Ringwald * @param remote_seid ID of a remote stream endpoint. 1605d2ab254SMatthias Ringwald * @param configuration MPEG AUDIO Configuration 1615d2ab254SMatthias Ringwald * @return status 1625d2ab254SMatthias Ringwald */ 1635d2ab254SMatthias Ringwald uint8_t a2dp_sink_set_config_mpeg_audio(uint16_t a2dp_cid, uint8_t local_seid, uint8_t remote_seid, const avdtp_configuration_mpeg_audio_t * configuration); 1645d2ab254SMatthias Ringwald 1655d2ab254SMatthias Ringwald /** 1665d2ab254SMatthias Ringwald * @brief Select and configure MPEG AAC endpoint 1675d2ab254SMatthias Ringwald * @param a2dp_cid A2DP channel identifier. 1685d2ab254SMatthias Ringwald * @param local_seid ID of a local stream endpoint. 1695d2ab254SMatthias Ringwald * @param remote_seid ID of a remote stream endpoint. 1705d2ab254SMatthias Ringwald * @param configuration MPEG AAC Configuration 1715d2ab254SMatthias Ringwald * @return status 1725d2ab254SMatthias Ringwald */ 1735d2ab254SMatthias Ringwald uint8_t a2dp_sink_set_config_mpeg_aac(uint16_t a2dp_cid, uint8_t local_seid, uint8_t remote_seid, const avdtp_configuration_mpeg_aac_t * configuration); 1745d2ab254SMatthias Ringwald 1755d2ab254SMatthias Ringwald /** 1765d2ab254SMatthias Ringwald * @brief Select and configure ATRAC endpoint 1775d2ab254SMatthias Ringwald * @param a2dp_cid A2DP channel identifier. 1785d2ab254SMatthias Ringwald * @param local_seid ID of a local stream endpoint. 1795d2ab254SMatthias Ringwald * @param remote_seid ID of a remote stream endpoint. 1805d2ab254SMatthias Ringwald * @param configuration ATRAC Configuration 1815d2ab254SMatthias Ringwald * @return status 1825d2ab254SMatthias Ringwald */ 1835d2ab254SMatthias Ringwald uint8_t a2dp_sink_set_config_atrac(uint16_t a2dp_cid, uint8_t local_seid, uint8_t remote_seid, const avdtp_configuration_atrac_t * configuration); 1845d2ab254SMatthias Ringwald 1855d2ab254SMatthias Ringwald /** 1865d2ab254SMatthias Ringwald * @brief Select and configure Non-A2DP endpoint. Bytes 0-3 of codec information contain Vendor ID, bytes 4-5 contain Vendor Specific Codec ID (little endian) 1875d2ab254SMatthias Ringwald * @param a2dp_cid A2DP channel identifier. 1885d2ab254SMatthias Ringwald * @param local_seid ID of a local stream endpoint. 1895d2ab254SMatthias Ringwald * @param remote_seid ID of a remote stream endpoint. 1905d2ab254SMatthias Ringwald * @param media_codec_information 1915d2ab254SMatthias Ringwald * @param media_codec_information_len 1925d2ab254SMatthias Ringwald * @return status 1935d2ab254SMatthias Ringwald */ 1945d2ab254SMatthias Ringwald uint8_t a2dp_sink_set_config_other(uint16_t a2dp_cid, uint8_t local_seid, uint8_t remote_seid, const uint8_t * media_codec_information, uint8_t media_codec_information_len); 1955d2ab254SMatthias Ringwald 1965d2ab254SMatthias Ringwald /** 197a95794ceSMatthias Ringwald * @brief Register media configuration validator. Can reject insuitable configuration or report stream endpoint as currently busy 198a95794ceSMatthias Ringwald * @note validator has to return AVDTP error codes like: AVDTP_ERROR_CODE_SEP_IN_USE or AVDTP_ERROR_CODE_UNSUPPORTED_CONFIGURATION 199a95794ceSMatthias Ringwald * the callback receives the media configuration in the same format as the existing A2dP_SUBEVENT_SIGNALING_MEDIA_CODEC_SBC_CONFIGURATION 200a95794ceSMatthias Ringwald * and similar 201a95794ceSMatthias Ringwald * @param callback 202a95794ceSMatthias Ringwald */ 203a95794ceSMatthias Ringwald void a2dp_sink_register_media_config_validator(uint8_t (*callback)(const avdtp_stream_endpoint_t * stream_endpoint, const uint8_t * event, uint16_t size)); 204a95794ceSMatthias Ringwald 205a95794ceSMatthias Ringwald /** 2067569dc61SMatthias Ringwald * @brief De-Init A2DP Sink device. 2077569dc61SMatthias Ringwald */ 2087569dc61SMatthias Ringwald void a2dp_sink_deinit(void); 2097569dc61SMatthias Ringwald 210b442c9e6SMilanka Ringwald /* API_END */ 211b442c9e6SMilanka Ringwald 2127050d2caSMilanka Ringwald 213b442c9e6SMilanka Ringwald #if defined __cplusplus 214b442c9e6SMilanka Ringwald } 215b442c9e6SMilanka Ringwald #endif 216b442c9e6SMilanka Ringwald 21780e33422SMatthias Ringwald #endif // A2DP_SINK_H 218