annotate audioconvert.c @ 6017:e1404acccac3 libavcodec

Actually return with an error condition if we're being asked to deal with too many reference frames. Also check max num ref frames against our internal ref buffer sizes. Part of fix for roundup issue 281
author heydowns
date Fri, 14 Dec 2007 05:48:27 +0000
parents 2b72f9bc4f06
children d1d15f2dca4c
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
3594
10c577c37617 audio format conversion
michael
parents:
diff changeset
1 /*
3596
2dc9933dc75f cosmetics
michael
parents: 3594
diff changeset
2 * audio conversion
3594
10c577c37617 audio format conversion
michael
parents:
diff changeset
3 * Copyright (c) 2006 Michael Niedermayer <michaelni@gmx.at>
10c577c37617 audio format conversion
michael
parents:
diff changeset
4 *
3947
c8c591fe26f8 Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 3596
diff changeset
5 * This file is part of FFmpeg.
c8c591fe26f8 Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 3596
diff changeset
6 *
c8c591fe26f8 Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 3596
diff changeset
7 * FFmpeg is free software; you can redistribute it and/or
3594
10c577c37617 audio format conversion
michael
parents:
diff changeset
8 * modify it under the terms of the GNU Lesser General Public
10c577c37617 audio format conversion
michael
parents:
diff changeset
9 * License as published by the Free Software Foundation; either
3947
c8c591fe26f8 Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 3596
diff changeset
10 * version 2.1 of the License, or (at your option) any later version.
3594
10c577c37617 audio format conversion
michael
parents:
diff changeset
11 *
3947
c8c591fe26f8 Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 3596
diff changeset
12 * FFmpeg is distributed in the hope that it will be useful,
3594
10c577c37617 audio format conversion
michael
parents:
diff changeset
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
10c577c37617 audio format conversion
michael
parents:
diff changeset
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
10c577c37617 audio format conversion
michael
parents:
diff changeset
15 * Lesser General Public License for more details.
10c577c37617 audio format conversion
michael
parents:
diff changeset
16 *
10c577c37617 audio format conversion
michael
parents:
diff changeset
17 * You should have received a copy of the GNU Lesser General Public
3947
c8c591fe26f8 Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 3596
diff changeset
18 * License along with FFmpeg; if not, write to the Free Software
3594
10c577c37617 audio format conversion
michael
parents:
diff changeset
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
10c577c37617 audio format conversion
michael
parents:
diff changeset
20 */
10c577c37617 audio format conversion
michael
parents:
diff changeset
21
10c577c37617 audio format conversion
michael
parents:
diff changeset
22 /**
10c577c37617 audio format conversion
michael
parents:
diff changeset
23 * @file audioconvert.c
3596
2dc9933dc75f cosmetics
michael
parents: 3594
diff changeset
24 * audio conversion
3594
10c577c37617 audio format conversion
michael
parents:
diff changeset
25 * @author Michael Niedermayer <michaelni@gmx.at>
10c577c37617 audio format conversion
michael
parents:
diff changeset
26 */
10c577c37617 audio format conversion
michael
parents:
diff changeset
27
10c577c37617 audio format conversion
michael
parents:
diff changeset
28 #include "avcodec.h"
10c577c37617 audio format conversion
michael
parents:
diff changeset
29
10c577c37617 audio format conversion
michael
parents:
diff changeset
30 int av_audio_convert(void *maybe_dspcontext_or_something_av_convert_specific,
10c577c37617 audio format conversion
michael
parents:
diff changeset
31 void *out[6], int out_stride[6], enum SampleFormat out_fmt,
10c577c37617 audio format conversion
michael
parents:
diff changeset
32 void * in[6], int in_stride[6], enum SampleFormat in_fmt, int len){
10c577c37617 audio format conversion
michael
parents:
diff changeset
33 int ch;
10c577c37617 audio format conversion
michael
parents:
diff changeset
34 const int isize= FFMIN( in_fmt+1, 4);
10c577c37617 audio format conversion
michael
parents:
diff changeset
35 const int osize= FFMIN(out_fmt+1, 4);
10c577c37617 audio format conversion
michael
parents:
diff changeset
36 const int fmt_pair= out_fmt + 5*in_fmt;
10c577c37617 audio format conversion
michael
parents:
diff changeset
37
10c577c37617 audio format conversion
michael
parents:
diff changeset
38 //FIXME optimize common cases
10c577c37617 audio format conversion
michael
parents:
diff changeset
39
10c577c37617 audio format conversion
michael
parents:
diff changeset
40 for(ch=0; ch<6; ch++){
10c577c37617 audio format conversion
michael
parents:
diff changeset
41 const int is= in_stride[ch] * isize;
10c577c37617 audio format conversion
michael
parents:
diff changeset
42 const int os= out_stride[ch] * osize;
10c577c37617 audio format conversion
michael
parents:
diff changeset
43 uint8_t *pi= in[ch];
10c577c37617 audio format conversion
michael
parents:
diff changeset
44 uint8_t *po= out[ch];
10c577c37617 audio format conversion
michael
parents:
diff changeset
45 uint8_t *end= po + os;
10c577c37617 audio format conversion
michael
parents:
diff changeset
46 if(!out[ch])
10c577c37617 audio format conversion
michael
parents:
diff changeset
47 continue;
10c577c37617 audio format conversion
michael
parents:
diff changeset
48
10c577c37617 audio format conversion
michael
parents:
diff changeset
49 #define CONV(ofmt, otype, ifmt, expr)\
10c577c37617 audio format conversion
michael
parents:
diff changeset
50 if(fmt_pair == ofmt + 5*ifmt){\
10c577c37617 audio format conversion
michael
parents:
diff changeset
51 do{\
10c577c37617 audio format conversion
michael
parents:
diff changeset
52 *(otype*)po = expr; pi += is; po += os;\
10c577c37617 audio format conversion
michael
parents:
diff changeset
53 }while(po < end);\
10c577c37617 audio format conversion
michael
parents:
diff changeset
54 }
10c577c37617 audio format conversion
michael
parents:
diff changeset
55
5127
4dbe6578f811 misc spelling fixes
diego
parents: 3947
diff changeset
56 //FIXME put things below under ifdefs so we do not waste space for cases no codec will need
4dbe6578f811 misc spelling fixes
diego
parents: 3947
diff changeset
57 //FIXME rounding and clipping ?
3594
10c577c37617 audio format conversion
michael
parents:
diff changeset
58
10c577c37617 audio format conversion
michael
parents:
diff changeset
59 CONV(SAMPLE_FMT_U8 , uint8_t, SAMPLE_FMT_U8 , *(uint8_t*)pi)
10c577c37617 audio format conversion
michael
parents:
diff changeset
60 else CONV(SAMPLE_FMT_S16, int16_t, SAMPLE_FMT_U8 , (*(uint8_t*)pi - 0x80)<<8)
10c577c37617 audio format conversion
michael
parents:
diff changeset
61 else CONV(SAMPLE_FMT_S32, int32_t, SAMPLE_FMT_U8 , (*(uint8_t*)pi - 0x80)<<24)
10c577c37617 audio format conversion
michael
parents:
diff changeset
62 else CONV(SAMPLE_FMT_FLT, float , SAMPLE_FMT_U8 , (*(uint8_t*)pi - 0x80)*(1.0 / (1<<7)))
10c577c37617 audio format conversion
michael
parents:
diff changeset
63 else CONV(SAMPLE_FMT_U8 , uint8_t, SAMPLE_FMT_S16, (*(int16_t*)pi>>8) + 0x80)
10c577c37617 audio format conversion
michael
parents:
diff changeset
64 else CONV(SAMPLE_FMT_S16, int16_t, SAMPLE_FMT_S16, *(int16_t*)pi)
10c577c37617 audio format conversion
michael
parents:
diff changeset
65 else CONV(SAMPLE_FMT_S32, int32_t, SAMPLE_FMT_S16, *(int16_t*)pi<<16)
10c577c37617 audio format conversion
michael
parents:
diff changeset
66 else CONV(SAMPLE_FMT_FLT, float , SAMPLE_FMT_S16, *(int16_t*)pi*(1.0 / (1<<15)))
10c577c37617 audio format conversion
michael
parents:
diff changeset
67 else CONV(SAMPLE_FMT_U8 , uint8_t, SAMPLE_FMT_S32, (*(int32_t*)pi>>24) + 0x80)
10c577c37617 audio format conversion
michael
parents:
diff changeset
68 else CONV(SAMPLE_FMT_S16, int16_t, SAMPLE_FMT_S32, *(int32_t*)pi>>16)
10c577c37617 audio format conversion
michael
parents:
diff changeset
69 else CONV(SAMPLE_FMT_S32, int32_t, SAMPLE_FMT_S32, *(int32_t*)pi)
10c577c37617 audio format conversion
michael
parents:
diff changeset
70 else CONV(SAMPLE_FMT_FLT, float , SAMPLE_FMT_S32, *(int32_t*)pi*(1.0 / (1<<31)))
10c577c37617 audio format conversion
michael
parents:
diff changeset
71 else CONV(SAMPLE_FMT_U8 , uint8_t, SAMPLE_FMT_FLT, lrintf(*(float*)pi * (1<<7)) + 0x80)
10c577c37617 audio format conversion
michael
parents:
diff changeset
72 else CONV(SAMPLE_FMT_S16, int16_t, SAMPLE_FMT_FLT, lrintf(*(float*)pi * (1<<15)))
10c577c37617 audio format conversion
michael
parents:
diff changeset
73 else CONV(SAMPLE_FMT_S32, int32_t, SAMPLE_FMT_FLT, lrintf(*(float*)pi * (1<<31)))
10c577c37617 audio format conversion
michael
parents:
diff changeset
74 else CONV(SAMPLE_FMT_FLT, float , SAMPLE_FMT_FLT, *(float*)pi)
10c577c37617 audio format conversion
michael
parents:
diff changeset
75 else return -1;
10c577c37617 audio format conversion
michael
parents:
diff changeset
76 }
10c577c37617 audio format conversion
michael
parents:
diff changeset
77 return 0;
10c577c37617 audio format conversion
michael
parents:
diff changeset
78 }