xref: /btstack/test/sbc/msbc_encoder_test.c (revision 747ec6460079331e99714eff78c32965deecf549)
1*747ec646SMilanka Ringwald /*
2*747ec646SMilanka Ringwald  * Copyright (C) 2014 BlueKitchen GmbH
3*747ec646SMilanka Ringwald  *
4*747ec646SMilanka Ringwald  * Redistribution and use in source and binary forms, with or without
5*747ec646SMilanka Ringwald  * modification, are permitted provided that the following conditions
6*747ec646SMilanka Ringwald  * are met:
7*747ec646SMilanka Ringwald  *
8*747ec646SMilanka Ringwald  * 1. Redistributions of source code must retain the above copyright
9*747ec646SMilanka Ringwald  *    notice, this list of conditions and the following disclaimer.
10*747ec646SMilanka Ringwald  * 2. Redistributions in binary form must reproduce the above copyright
11*747ec646SMilanka Ringwald  *    notice, this list of conditions and the following disclaimer in the
12*747ec646SMilanka Ringwald  *    documentation and/or other materials provided with the distribution.
13*747ec646SMilanka Ringwald  * 3. Neither the name of the copyright holders nor the names of
14*747ec646SMilanka Ringwald  *    contributors may be used to endorse or promote products derived
15*747ec646SMilanka Ringwald  *    from this software without specific prior written permission.
16*747ec646SMilanka Ringwald  * 4. Any redistribution, use, or modification is done solely for
17*747ec646SMilanka Ringwald  *    personal benefit and not for any commercial purpose or for
18*747ec646SMilanka Ringwald  *    monetary gain.
19*747ec646SMilanka Ringwald  *
20*747ec646SMilanka Ringwald  * THIS SOFTWARE IS PROVIDED BY BLUEKITCHEN GMBH AND CONTRIBUTORS
21*747ec646SMilanka Ringwald  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22*747ec646SMilanka Ringwald  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
23*747ec646SMilanka Ringwald  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL MATTHIAS
24*747ec646SMilanka Ringwald  * RINGWALD OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
25*747ec646SMilanka Ringwald  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
26*747ec646SMilanka Ringwald  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
27*747ec646SMilanka Ringwald  * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
28*747ec646SMilanka Ringwald  * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
29*747ec646SMilanka Ringwald  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
30*747ec646SMilanka Ringwald  * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
31*747ec646SMilanka Ringwald  * SUCH DAMAGE.
32*747ec646SMilanka Ringwald  *
33*747ec646SMilanka Ringwald  * Please inquire about commercial licensing options at
34*747ec646SMilanka Ringwald  * [email protected]
35*747ec646SMilanka Ringwald  *
36*747ec646SMilanka Ringwald  */
37*747ec646SMilanka Ringwald 
38*747ec646SMilanka Ringwald // *****************************************************************************
39*747ec646SMilanka Ringwald //
40*747ec646SMilanka Ringwald // SBC encoder tests
41*747ec646SMilanka Ringwald //
42*747ec646SMilanka Ringwald // *****************************************************************************
43*747ec646SMilanka Ringwald 
44*747ec646SMilanka Ringwald #include "btstack_config.h"
45*747ec646SMilanka Ringwald 
46*747ec646SMilanka Ringwald #include <stdint.h>
47*747ec646SMilanka Ringwald #include <stdio.h>
48*747ec646SMilanka Ringwald #include <stdlib.h>
49*747ec646SMilanka Ringwald #include <string.h>
50*747ec646SMilanka Ringwald #include <fcntl.h>
51*747ec646SMilanka Ringwald #include <unistd.h>
52*747ec646SMilanka Ringwald 
53*747ec646SMilanka Ringwald #include "btstack.h"
54*747ec646SMilanka Ringwald 
55*747ec646SMilanka Ringwald #include "hfp_msbc.h"
56*747ec646SMilanka Ringwald #include "btstack_sbc.h"
57*747ec646SMilanka Ringwald #include "wav_util.h"
58*747ec646SMilanka Ringwald 
59*747ec646SMilanka Ringwald static int16_t read_buffer[8*16*2];
60*747ec646SMilanka Ringwald static uint8_t output_buffer[24];
61*747ec646SMilanka Ringwald 
main(int argc,const char * argv[])62*747ec646SMilanka Ringwald int main (int argc, const char * argv[]){
63*747ec646SMilanka Ringwald     if (argc < 3){
64*747ec646SMilanka Ringwald         printf("Usage: %s WAV_FILE mSBC_FILE\n", argv[0]);
65*747ec646SMilanka Ringwald         return -1;
66*747ec646SMilanka Ringwald     }
67*747ec646SMilanka Ringwald 
68*747ec646SMilanka Ringwald     const char * wav_filename = argv[1];
69*747ec646SMilanka Ringwald     const char * sbc_filename = argv[2];
70*747ec646SMilanka Ringwald 
71*747ec646SMilanka Ringwald     if (wav_reader_open(wav_filename) != 0) {
72*747ec646SMilanka Ringwald         printf("Can't open file %s", wav_filename);
73*747ec646SMilanka Ringwald         return -1;
74*747ec646SMilanka Ringwald     }
75*747ec646SMilanka Ringwald 
76*747ec646SMilanka Ringwald     FILE * sbc_fd = fopen(sbc_filename, "wb");
77*747ec646SMilanka Ringwald     if (!sbc_fd) {
78*747ec646SMilanka Ringwald         printf("Can't open file %s", sbc_filename);
79*747ec646SMilanka Ringwald         return -1;
80*747ec646SMilanka Ringwald     }
81*747ec646SMilanka Ringwald 
82*747ec646SMilanka Ringwald     hfp_msbc_init();
83*747ec646SMilanka Ringwald     int num_samples = hfp_msbc_num_audio_samples_per_frame();
84*747ec646SMilanka Ringwald 
85*747ec646SMilanka Ringwald     while (1){
86*747ec646SMilanka Ringwald         if (hfp_msbc_can_encode_audio_frame_now()){
87*747ec646SMilanka Ringwald             int error = wav_reader_read_int16(num_samples, read_buffer);
88*747ec646SMilanka Ringwald             if (error) break;
89*747ec646SMilanka Ringwald 
90*747ec646SMilanka Ringwald             hfp_msbc_encode_audio_frame(read_buffer);
91*747ec646SMilanka Ringwald         }
92*747ec646SMilanka Ringwald         if (hfp_msbc_num_bytes_in_stream() >= sizeof(output_buffer)){
93*747ec646SMilanka Ringwald             hfp_msbc_read_from_stream(output_buffer, sizeof(output_buffer));
94*747ec646SMilanka Ringwald             fwrite(output_buffer, 1, sizeof(output_buffer), sbc_fd);
95*747ec646SMilanka Ringwald         }
96*747ec646SMilanka Ringwald     }
97*747ec646SMilanka Ringwald 
98*747ec646SMilanka Ringwald     printf("Done\n");
99*747ec646SMilanka Ringwald     wav_reader_close();
100*747ec646SMilanka Ringwald     fclose(sbc_fd);
101*747ec646SMilanka Ringwald     return 0;
102*747ec646SMilanka Ringwald }
103*747ec646SMilanka Ringwald 
104