123a1bbc3SMatthias Ringwald /* 223a1bbc3SMatthias Ringwald * Copyright (C) 2017 BlueKitchen GmbH 323a1bbc3SMatthias Ringwald * 423a1bbc3SMatthias Ringwald * Redistribution and use in source and binary forms, with or without 523a1bbc3SMatthias Ringwald * modification, are permitted provided that the following conditions 623a1bbc3SMatthias Ringwald * are met: 723a1bbc3SMatthias Ringwald * 823a1bbc3SMatthias Ringwald * 1. Redistributions of source code must retain the above copyright 923a1bbc3SMatthias Ringwald * notice, this list of conditions and the following disclaimer. 1023a1bbc3SMatthias Ringwald * 2. Redistributions in binary form must reproduce the above copyright 1123a1bbc3SMatthias Ringwald * notice, this list of conditions and the following disclaimer in the 1223a1bbc3SMatthias Ringwald * documentation and/or other materials provided with the distribution. 1323a1bbc3SMatthias Ringwald * 3. Neither the name of the copyright holders nor the names of 1423a1bbc3SMatthias Ringwald * contributors may be used to endorse or promote products derived 1523a1bbc3SMatthias Ringwald * from this software without specific prior written permission. 1623a1bbc3SMatthias Ringwald * 4. Any redistribution, use, or modification is done solely for 1723a1bbc3SMatthias Ringwald * personal benefit and not for any commercial purpose or for 1823a1bbc3SMatthias Ringwald * monetary gain. 1923a1bbc3SMatthias Ringwald * 2023a1bbc3SMatthias Ringwald * THIS SOFTWARE IS PROVIDED BY BLUEKITCHEN GMBH AND CONTRIBUTORS 2123a1bbc3SMatthias Ringwald * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 2223a1bbc3SMatthias 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, 2523a1bbc3SMatthias Ringwald * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, 2623a1bbc3SMatthias Ringwald * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS 2723a1bbc3SMatthias Ringwald * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED 2823a1bbc3SMatthias Ringwald * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, 2923a1bbc3SMatthias Ringwald * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF 3023a1bbc3SMatthias Ringwald * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 3123a1bbc3SMatthias Ringwald * SUCH DAMAGE. 3223a1bbc3SMatthias Ringwald * 3323a1bbc3SMatthias Ringwald * Please inquire about commercial licensing options at 3423a1bbc3SMatthias Ringwald * [email protected] 3523a1bbc3SMatthias Ringwald * 3623a1bbc3SMatthias Ringwald */ 3723a1bbc3SMatthias Ringwald 38fe5a6c4eSMilanka Ringwald /** 39fe5a6c4eSMilanka Ringwald * @title Audio Interface 40fe5a6c4eSMilanka Ringwald * 41fe5a6c4eSMilanka Ringwald * Abstraction layer for 16-bit audio playback and recording within BTstack. 42*b57bbaeeSMatthias Ringwald * 43*b57bbaeeSMatthias Ringwald * Most embedded implementations, e.g. the one for ESP32, use a single I2S interface which 44*b57bbaeeSMatthias Ringwald * requires that the sample rate is the same for sink and source roles 45fe5a6c4eSMilanka Ringwald */ 46fe5a6c4eSMilanka Ringwald 4780e33422SMatthias Ringwald #ifndef BTSTACK_AUDIO_H 4880e33422SMatthias Ringwald #define BTSTACK_AUDIO_H 4923a1bbc3SMatthias Ringwald 5023a1bbc3SMatthias Ringwald #include <stdint.h> 5123a1bbc3SMatthias Ringwald 5223a1bbc3SMatthias Ringwald #if defined __cplusplus 5323a1bbc3SMatthias Ringwald extern "C" { 5423a1bbc3SMatthias Ringwald #endif 5523a1bbc3SMatthias Ringwald 56fe5a6c4eSMilanka Ringwald /* API_START */ 5723a1bbc3SMatthias Ringwald 5823a1bbc3SMatthias Ringwald typedef struct { 5923a1bbc3SMatthias Ringwald 6023a1bbc3SMatthias Ringwald /** 6123a1bbc3SMatthias Ringwald * @brief Setup audio codec for specified samplerate and number of channels 6223a1bbc3SMatthias Ringwald * @param Channels (1=mono, 2=stereo) 6323a1bbc3SMatthias Ringwald * @param Sample rate 6423a1bbc3SMatthias Ringwald * @param Playback callback 65e39d945bSDirk Helbig * @return 1 on success 66e39d945bSDirk Helbig */ 67e39d945bSDirk Helbig int (*init)(uint8_t channels, 68e39d945bSDirk Helbig uint32_t samplerate, 69e39d945bSDirk Helbig void (*playback) (int16_t * buffer, uint16_t num_samples)); 70e39d945bSDirk Helbig 71e39d945bSDirk Helbig /** 721b7f8fa1SMatthias Ringwald * @brief Set volume 731b7f8fa1SMatthias Ringwald * @param Volume 0..127 741b7f8fa1SMatthias Ringwald */ 751b7f8fa1SMatthias Ringwald void (*set_volume)(uint8_t volume); 761b7f8fa1SMatthias Ringwald 771b7f8fa1SMatthias Ringwald /** 78e39d945bSDirk Helbig * @brief Start stream 79e39d945bSDirk Helbig */ 80e39d945bSDirk Helbig void (*start_stream)(void); 81e39d945bSDirk Helbig 82e39d945bSDirk Helbig /** 83e39d945bSDirk Helbig * @brief Stop stream 84e39d945bSDirk Helbig */ 85e39d945bSDirk Helbig void (*stop_stream)(void); 86e39d945bSDirk Helbig 87e39d945bSDirk Helbig /** 88e39d945bSDirk Helbig * @brief Close audio codec 89e39d945bSDirk Helbig */ 90e39d945bSDirk Helbig void (*close)(void); 91e39d945bSDirk Helbig 92e39d945bSDirk Helbig } btstack_audio_sink_t; 93e39d945bSDirk Helbig 94e39d945bSDirk Helbig 95e39d945bSDirk Helbig typedef struct { 96e39d945bSDirk Helbig 97e39d945bSDirk Helbig /** 98e39d945bSDirk Helbig * @brief Setup audio codec for specified samplerate and number of channels 99e39d945bSDirk Helbig * @param Channels (1=mono, 2=stereo) 100e39d945bSDirk Helbig * @param Sample rate 10123a1bbc3SMatthias Ringwald * @param Recording callback 10223a1bbc3SMatthias Ringwald * @return 1 on success 10323a1bbc3SMatthias Ringwald */ 10423a1bbc3SMatthias Ringwald int (*init)(uint8_t channels, 10523a1bbc3SMatthias Ringwald uint32_t samplerate, 10623a1bbc3SMatthias Ringwald void (*recording)(const int16_t * buffer, uint16_t num_samples)); 10723a1bbc3SMatthias Ringwald 10823a1bbc3SMatthias Ringwald /** 1091b7f8fa1SMatthias Ringwald * @brief Set Gain 1101b7f8fa1SMatthias Ringwald * @param Gain 0..127 1111b7f8fa1SMatthias Ringwald */ 1121b7f8fa1SMatthias Ringwald void (*set_gain)(uint8_t gain); 1131b7f8fa1SMatthias Ringwald 1141b7f8fa1SMatthias Ringwald /** 11523a1bbc3SMatthias Ringwald * @brief Start stream 11623a1bbc3SMatthias Ringwald */ 11723a1bbc3SMatthias Ringwald void (*start_stream)(void); 11823a1bbc3SMatthias Ringwald 11923a1bbc3SMatthias Ringwald /** 120e39d945bSDirk Helbig * @brief Stop stream 121e39d945bSDirk Helbig */ 122e39d945bSDirk Helbig void (*stop_stream)(void); 123e39d945bSDirk Helbig 124e39d945bSDirk Helbig /** 12523a1bbc3SMatthias Ringwald * @brief Close audio codec 12623a1bbc3SMatthias Ringwald */ 12723a1bbc3SMatthias Ringwald void (*close)(void); 12823a1bbc3SMatthias Ringwald 129e39d945bSDirk Helbig } btstack_audio_source_t; 130e39d945bSDirk Helbig 13123a1bbc3SMatthias Ringwald 13223a1bbc3SMatthias Ringwald /** 133e39d945bSDirk Helbig * @brief Get BTstack Audio Sink Instance 1346b65794dSMilanka Ringwald * @return btstack_audio_sink implementation 13523a1bbc3SMatthias Ringwald */ 136e39d945bSDirk Helbig const btstack_audio_sink_t * btstack_audio_sink_get_instance(void); 13723a1bbc3SMatthias Ringwald 13823a1bbc3SMatthias Ringwald /** 139e39d945bSDirk Helbig * @brief Get BTstack Audio Source Instance 1406b65794dSMilanka Ringwald * @return btstack_audio_source implementation 14123a1bbc3SMatthias Ringwald */ 142e39d945bSDirk Helbig const btstack_audio_source_t * btstack_audio_source_get_instance(void); 143e39d945bSDirk Helbig 144e39d945bSDirk Helbig 145e39d945bSDirk Helbig /** 146e39d945bSDirk Helbig * @brief Get BTstack Audio Sink Instance 147e39d945bSDirk Helbig * @param btstack_audio_sink implementation 148e39d945bSDirk Helbig */ 149e39d945bSDirk Helbig void btstack_audio_sink_set_instance(const btstack_audio_sink_t * audio_sink_impl); 150e39d945bSDirk Helbig 151e39d945bSDirk Helbig /** 152e39d945bSDirk Helbig * @brief Get BTstack Audio Source Instance 153e39d945bSDirk Helbig * @param btstack_audio_source implementation 154e39d945bSDirk Helbig */ 155e39d945bSDirk Helbig void btstack_audio_source_set_instance(const btstack_audio_source_t * audio_source_impl); 15623a1bbc3SMatthias Ringwald 15723a1bbc3SMatthias Ringwald 15823a1bbc3SMatthias Ringwald // common implementations 159e39d945bSDirk Helbig const btstack_audio_sink_t * btstack_audio_portaudio_sink_get_instance(void); 160e39d945bSDirk Helbig const btstack_audio_source_t * btstack_audio_portaudio_source_get_instance(void); 161e39d945bSDirk Helbig 16265ec5d42SMatthias Ringwald const btstack_audio_sink_t * btstack_audio_embedded_sink_get_instance(void); 16365ec5d42SMatthias Ringwald const btstack_audio_source_t * btstack_audio_embedded_source_get_instance(void); 16465ec5d42SMatthias Ringwald 16565ec5d42SMatthias Ringwald const btstack_audio_sink_t * btstack_audio_esp32_sink_get_instance(void); 166*b57bbaeeSMatthias Ringwald const btstack_audio_source_t * btstack_audio_esp32_source_get_instance(void); 167fe5a6c4eSMilanka Ringwald 168*b57bbaeeSMatthias Ringwald /* API_END */ 16923a1bbc3SMatthias Ringwald 17023a1bbc3SMatthias Ringwald #if defined __cplusplus 17123a1bbc3SMatthias Ringwald } 17223a1bbc3SMatthias Ringwald #endif 17323a1bbc3SMatthias Ringwald 17423a1bbc3SMatthias Ringwald #endif 175