xref: /btstack/src/btstack_audio.h (revision 6b65794db8e2b018da30909c31e5ce969914bcea)
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
2323a1bbc3SMatthias Ringwald  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL MATTHIAS
2423a1bbc3SMatthias Ringwald  * RINGWALD 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.
42fe5a6c4eSMilanka Ringwald  */
43fe5a6c4eSMilanka Ringwald 
4480e33422SMatthias Ringwald #ifndef BTSTACK_AUDIO_H
4580e33422SMatthias Ringwald #define BTSTACK_AUDIO_H
4623a1bbc3SMatthias Ringwald 
4723a1bbc3SMatthias Ringwald #include <stdint.h>
4823a1bbc3SMatthias Ringwald 
4923a1bbc3SMatthias Ringwald #if defined __cplusplus
5023a1bbc3SMatthias Ringwald extern "C" {
5123a1bbc3SMatthias Ringwald #endif
5223a1bbc3SMatthias Ringwald 
53fe5a6c4eSMilanka Ringwald /* API_START */
5423a1bbc3SMatthias Ringwald 
5523a1bbc3SMatthias Ringwald typedef struct {
5623a1bbc3SMatthias Ringwald 
5723a1bbc3SMatthias Ringwald     /**
5823a1bbc3SMatthias Ringwald      * @brief Setup audio codec for specified samplerate and number of channels
5923a1bbc3SMatthias Ringwald      * @param Channels (1=mono, 2=stereo)
6023a1bbc3SMatthias Ringwald      * @param Sample rate
6123a1bbc3SMatthias Ringwald      * @param Playback callback
62e39d945bSDirk Helbig      * @return 1 on success
63e39d945bSDirk Helbig      */
64e39d945bSDirk Helbig     int (*init)(uint8_t channels,
65e39d945bSDirk Helbig                 uint32_t samplerate,
66e39d945bSDirk Helbig                 void (*playback) (int16_t * buffer, uint16_t num_samples));
67e39d945bSDirk Helbig 
68e39d945bSDirk Helbig     /**
691b7f8fa1SMatthias Ringwald      * @brief Set volume
701b7f8fa1SMatthias Ringwald      * @param Volume 0..127
711b7f8fa1SMatthias Ringwald      */
721b7f8fa1SMatthias Ringwald     void (*set_volume)(uint8_t volume);
731b7f8fa1SMatthias Ringwald 
741b7f8fa1SMatthias Ringwald     /**
75e39d945bSDirk Helbig      * @brief Start stream
76e39d945bSDirk Helbig      */
77e39d945bSDirk Helbig     void (*start_stream)(void);
78e39d945bSDirk Helbig 
79e39d945bSDirk Helbig     /**
80e39d945bSDirk Helbig      * @brief Stop stream
81e39d945bSDirk Helbig      */
82e39d945bSDirk Helbig     void (*stop_stream)(void);
83e39d945bSDirk Helbig 
84e39d945bSDirk Helbig     /**
85e39d945bSDirk Helbig      * @brief Close audio codec
86e39d945bSDirk Helbig      */
87e39d945bSDirk Helbig     void (*close)(void);
88e39d945bSDirk Helbig 
89e39d945bSDirk Helbig } btstack_audio_sink_t;
90e39d945bSDirk Helbig 
91e39d945bSDirk Helbig 
92e39d945bSDirk Helbig typedef struct {
93e39d945bSDirk Helbig 
94e39d945bSDirk Helbig     /**
95e39d945bSDirk Helbig      * @brief Setup audio codec for specified samplerate and number of channels
96e39d945bSDirk Helbig      * @param Channels (1=mono, 2=stereo)
97e39d945bSDirk Helbig      * @param Sample rate
9823a1bbc3SMatthias Ringwald      * @param Recording callback
9923a1bbc3SMatthias Ringwald      * @return 1 on success
10023a1bbc3SMatthias Ringwald      */
10123a1bbc3SMatthias Ringwald     int (*init)(uint8_t channels,
10223a1bbc3SMatthias Ringwald                 uint32_t samplerate,
10323a1bbc3SMatthias Ringwald                 void (*recording)(const int16_t * buffer, uint16_t num_samples));
10423a1bbc3SMatthias Ringwald 
10523a1bbc3SMatthias Ringwald     /**
1061b7f8fa1SMatthias Ringwald      * @brief Set Gain
1071b7f8fa1SMatthias Ringwald      * @param Gain 0..127
1081b7f8fa1SMatthias Ringwald      */
1091b7f8fa1SMatthias Ringwald     void (*set_gain)(uint8_t gain);
1101b7f8fa1SMatthias Ringwald 
1111b7f8fa1SMatthias Ringwald     /**
11223a1bbc3SMatthias Ringwald      * @brief Start stream
11323a1bbc3SMatthias Ringwald      */
11423a1bbc3SMatthias Ringwald     void (*start_stream)(void);
11523a1bbc3SMatthias Ringwald 
11623a1bbc3SMatthias Ringwald     /**
117e39d945bSDirk Helbig      * @brief Stop stream
118e39d945bSDirk Helbig      */
119e39d945bSDirk Helbig     void (*stop_stream)(void);
120e39d945bSDirk Helbig 
121e39d945bSDirk Helbig     /**
12223a1bbc3SMatthias Ringwald      * @brief Close audio codec
12323a1bbc3SMatthias Ringwald      */
12423a1bbc3SMatthias Ringwald     void (*close)(void);
12523a1bbc3SMatthias Ringwald 
126e39d945bSDirk Helbig } btstack_audio_source_t;
127e39d945bSDirk Helbig 
12823a1bbc3SMatthias Ringwald 
12923a1bbc3SMatthias Ringwald /**
130e39d945bSDirk Helbig  * @brief Get BTstack Audio Sink Instance
131*6b65794dSMilanka Ringwald  * @return btstack_audio_sink implementation
13223a1bbc3SMatthias Ringwald  */
133e39d945bSDirk Helbig const btstack_audio_sink_t * btstack_audio_sink_get_instance(void);
13423a1bbc3SMatthias Ringwald 
13523a1bbc3SMatthias Ringwald /**
136e39d945bSDirk Helbig  * @brief Get BTstack Audio Source Instance
137*6b65794dSMilanka Ringwald  * @return btstack_audio_source implementation
13823a1bbc3SMatthias Ringwald  */
139e39d945bSDirk Helbig const btstack_audio_source_t * btstack_audio_source_get_instance(void);
140e39d945bSDirk Helbig 
141e39d945bSDirk Helbig 
142e39d945bSDirk Helbig /**
143e39d945bSDirk Helbig  * @brief Get BTstack Audio Sink Instance
144e39d945bSDirk Helbig  * @param btstack_audio_sink implementation
145e39d945bSDirk Helbig  */
146e39d945bSDirk Helbig void btstack_audio_sink_set_instance(const btstack_audio_sink_t * audio_sink_impl);
147e39d945bSDirk Helbig 
148e39d945bSDirk Helbig /**
149e39d945bSDirk Helbig  * @brief Get BTstack Audio Source Instance
150e39d945bSDirk Helbig  * @param btstack_audio_source implementation
151e39d945bSDirk Helbig  */
152e39d945bSDirk Helbig void btstack_audio_source_set_instance(const btstack_audio_source_t * audio_source_impl);
15323a1bbc3SMatthias Ringwald 
15423a1bbc3SMatthias Ringwald 
15523a1bbc3SMatthias Ringwald // common implementations
156e39d945bSDirk Helbig const btstack_audio_sink_t *   btstack_audio_portaudio_sink_get_instance(void);
157e39d945bSDirk Helbig const btstack_audio_source_t * btstack_audio_portaudio_source_get_instance(void);
158e39d945bSDirk Helbig 
15965ec5d42SMatthias Ringwald const btstack_audio_sink_t *   btstack_audio_embedded_sink_get_instance(void);
16065ec5d42SMatthias Ringwald const btstack_audio_source_t * btstack_audio_embedded_source_get_instance(void);
16165ec5d42SMatthias Ringwald 
16265ec5d42SMatthias Ringwald const btstack_audio_sink_t *   btstack_audio_esp32_sink_get_instance(void);
163fe5a6c4eSMilanka Ringwald /* API_END */
164fe5a6c4eSMilanka Ringwald 
16565ec5d42SMatthias Ringwald // const btstack_audio_source_t *   btstack_audio_esp32_source_get_instance(void);
16623a1bbc3SMatthias Ringwald 
16723a1bbc3SMatthias Ringwald #if defined __cplusplus
16823a1bbc3SMatthias Ringwald }
16923a1bbc3SMatthias Ringwald #endif
17023a1bbc3SMatthias Ringwald 
17123a1bbc3SMatthias Ringwald #endif
172