1 /***************************************************************************
3 * Open \______ \ ____ ____ | | _\_ |__ _______ ___
4 * Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
5 * Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
6 * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
10 * Copyright (C) 2009 Yoshihisa Uchida
12 * This program is free software; you can redistribute it and/or
13 * modify it under the terms of the GNU General Public License
14 * as published by the Free Software Foundation; either version 2
15 * of the License, or (at your option) any later version.
17 * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
18 * KIND, either express or implied.
20 ****************************************************************************/
21 #ifndef CODEC_LIBPCM_PCM_COMMON_H
22 #define CODEC_LIBPCM_PCM_COMMON_H
27 /* decoded pcm sample depth (sample 28bit + sign 1bit) */
28 #define PCM_OUTPUT_DEPTH 29
30 /* Macro that sign extends an unsigned byte */
31 #define SE(x) ((int32_t)((int8_t)(x)))
33 /* Macro that shift to -0x80. (0 .. 127 to -128 .. -1, 128 .. 255 to 0 .. 127) */
34 #define SFT(x) ((int32_t)x-0x80)
36 /* Macro that clipping data */
37 #define CLIP(data, min, max) \
38 if ((data) > (max)) data = max; \
39 else if ((data) < (min)) data = min;
41 /* nums of msadpcm coeffs
42 * In many case, nNumCoef is 7.
43 * Depending upon the encoder, as for this value there is a possibility
45 * If you found the file where this value exceeds 7, please report.
47 #define MSADPCM_NUM_COEFF 7
51 * RIFF: wFormatTag (in 'fmt ' chunk)
52 * AIFF: compressionType (in 'COMM' chunk)
57 * RIFF: wChannels (in 'fmt ' chunk)
58 * AIFF: numChannels (in 'COMM' chunk)
63 * RIFF: dwSamplesPerSec (in 'fmt ' chunk)
64 * AIFF: sampleRate (in 'COMM' chunk)
66 uint32_t samplespersec
;
68 /* RIFF: dwAvgBytesPerSec (in 'fmt ' chunk) */
69 uint32_t avgbytespersec
;
72 * RIFF: wBlockAlign (in 'fmt ' chunk)
73 * AIFF: blockSize (in 'SSND' chunk)
78 * RIFF: wBitsPerSample (in 'fmt ' chunk)
79 * AIFF: sampleSize (in 'COMM' chunk)
81 uint16_t bitspersample
;
83 /* RIFF: wSize (in 'fmt ' chunk) */
86 /* RIFF: dSamplesPerBlock (in 'fmt ' chunk) */
87 uint16_t samplesperblock
;
89 /* RIFF: wTotalSamples (in 'fact' chunk) */
90 uint16_t totalsamples
;
92 /* the following values are not RIFF/AIFF chunk values */
94 /* bytes per sample */
105 * true: little endian, false: big endian
107 bool is_little_endian
;
111 * true: signed, false: unsigned
115 /* the following values are format speciffic parameters */
117 /* microsoft adpcm: aCoeff */
118 int16_t coeffs
[MSADPCM_NUM_COEFF
][2];
126 #define PCM_SEEK_TIME 0
127 #define PCM_SEEK_POS 1
131 * sets the format speciffic RIFF/AIFF header information and checks the pcm_format.
134 * the structure which supplies RIFF/AIFF header information.
137 * true: RIFF/AIFF header check OK
138 * false: RIFF/AIFF header check NG
140 bool (*set_format
)(struct pcm_format
*format
);
146 * seek time [ms] or seek position
149 * if seek_mode sets PCM_SEEK_TIME, then seek_val means the seek time.
150 * if seek_mode sets PCM_SEEK_POS, then seek_val means the seek position.
153 * the function which reads the data from the file (chunksize bytes read).
156 * position after the seeking.
158 struct pcm_pos
*(*get_seek_pos
)(uint32_t seek_val
, int seek_mode
,
159 uint8_t *(*read_buffer
)(size_t *realsize
));
165 * the start pointer of wave data buffer.
168 * wave data buffer size (bytes).
171 * the start pointer of the buffer which supplies decoded pcm data.
174 * decoded pcm data count.
177 * CODEC_OK: decode succeed.
178 * CODEC_ERROR: decode failure.
180 int (*decode
)(const uint8_t *inbuf
, size_t inbufsize
,
181 int32_t *outbuf
, int *outbufcount
);
186 const struct pcm_codec
*(*get_codec
)(void);