xref: /btstack/src/classic/hfp_msbc.c (revision 5b4ff0f76de63bc37890a49a94815f4f09ac38e3)
1*5b4ff0f7SMilanka Ringwald /*
2*5b4ff0f7SMilanka Ringwald  * Copyright (C) 2014 BlueKitchen GmbH
3*5b4ff0f7SMilanka Ringwald  *
4*5b4ff0f7SMilanka Ringwald  * Redistribution and use in source and binary forms, with or without
5*5b4ff0f7SMilanka Ringwald  * modification, are permitted provided that the following conditions
6*5b4ff0f7SMilanka Ringwald  * are met:
7*5b4ff0f7SMilanka Ringwald  *
8*5b4ff0f7SMilanka Ringwald  * 1. Redistributions of source code must retain the above copyright
9*5b4ff0f7SMilanka Ringwald  *    notice, this list of conditions and the following disclaimer.
10*5b4ff0f7SMilanka Ringwald  * 2. Redistributions in binary form must reproduce the above copyright
11*5b4ff0f7SMilanka Ringwald  *    notice, this list of conditions and the following disclaimer in the
12*5b4ff0f7SMilanka Ringwald  *    documentation and/or other materials provided with the distribution.
13*5b4ff0f7SMilanka Ringwald  * 3. Neither the name of the copyright holders nor the names of
14*5b4ff0f7SMilanka Ringwald  *    contributors may be used to endorse or promote products derived
15*5b4ff0f7SMilanka Ringwald  *    from this software without specific prior written permission.
16*5b4ff0f7SMilanka Ringwald  * 4. Any redistribution, use, or modification is done solely for
17*5b4ff0f7SMilanka Ringwald  *    personal benefit and not for any commercial purpose or for
18*5b4ff0f7SMilanka Ringwald  *    monetary gain.
19*5b4ff0f7SMilanka Ringwald  *
20*5b4ff0f7SMilanka Ringwald  * THIS SOFTWARE IS PROVIDED BY BLUEKITCHEN GMBH AND CONTRIBUTORS
21*5b4ff0f7SMilanka Ringwald  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22*5b4ff0f7SMilanka Ringwald  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
23*5b4ff0f7SMilanka Ringwald  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL MATTHIAS
24*5b4ff0f7SMilanka Ringwald  * RINGWALD OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
25*5b4ff0f7SMilanka Ringwald  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
26*5b4ff0f7SMilanka Ringwald  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
27*5b4ff0f7SMilanka Ringwald  * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
28*5b4ff0f7SMilanka Ringwald  * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
29*5b4ff0f7SMilanka Ringwald  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
30*5b4ff0f7SMilanka Ringwald  * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
31*5b4ff0f7SMilanka Ringwald  * SUCH DAMAGE.
32*5b4ff0f7SMilanka Ringwald  *
33*5b4ff0f7SMilanka Ringwald  * Please inquire about commercial licensing options at
34*5b4ff0f7SMilanka Ringwald  * [email protected]
35*5b4ff0f7SMilanka Ringwald  *
36*5b4ff0f7SMilanka Ringwald  */
37*5b4ff0f7SMilanka Ringwald 
38*5b4ff0f7SMilanka Ringwald // *****************************************************************************
39*5b4ff0f7SMilanka Ringwald //
40*5b4ff0f7SMilanka Ringwald // HFP mSBC encoder wrapper
41*5b4ff0f7SMilanka Ringwald //
42*5b4ff0f7SMilanka Ringwald // *****************************************************************************
43*5b4ff0f7SMilanka Ringwald 
44*5b4ff0f7SMilanka Ringwald #include "btstack_config.h"
45*5b4ff0f7SMilanka Ringwald 
46*5b4ff0f7SMilanka Ringwald #include <string.h>
47*5b4ff0f7SMilanka Ringwald 
48*5b4ff0f7SMilanka Ringwald #include "btstack_debug.h"
49*5b4ff0f7SMilanka Ringwald #include "btstack_sbc_encoder.h"
50*5b4ff0f7SMilanka Ringwald #include "hfp_msbc.h"
51*5b4ff0f7SMilanka Ringwald 
52*5b4ff0f7SMilanka Ringwald #define MSBC_FRAME_SIZE 57
53*5b4ff0f7SMilanka Ringwald 
54*5b4ff0f7SMilanka Ringwald static btstack_sbc_encoder_state_t state;
55*5b4ff0f7SMilanka Ringwald static uint8_t msbc_padding[] = {0,0,0};
56*5b4ff0f7SMilanka Ringwald 
57*5b4ff0f7SMilanka Ringwald static uint8_t msbc_buffer[2*(MSBC_FRAME_SIZE + sizeof(msbc_padding))];
58*5b4ff0f7SMilanka Ringwald static int msbc_buffer_offset = 0;
59*5b4ff0f7SMilanka Ringwald 
60*5b4ff0f7SMilanka Ringwald void hfp_msbc_init(void){
61*5b4ff0f7SMilanka Ringwald     btstack_sbc_encoder_init(&state, SBC_MODE_mSBC, 16, 8, 0, 16000, 26);
62*5b4ff0f7SMilanka Ringwald     msbc_buffer_offset = 0;
63*5b4ff0f7SMilanka Ringwald }
64*5b4ff0f7SMilanka Ringwald 
65*5b4ff0f7SMilanka Ringwald int hfp_msbc_can_encode_audio_frame_now(void){
66*5b4ff0f7SMilanka Ringwald     return sizeof(msbc_buffer) - msbc_buffer_offset >= MSBC_FRAME_SIZE + sizeof(msbc_padding);
67*5b4ff0f7SMilanka Ringwald }
68*5b4ff0f7SMilanka Ringwald 
69*5b4ff0f7SMilanka Ringwald void hfp_msbc_encode_audio_frame(int16_t * pcm_samples){
70*5b4ff0f7SMilanka Ringwald     if (!hfp_msbc_can_encode_audio_frame_now()) return;
71*5b4ff0f7SMilanka Ringwald 
72*5b4ff0f7SMilanka Ringwald     btstack_sbc_encoder_process_data(pcm_samples);
73*5b4ff0f7SMilanka Ringwald 
74*5b4ff0f7SMilanka Ringwald     memcpy(msbc_buffer + msbc_buffer_offset, msbc_padding, sizeof(msbc_padding));
75*5b4ff0f7SMilanka Ringwald     msbc_buffer_offset += sizeof(msbc_padding);
76*5b4ff0f7SMilanka Ringwald 
77*5b4ff0f7SMilanka Ringwald     memcpy(msbc_buffer + msbc_buffer_offset, btstack_sbc_encoder_sbc_buffer(), MSBC_FRAME_SIZE);
78*5b4ff0f7SMilanka Ringwald     msbc_buffer_offset += MSBC_FRAME_SIZE;
79*5b4ff0f7SMilanka Ringwald }
80*5b4ff0f7SMilanka Ringwald 
81*5b4ff0f7SMilanka Ringwald void hfp_msbc_read_from_stream(uint8_t * buf, int size){
82*5b4ff0f7SMilanka Ringwald     int bytes_to_copy = size;
83*5b4ff0f7SMilanka Ringwald     if (size > msbc_buffer_offset){
84*5b4ff0f7SMilanka Ringwald         bytes_to_copy = msbc_buffer_offset;
85*5b4ff0f7SMilanka Ringwald         log_error("sbc frame storage is smaller then the output buffer");
86*5b4ff0f7SMilanka Ringwald         return;
87*5b4ff0f7SMilanka Ringwald     }
88*5b4ff0f7SMilanka Ringwald 
89*5b4ff0f7SMilanka Ringwald     memcpy(buf, msbc_buffer, bytes_to_copy);
90*5b4ff0f7SMilanka Ringwald     memmove(msbc_buffer, msbc_buffer + bytes_to_copy, sizeof(msbc_buffer) - bytes_to_copy);
91*5b4ff0f7SMilanka Ringwald     msbc_buffer_offset -= bytes_to_copy;
92*5b4ff0f7SMilanka Ringwald }
93*5b4ff0f7SMilanka Ringwald 
94*5b4ff0f7SMilanka Ringwald int hfp_msbc_num_bytes_in_stream(void){
95*5b4ff0f7SMilanka Ringwald     return msbc_buffer_offset;
96*5b4ff0f7SMilanka Ringwald }
97*5b4ff0f7SMilanka Ringwald 
98*5b4ff0f7SMilanka Ringwald int hfp_msbc_num_audio_samples_per_frame(void){
99*5b4ff0f7SMilanka Ringwald     return btstack_sbc_encoder_num_audio_samples();
100*5b4ff0f7SMilanka Ringwald }
101*5b4ff0f7SMilanka Ringwald 
102*5b4ff0f7SMilanka Ringwald 
103