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 4680e33422SMatthias Ringwald #ifndef A2DP_SINK_H 4780e33422SMatthias 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 * 828b94010eSMilanka Ringwald * @return local_stream_endpoint 83fd58c900SMilanka Ringwald */ 848b94010eSMilanka Ringwald avdtp_stream_endpoint_t * a2dp_sink_create_stream_endpoint(avdtp_media_type_t media_type, avdtp_media_codec_type_t media_codec_type, 857050d2caSMilanka Ringwald uint8_t * codec_capabilities, uint16_t codec_capabilities_len, 868b94010eSMilanka Ringwald uint8_t * codec_configuration, uint16_t codec_configuration_len); 877050d2caSMilanka Ringwald 887050d2caSMilanka Ringwald /** 89*17ddf501SMatthias Ringwald * @brief Unregister stream endpoint and free it's memory 90*17ddf501SMatthias Ringwald * @param stream_endpoint created by a2dp_sink_create_stream_endpoint 91*17ddf501SMatthias Ringwald */ 92*17ddf501SMatthias Ringwald void a2dp_sink_finalize_stream_endpoint(avdtp_stream_endpoint_t * stream_endpoint); 93*17ddf501SMatthias Ringwald 94*17ddf501SMatthias Ringwald /** 95fd58c900SMilanka Ringwald * @brief Register callback for the A2DP Sink client. It will receive following subevents of HCI_EVENT_A2DP_META HCI event type: 96fd58c900SMilanka Ringwald * - A2DP_SUBEVENT_SIGNALING_MEDIA_CODEC_SBC_CONFIGURATION: indicates from remote chosen SBC media codec configuration 97fd58c900SMilanka Ringwald * - A2DP_SUBEVENT_SIGNALING_MEDIA_CODEC_OTHER_CONFIGURATION: indicates from remote chosen other then SBC media codec configuration 98fd58c900SMilanka Ringwald * - A2DP_SUBEVENT_STREAM_ESTABLISHED: received when stream to a remote device is established 99fd58c900SMilanka Ringwald * - A2DP_SUBEVENT_STREAM_STARTED: received when stream is started 100fd58c900SMilanka Ringwald * - A2DP_SUBEVENT_STREAM_SUSPENDED: received when stream is paused 101133bececSMilanka Ringwald * - A2DP_SUBEVENT_STREAM_STOPED: received when stream is aborted or stopped 102fd58c900SMilanka Ringwald * - A2DP_SUBEVENT_STREAM_RELEASED: received when stream is released 103a466d508SMilanka Ringwald * - A2DP_SUBEVENT_SIGNALING_CONNECTION_RELEASED: received when signaling channel is disconnected 104fd58c900SMilanka Ringwald * 1057050d2caSMilanka Ringwald * @param callback 1067050d2caSMilanka Ringwald */ 1077050d2caSMilanka Ringwald void a2dp_sink_register_packet_handler(btstack_packet_handler_t callback); 1087050d2caSMilanka Ringwald 1097050d2caSMilanka Ringwald /** 1107050d2caSMilanka Ringwald * @brief Register media handler for the A2DP Sink client. 1117050d2caSMilanka Ringwald * @param callback 112fd58c900SMilanka Ringwald * @param packet 113fd58c900SMilanka Ringwald * @param size 1147050d2caSMilanka Ringwald */ 115fd58c900SMilanka Ringwald void a2dp_sink_register_media_handler(void (*callback)(uint8_t local_seid, uint8_t *packet, uint16_t size)); 1167050d2caSMilanka Ringwald 1177050d2caSMilanka Ringwald /** 118fd58c900SMilanka Ringwald * @brief Establish stream. 119fd58c900SMilanka Ringwald * @param remote 12088132161SMilanka Ringwald * @param local_seid ID of a local stream endpoint. 12188132161SMilanka Ringwald * @param out_a2dp_cid Assigned A2DP channel identifyer used for furhter A2DP commands. 1227050d2caSMilanka Ringwald */ 12388132161SMilanka Ringwald uint8_t a2dp_sink_establish_stream(bd_addr_t remote, uint8_t local_seid, uint16_t * out_a2dp_cid); 1247050d2caSMilanka Ringwald 1257050d2caSMilanka Ringwald /** 12688132161SMilanka Ringwald * @brief Release stream and disconnect from remote. 12788132161SMilanka Ringwald * @param a2dp_cid A2DP channel identifyer. 1287050d2caSMilanka Ringwald */ 1297050d2caSMilanka Ringwald void a2dp_sink_disconnect(uint16_t a2dp_cid); 130fd58c900SMilanka Ringwald 131b442c9e6SMilanka Ringwald /* API_END */ 132b442c9e6SMilanka Ringwald 1337050d2caSMilanka Ringwald 134b442c9e6SMilanka Ringwald #if defined __cplusplus 135b442c9e6SMilanka Ringwald } 136b442c9e6SMilanka Ringwald #endif 137b442c9e6SMilanka Ringwald 13880e33422SMatthias Ringwald #endif // A2DP_SINK_H 139