annotate shorten.c @ 2956:5f51b1e0bed6 libavcodec

Cook compatibe decoder, patch by Benjamin Larsson Add cook demucing, change rm demuxer so that it reorders audio packets before sending them to the decoder, and send minimum decodeable sized packets; pass only real codec extradata fo the decoder Fix 28_8 decoder for the new demuxer strategy
author rtognimp
date Fri, 09 Dec 2005 16:08:18 +0000
parents b47af698085e
children 0b546eab515d
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
2525
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
1 /*
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
2 * Shorten decoder
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
3 * Copyright (c) 2005 Jeff Muizelaar
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
4 *
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
5 * This library is free software; you can redistribute it and/or
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
6 * modify it under the terms of the GNU Lesser General Public
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
7 * License as published by the Free Software Foundation; either
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
8 * version 2 of the License, or (at your option) any later version.
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
9 *
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
10 * This library is distributed in the hope that it will be useful,
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
13 * Lesser General Public License for more details.
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
14 *
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
15 * You should have received a copy of the GNU Lesser General Public
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
16 * License along with this library; if not, write to the Free Software
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
17 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
18 */
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
19
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
20 /**
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
21 * @file shorten.c
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
22 * Shorten decoder
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
23 * @author Jeff Muizelaar
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
24 *
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
25 */
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
26
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
27 #define DEBUG
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
28 #include <limits.h>
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
29 #include "avcodec.h"
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
30 #include "bitstream.h"
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
31 #include "golomb.h"
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
32
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
33 #define MAX_CHANNELS 8
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
34 #define MAX_BLOCKSIZE 65535
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
35
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
36 #define OUT_BUFFER_SIZE 16384
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
37
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
38 #define ULONGSIZE 2
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
39
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
40 #define WAVE_FORMAT_PCM 0x0001
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
41
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
42 #define DEFAULT_BLOCK_SIZE 256
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
43
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
44 #define TYPESIZE 4
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
45 #define CHANSIZE 0
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
46 #define LPCQSIZE 2
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
47 #define ENERGYSIZE 3
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
48 #define BITSHIFTSIZE 2
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
49
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
50 #define TYPE_S16HL 3
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
51 #define TYPE_S16LH 5
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
52
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
53 #define NWRAP 3
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
54 #define NSKIPSIZE 1
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
55
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
56 #define LPCQUANT 5
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
57 #define V2LPCQOFFSET (1 << LPCQUANT)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
58
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
59 #define FNSIZE 2
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
60 #define FN_DIFF0 0
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
61 #define FN_DIFF1 1
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
62 #define FN_DIFF2 2
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
63 #define FN_DIFF3 3
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
64 #define FN_QUIT 4
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
65 #define FN_BLOCKSIZE 5
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
66 #define FN_BITSHIFT 6
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
67 #define FN_QLPC 7
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
68 #define FN_ZERO 8
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
69 #define FN_VERBATIM 9
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
70
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
71 #define VERBATIM_CKSIZE_SIZE 5
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
72 #define VERBATIM_BYTE_SIZE 8
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
73 #define CANONICAL_HEADER_SIZE 44
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
74
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
75 typedef struct ShortenContext {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
76 AVCodecContext *avctx;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
77 GetBitContext gb;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
78
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
79 int min_framesize, max_framesize;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
80 int channels;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
81
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
82 int32_t *decoded[MAX_CHANNELS];
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
83 int32_t *offset[MAX_CHANNELS];
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
84 uint8_t *bitstream;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
85 int bitstream_size;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
86 int bitstream_index;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
87 int allocated_bitstream_size;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
88 int header_size;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
89 uint8_t header[OUT_BUFFER_SIZE];
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
90 int version;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
91 int cur_chan;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
92 int bitshift;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
93 int nmean;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
94 int internal_ftype;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
95 int nwrap;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
96 int blocksize;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
97 int bitindex;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
98 int32_t lpcqoffset;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
99 } ShortenContext;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
100
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
101 static int shorten_decode_init(AVCodecContext * avctx)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
102 {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
103 ShortenContext *s = avctx->priv_data;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
104 s->avctx = avctx;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
105
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
106 return 0;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
107 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
108
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
109 static void allocate_buffers(ShortenContext *s)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
110 {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
111 int i, chan;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
112 for (chan=0; chan<s->channels; chan++) {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
113 s->offset[chan] = av_realloc(s->offset[chan], sizeof(int32_t)*FFMAX(1, s->nmean));
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
114
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
115 s->decoded[chan] = av_realloc(s->decoded[chan], sizeof(int32_t)*(s->blocksize + s->nwrap));
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
116 for (i=0; i<s->nwrap; i++)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
117 s->decoded[chan][i] = 0;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
118 s->decoded[chan] += s->nwrap;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
119
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
120 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
121 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
122
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
123
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
124 static inline unsigned int get_uint(ShortenContext *s, int k)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
125 {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
126 if (s->version != 0)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
127 k = get_ur_golomb_shorten(&s->gb, ULONGSIZE);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
128 return get_ur_golomb_shorten(&s->gb, k);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
129 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
130
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
131
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
132 static void fix_bitshift(ShortenContext *s, int32_t *buffer)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
133 {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
134 int i;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
135
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
136 if (s->bitshift != 0)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
137 for (i = 0; i < s->blocksize; i++)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
138 buffer[s->nwrap + i] <<= s->bitshift;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
139 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
140
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
141
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
142 static void init_offset(ShortenContext *s)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
143 {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
144 int32_t mean = 0;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
145 int chan, i;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
146 int nblock = FFMAX(1, s->nmean);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
147 /* initialise offset */
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
148 switch (s->internal_ftype)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
149 {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
150 case TYPE_S16HL:
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
151 case TYPE_S16LH:
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
152 mean = 0;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
153 break;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
154 default:
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
155 av_log(s->avctx, AV_LOG_ERROR, "unknown audio type");
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
156 abort();
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
157 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
158
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
159 for (chan = 0; chan < s->channels; chan++)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
160 for (i = 0; i < nblock; i++)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
161 s->offset[chan][i] = mean;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
162 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
163
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
164 static int inline get_le32(GetBitContext *gb)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
165 {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
166 return bswap_32(get_bits_long(gb, 32));
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
167 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
168
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
169 static short inline get_le16(GetBitContext *gb)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
170 {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
171 return bswap_16(get_bits_long(gb, 16));
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
172 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
173
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
174 static int decode_wave_header(AVCodecContext *avctx, uint8_t *header, int header_size)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
175 {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
176 GetBitContext hb;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
177 int len;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
178 int chunk_size;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
179 short wave_format;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
180
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
181 init_get_bits(&hb, header, header_size*8);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
182 if (get_le32(&hb) != MKTAG('R','I','F','F')) {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
183 av_log(avctx, AV_LOG_ERROR, "missing RIFF tag\n");
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
184 return -1;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
185 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
186
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
187 chunk_size = get_le32(&hb);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
188
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
189 if (get_le32(&hb) != MKTAG('W','A','V','E')) {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
190 av_log(avctx, AV_LOG_ERROR, "missing WAVE tag\n");
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
191 return -1;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
192 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
193
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
194 while (get_le32(&hb) != MKTAG('f','m','t',' ')) {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
195 len = get_le32(&hb);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
196 skip_bits(&hb, 8*len);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
197 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
198 len = get_le32(&hb);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
199
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
200 if (len < 16) {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
201 av_log(avctx, AV_LOG_ERROR, "fmt chunk was too short\n");
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
202 return -1;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
203 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
204
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
205 wave_format = get_le16(&hb);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
206
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
207 switch (wave_format) {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
208 case WAVE_FORMAT_PCM:
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
209 break;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
210 default:
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
211 av_log(avctx, AV_LOG_ERROR, "unsupported wave format\n");
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
212 return -1;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
213 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
214
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
215 avctx->channels = get_le16(&hb);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
216 avctx->sample_rate = get_le32(&hb);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
217 avctx->bit_rate = get_le32(&hb) * 8;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
218 avctx->block_align = get_le16(&hb);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
219 avctx->bits_per_sample = get_le16(&hb);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
220
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
221 if (avctx->bits_per_sample != 16) {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
222 av_log(avctx, AV_LOG_ERROR, "unsupported number of bits per sample\n");
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
223 return -1;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
224 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
225
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
226 len -= 16;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
227 if (len > 0)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
228 av_log(avctx, AV_LOG_INFO, "%d header bytes unparsed\n", len);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
229
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
230 return 0;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
231 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
232
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
233 static int16_t * interleave_buffer(int16_t *samples, int nchan, int blocksize, int32_t **buffer) {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
234 int i, chan;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
235 for (i=0; i<blocksize; i++)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
236 for (chan=0; chan < nchan; chan++)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
237 *samples++ = FFMIN(buffer[chan][i], 32768);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
238 return samples;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
239 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
240
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
241 static void decode_subframe_lpc(ShortenContext *s, int channel, int residual_size, int pred_order)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
242 {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
243 int sum, i, j;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
244 int coeffs[pred_order];
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
245
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
246 for (i=0; i<pred_order; i++)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
247 coeffs[i] = get_sr_golomb_shorten(&s->gb, LPCQUANT);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
248
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
249 for (i=0; i < s->blocksize; i++) {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
250 sum = s->lpcqoffset;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
251 for (j=0; j<pred_order; j++)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
252 sum += coeffs[j] * s->decoded[channel][i-j-1];
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
253 s->decoded[channel][i] = get_sr_golomb_shorten(&s->gb, residual_size) + (sum >> LPCQUANT);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
254 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
255 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
256
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
257
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
258 static int shorten_decode_frame(AVCodecContext *avctx,
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
259 void *data, int *data_size,
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
260 uint8_t *buf, int buf_size)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
261 {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
262 ShortenContext *s = avctx->priv_data;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
263 int i, input_buf_size = 0;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
264 int16_t *samples = data;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
265 if(s->max_framesize == 0){
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
266 s->max_framesize= 1024; // should hopefully be enough for the first header
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
267 s->bitstream= av_fast_realloc(s->bitstream, &s->allocated_bitstream_size, s->max_framesize);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
268 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
269
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
270 if(1 && s->max_framesize){//FIXME truncated
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
271 buf_size= FFMIN(buf_size, s->max_framesize - s->bitstream_size);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
272 input_buf_size= buf_size;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
273
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
274 if(s->bitstream_index + s->bitstream_size + buf_size > s->allocated_bitstream_size){
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
275 // printf("memmove\n");
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
276 memmove(s->bitstream, &s->bitstream[s->bitstream_index], s->bitstream_size);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
277 s->bitstream_index=0;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
278 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
279 memcpy(&s->bitstream[s->bitstream_index + s->bitstream_size], buf, buf_size);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
280 buf= &s->bitstream[s->bitstream_index];
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
281 buf_size += s->bitstream_size;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
282 s->bitstream_size= buf_size;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
283
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
284 if(buf_size < s->max_framesize){
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
285 //dprintf("wanna more data ... %d\n", buf_size);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
286 return input_buf_size;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
287 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
288 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
289 init_get_bits(&s->gb, buf, buf_size*8);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
290 get_bits(&s->gb, s->bitindex);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
291 if (!s->blocksize)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
292 {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
293 int maxnlpc = 0;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
294 /* shorten signature */
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
295 if (get_bits_long(&s->gb, 32) != bswap_32(ff_get_fourcc("ajkg"))) {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
296 av_log(s->avctx, AV_LOG_ERROR, "missing shorten magic 'ajkg'\n");
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
297 return -1;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
298 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
299
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
300 s->lpcqoffset = 0;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
301 s->blocksize = DEFAULT_BLOCK_SIZE;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
302 s->channels = 1;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
303 s->nmean = -1;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
304 s->version = get_bits(&s->gb, 8);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
305 s->internal_ftype = get_uint(s, TYPESIZE);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
306
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
307 s->channels = get_uint(s, CHANSIZE);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
308 if (s->channels > MAX_CHANNELS) {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
309 av_log(s->avctx, AV_LOG_ERROR, "too many channels: %d\n", s->channels);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
310 return -1;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
311 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
312
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
313 /* get blocksize if version > 0 */
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
314 if (s->version > 0) {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
315 int skip_bytes;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
316 s->blocksize = get_uint(s, av_log2(DEFAULT_BLOCK_SIZE));
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
317 maxnlpc = get_uint(s, LPCQSIZE);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
318 s->nmean = get_uint(s, 0);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
319
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
320 skip_bytes = get_uint(s, NSKIPSIZE);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
321 for (i=0; i<skip_bytes; i++) {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
322 skip_bits(&s->gb, 8);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
323 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
324 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
325 s->nwrap = FFMAX(NWRAP, maxnlpc);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
326
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
327 allocate_buffers(s);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
328
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
329 init_offset(s);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
330
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
331 if (s->version > 1)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
332 s->lpcqoffset = V2LPCQOFFSET;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
333
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
334 if (get_ur_golomb_shorten(&s->gb, FNSIZE) != FN_VERBATIM) {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
335 av_log(s->avctx, AV_LOG_ERROR, "missing verbatim section at begining of stream\n");
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
336 return -1;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
337 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
338
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
339 s->header_size = get_ur_golomb_shorten(&s->gb, VERBATIM_CKSIZE_SIZE);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
340 if (s->header_size >= OUT_BUFFER_SIZE || s->header_size < CANONICAL_HEADER_SIZE) {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
341 av_log(s->avctx, AV_LOG_ERROR, "header is wrong size: %d\n", s->header_size);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
342 return -1;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
343 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
344
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
345 for (i=0; i<s->header_size; i++)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
346 s->header[i] = (char)get_ur_golomb_shorten(&s->gb, VERBATIM_BYTE_SIZE);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
347
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
348 if (decode_wave_header(avctx, s->header, s->header_size) < 0)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
349 return -1;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
350
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
351 s->cur_chan = 0;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
352 s->bitshift = 0;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
353 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
354 else
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
355 {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
356 int cmd;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
357 int len;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
358 cmd = get_ur_golomb_shorten(&s->gb, FNSIZE);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
359 switch (cmd) {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
360 case FN_ZERO:
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
361 case FN_DIFF0:
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
362 case FN_DIFF1:
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
363 case FN_DIFF2:
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
364 case FN_DIFF3:
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
365 case FN_QLPC:
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
366 {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
367 int residual_size = 0;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
368 int channel = s->cur_chan;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
369 int32_t coffset;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
370 if (cmd != FN_ZERO) {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
371 residual_size = get_ur_golomb_shorten(&s->gb, ENERGYSIZE);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
372 /* this is a hack as version 0 differed in defintion of get_sr_golomb_shorten */
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
373 if (s->version == 0)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
374 residual_size--;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
375 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
376
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
377 if (s->nmean == 0)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
378 coffset = s->offset[channel][0];
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
379 else {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
380 int32_t sum = (s->version < 2) ? 0 : s->nmean / 2;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
381 for (i=0; i<s->nmean; i++)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
382 sum += s->offset[channel][i];
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
383 coffset = sum / s->nmean;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
384 if (s->version >= 2)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
385 coffset >>= FFMIN(1, s->bitshift);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
386 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
387 switch (cmd) {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
388 case FN_ZERO:
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
389 for (i=0; i<s->blocksize; i++)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
390 s->decoded[channel][i] = 0;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
391 break;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
392 case FN_DIFF0:
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
393 for (i=0; i<s->blocksize; i++)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
394 s->decoded[channel][i] = get_sr_golomb_shorten(&s->gb, residual_size) + coffset;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
395 break;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
396 case FN_DIFF1:
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
397 for (i=0; i<s->blocksize; i++)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
398 s->decoded[channel][i] = get_sr_golomb_shorten(&s->gb, residual_size) + s->decoded[channel][i - 1];
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
399 break;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
400 case FN_DIFF2:
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
401 for (i=0; i<s->blocksize; i++)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
402 s->decoded[channel][i] = get_sr_golomb_shorten(&s->gb, residual_size) + 2*s->decoded[channel][i-1]
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
403 - s->decoded[channel][i-2];
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
404 break;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
405 case FN_DIFF3:
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
406 for (i=0; i<s->blocksize; i++)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
407 s->decoded[channel][i] = get_sr_golomb_shorten(&s->gb, residual_size) + 3*s->decoded[channel][i-1]
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
408 - 3*s->decoded[channel][i-2]
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
409 + s->decoded[channel][i-3];
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
410 break;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
411 case FN_QLPC:
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
412 {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
413 int pred_order = get_ur_golomb_shorten(&s->gb, LPCQSIZE);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
414 for (i=0; i<pred_order; i++)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
415 s->decoded[channel][i - pred_order] -= coffset;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
416 decode_subframe_lpc(s, channel, residual_size, pred_order);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
417 if (coffset != 0)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
418 for (i=0; i < s->blocksize; i++)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
419 s->decoded[channel][i] += coffset;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
420 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
421 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
422 if (s->nmean > 0) {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
423 int32_t sum = (s->version < 2) ? 0 : s->blocksize / 2;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
424 for (i=0; i<s->blocksize; i++)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
425 sum += s->decoded[channel][i];
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
426
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
427 for (i=1; i<s->nmean; i++)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
428 s->offset[channel][i-1] = s->offset[channel][i];
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
429
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
430 if (s->version < 2)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
431 s->offset[channel][s->nmean - 1] = sum / s->blocksize;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
432 else
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
433 s->offset[channel][s->nmean - 1] = (sum / s->blocksize) << s->bitshift;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
434 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
435 for (i=-s->nwrap; i<0; i++)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
436 s->decoded[channel][i] = s->decoded[channel][i + s->blocksize];
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
437
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
438 fix_bitshift(s, s->decoded[channel]);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
439
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
440 s->cur_chan++;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
441 if (s->cur_chan == s->channels) {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
442 samples = interleave_buffer(samples, s->channels, s->blocksize, s->decoded);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
443 s->cur_chan = 0;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
444 goto frame_done;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
445 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
446 break;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
447 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
448 break;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
449 case FN_VERBATIM:
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
450 len = get_ur_golomb_shorten(&s->gb, VERBATIM_CKSIZE_SIZE);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
451 while (len--) {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
452 get_ur_golomb_shorten(&s->gb, VERBATIM_BYTE_SIZE);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
453 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
454 break;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
455 case FN_BITSHIFT:
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
456 s->bitshift = get_ur_golomb_shorten(&s->gb, BITSHIFTSIZE);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
457 break;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
458 case FN_BLOCKSIZE:
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
459 s->blocksize = get_uint(s, av_log2(s->blocksize));
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
460 break;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
461 case FN_QUIT:
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
462 return buf_size;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
463 break;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
464 default:
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
465 av_log(avctx, AV_LOG_ERROR, "unknown shorten function %d\n", cmd);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
466 return -1;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
467 break;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
468 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
469 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
470 frame_done:
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
471 *data_size = (int8_t *)samples - (int8_t *)data;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
472
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
473 // s->last_blocksize = s->blocksize;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
474 s->bitindex = get_bits_count(&s->gb) - 8*((get_bits_count(&s->gb))/8);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
475 i= (get_bits_count(&s->gb))/8;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
476 if (i > buf_size) {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
477 av_log(s->avctx, AV_LOG_ERROR, "overread: %d\n", i - buf_size);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
478 s->bitstream_size=0;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
479 s->bitstream_index=0;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
480 return -1;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
481 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
482 if (s->bitstream_size) {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
483 s->bitstream_index += i;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
484 s->bitstream_size -= i;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
485 return input_buf_size;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
486 } else
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
487 return i;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
488 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
489
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
490 static int shorten_decode_close(AVCodecContext *avctx)
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
491 {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
492 ShortenContext *s = avctx->priv_data;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
493 int i;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
494
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
495 for (i = 0; i < s->channels; i++) {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
496 s->decoded[i] -= s->nwrap;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
497 av_freep(&s->decoded[i]);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
498 av_freep(&s->offset[i]);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
499 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
500 av_freep(&s->bitstream);
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
501 return 0;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
502 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
503
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
504 static void shorten_flush(AVCodecContext *avctx){
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
505 ShortenContext *s = avctx->priv_data;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
506
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
507 s->bitstream_size=
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
508 s->bitstream_index= 0;
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
509 }
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
510
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
511 AVCodec shorten_decoder = {
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
512 "shorten",
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
513 CODEC_TYPE_AUDIO,
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
514 CODEC_ID_SHORTEN,
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
515 sizeof(ShortenContext),
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
516 shorten_decode_init,
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
517 NULL,
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
518 shorten_decode_close,
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
519 shorten_decode_frame,
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
520 .flush= shorten_flush,
b47af698085e shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
diff changeset
521 };