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 23b442c9e6SMilanka Ringwald * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL MATTHIAS 24b442c9e6SMilanka Ringwald * RINGWALD 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 38b442c9e6SMilanka Ringwald /* 39b442c9e6SMilanka Ringwald * a2dp_sink.h 40b442c9e6SMilanka Ringwald * 41b442c9e6SMilanka Ringwald * Advanced Audio Distribution Transport Profile (A2DP) Sink 42b442c9e6SMilanka Ringwald * 43b442c9e6SMilanka Ringwald * A2DP Sink is a device that accepts streamed media data. 44b442c9e6SMilanka Ringwald */ 45b442c9e6SMilanka Ringwald 46*80e33422SMatthias Ringwald #ifndef A2DP_SINK_H 47*80e33422SMatthias Ringwald #define A2DP_SINK_H 48b442c9e6SMilanka Ringwald 49b442c9e6SMilanka Ringwald #include <stdint.h> 50ac881096SMatthias Ringwald #include "classic/avdtp.h" 51b442c9e6SMilanka Ringwald 52b442c9e6SMilanka Ringwald #if defined __cplusplus 53b442c9e6SMilanka Ringwald extern "C" { 54b442c9e6SMilanka Ringwald #endif 55b442c9e6SMilanka Ringwald 56b442c9e6SMilanka Ringwald /* API_START */ 57b442c9e6SMilanka Ringwald 58b442c9e6SMilanka Ringwald /** 59fd58c900SMilanka Ringwald * @brief Create A2DP Sink service record. 60b442c9e6SMilanka Ringwald * @param service 61b442c9e6SMilanka Ringwald * @param service_record_handle 62fd58c900SMilanka Ringwald * @param supported_features 16-bit bitmap, see AVDTP_SINK_SF_* values in avdtp.h 63b442c9e6SMilanka Ringwald * @param service_name 64b442c9e6SMilanka Ringwald * @param service_provider_name 65b442c9e6SMilanka Ringwald */ 66b442c9e6SMilanka 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); 67b442c9e6SMilanka Ringwald 687050d2caSMilanka Ringwald /** 69fd58c900SMilanka Ringwald * @brief Initialize up A2DP Sink device. 707050d2caSMilanka Ringwald */ 717050d2caSMilanka Ringwald void a2dp_sink_init(void); 727050d2caSMilanka Ringwald 73fd58c900SMilanka Ringwald /** 74fd58c900SMilanka Ringwald * @brief Create a stream endpoint of type SINK, and register media codec by specifying its capabilities and the default configuration. 75fd58c900SMilanka Ringwald * @param media_type see avdtp_media_type_t values in avdtp.h (audio, video or multimedia) 76fd58c900SMilanka Ringwald * @param media_codec_type see avdtp_media_codec_type_t values in avdtp.h 77fd58c900SMilanka Ringwald * @param codec_capabilities media codec capabilities as defined in A2DP spec, section 4 - Audio Codec Interoperability Requirements. 78fd58c900SMilanka Ringwald * @param codec_capabilities_len media codec capabilities length 79fd58c900SMilanka Ringwald * @param codec_configuration default media codec configuration 80fd58c900SMilanka Ringwald * @param codec_configuration_len media codec configuration length 8188132161SMilanka Ringwald * @param out_local_seid Assigned stream endpoint ID used in further A2DP commands. 8288132161SMilanka Ringwald * 8388132161SMilanka Ringwald * @return status ERROR_CODE_SUCCESS if sucessful 84fd58c900SMilanka Ringwald */ 85fd58c900SMilanka Ringwald uint8_t a2dp_sink_create_stream_endpoint(avdtp_media_type_t media_type, avdtp_media_codec_type_t media_codec_type, 867050d2caSMilanka Ringwald uint8_t * codec_capabilities, uint16_t codec_capabilities_len, 8788132161SMilanka Ringwald uint8_t * codec_configuration, uint16_t codec_configuration_len, uint8_t * out_local_seid); 887050d2caSMilanka Ringwald 897050d2caSMilanka Ringwald /** 90fd58c900SMilanka Ringwald * @brief Register callback for the A2DP Sink client. It will receive following subevents of HCI_EVENT_A2DP_META HCI event type: 91fd58c900SMilanka Ringwald * - A2DP_SUBEVENT_SIGNALING_MEDIA_CODEC_SBC_CONFIGURATION: indicates from remote chosen SBC media codec configuration 92fd58c900SMilanka Ringwald * - A2DP_SUBEVENT_SIGNALING_MEDIA_CODEC_OTHER_CONFIGURATION: indicates from remote chosen other then SBC media codec configuration 93fd58c900SMilanka Ringwald * - A2DP_SUBEVENT_STREAM_ESTABLISHED: received when stream to a remote device is established 94fd58c900SMilanka Ringwald * - A2DP_SUBEVENT_STREAM_STARTED: received when stream is started 95fd58c900SMilanka Ringwald * - A2DP_SUBEVENT_STREAM_SUSPENDED: received when stream is paused 96133bececSMilanka Ringwald * - A2DP_SUBEVENT_STREAM_STOPED: received when stream is aborted or stopped 97fd58c900SMilanka Ringwald * - A2DP_SUBEVENT_STREAM_RELEASED: received when stream is released 98a466d508SMilanka Ringwald * - A2DP_SUBEVENT_SIGNALING_CONNECTION_RELEASED: received when signaling channel is disconnected 99fd58c900SMilanka Ringwald * 1007050d2caSMilanka Ringwald * @param callback 1017050d2caSMilanka Ringwald */ 1027050d2caSMilanka Ringwald void a2dp_sink_register_packet_handler(btstack_packet_handler_t callback); 1037050d2caSMilanka Ringwald 1047050d2caSMilanka Ringwald /** 1057050d2caSMilanka Ringwald * @brief Register media handler for the A2DP Sink client. 1067050d2caSMilanka Ringwald * @param callback 107fd58c900SMilanka Ringwald * @param packet 108fd58c900SMilanka Ringwald * @param size 1097050d2caSMilanka Ringwald */ 110fd58c900SMilanka Ringwald void a2dp_sink_register_media_handler(void (*callback)(uint8_t local_seid, uint8_t *packet, uint16_t size)); 1117050d2caSMilanka Ringwald 1127050d2caSMilanka Ringwald /** 113fd58c900SMilanka Ringwald * @brief Establish stream. 114fd58c900SMilanka Ringwald * @param remote 11588132161SMilanka Ringwald * @param local_seid ID of a local stream endpoint. 11688132161SMilanka Ringwald * @param out_a2dp_cid Assigned A2DP channel identifyer used for furhter A2DP commands. 1177050d2caSMilanka Ringwald */ 11888132161SMilanka Ringwald uint8_t a2dp_sink_establish_stream(bd_addr_t remote, uint8_t local_seid, uint16_t * out_a2dp_cid); 1197050d2caSMilanka Ringwald 1207050d2caSMilanka Ringwald /** 12188132161SMilanka Ringwald * @brief Release stream and disconnect from remote. 12288132161SMilanka Ringwald * @param a2dp_cid A2DP channel identifyer. 1237050d2caSMilanka Ringwald */ 1247050d2caSMilanka Ringwald void a2dp_sink_disconnect(uint16_t a2dp_cid); 125fd58c900SMilanka Ringwald 126b442c9e6SMilanka Ringwald /* API_END */ 127b442c9e6SMilanka Ringwald 1287050d2caSMilanka Ringwald 129b442c9e6SMilanka Ringwald #if defined __cplusplus 130b442c9e6SMilanka Ringwald } 131b442c9e6SMilanka Ringwald #endif 132b442c9e6SMilanka Ringwald 133*80e33422SMatthias Ringwald #endif // A2DP_SINK_H 134