xref: /btstack/src/btstack_audio.h (revision b57bbaee1035845711da07857d4b1760f516c8a2)
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