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