annotate utils.c @ 3604:dad0296d4522 libavcodec

replace MULL with asm too, no significnat speedup but its probably better to not take any chances, some versions of gcc will almost certainly mess it up too if they can
author michael
date Tue, 22 Aug 2006 12:07:02 +0000
parents 05bb54c1d979
children faa8dc533ad3
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
1 /*
986e461dc072 Initial revision
glantau
parents:
diff changeset
2 * utils for libavcodec
429
718a22dc121f license/copyright change
glantau
parents: 400
diff changeset
3 * Copyright (c) 2001 Fabrice Bellard.
1739
07a484280a82 copyright year update of the files i touched and remembered, things look annoyingly unmaintained otherwise
michael
parents: 1730
diff changeset
4 * Copyright (c) 2002-2004 Michael Niedermayer <michaelni@gmx.at>
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
5 *
429
718a22dc121f license/copyright change
glantau
parents: 400
diff changeset
6 * This library is free software; you can redistribute it and/or
718a22dc121f license/copyright change
glantau
parents: 400
diff changeset
7 * modify it under the terms of the GNU Lesser General Public
718a22dc121f license/copyright change
glantau
parents: 400
diff changeset
8 * License as published by the Free Software Foundation; either
718a22dc121f license/copyright change
glantau
parents: 400
diff changeset
9 * version 2 of the License, or (at your option) any later version.
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
10 *
429
718a22dc121f license/copyright change
glantau
parents: 400
diff changeset
11 * This library is distributed in the hope that it will be useful,
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
429
718a22dc121f license/copyright change
glantau
parents: 400
diff changeset
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
718a22dc121f license/copyright change
glantau
parents: 400
diff changeset
14 * Lesser General Public License for more details.
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
15 *
429
718a22dc121f license/copyright change
glantau
parents: 400
diff changeset
16 * You should have received a copy of the GNU Lesser General Public
718a22dc121f license/copyright change
glantau
parents: 400
diff changeset
17 * License along with this library; if not, write to the Free Software
3036
0b546eab515d Update licensing information: The FSF changed postal address.
diego
parents: 3031
diff changeset
18 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
19 */
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
20
1106
1e39f273ecd6 per file doxy
michaelni
parents: 1064
diff changeset
21 /**
1e39f273ecd6 per file doxy
michaelni
parents: 1064
diff changeset
22 * @file utils.c
1e39f273ecd6 per file doxy
michaelni
parents: 1064
diff changeset
23 * utils.
1e39f273ecd6 per file doxy
michaelni
parents: 1064
diff changeset
24 */
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
25
394
e2cb8a4ee0c5 proper memory handling functions
glantau
parents: 379
diff changeset
26 #include "avcodec.h"
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
27 #include "dsputil.h"
341
bf26081c373c avcodec_flush_buffers()
michaelni
parents: 337
diff changeset
28 #include "mpegvideo.h"
2002
b737b5e96ee0 use AVInteger in av_rescale() so it can finally do 64*64/64 instead of just 64*32/32
michael
parents: 1996
diff changeset
29 #include "integer.h"
2880
4d91f38477ee dont include opt.h in avcodec.h
michael
parents: 2879
diff changeset
30 #include "opt.h"
3169
53f0b29ff865 generic crc calculation code
michael
parents: 3159
diff changeset
31 #include "crc.h"
1598
932d306bf1dc av_log() patch by (Michel Bardiaux <mbardiaux at peaktime dot be>)
michael
parents: 1588
diff changeset
32 #include <stdarg.h>
2002
b737b5e96ee0 use AVInteger in av_rescale() so it can finally do 64*64/64 instead of just 64*32/32
michael
parents: 1996
diff changeset
33 #include <limits.h>
2862
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
34 #include <float.h>
3461
7581658de3d1 CONFIG_WIN32 implies MinGW and Cygwin and possibly more, so use just
diego
parents: 3442
diff changeset
35 #ifdef __MINGW32__
3233
18af2f7788c6 - Add new file internal.h for common internal-use-only functions.
corey
parents: 3171
diff changeset
36 #include <fcntl.h>
18af2f7788c6 - Add new file internal.h for common internal-use-only functions.
corey
parents: 3171
diff changeset
37 #endif
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
38
2652
659b92488061 ff_reverse to utils.c patch by (Roine Gustafsson )roine users.sourceforge net)
michael
parents: 2637
diff changeset
39 const uint8_t ff_reverse[256]={
659b92488061 ff_reverse to utils.c patch by (Roine Gustafsson )roine users.sourceforge net)
michael
parents: 2637
diff changeset
40 0x00,0x80,0x40,0xC0,0x20,0xA0,0x60,0xE0,0x10,0x90,0x50,0xD0,0x30,0xB0,0x70,0xF0,
659b92488061 ff_reverse to utils.c patch by (Roine Gustafsson )roine users.sourceforge net)
michael
parents: 2637
diff changeset
41 0x08,0x88,0x48,0xC8,0x28,0xA8,0x68,0xE8,0x18,0x98,0x58,0xD8,0x38,0xB8,0x78,0xF8,
659b92488061 ff_reverse to utils.c patch by (Roine Gustafsson )roine users.sourceforge net)
michael
parents: 2637
diff changeset
42 0x04,0x84,0x44,0xC4,0x24,0xA4,0x64,0xE4,0x14,0x94,0x54,0xD4,0x34,0xB4,0x74,0xF4,
659b92488061 ff_reverse to utils.c patch by (Roine Gustafsson )roine users.sourceforge net)
michael
parents: 2637
diff changeset
43 0x0C,0x8C,0x4C,0xCC,0x2C,0xAC,0x6C,0xEC,0x1C,0x9C,0x5C,0xDC,0x3C,0xBC,0x7C,0xFC,
659b92488061 ff_reverse to utils.c patch by (Roine Gustafsson )roine users.sourceforge net)
michael
parents: 2637
diff changeset
44 0x02,0x82,0x42,0xC2,0x22,0xA2,0x62,0xE2,0x12,0x92,0x52,0xD2,0x32,0xB2,0x72,0xF2,
659b92488061 ff_reverse to utils.c patch by (Roine Gustafsson )roine users.sourceforge net)
michael
parents: 2637
diff changeset
45 0x0A,0x8A,0x4A,0xCA,0x2A,0xAA,0x6A,0xEA,0x1A,0x9A,0x5A,0xDA,0x3A,0xBA,0x7A,0xFA,
659b92488061 ff_reverse to utils.c patch by (Roine Gustafsson )roine users.sourceforge net)
michael
parents: 2637
diff changeset
46 0x06,0x86,0x46,0xC6,0x26,0xA6,0x66,0xE6,0x16,0x96,0x56,0xD6,0x36,0xB6,0x76,0xF6,
659b92488061 ff_reverse to utils.c patch by (Roine Gustafsson )roine users.sourceforge net)
michael
parents: 2637
diff changeset
47 0x0E,0x8E,0x4E,0xCE,0x2E,0xAE,0x6E,0xEE,0x1E,0x9E,0x5E,0xDE,0x3E,0xBE,0x7E,0xFE,
659b92488061 ff_reverse to utils.c patch by (Roine Gustafsson )roine users.sourceforge net)
michael
parents: 2637
diff changeset
48 0x01,0x81,0x41,0xC1,0x21,0xA1,0x61,0xE1,0x11,0x91,0x51,0xD1,0x31,0xB1,0x71,0xF1,
659b92488061 ff_reverse to utils.c patch by (Roine Gustafsson )roine users.sourceforge net)
michael
parents: 2637
diff changeset
49 0x09,0x89,0x49,0xC9,0x29,0xA9,0x69,0xE9,0x19,0x99,0x59,0xD9,0x39,0xB9,0x79,0xF9,
659b92488061 ff_reverse to utils.c patch by (Roine Gustafsson )roine users.sourceforge net)
michael
parents: 2637
diff changeset
50 0x05,0x85,0x45,0xC5,0x25,0xA5,0x65,0xE5,0x15,0x95,0x55,0xD5,0x35,0xB5,0x75,0xF5,
659b92488061 ff_reverse to utils.c patch by (Roine Gustafsson )roine users.sourceforge net)
michael
parents: 2637
diff changeset
51 0x0D,0x8D,0x4D,0xCD,0x2D,0xAD,0x6D,0xED,0x1D,0x9D,0x5D,0xDD,0x3D,0xBD,0x7D,0xFD,
659b92488061 ff_reverse to utils.c patch by (Roine Gustafsson )roine users.sourceforge net)
michael
parents: 2637
diff changeset
52 0x03,0x83,0x43,0xC3,0x23,0xA3,0x63,0xE3,0x13,0x93,0x53,0xD3,0x33,0xB3,0x73,0xF3,
659b92488061 ff_reverse to utils.c patch by (Roine Gustafsson )roine users.sourceforge net)
michael
parents: 2637
diff changeset
53 0x0B,0x8B,0x4B,0xCB,0x2B,0xAB,0x6B,0xEB,0x1B,0x9B,0x5B,0xDB,0x3B,0xBB,0x7B,0xFB,
659b92488061 ff_reverse to utils.c patch by (Roine Gustafsson )roine users.sourceforge net)
michael
parents: 2637
diff changeset
54 0x07,0x87,0x47,0xC7,0x27,0xA7,0x67,0xE7,0x17,0x97,0x57,0xD7,0x37,0xB7,0x77,0xF7,
659b92488061 ff_reverse to utils.c patch by (Roine Gustafsson )roine users.sourceforge net)
michael
parents: 2637
diff changeset
55 0x0F,0x8F,0x4F,0xCF,0x2F,0xAF,0x6F,0xEF,0x1F,0x9F,0x5F,0xDF,0x3F,0xBF,0x7F,0xFF,
659b92488061 ff_reverse to utils.c patch by (Roine Gustafsson )roine users.sourceforge net)
michael
parents: 2637
diff changeset
56 };
659b92488061 ff_reverse to utils.c patch by (Roine Gustafsson )roine users.sourceforge net)
michael
parents: 2637
diff changeset
57
2806
af3a36e20010 thread mess check for avcodec_open/close()
michael
parents: 2800
diff changeset
58 static int volatile entangled_thread_counter=0;
af3a36e20010 thread mess check for avcodec_open/close()
michael
parents: 2800
diff changeset
59
2231
c87bab25f89f changing size segfault fix
michael
parents: 2169
diff changeset
60 void avcodec_default_free_buffers(AVCodecContext *s);
1994
8d3540dddd1b cleanup & memleak fix
michael
parents: 1901
diff changeset
61
862
058194d7ade6 * fixing some minor const warnings
kabi
parents: 851
diff changeset
62 void *av_mallocz(unsigned int size)
394
e2cb8a4ee0c5 proper memory handling functions
glantau
parents: 379
diff changeset
63 {
e2cb8a4ee0c5 proper memory handling functions
glantau
parents: 379
diff changeset
64 void *ptr;
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
65
394
e2cb8a4ee0c5 proper memory handling functions
glantau
parents: 379
diff changeset
66 ptr = av_malloc(size);
e2cb8a4ee0c5 proper memory handling functions
glantau
parents: 379
diff changeset
67 if (!ptr)
e2cb8a4ee0c5 proper memory handling functions
glantau
parents: 379
diff changeset
68 return NULL;
e2cb8a4ee0c5 proper memory handling functions
glantau
parents: 379
diff changeset
69 memset(ptr, 0, size);
e2cb8a4ee0c5 proper memory handling functions
glantau
parents: 379
diff changeset
70 return ptr;
e2cb8a4ee0c5 proper memory handling functions
glantau
parents: 379
diff changeset
71 }
e2cb8a4ee0c5 proper memory handling functions
glantau
parents: 379
diff changeset
72
1031
19de1445beb2 use av_malloc() functions - added av_strdup and av_realloc()
bellard
parents: 998
diff changeset
73 char *av_strdup(const char *s)
19de1445beb2 use av_malloc() functions - added av_strdup and av_realloc()
bellard
parents: 998
diff changeset
74 {
19de1445beb2 use av_malloc() functions - added av_strdup and av_realloc()
bellard
parents: 998
diff changeset
75 char *ptr;
19de1445beb2 use av_malloc() functions - added av_strdup and av_realloc()
bellard
parents: 998
diff changeset
76 int len;
19de1445beb2 use av_malloc() functions - added av_strdup and av_realloc()
bellard
parents: 998
diff changeset
77 len = strlen(s) + 1;
19de1445beb2 use av_malloc() functions - added av_strdup and av_realloc()
bellard
parents: 998
diff changeset
78 ptr = av_malloc(len);
19de1445beb2 use av_malloc() functions - added av_strdup and av_realloc()
bellard
parents: 998
diff changeset
79 if (!ptr)
19de1445beb2 use av_malloc() functions - added av_strdup and av_realloc()
bellard
parents: 998
diff changeset
80 return NULL;
19de1445beb2 use av_malloc() functions - added av_strdup and av_realloc()
bellard
parents: 998
diff changeset
81 memcpy(ptr, s, len);
19de1445beb2 use av_malloc() functions - added av_strdup and av_realloc()
bellard
parents: 998
diff changeset
82 return ptr;
19de1445beb2 use av_malloc() functions - added av_strdup and av_realloc()
bellard
parents: 998
diff changeset
83 }
19de1445beb2 use av_malloc() functions - added av_strdup and av_realloc()
bellard
parents: 998
diff changeset
84
19de1445beb2 use av_malloc() functions - added av_strdup and av_realloc()
bellard
parents: 998
diff changeset
85 /**
19de1445beb2 use av_malloc() functions - added av_strdup and av_realloc()
bellard
parents: 998
diff changeset
86 * realloc which does nothing if the block is large enough
19de1445beb2 use av_malloc() functions - added av_strdup and av_realloc()
bellard
parents: 998
diff changeset
87 */
1057
bb5de8a59da8 * static,const,compiler warning cleanup
kabi
parents: 1032
diff changeset
88 void *av_fast_realloc(void *ptr, unsigned int *size, unsigned int min_size)
1031
19de1445beb2 use av_malloc() functions - added av_strdup and av_realloc()
bellard
parents: 998
diff changeset
89 {
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
90 if(min_size < *size)
1031
19de1445beb2 use av_malloc() functions - added av_strdup and av_realloc()
bellard
parents: 998
diff changeset
91 return ptr;
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
92
2422
18b8b2dcc037 various security fixes and precautionary checks
michael
parents: 2418
diff changeset
93 *size= FFMAX(17*min_size/16 + 32, min_size);
1031
19de1445beb2 use av_malloc() functions - added av_strdup and av_realloc()
bellard
parents: 998
diff changeset
94
19de1445beb2 use av_malloc() functions - added av_strdup and av_realloc()
bellard
parents: 998
diff changeset
95 return av_realloc(ptr, *size);
19de1445beb2 use av_malloc() functions - added av_strdup and av_realloc()
bellard
parents: 998
diff changeset
96 }
19de1445beb2 use av_malloc() functions - added av_strdup and av_realloc()
bellard
parents: 998
diff changeset
97
19de1445beb2 use av_malloc() functions - added av_strdup and av_realloc()
bellard
parents: 998
diff changeset
98
902
6acc8394960d * two functions to handle allocation of static data more simple
kabi
parents: 862
diff changeset
99 static unsigned int last_static = 0;
1900
5cde80c5d929 static allocation rewrite (old code was plain a broken mess)
michael
parents: 1858
diff changeset
100 static unsigned int allocated_static = 0;
5cde80c5d929 static allocation rewrite (old code was plain a broken mess)
michael
parents: 1858
diff changeset
101 static void** array_static = NULL;
5cde80c5d929 static allocation rewrite (old code was plain a broken mess)
michael
parents: 1858
diff changeset
102
5cde80c5d929 static allocation rewrite (old code was plain a broken mess)
michael
parents: 1858
diff changeset
103 /**
5cde80c5d929 static allocation rewrite (old code was plain a broken mess)
michael
parents: 1858
diff changeset
104 * allocation of static arrays - do not use for normal allocation.
5cde80c5d929 static allocation rewrite (old code was plain a broken mess)
michael
parents: 1858
diff changeset
105 */
5cde80c5d929 static allocation rewrite (old code was plain a broken mess)
michael
parents: 1858
diff changeset
106 void *av_mallocz_static(unsigned int size)
902
6acc8394960d * two functions to handle allocation of static data more simple
kabi
parents: 862
diff changeset
107 {
6acc8394960d * two functions to handle allocation of static data more simple
kabi
parents: 862
diff changeset
108 void *ptr = av_mallocz(size);
6acc8394960d * two functions to handle allocation of static data more simple
kabi
parents: 862
diff changeset
109
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
110 if(ptr){
1901
bc5039adb9af 1000l in av_mallocz_static()
michael
parents: 1900
diff changeset
111 array_static =av_fast_realloc(array_static, &allocated_static, sizeof(void*)*(last_static+1));
2422
18b8b2dcc037 various security fixes and precautionary checks
michael
parents: 2418
diff changeset
112 if(!array_static)
18b8b2dcc037 various security fixes and precautionary checks
michael
parents: 2418
diff changeset
113 return NULL;
1900
5cde80c5d929 static allocation rewrite (old code was plain a broken mess)
michael
parents: 1858
diff changeset
114 array_static[last_static++] = ptr;
902
6acc8394960d * two functions to handle allocation of static data more simple
kabi
parents: 862
diff changeset
115 }
1900
5cde80c5d929 static allocation rewrite (old code was plain a broken mess)
michael
parents: 1858
diff changeset
116
902
6acc8394960d * two functions to handle allocation of static data more simple
kabi
parents: 862
diff changeset
117 return ptr;
6acc8394960d * two functions to handle allocation of static data more simple
kabi
parents: 862
diff changeset
118 }
1900
5cde80c5d929 static allocation rewrite (old code was plain a broken mess)
michael
parents: 1858
diff changeset
119
5cde80c5d929 static allocation rewrite (old code was plain a broken mess)
michael
parents: 1858
diff changeset
120 /**
2370
26560d4fdb1f Memory leak fix patch by (Burkhard Plaum <plaum >at< ipf.uni-stuttgart )dot( de>)
michael
parents: 2362
diff changeset
121 * same as above, but does realloc
26560d4fdb1f Memory leak fix patch by (Burkhard Plaum <plaum >at< ipf.uni-stuttgart )dot( de>)
michael
parents: 2362
diff changeset
122 */
26560d4fdb1f Memory leak fix patch by (Burkhard Plaum <plaum >at< ipf.uni-stuttgart )dot( de>)
michael
parents: 2362
diff changeset
123
26560d4fdb1f Memory leak fix patch by (Burkhard Plaum <plaum >at< ipf.uni-stuttgart )dot( de>)
michael
parents: 2362
diff changeset
124 void *av_realloc_static(void *ptr, unsigned int size)
26560d4fdb1f Memory leak fix patch by (Burkhard Plaum <plaum >at< ipf.uni-stuttgart )dot( de>)
michael
parents: 2362
diff changeset
125 {
26560d4fdb1f Memory leak fix patch by (Burkhard Plaum <plaum >at< ipf.uni-stuttgart )dot( de>)
michael
parents: 2362
diff changeset
126 int i;
26560d4fdb1f Memory leak fix patch by (Burkhard Plaum <plaum >at< ipf.uni-stuttgart )dot( de>)
michael
parents: 2362
diff changeset
127 if(!ptr)
26560d4fdb1f Memory leak fix patch by (Burkhard Plaum <plaum >at< ipf.uni-stuttgart )dot( de>)
michael
parents: 2362
diff changeset
128 return av_mallocz_static(size);
26560d4fdb1f Memory leak fix patch by (Burkhard Plaum <plaum >at< ipf.uni-stuttgart )dot( de>)
michael
parents: 2362
diff changeset
129 /* Look for the old ptr */
26560d4fdb1f Memory leak fix patch by (Burkhard Plaum <plaum >at< ipf.uni-stuttgart )dot( de>)
michael
parents: 2362
diff changeset
130 for(i = 0; i < last_static; i++) {
26560d4fdb1f Memory leak fix patch by (Burkhard Plaum <plaum >at< ipf.uni-stuttgart )dot( de>)
michael
parents: 2362
diff changeset
131 if(array_static[i] == ptr) {
26560d4fdb1f Memory leak fix patch by (Burkhard Plaum <plaum >at< ipf.uni-stuttgart )dot( de>)
michael
parents: 2362
diff changeset
132 array_static[i] = av_realloc(array_static[i], size);
26560d4fdb1f Memory leak fix patch by (Burkhard Plaum <plaum >at< ipf.uni-stuttgart )dot( de>)
michael
parents: 2362
diff changeset
133 return array_static[i];
26560d4fdb1f Memory leak fix patch by (Burkhard Plaum <plaum >at< ipf.uni-stuttgart )dot( de>)
michael
parents: 2362
diff changeset
134 }
26560d4fdb1f Memory leak fix patch by (Burkhard Plaum <plaum >at< ipf.uni-stuttgart )dot( de>)
michael
parents: 2362
diff changeset
135 }
26560d4fdb1f Memory leak fix patch by (Burkhard Plaum <plaum >at< ipf.uni-stuttgart )dot( de>)
michael
parents: 2362
diff changeset
136 return NULL;
26560d4fdb1f Memory leak fix patch by (Burkhard Plaum <plaum >at< ipf.uni-stuttgart )dot( de>)
michael
parents: 2362
diff changeset
137
26560d4fdb1f Memory leak fix patch by (Burkhard Plaum <plaum >at< ipf.uni-stuttgart )dot( de>)
michael
parents: 2362
diff changeset
138 }
26560d4fdb1f Memory leak fix patch by (Burkhard Plaum <plaum >at< ipf.uni-stuttgart )dot( de>)
michael
parents: 2362
diff changeset
139
26560d4fdb1f Memory leak fix patch by (Burkhard Plaum <plaum >at< ipf.uni-stuttgart )dot( de>)
michael
parents: 2362
diff changeset
140 /**
1900
5cde80c5d929 static allocation rewrite (old code was plain a broken mess)
michael
parents: 1858
diff changeset
141 * free all static arrays and reset pointers to 0.
5cde80c5d929 static allocation rewrite (old code was plain a broken mess)
michael
parents: 1858
diff changeset
142 */
1282
8988af3ae1e8 Warning and compatibility fixes.
mellum
parents: 1264
diff changeset
143 void av_free_static(void)
902
6acc8394960d * two functions to handle allocation of static data more simple
kabi
parents: 862
diff changeset
144 {
1900
5cde80c5d929 static allocation rewrite (old code was plain a broken mess)
michael
parents: 1858
diff changeset
145 while(last_static){
5cde80c5d929 static allocation rewrite (old code was plain a broken mess)
michael
parents: 1858
diff changeset
146 av_freep(&array_static[--last_static]);
902
6acc8394960d * two functions to handle allocation of static data more simple
kabi
parents: 862
diff changeset
147 }
1900
5cde80c5d929 static allocation rewrite (old code was plain a broken mess)
michael
parents: 1858
diff changeset
148 av_freep(&array_static);
902
6acc8394960d * two functions to handle allocation of static data more simple
kabi
parents: 862
diff changeset
149 }
6acc8394960d * two functions to handle allocation of static data more simple
kabi
parents: 862
diff changeset
150
1854
73ee15c391bf macrofree av_freep()
michael
parents: 1831
diff changeset
151 /**
2840
22eec5a1b043 Call av_free_static automatically before DLL unload patch by (plaum:ipf uni-stuttgart de)
michael
parents: 2817
diff changeset
152 * Call av_free_static automatically before it's too late
22eec5a1b043 Call av_free_static automatically before DLL unload patch by (plaum:ipf uni-stuttgart de)
michael
parents: 2817
diff changeset
153 */
22eec5a1b043 Call av_free_static automatically before DLL unload patch by (plaum:ipf uni-stuttgart de)
michael
parents: 2817
diff changeset
154
3075
961af1358c7f add static keyword to some functions
mru
parents: 3061
diff changeset
155 static void do_free(void) __attribute__ ((destructor));
2840
22eec5a1b043 Call av_free_static automatically before DLL unload patch by (plaum:ipf uni-stuttgart de)
michael
parents: 2817
diff changeset
156
3075
961af1358c7f add static keyword to some functions
mru
parents: 3061
diff changeset
157 static void do_free(void)
2840
22eec5a1b043 Call av_free_static automatically before DLL unload patch by (plaum:ipf uni-stuttgart de)
michael
parents: 2817
diff changeset
158 {
22eec5a1b043 Call av_free_static automatically before DLL unload patch by (plaum:ipf uni-stuttgart de)
michael
parents: 2817
diff changeset
159 av_free_static();
22eec5a1b043 Call av_free_static automatically before DLL unload patch by (plaum:ipf uni-stuttgart de)
michael
parents: 2817
diff changeset
160 }
22eec5a1b043 Call av_free_static automatically before DLL unload patch by (plaum:ipf uni-stuttgart de)
michael
parents: 2817
diff changeset
161
22eec5a1b043 Call av_free_static automatically before DLL unload patch by (plaum:ipf uni-stuttgart de)
michael
parents: 2817
diff changeset
162 /**
1854
73ee15c391bf macrofree av_freep()
michael
parents: 1831
diff changeset
163 * Frees memory and sets the pointer to NULL.
73ee15c391bf macrofree av_freep()
michael
parents: 1831
diff changeset
164 * @param arg pointer to the pointer which should be freed
73ee15c391bf macrofree av_freep()
michael
parents: 1831
diff changeset
165 */
73ee15c391bf macrofree av_freep()
michael
parents: 1831
diff changeset
166 void av_freep(void *arg)
400
b0aed401a756 better av_freep()
glantau
parents: 394
diff changeset
167 {
1854
73ee15c391bf macrofree av_freep()
michael
parents: 1831
diff changeset
168 void **ptr= (void**)arg;
400
b0aed401a756 better av_freep()
glantau
parents: 394
diff changeset
169 av_free(*ptr);
b0aed401a756 better av_freep()
glantau
parents: 394
diff changeset
170 *ptr = NULL;
b0aed401a756 better av_freep()
glantau
parents: 394
diff changeset
171 }
b0aed401a756 better av_freep()
glantau
parents: 394
diff changeset
172
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
173 /* encoder management */
2169
db8baace74d8 Minor Patch for shared libs on Mac OSX by (Bill May <wmay at cisco dot com>)
michael
parents: 2167
diff changeset
174 AVCodec *first_avcodec = NULL;
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
175
986e461dc072 Initial revision
glantau
parents:
diff changeset
176 void register_avcodec(AVCodec *format)
986e461dc072 Initial revision
glantau
parents:
diff changeset
177 {
986e461dc072 Initial revision
glantau
parents:
diff changeset
178 AVCodec **p;
986e461dc072 Initial revision
glantau
parents:
diff changeset
179 p = &first_avcodec;
986e461dc072 Initial revision
glantau
parents:
diff changeset
180 while (*p != NULL) p = &(*p)->next;
986e461dc072 Initial revision
glantau
parents:
diff changeset
181 *p = format;
986e461dc072 Initial revision
glantau
parents:
diff changeset
182 format->next = NULL;
986e461dc072 Initial revision
glantau
parents:
diff changeset
183 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
184
2270
21f450be6cb5 lowres width/height cleanup 3rd try
michael
parents: 2242
diff changeset
185 void avcodec_set_dimensions(AVCodecContext *s, int width, int height){
21f450be6cb5 lowres width/height cleanup 3rd try
michael
parents: 2242
diff changeset
186 s->coded_width = width;
21f450be6cb5 lowres width/height cleanup 3rd try
michael
parents: 2242
diff changeset
187 s->coded_height= height;
21f450be6cb5 lowres width/height cleanup 3rd try
michael
parents: 2242
diff changeset
188 s->width = -((-width )>>s->lowres);
21f450be6cb5 lowres width/height cleanup 3rd try
michael
parents: 2242
diff changeset
189 s->height= -((-height)>>s->lowres);
21f450be6cb5 lowres width/height cleanup 3rd try
michael
parents: 2242
diff changeset
190 }
21f450be6cb5 lowres width/height cleanup 3rd try
michael
parents: 2242
diff changeset
191
1214
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
192 typedef struct InternalBuffer{
903
22ee74da2cd3 cleanup
michaelni
parents: 902
diff changeset
193 int last_pic_num;
1214
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
194 uint8_t *base[4];
903
22ee74da2cd3 cleanup
michaelni
parents: 902
diff changeset
195 uint8_t *data[4];
1588
de5e2acd0f80 initalize various uninitalized variables and avoid coded_picture_number as its not always correct (later should be reversed after fixing the picture_number mess)
michael
parents: 1585
diff changeset
196 int linesize[4];
1214
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
197 }InternalBuffer;
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
198
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
199 #define INTERNAL_BUFFER_SIZE 32
903
22ee74da2cd3 cleanup
michaelni
parents: 902
diff changeset
200
1538
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
201 #define ALIGN(x, a) (((x)+(a)-1)&~((a)-1))
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
202
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
203 void avcodec_align_dimensions(AVCodecContext *s, int *width, int *height){
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
204 int w_align= 1;
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
205 int h_align= 1;
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
206
1538
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
207 switch(s->pix_fmt){
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
208 case PIX_FMT_YUV420P:
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
209 case PIX_FMT_YUV422:
2137
ef47c0b1ff28 UYVY support patch by ("Todd.Kirby" <doubleshot at pacbell dot net>)
michael
parents: 2125
diff changeset
210 case PIX_FMT_UYVY422:
1538
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
211 case PIX_FMT_YUV422P:
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
212 case PIX_FMT_YUV444P:
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
213 case PIX_FMT_GRAY8:
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
214 case PIX_FMT_YUVJ420P:
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
215 case PIX_FMT_YUVJ422P:
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
216 case PIX_FMT_YUVJ444P:
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
217 w_align= 16; //FIXME check for non mpeg style codecs and use less alignment
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
218 h_align= 16;
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
219 break;
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
220 case PIX_FMT_YUV411P:
2309
550ae8914fd3 * Introducing IIDC1394 grabbing interface.
romansh
parents: 2301
diff changeset
221 case PIX_FMT_UYVY411:
1538
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
222 w_align=32;
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
223 h_align=8;
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
224 break;
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
225 case PIX_FMT_YUV410P:
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
226 if(s->codec_id == CODEC_ID_SVQ1){
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
227 w_align=64;
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
228 h_align=64;
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
229 }
2104
586a6e8f3290 Force alignement for rpza and smc
rtognimp
parents: 2091
diff changeset
230 case PIX_FMT_RGB555:
586a6e8f3290 Force alignement for rpza and smc
rtognimp
parents: 2091
diff changeset
231 if(s->codec_id == CODEC_ID_RPZA){
586a6e8f3290 Force alignement for rpza and smc
rtognimp
parents: 2091
diff changeset
232 w_align=4;
586a6e8f3290 Force alignement for rpza and smc
rtognimp
parents: 2091
diff changeset
233 h_align=4;
586a6e8f3290 Force alignement for rpza and smc
rtognimp
parents: 2091
diff changeset
234 }
586a6e8f3290 Force alignement for rpza and smc
rtognimp
parents: 2091
diff changeset
235 case PIX_FMT_PAL8:
586a6e8f3290 Force alignement for rpza and smc
rtognimp
parents: 2091
diff changeset
236 if(s->codec_id == CODEC_ID_SMC){
586a6e8f3290 Force alignement for rpza and smc
rtognimp
parents: 2091
diff changeset
237 w_align=4;
586a6e8f3290 Force alignement for rpza and smc
rtognimp
parents: 2091
diff changeset
238 h_align=4;
586a6e8f3290 Force alignement for rpza and smc
rtognimp
parents: 2091
diff changeset
239 }
1538
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
240 break;
2418
82af834636c2 Check pointers before writing to memory, fix possible integer overflows
rtognimp
parents: 2398
diff changeset
241 case PIX_FMT_BGR24:
82af834636c2 Check pointers before writing to memory, fix possible integer overflows
rtognimp
parents: 2398
diff changeset
242 if((s->codec_id == CODEC_ID_MSZH) || (s->codec_id == CODEC_ID_ZLIB)){
82af834636c2 Check pointers before writing to memory, fix possible integer overflows
rtognimp
parents: 2398
diff changeset
243 w_align=4;
82af834636c2 Check pointers before writing to memory, fix possible integer overflows
rtognimp
parents: 2398
diff changeset
244 h_align=4;
82af834636c2 Check pointers before writing to memory, fix possible integer overflows
rtognimp
parents: 2398
diff changeset
245 }
82af834636c2 Check pointers before writing to memory, fix possible integer overflows
rtognimp
parents: 2398
diff changeset
246 break;
1538
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
247 default:
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
248 w_align= 1;
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
249 h_align= 1;
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
250 break;
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
251 }
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
252
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
253 *width = ALIGN(*width , w_align);
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
254 *height= ALIGN(*height, h_align);
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
255 }
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
256
2422
18b8b2dcc037 various security fixes and precautionary checks
michael
parents: 2418
diff changeset
257 int avcodec_check_dimensions(void *av_log_ctx, unsigned int w, unsigned int h){
18b8b2dcc037 various security fixes and precautionary checks
michael
parents: 2418
diff changeset
258 if((int)w>0 && (int)h>0 && (w+128)*(uint64_t)(h+128) < INT_MAX/4)
18b8b2dcc037 various security fixes and precautionary checks
michael
parents: 2418
diff changeset
259 return 0;
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
260
2422
18b8b2dcc037 various security fixes and precautionary checks
michael
parents: 2418
diff changeset
261 av_log(av_log_ctx, AV_LOG_ERROR, "picture size invalid (%ux%u)\n", w, h);
18b8b2dcc037 various security fixes and precautionary checks
michael
parents: 2418
diff changeset
262 return -1;
18b8b2dcc037 various security fixes and precautionary checks
michael
parents: 2418
diff changeset
263 }
18b8b2dcc037 various security fixes and precautionary checks
michael
parents: 2418
diff changeset
264
925
7fccaa0d699d AVVideoFrame -> AVFrame
michaelni
parents: 924
diff changeset
265 int avcodec_default_get_buffer(AVCodecContext *s, AVFrame *pic){
903
22ee74da2cd3 cleanup
michaelni
parents: 902
diff changeset
266 int i;
1538
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
267 int w= s->width;
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
268 int h= s->height;
1214
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
269 InternalBuffer *buf;
1588
de5e2acd0f80 initalize various uninitalized variables and avoid coded_picture_number as its not always correct (later should be reversed after fixing the picture_number mess)
michael
parents: 1585
diff changeset
270 int *picture_number;
2422
18b8b2dcc037 various security fixes and precautionary checks
michael
parents: 2418
diff changeset
271
924
3814e9115672 cleanup / messup?
michaelni
parents: 908
diff changeset
272 assert(pic->data[0]==NULL);
1214
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
273 assert(INTERNAL_BUFFER_SIZE > s->internal_buffer_count);
903
22ee74da2cd3 cleanup
michaelni
parents: 902
diff changeset
274
2422
18b8b2dcc037 various security fixes and precautionary checks
michael
parents: 2418
diff changeset
275 if(avcodec_check_dimensions(s,w,h))
18b8b2dcc037 various security fixes and precautionary checks
michael
parents: 2418
diff changeset
276 return -1;
18b8b2dcc037 various security fixes and precautionary checks
michael
parents: 2418
diff changeset
277
1214
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
278 if(s->internal_buffer==NULL){
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
279 s->internal_buffer= av_mallocz(INTERNAL_BUFFER_SIZE*sizeof(InternalBuffer));
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
280 }
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
281 #if 0
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
282 s->internal_buffer= av_fast_realloc(
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
283 s->internal_buffer,
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
284 &s->internal_buffer_size,
1214
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
285 sizeof(InternalBuffer)*FFMAX(99, s->internal_buffer_count+1)/*FIXME*/
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
286 );
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
287 #endif
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
288
1214
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
289 buf= &((InternalBuffer*)s->internal_buffer)[s->internal_buffer_count];
1588
de5e2acd0f80 initalize various uninitalized variables and avoid coded_picture_number as its not always correct (later should be reversed after fixing the picture_number mess)
michael
parents: 1585
diff changeset
290 picture_number= &(((InternalBuffer*)s->internal_buffer)[INTERNAL_BUFFER_SIZE-1]).last_pic_num; //FIXME ugly hack
de5e2acd0f80 initalize various uninitalized variables and avoid coded_picture_number as its not always correct (later should be reversed after fixing the picture_number mess)
michael
parents: 1585
diff changeset
291 (*picture_number)++;
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
292
1214
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
293 if(buf->base[0]){
1588
de5e2acd0f80 initalize various uninitalized variables and avoid coded_picture_number as its not always correct (later should be reversed after fixing the picture_number mess)
michael
parents: 1585
diff changeset
294 pic->age= *picture_number - buf->last_pic_num;
de5e2acd0f80 initalize various uninitalized variables and avoid coded_picture_number as its not always correct (later should be reversed after fixing the picture_number mess)
michael
parents: 1585
diff changeset
295 buf->last_pic_num= *picture_number;
903
22ee74da2cd3 cleanup
michaelni
parents: 902
diff changeset
296 }else{
1538
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
297 int h_chroma_shift, v_chroma_shift;
2950
2c4753d27834 default_get_buffer() cleanup
michael
parents: 2927
diff changeset
298 int pixel_size, size[3];
2c4753d27834 default_get_buffer() cleanup
michael
parents: 2927
diff changeset
299 AVPicture picture;
2c4753d27834 default_get_buffer() cleanup
michael
parents: 2927
diff changeset
300
903
22ee74da2cd3 cleanup
michaelni
parents: 902
diff changeset
301 avcodec_get_chroma_sub_sample(s->pix_fmt, &h_chroma_shift, &v_chroma_shift);
1538
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
302
2312ceb69d17 default_get_buffer() fixes
michael
parents: 1505
diff changeset
303 avcodec_align_dimensions(s, &w, &h);
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
304
903
22ee74da2cd3 cleanup
michaelni
parents: 902
diff changeset
305 if(!(s->flags&CODEC_FLAG_EMU_EDGE)){
22ee74da2cd3 cleanup
michaelni
parents: 902
diff changeset
306 w+= EDGE_WIDTH*2;
22ee74da2cd3 cleanup
michaelni
parents: 902
diff changeset
307 h+= EDGE_WIDTH*2;
22ee74da2cd3 cleanup
michaelni
parents: 902
diff changeset
308 }
2950
2c4753d27834 default_get_buffer() cleanup
michael
parents: 2927
diff changeset
309 avpicture_fill(&picture, NULL, s->pix_fmt, w, h);
2c4753d27834 default_get_buffer() cleanup
michael
parents: 2927
diff changeset
310 pixel_size= picture.linesize[0]*8 / w;
2c4753d27834 default_get_buffer() cleanup
michael
parents: 2927
diff changeset
311 //av_log(NULL, AV_LOG_ERROR, "%d %d %d %d\n", (int)picture.data[1], w, h, s->pix_fmt);
2c4753d27834 default_get_buffer() cleanup
michael
parents: 2927
diff changeset
312 assert(pixel_size>=1);
2c4753d27834 default_get_buffer() cleanup
michael
parents: 2927
diff changeset
313 //FIXME next ensures that linesize= 2^x uvlinesize, thats needed because some MC code assumes it
2c4753d27834 default_get_buffer() cleanup
michael
parents: 2927
diff changeset
314 if(pixel_size == 3*8)
2c4753d27834 default_get_buffer() cleanup
michael
parents: 2927
diff changeset
315 w= ALIGN(w, STRIDE_ALIGN<<h_chroma_shift);
2c4753d27834 default_get_buffer() cleanup
michael
parents: 2927
diff changeset
316 else
2c4753d27834 default_get_buffer() cleanup
michael
parents: 2927
diff changeset
317 w= ALIGN(pixel_size*w, STRIDE_ALIGN<<(h_chroma_shift+3)) / pixel_size;
2c4753d27834 default_get_buffer() cleanup
michael
parents: 2927
diff changeset
318 size[1] = avpicture_fill(&picture, NULL, s->pix_fmt, w, h);
2c4753d27834 default_get_buffer() cleanup
michael
parents: 2927
diff changeset
319 size[0] = picture.linesize[0] * h;
2c4753d27834 default_get_buffer() cleanup
michael
parents: 2927
diff changeset
320 size[1] -= size[0];
2c4753d27834 default_get_buffer() cleanup
michael
parents: 2927
diff changeset
321 if(picture.data[2])
2c4753d27834 default_get_buffer() cleanup
michael
parents: 2927
diff changeset
322 size[1]= size[2]= size[1]/2;
2c4753d27834 default_get_buffer() cleanup
michael
parents: 2927
diff changeset
323 else
2c4753d27834 default_get_buffer() cleanup
michael
parents: 2927
diff changeset
324 size[2]= 0;
2c4753d27834 default_get_buffer() cleanup
michael
parents: 2927
diff changeset
325
1214
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
326 buf->last_pic_num= -256*256*256*64;
2950
2c4753d27834 default_get_buffer() cleanup
michael
parents: 2927
diff changeset
327 memset(buf->base, 0, sizeof(buf->base));
2c4753d27834 default_get_buffer() cleanup
michael
parents: 2927
diff changeset
328 memset(buf->data, 0, sizeof(buf->data));
903
22ee74da2cd3 cleanup
michaelni
parents: 902
diff changeset
329
2950
2c4753d27834 default_get_buffer() cleanup
michael
parents: 2927
diff changeset
330 for(i=0; i<3 && size[i]; i++){
1165
michaelni
parents: 1150
diff changeset
331 const int h_shift= i==0 ? 0 : h_chroma_shift;
michaelni
parents: 1150
diff changeset
332 const int v_shift= i==0 ? 0 : v_chroma_shift;
903
22ee74da2cd3 cleanup
michaelni
parents: 902
diff changeset
333
2950
2c4753d27834 default_get_buffer() cleanup
michael
parents: 2927
diff changeset
334 buf->linesize[i]= picture.linesize[i];
903
22ee74da2cd3 cleanup
michaelni
parents: 902
diff changeset
335
2950
2c4753d27834 default_get_buffer() cleanup
michael
parents: 2927
diff changeset
336 buf->base[i]= av_malloc(size[i]+16); //FIXME 16
1214
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
337 if(buf->base[i]==NULL) return -1;
2950
2c4753d27834 default_get_buffer() cleanup
michael
parents: 2927
diff changeset
338 memset(buf->base[i], 128, size[i]);
2c4753d27834 default_get_buffer() cleanup
michael
parents: 2927
diff changeset
339
2c4753d27834 default_get_buffer() cleanup
michael
parents: 2927
diff changeset
340 // no edge if EDEG EMU or not planar YUV, we check for PAL8 redundantly to protect against a exploitable bug regression ...
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
341 if((s->flags&CODEC_FLAG_EMU_EDGE) || (s->pix_fmt == PIX_FMT_PAL8) || !size[2])
1214
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
342 buf->data[i] = buf->base[i];
903
22ee74da2cd3 cleanup
michaelni
parents: 902
diff changeset
343 else
2324
ba91c976c7aa stride align cleanup
michael
parents: 2309
diff changeset
344 buf->data[i] = buf->base[i] + ALIGN((buf->linesize[i]*EDGE_WIDTH>>v_shift) + (EDGE_WIDTH>>h_shift), STRIDE_ALIGN);
903
22ee74da2cd3 cleanup
michaelni
parents: 902
diff changeset
345 }
22ee74da2cd3 cleanup
michaelni
parents: 902
diff changeset
346 pic->age= 256*256*256*64;
22ee74da2cd3 cleanup
michaelni
parents: 902
diff changeset
347 }
1588
de5e2acd0f80 initalize various uninitalized variables and avoid coded_picture_number as its not always correct (later should be reversed after fixing the picture_number mess)
michael
parents: 1585
diff changeset
348 pic->type= FF_BUFFER_TYPE_INTERNAL;
903
22ee74da2cd3 cleanup
michaelni
parents: 902
diff changeset
349
1214
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
350 for(i=0; i<4; i++){
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
351 pic->base[i]= buf->base[i];
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
352 pic->data[i]= buf->data[i];
1588
de5e2acd0f80 initalize various uninitalized variables and avoid coded_picture_number as its not always correct (later should be reversed after fixing the picture_number mess)
michael
parents: 1585
diff changeset
353 pic->linesize[i]= buf->linesize[i];
1214
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
354 }
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
355 s->internal_buffer_count++;
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
356
903
22ee74da2cd3 cleanup
michaelni
parents: 902
diff changeset
357 return 0;
22ee74da2cd3 cleanup
michaelni
parents: 902
diff changeset
358 }
22ee74da2cd3 cleanup
michaelni
parents: 902
diff changeset
359
925
7fccaa0d699d AVVideoFrame -> AVFrame
michaelni
parents: 924
diff changeset
360 void avcodec_default_release_buffer(AVCodecContext *s, AVFrame *pic){
903
22ee74da2cd3 cleanup
michaelni
parents: 902
diff changeset
361 int i;
1214
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
362 InternalBuffer *buf, *last, temp;
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
363
924
3814e9115672 cleanup / messup?
michaelni
parents: 908
diff changeset
364 assert(pic->type==FF_BUFFER_TYPE_INTERNAL);
1396
e380ac39024a cleanup / fixes
michaelni
parents: 1389
diff changeset
365 assert(s->internal_buffer_count);
1214
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
366
1455
c4539ef4d8cb removed warnings
bellard
parents: 1449
diff changeset
367 buf = NULL; /* avoids warning */
1214
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
368 for(i=0; i<s->internal_buffer_count; i++){ //just 3-5 checks so is not worth to optimize
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
369 buf= &((InternalBuffer*)s->internal_buffer)[i];
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
370 if(buf->data[0] == pic->data[0])
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
371 break;
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
372 }
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
373 assert(i < s->internal_buffer_count);
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
374 s->internal_buffer_count--;
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
375 last = &((InternalBuffer*)s->internal_buffer)[s->internal_buffer_count];
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
376
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
377 temp= *buf;
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
378 *buf= *last;
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
379 *last= temp;
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
380
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
381 for(i=0; i<3; i++){
903
22ee74da2cd3 cleanup
michaelni
parents: 902
diff changeset
382 pic->data[i]=NULL;
1214
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
383 // pic->base[i]=NULL;
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
384 }
903
22ee74da2cd3 cleanup
michaelni
parents: 902
diff changeset
385 //printf("R%X\n", pic->opaque);
22ee74da2cd3 cleanup
michaelni
parents: 902
diff changeset
386 }
22ee74da2cd3 cleanup
michaelni
parents: 902
diff changeset
387
1630
586b5c08863c - Add reget_buffer() function to AVCodecContext
rtognimp
parents: 1606
diff changeset
388 int avcodec_default_reget_buffer(AVCodecContext *s, AVFrame *pic){
586b5c08863c - Add reget_buffer() function to AVCodecContext
rtognimp
parents: 1606
diff changeset
389 AVFrame temp_pic;
586b5c08863c - Add reget_buffer() function to AVCodecContext
rtognimp
parents: 1606
diff changeset
390 int i;
586b5c08863c - Add reget_buffer() function to AVCodecContext
rtognimp
parents: 1606
diff changeset
391
586b5c08863c - Add reget_buffer() function to AVCodecContext
rtognimp
parents: 1606
diff changeset
392 /* If no picture return a new buffer */
586b5c08863c - Add reget_buffer() function to AVCodecContext
rtognimp
parents: 1606
diff changeset
393 if(pic->data[0] == NULL) {
586b5c08863c - Add reget_buffer() function to AVCodecContext
rtognimp
parents: 1606
diff changeset
394 /* We will copy from buffer, so must be readable */
586b5c08863c - Add reget_buffer() function to AVCodecContext
rtognimp
parents: 1606
diff changeset
395 pic->buffer_hints |= FF_BUFFER_HINTS_READABLE;
586b5c08863c - Add reget_buffer() function to AVCodecContext
rtognimp
parents: 1606
diff changeset
396 return s->get_buffer(s, pic);
586b5c08863c - Add reget_buffer() function to AVCodecContext
rtognimp
parents: 1606
diff changeset
397 }
586b5c08863c - Add reget_buffer() function to AVCodecContext
rtognimp
parents: 1606
diff changeset
398
586b5c08863c - Add reget_buffer() function to AVCodecContext
rtognimp
parents: 1606
diff changeset
399 /* If internal buffer type return the same buffer */
586b5c08863c - Add reget_buffer() function to AVCodecContext
rtognimp
parents: 1606
diff changeset
400 if(pic->type == FF_BUFFER_TYPE_INTERNAL)
586b5c08863c - Add reget_buffer() function to AVCodecContext
rtognimp
parents: 1606
diff changeset
401 return 0;
586b5c08863c - Add reget_buffer() function to AVCodecContext
rtognimp
parents: 1606
diff changeset
402
586b5c08863c - Add reget_buffer() function to AVCodecContext
rtognimp
parents: 1606
diff changeset
403 /*
586b5c08863c - Add reget_buffer() function to AVCodecContext
rtognimp
parents: 1606
diff changeset
404 * Not internal type and reget_buffer not overridden, emulate cr buffer
586b5c08863c - Add reget_buffer() function to AVCodecContext
rtognimp
parents: 1606
diff changeset
405 */
586b5c08863c - Add reget_buffer() function to AVCodecContext
rtognimp
parents: 1606
diff changeset
406 temp_pic = *pic;
586b5c08863c - Add reget_buffer() function to AVCodecContext
rtognimp
parents: 1606
diff changeset
407 for(i = 0; i < 4; i++)
586b5c08863c - Add reget_buffer() function to AVCodecContext
rtognimp
parents: 1606
diff changeset
408 pic->data[i] = pic->base[i] = NULL;
586b5c08863c - Add reget_buffer() function to AVCodecContext
rtognimp
parents: 1606
diff changeset
409 pic->opaque = NULL;
586b5c08863c - Add reget_buffer() function to AVCodecContext
rtognimp
parents: 1606
diff changeset
410 /* Allocate new frame */
586b5c08863c - Add reget_buffer() function to AVCodecContext
rtognimp
parents: 1606
diff changeset
411 if (s->get_buffer(s, pic))
586b5c08863c - Add reget_buffer() function to AVCodecContext
rtognimp
parents: 1606
diff changeset
412 return -1;
586b5c08863c - Add reget_buffer() function to AVCodecContext
rtognimp
parents: 1606
diff changeset
413 /* Copy image data from old buffer to new buffer */
586b5c08863c - Add reget_buffer() function to AVCodecContext
rtognimp
parents: 1606
diff changeset
414 img_copy((AVPicture*)pic, (AVPicture*)&temp_pic, s->pix_fmt, s->width,
586b5c08863c - Add reget_buffer() function to AVCodecContext
rtognimp
parents: 1606
diff changeset
415 s->height);
586b5c08863c - Add reget_buffer() function to AVCodecContext
rtognimp
parents: 1606
diff changeset
416 s->release_buffer(s, &temp_pic); // Release old frame
586b5c08863c - Add reget_buffer() function to AVCodecContext
rtognimp
parents: 1606
diff changeset
417 return 0;
586b5c08863c - Add reget_buffer() function to AVCodecContext
rtognimp
parents: 1606
diff changeset
418 }
586b5c08863c - Add reget_buffer() function to AVCodecContext
rtognimp
parents: 1606
diff changeset
419
1799
95612d423fde multithreaded/SMP motion estimation
michael
parents: 1798
diff changeset
420 int avcodec_default_execute(AVCodecContext *c, int (*func)(AVCodecContext *c2, void *arg2),void **arg, int *ret, int count){
95612d423fde multithreaded/SMP motion estimation
michael
parents: 1798
diff changeset
421 int i;
95612d423fde multithreaded/SMP motion estimation
michael
parents: 1798
diff changeset
422
95612d423fde multithreaded/SMP motion estimation
michael
parents: 1798
diff changeset
423 for(i=0; i<count; i++){
95612d423fde multithreaded/SMP motion estimation
michael
parents: 1798
diff changeset
424 int r= func(c, arg[i]);
95612d423fde multithreaded/SMP motion estimation
michael
parents: 1798
diff changeset
425 if(ret) ret[i]= r;
95612d423fde multithreaded/SMP motion estimation
michael
parents: 1798
diff changeset
426 }
95612d423fde multithreaded/SMP motion estimation
michael
parents: 1798
diff changeset
427 return 0;
95612d423fde multithreaded/SMP motion estimation
michael
parents: 1798
diff changeset
428 }
95612d423fde multithreaded/SMP motion estimation
michael
parents: 1798
diff changeset
429
1858
ea2a4058441c silence warnings
iive
parents: 1856
diff changeset
430 enum PixelFormat avcodec_default_get_format(struct AVCodecContext *s, const enum PixelFormat * fmt){
998
6129c88a6393 get_format()
michaelni
parents: 992
diff changeset
431 return fmt[0];
6129c88a6393 get_format()
michaelni
parents: 992
diff changeset
432 }
6129c88a6393 get_format()
michaelni
parents: 992
diff changeset
433
1856
ed6eb3e304cc av_log() cleanup
michael
parents: 1855
diff changeset
434 static const char* context_to_name(void* ptr) {
ed6eb3e304cc av_log() cleanup
michael
parents: 1855
diff changeset
435 AVCodecContext *avc= ptr;
ed6eb3e304cc av_log() cleanup
michael
parents: 1855
diff changeset
436
ed6eb3e304cc av_log() cleanup
michael
parents: 1855
diff changeset
437 if(avc && avc->codec && avc->codec->name)
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
438 return avc->codec->name;
1856
ed6eb3e304cc av_log() cleanup
michael
parents: 1855
diff changeset
439 else
ed6eb3e304cc av_log() cleanup
michael
parents: 1855
diff changeset
440 return "NULL";
ed6eb3e304cc av_log() cleanup
michael
parents: 1855
diff changeset
441 }
ed6eb3e304cc av_log() cleanup
michael
parents: 1855
diff changeset
442
2862
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
443 #define OFFSET(x) (int)&((AVCodecContext*)0)->x
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
444 #define DEFAULT 0 //should be NAN but it doesnt work as its not a constant in glibc as required by ANSI/ISO C
2873
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
445 //these names are too long to be readable
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
446 #define V AV_OPT_FLAG_VIDEO_PARAM
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
447 #define A AV_OPT_FLAG_AUDIO_PARAM
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
448 #define S AV_OPT_FLAG_SUBTITLE_PARAM
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
449 #define E AV_OPT_FLAG_ENCODING_PARAM
2873
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
450 #define D AV_OPT_FLAG_DECODING_PARAM
2862
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
451
3420
54814e15aa3d Mark some read-only datastructures as const.
diego
parents: 3385
diff changeset
452 static const AVOption options[]={
2873
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
453 {"bit_rate", NULL, OFFSET(bit_rate), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|A|E},
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
454 {"bit_rate_tolerance", NULL, OFFSET(bit_rate_tolerance), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
2877
b447caeb6978 convert some options in ffmpeg.c to AVOptions
michael
parents: 2874
diff changeset
455 {"flags", NULL, OFFSET(flags), FF_OPT_TYPE_FLAGS, DEFAULT, INT_MIN, INT_MAX, V|A|E|D, "flags"},
2881
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
456 {"mv4", "use four motion vector by macroblock (mpeg4)", 0, FF_OPT_TYPE_CONST, CODEC_FLAG_4MV, INT_MIN, INT_MAX, V|E, "flags"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
457 {"obmc", "use overlapped block motion compensation (h263+)", 0, FF_OPT_TYPE_CONST, CODEC_FLAG_OBMC, INT_MIN, INT_MAX, V|E, "flags"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
458 {"qpel", "use 1/4 pel motion compensation", 0, FF_OPT_TYPE_CONST, CODEC_FLAG_QPEL, INT_MIN, INT_MAX, V|E, "flags"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
459 {"loop", "use loop filter", 0, FF_OPT_TYPE_CONST, CODEC_FLAG_LOOP_FILTER, INT_MIN, INT_MAX, V|E, "flags"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
460 {"qscale", "use fixed qscale", 0, FF_OPT_TYPE_CONST, CODEC_FLAG_QSCALE, INT_MIN, INT_MAX, 0, "flags"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
461 {"gmc", "use gmc", 0, FF_OPT_TYPE_CONST, CODEC_FLAG_GMC, INT_MIN, INT_MAX, V|E, "flags"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
462 {"mv0", "always try a mb with mv=<0,0>", 0, FF_OPT_TYPE_CONST, CODEC_FLAG_MV0, INT_MIN, INT_MAX, V|E, "flags"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
463 {"part", "use data partitioning", 0, FF_OPT_TYPE_CONST, CODEC_FLAG_PART, INT_MIN, INT_MAX, V|E, "flags"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
464 {"input_preserved", NULL, 0, FF_OPT_TYPE_CONST, CODEC_FLAG_INPUT_PRESERVED, INT_MIN, INT_MAX, 0, "flags"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
465 {"pass1", "use internal 2pass ratecontrol in first pass mode", 0, FF_OPT_TYPE_CONST, CODEC_FLAG_PASS1, INT_MIN, INT_MAX, 0, "flags"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
466 {"pass2", "use internal 2pass ratecontrol in second pass mode", 0, FF_OPT_TYPE_CONST, CODEC_FLAG_PASS2, INT_MIN, INT_MAX, 0, "flags"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
467 {"extern_huff", "use external huffman table (for mjpeg)", 0, FF_OPT_TYPE_CONST, CODEC_FLAG_EXTERN_HUFF, INT_MIN, INT_MAX, 0, "flags"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
468 {"gray", "only decode/encode grayscale", 0, FF_OPT_TYPE_CONST, CODEC_FLAG_GRAY, INT_MIN, INT_MAX, V|E|D, "flags"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
469 {"emu_edge", "don't draw edges", 0, FF_OPT_TYPE_CONST, CODEC_FLAG_EMU_EDGE, INT_MIN, INT_MAX, 0, "flags"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
470 {"psnr", "error[?] variables will be set during encoding", 0, FF_OPT_TYPE_CONST, CODEC_FLAG_PSNR, INT_MIN, INT_MAX, V|E, "flags"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
471 {"truncated", NULL, 0, FF_OPT_TYPE_CONST, CODEC_FLAG_TRUNCATED, INT_MIN, INT_MAX, 0, "flags"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
472 {"naq", "normalize adaptive quantization", 0, FF_OPT_TYPE_CONST, CODEC_FLAG_NORMALIZE_AQP, INT_MIN, INT_MAX, V|E, "flags"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
473 {"ildct", "use interlaced dct", 0, FF_OPT_TYPE_CONST, CODEC_FLAG_INTERLACED_DCT, INT_MIN, INT_MAX, V|E, "flags"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
474 {"low_delay", "force low delay", 0, FF_OPT_TYPE_CONST, CODEC_FLAG_LOW_DELAY, INT_MIN, INT_MAX, V|D, "flags"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
475 {"alt", "enable alternate scantable (mpeg2/mpeg4)", 0, FF_OPT_TYPE_CONST, CODEC_FLAG_ALT_SCAN, INT_MIN, INT_MAX, V|E, "flags"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
476 {"trell", "use trellis quantization", 0, FF_OPT_TYPE_CONST, CODEC_FLAG_TRELLIS_QUANT, INT_MIN, INT_MAX, V|E, "flags"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
477 {"global_header", "place global headers in extradata instead of every keyframe", 0, FF_OPT_TYPE_CONST, CODEC_FLAG_GLOBAL_HEADER, INT_MIN, INT_MAX, 0, "flags"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
478 {"bitexact", "use only bitexact stuff (except (i)dct)", 0, FF_OPT_TYPE_CONST, CODEC_FLAG_BITEXACT, INT_MIN, INT_MAX, A|V|S|D|E, "flags"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
479 {"aic", "h263 advanced intra coding / mpeg4 ac prediction", 0, FF_OPT_TYPE_CONST, CODEC_FLAG_AC_PRED, INT_MIN, INT_MAX, V|E, "flags"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
480 {"umv", "use unlimited motion vectors", 0, FF_OPT_TYPE_CONST, CODEC_FLAG_H263P_UMV, INT_MIN, INT_MAX, V|E, "flags"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
481 {"cbp", "use rate distortion optimization for cbp", 0, FF_OPT_TYPE_CONST, CODEC_FLAG_CBP_RD, INT_MIN, INT_MAX, V|E, "flags"},
2890
8c9eee3fb35d changing a few options to AVOptions
michael
parents: 2884
diff changeset
482 {"qprd", "use rate distortion optimization for qp selection", 0, FF_OPT_TYPE_CONST, CODEC_FLAG_QP_RD, INT_MIN, INT_MAX, V|E, "flags"},
2881
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
483 {"aiv", "h263 alternative inter vlc", 0, FF_OPT_TYPE_CONST, CODEC_FLAG_H263P_AIV, INT_MIN, INT_MAX, V|E, "flags"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
484 {"slice", NULL, 0, FF_OPT_TYPE_CONST, CODEC_FLAG_H263P_SLICE_STRUCT, INT_MIN, INT_MAX, V|E, "flags"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
485 {"ilme", "interlaced motion estimation", 0, FF_OPT_TYPE_CONST, CODEC_FLAG_INTERLACED_ME, INT_MIN, INT_MAX, V|E, "flags"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
486 {"scan_offset", "will reserve space for svcd scan offset user data", 0, FF_OPT_TYPE_CONST, CODEC_FLAG_SVCD_SCAN_OFFSET, INT_MIN, INT_MAX, V|E, "flags"},
2890
8c9eee3fb35d changing a few options to AVOptions
michael
parents: 2884
diff changeset
487 {"cgop", "closed gop", 0, FF_OPT_TYPE_CONST, CODEC_FLAG_CLOSED_GOP, INT_MIN, INT_MAX, V|E, "flags"},
2881
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
488 {"fast", "allow non spec compliant speedup tricks", 0, FF_OPT_TYPE_CONST, CODEC_FLAG2_FAST, INT_MIN, INT_MAX, V|E, "flags2"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
489 {"sgop", "strictly enforce gop size", 0, FF_OPT_TYPE_CONST, CODEC_FLAG2_STRICT_GOP, INT_MIN, INT_MAX, V|E, "flags2"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
490 {"noout", "skip bitstream encoding", 0, FF_OPT_TYPE_CONST, CODEC_FLAG2_NO_OUTPUT, INT_MIN, INT_MAX, V|E, "flags2"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
491 {"local_header", "place global headers at every keyframe instead of in extradata", 0, FF_OPT_TYPE_CONST, CODEC_FLAG2_LOCAL_HEADER, INT_MIN, INT_MAX, V|E, "flags2"},
2862
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
492 {"sub_id", NULL, OFFSET(sub_id), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX},
2874
b6def74f5811 flags and named constants with type checking of course for AVOption
michael
parents: 2873
diff changeset
493 {"me_method", NULL, OFFSET(me_method), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E, "me_method"},
2862
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
494 {"extradata_size", NULL, OFFSET(extradata_size), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX},
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
495 {"time_base", NULL, OFFSET(time_base), FF_OPT_TYPE_RATIONAL, DEFAULT, INT_MIN, INT_MAX},
2873
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
496 {"gop_size", NULL, OFFSET(gop_size), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
2862
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
497 {"rate_emu", NULL, OFFSET(rate_emu), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX},
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
498 {"sample_rate", NULL, OFFSET(sample_rate), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX},
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
499 {"channels", NULL, OFFSET(channels), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX},
3031
0f5f311f2f94 Parameter added for user to set the cutoff frequency when encoding with faac.
banan
parents: 2996
diff changeset
500 {"cutoff", "set cutoff bandwidth", OFFSET(cutoff), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, A|E},
3442
5d133e59ecf2 allows user-settable block size and fixes related typo
jbr
parents: 3438
diff changeset
501 {"frame_size", NULL, OFFSET(frame_size), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, A|E},
2862
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
502 {"frame_number", NULL, OFFSET(frame_number), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX},
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
503 {"real_pict_num", NULL, OFFSET(real_pict_num), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX},
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
504 {"delay", NULL, OFFSET(delay), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX},
2873
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
505 {"qcompress", NULL, OFFSET(qcompress), FF_OPT_TYPE_FLOAT, DEFAULT, FLT_MIN, FLT_MAX, V|E},
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
506 {"qblur", NULL, OFFSET(qblur), FF_OPT_TYPE_FLOAT, DEFAULT, FLT_MIN, FLT_MAX, V|E},
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
507 {"qmin", NULL, OFFSET(qmin), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
508 {"qmax", NULL, OFFSET(qmax), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
509 {"max_qdiff", NULL, OFFSET(max_qdiff), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
510 {"max_b_frames", NULL, OFFSET(max_b_frames), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
511 {"b_quant_factor", NULL, OFFSET(b_quant_factor), FF_OPT_TYPE_FLOAT, DEFAULT, FLT_MIN, FLT_MAX, V|E},
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
512 {"rc_strategy", NULL, OFFSET(rc_strategy), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
2989
c6e656e76eed 10l (didnt remove option from old ones after converting to AVOption)
michael
parents: 2983
diff changeset
513 {"b_strategy", NULL, OFFSET(b_frame_strategy), FF_OPT_TYPE_INT, 0, INT_MIN, INT_MAX, V|E},
2873
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
514 {"hurry_up", NULL, OFFSET(hurry_up), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|D},
2862
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
515 {"rtp_mode", NULL, OFFSET(rtp_mode), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX},
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
516 {"rtp_payload_size", NULL, OFFSET(rtp_payload_size), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX},
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
517 {"mv_bits", NULL, OFFSET(mv_bits), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX},
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
518 {"header_bits", NULL, OFFSET(header_bits), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX},
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
519 {"i_tex_bits", NULL, OFFSET(i_tex_bits), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX},
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
520 {"p_tex_bits", NULL, OFFSET(p_tex_bits), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX},
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
521 {"i_count", NULL, OFFSET(i_count), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX},
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
522 {"p_count", NULL, OFFSET(p_count), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX},
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
523 {"skip_count", NULL, OFFSET(skip_count), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX},
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
524 {"misc_bits", NULL, OFFSET(misc_bits), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX},
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
525 {"frame_bits", NULL, OFFSET(frame_bits), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX},
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
526 {"codec_tag", NULL, OFFSET(codec_tag), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX},
2878
71644f84e79d converting a few more options to AVOptions
michael
parents: 2877
diff changeset
527 {"bugs", NULL, OFFSET(workaround_bugs), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|D, "bug"},
2881
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
528 {"autodetect", NULL, 0, FF_OPT_TYPE_CONST, FF_BUG_AUTODETECT, INT_MIN, INT_MAX, V|D, "bug"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
529 {"old_msmpeg4", NULL, 0, FF_OPT_TYPE_CONST, FF_BUG_OLD_MSMPEG4, INT_MIN, INT_MAX, V|D, "bug"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
530 {"xvid_ilace", NULL, 0, FF_OPT_TYPE_CONST, FF_BUG_XVID_ILACE, INT_MIN, INT_MAX, V|D, "bug"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
531 {"ump4", NULL, 0, FF_OPT_TYPE_CONST, FF_BUG_UMP4, INT_MIN, INT_MAX, V|D, "bug"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
532 {"no_padding", NULL, 0, FF_OPT_TYPE_CONST, FF_BUG_NO_PADDING, INT_MIN, INT_MAX, V|D, "bug"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
533 {"amv", NULL, 0, FF_OPT_TYPE_CONST, FF_BUG_AMV, INT_MIN, INT_MAX, V|D, "bug"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
534 {"ac_vlc", NULL, 0, FF_OPT_TYPE_CONST, FF_BUG_AC_VLC, INT_MIN, INT_MAX, V|D, "bug"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
535 {"qpel_chroma", NULL, 0, FF_OPT_TYPE_CONST, FF_BUG_QPEL_CHROMA, INT_MIN, INT_MAX, V|D, "bug"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
536 {"std_qpel", NULL, 0, FF_OPT_TYPE_CONST, FF_BUG_STD_QPEL, INT_MIN, INT_MAX, V|D, "bug"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
537 {"qpel_chroma2", NULL, 0, FF_OPT_TYPE_CONST, FF_BUG_QPEL_CHROMA2, INT_MIN, INT_MAX, V|D, "bug"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
538 {"direct_blocksize", NULL, 0, FF_OPT_TYPE_CONST, FF_BUG_DIRECT_BLOCKSIZE, INT_MIN, INT_MAX, V|D, "bug"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
539 {"edge", NULL, 0, FF_OPT_TYPE_CONST, FF_BUG_EDGE, INT_MIN, INT_MAX, V|D, "bug"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
540 {"hpel_chroma", NULL, 0, FF_OPT_TYPE_CONST, FF_BUG_HPEL_CHROMA, INT_MIN, INT_MAX, V|D, "bug"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
541 {"dc_clip", NULL, 0, FF_OPT_TYPE_CONST, FF_BUG_DC_CLIP, INT_MIN, INT_MAX, V|D, "bug"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
542 {"ms", NULL, 0, FF_OPT_TYPE_CONST, FF_BUG_MS, INT_MIN, INT_MAX, V|D, "bug"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
543 {"lelim", "single coefficient elimination threshold for luminance (negative values also consider dc coefficient)", OFFSET(luma_elim_threshold), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
544 {"celim", "single coefficient elimination threshold for chrominance (negative values also consider dc coefficient)", OFFSET(chroma_elim_threshold), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
2878
71644f84e79d converting a few more options to AVOptions
michael
parents: 2877
diff changeset
545 {"strict", NULL, OFFSET(strict_std_compliance), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E, "strict"},
2881
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
546 {"very", NULL, 0, FF_OPT_TYPE_CONST, FF_COMPLIANCE_VERY_STRICT, INT_MIN, INT_MAX, V|E, "strict"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
547 {"strict", NULL, 0, FF_OPT_TYPE_CONST, FF_COMPLIANCE_STRICT, INT_MIN, INT_MAX, V|E, "strict"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
548 {"normal", NULL, 0, FF_OPT_TYPE_CONST, FF_COMPLIANCE_NORMAL, INT_MIN, INT_MAX, V|E, "strict"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
549 {"inofficial", NULL, 0, FF_OPT_TYPE_CONST, FF_COMPLIANCE_INOFFICIAL, INT_MIN, INT_MAX, V|E, "strict"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
550 {"experimental", NULL, 0, FF_OPT_TYPE_CONST, FF_COMPLIANCE_EXPERIMENTAL, INT_MIN, INT_MAX, V|E, "strict"},
2873
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
551 {"b_quant_offset", NULL, OFFSET(b_quant_offset), FF_OPT_TYPE_FLOAT, DEFAULT, FLT_MIN, FLT_MAX, V|E},
2890
8c9eee3fb35d changing a few options to AVOptions
michael
parents: 2884
diff changeset
552 {"er", NULL, OFFSET(error_resilience), FF_OPT_TYPE_INT, FF_ER_CAREFUL, INT_MIN, INT_MAX, V|D, "er"},
2881
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
553 {"careful", NULL, 0, FF_OPT_TYPE_CONST, FF_ER_CAREFUL, INT_MIN, INT_MAX, V|D, "er"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
554 {"compliant", NULL, 0, FF_OPT_TYPE_CONST, FF_ER_COMPLIANT, INT_MIN, INT_MAX, V|D, "er"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
555 {"aggressive", NULL, 0, FF_OPT_TYPE_CONST, FF_ER_AGGRESSIVE, INT_MIN, INT_MAX, V|D, "er"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
556 {"very_aggressive", NULL, 0, FF_OPT_TYPE_CONST, FF_ER_VERY_AGGRESSIVE, INT_MIN, INT_MAX, V|D, "er"},
2862
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
557 {"has_b_frames", NULL, OFFSET(has_b_frames), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX},
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
558 {"block_align", NULL, OFFSET(block_align), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX},
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
559 {"parse_only", NULL, OFFSET(parse_only), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX},
2873
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
560 {"mpeg_quant", NULL, OFFSET(mpeg_quant), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
2862
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
561 {"stats_out", NULL, OFFSET(stats_out), FF_OPT_TYPE_STRING, DEFAULT, CHAR_MIN, CHAR_MAX},
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
562 {"stats_in", NULL, OFFSET(stats_in), FF_OPT_TYPE_STRING, DEFAULT, CHAR_MIN, CHAR_MAX},
2873
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
563 {"rc_qsquish", NULL, OFFSET(rc_qsquish), FF_OPT_TYPE_FLOAT, DEFAULT, FLT_MIN, FLT_MAX, V|E},
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
564 {"rc_qmod_amp", NULL, OFFSET(rc_qmod_amp), FF_OPT_TYPE_FLOAT, DEFAULT, FLT_MIN, FLT_MAX, V|E},
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
565 {"rc_qmod_freq", NULL, OFFSET(rc_qmod_freq), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
2862
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
566 {"rc_override_count", NULL, OFFSET(rc_override_count), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX},
2873
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
567 {"rc_eq", NULL, OFFSET(rc_eq), FF_OPT_TYPE_STRING, DEFAULT, CHAR_MIN, CHAR_MAX, V|E},
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
568 {"rc_max_rate", NULL, OFFSET(rc_max_rate), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
569 {"rc_min_rate", NULL, OFFSET(rc_min_rate), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
570 {"rc_buffer_size", NULL, OFFSET(rc_buffer_size), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
571 {"rc_buf_aggressivity", NULL, OFFSET(rc_buffer_aggressivity), FF_OPT_TYPE_FLOAT, DEFAULT, FLT_MIN, FLT_MAX, V|E},
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
572 {"i_quant_factor", NULL, OFFSET(i_quant_factor), FF_OPT_TYPE_FLOAT, DEFAULT, FLT_MIN, FLT_MAX, V|E},
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
573 {"i_quant_offset", NULL, OFFSET(i_quant_offset), FF_OPT_TYPE_FLOAT, DEFAULT, FLT_MIN, FLT_MAX, V|E},
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
574 {"rc_initial_cplx", NULL, OFFSET(rc_initial_cplx), FF_OPT_TYPE_FLOAT, DEFAULT, FLT_MIN, FLT_MAX, V|E},
2877
b447caeb6978 convert some options in ffmpeg.c to AVOptions
michael
parents: 2874
diff changeset
575 {"dct", NULL, OFFSET(dct_algo), FF_OPT_TYPE_INT, DEFAULT, 0, INT_MAX, V|E, "dct"},
2881
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
576 {"auto", NULL, 0, FF_OPT_TYPE_CONST, FF_DCT_AUTO, INT_MIN, INT_MAX, V|E, "dct"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
577 {"fastint", NULL, 0, FF_OPT_TYPE_CONST, FF_DCT_FASTINT, INT_MIN, INT_MAX, V|E, "dct"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
578 {"int", NULL, 0, FF_OPT_TYPE_CONST, FF_DCT_INT, INT_MIN, INT_MAX, V|E, "dct"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
579 {"mmx", NULL, 0, FF_OPT_TYPE_CONST, FF_DCT_MMX, INT_MIN, INT_MAX, V|E, "dct"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
580 {"mlib", NULL, 0, FF_OPT_TYPE_CONST, FF_DCT_MLIB, INT_MIN, INT_MAX, V|E, "dct"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
581 {"altivec", NULL, 0, FF_OPT_TYPE_CONST, FF_DCT_ALTIVEC, INT_MIN, INT_MAX, V|E, "dct"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
582 {"faan", NULL, 0, FF_OPT_TYPE_CONST, FF_DCT_FAAN, INT_MIN, INT_MAX, V|E, "dct"},
2890
8c9eee3fb35d changing a few options to AVOptions
michael
parents: 2884
diff changeset
583 {"lumi_mask", "lumimasking", OFFSET(lumi_masking), FF_OPT_TYPE_FLOAT, 0, FLT_MIN, FLT_MAX, V|E},
8c9eee3fb35d changing a few options to AVOptions
michael
parents: 2884
diff changeset
584 {"tcplx_mask", "temporal complexity masking", OFFSET(temporal_cplx_masking), FF_OPT_TYPE_FLOAT, 0, FLT_MIN, FLT_MAX, V|E},
8c9eee3fb35d changing a few options to AVOptions
michael
parents: 2884
diff changeset
585 {"scplx_mask", "spatial complexity masking", OFFSET(spatial_cplx_masking), FF_OPT_TYPE_FLOAT, 0, FLT_MIN, FLT_MAX, V|E},
8c9eee3fb35d changing a few options to AVOptions
michael
parents: 2884
diff changeset
586 {"p_mask", "inter masking", OFFSET(p_masking), FF_OPT_TYPE_FLOAT, 0, FLT_MIN, FLT_MAX, V|E},
8c9eee3fb35d changing a few options to AVOptions
michael
parents: 2884
diff changeset
587 {"dark_mask", "darkness masking", OFFSET(dark_masking), FF_OPT_TYPE_FLOAT, 0, FLT_MIN, FLT_MAX, V|E},
2862
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
588 {"unused", NULL, OFFSET(unused), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX},
2877
b447caeb6978 convert some options in ffmpeg.c to AVOptions
michael
parents: 2874
diff changeset
589 {"idct", NULL, OFFSET(idct_algo), FF_OPT_TYPE_INT, DEFAULT, 0, INT_MAX, V|E|D, "idct"},
2881
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
590 {"auto", NULL, 0, FF_OPT_TYPE_CONST, FF_IDCT_AUTO, INT_MIN, INT_MAX, V|E|D, "idct"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
591 {"int", NULL, 0, FF_OPT_TYPE_CONST, FF_IDCT_INT, INT_MIN, INT_MAX, V|E|D, "idct"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
592 {"simple", NULL, 0, FF_OPT_TYPE_CONST, FF_IDCT_SIMPLE, INT_MIN, INT_MAX, V|E|D, "idct"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
593 {"simplemmx", NULL, 0, FF_OPT_TYPE_CONST, FF_IDCT_SIMPLEMMX, INT_MIN, INT_MAX, V|E|D, "idct"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
594 {"libmpeg2mmx", NULL, 0, FF_OPT_TYPE_CONST, FF_IDCT_LIBMPEG2MMX, INT_MIN, INT_MAX, V|E|D, "idct"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
595 {"ps2", NULL, 0, FF_OPT_TYPE_CONST, FF_IDCT_PS2, INT_MIN, INT_MAX, V|E|D, "idct"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
596 {"mlib", NULL, 0, FF_OPT_TYPE_CONST, FF_IDCT_MLIB, INT_MIN, INT_MAX, V|E|D, "idct"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
597 {"arm", NULL, 0, FF_OPT_TYPE_CONST, FF_IDCT_ARM, INT_MIN, INT_MAX, V|E|D, "idct"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
598 {"altivec", NULL, 0, FF_OPT_TYPE_CONST, FF_IDCT_ALTIVEC, INT_MIN, INT_MAX, V|E|D, "idct"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
599 {"sh4", NULL, 0, FF_OPT_TYPE_CONST, FF_IDCT_SH4, INT_MIN, INT_MAX, V|E|D, "idct"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
600 {"simplearm", NULL, 0, FF_OPT_TYPE_CONST, FF_IDCT_SIMPLEARM, INT_MIN, INT_MAX, V|E|D, "idct"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
601 {"h264", NULL, 0, FF_OPT_TYPE_CONST, FF_IDCT_H264, INT_MIN, INT_MAX, V|E|D, "idct"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
602 {"vp3", NULL, 0, FF_OPT_TYPE_CONST, FF_IDCT_VP3, INT_MIN, INT_MAX, V|E|D, "idct"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
603 {"ipp", NULL, 0, FF_OPT_TYPE_CONST, FF_IDCT_IPP, INT_MIN, INT_MAX, V|E|D, "idct"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
604 {"xvidmmx", NULL, 0, FF_OPT_TYPE_CONST, FF_IDCT_XVIDMMX, INT_MIN, INT_MAX, V|E|D, "idct"},
2862
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
605 {"slice_count", NULL, OFFSET(slice_count), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX},
2890
8c9eee3fb35d changing a few options to AVOptions
michael
parents: 2884
diff changeset
606 {"ec", NULL, OFFSET(error_concealment), FF_OPT_TYPE_FLAGS, 3, INT_MIN, INT_MAX, V|D, "ec"},
2881
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
607 {"guess_mvs", NULL, 0, FF_OPT_TYPE_CONST, FF_EC_GUESS_MVS, INT_MIN, INT_MAX, V|D, "ec"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
608 {"deblock", NULL, 0, FF_OPT_TYPE_CONST, FF_EC_DEBLOCK, INT_MIN, INT_MAX, V|D, "ec"},
2862
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
609 {"bits_per_sample", NULL, OFFSET(bits_per_sample), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX},
2890
8c9eee3fb35d changing a few options to AVOptions
michael
parents: 2884
diff changeset
610 {"pred", "prediction method", OFFSET(prediction_method), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E, "pred"},
2881
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
611 {"left", NULL, 0, FF_OPT_TYPE_CONST, FF_PRED_LEFT, INT_MIN, INT_MAX, V|E, "pred"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
612 {"plane", NULL, 0, FF_OPT_TYPE_CONST, FF_PRED_PLANE, INT_MIN, INT_MAX, V|E, "pred"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
613 {"median", NULL, 0, FF_OPT_TYPE_CONST, FF_PRED_MEDIAN, INT_MIN, INT_MAX, V|E, "pred"},
2877
b447caeb6978 convert some options in ffmpeg.c to AVOptions
michael
parents: 2874
diff changeset
614 {"aspect", NULL, OFFSET(sample_aspect_ratio), FF_OPT_TYPE_RATIONAL, DEFAULT, 0, 10, V|E},
b447caeb6978 convert some options in ffmpeg.c to AVOptions
michael
parents: 2874
diff changeset
615 {"debug", "print specific debug info", OFFSET(debug), FF_OPT_TYPE_FLAGS, DEFAULT, 0, INT_MAX, V|A|S|E|D, "debug"},
2881
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
616 {"pict", NULL, 0, FF_OPT_TYPE_CONST, FF_DEBUG_PICT_INFO, INT_MIN, INT_MAX, V|D, "debug"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
617 {"rc", NULL, 0, FF_OPT_TYPE_CONST, FF_DEBUG_RC, INT_MIN, INT_MAX, V|E, "debug"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
618 {"bitstream", NULL, 0, FF_OPT_TYPE_CONST, FF_DEBUG_BITSTREAM, INT_MIN, INT_MAX, V|D, "debug"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
619 {"mb_type", NULL, 0, FF_OPT_TYPE_CONST, FF_DEBUG_MB_TYPE, INT_MIN, INT_MAX, V|D, "debug"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
620 {"qp", NULL, 0, FF_OPT_TYPE_CONST, FF_DEBUG_QP, INT_MIN, INT_MAX, V|D, "debug"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
621 {"mv", NULL, 0, FF_OPT_TYPE_CONST, FF_DEBUG_MV, INT_MIN, INT_MAX, V|D, "debug"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
622 {"dct_coeff", NULL, 0, FF_OPT_TYPE_CONST, FF_DEBUG_DCT_COEFF, INT_MIN, INT_MAX, V|D, "debug"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
623 {"skip", NULL, 0, FF_OPT_TYPE_CONST, FF_DEBUG_SKIP, INT_MIN, INT_MAX, V|D, "debug"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
624 {"startcode", NULL, 0, FF_OPT_TYPE_CONST, FF_DEBUG_STARTCODE, INT_MIN, INT_MAX, V|D, "debug"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
625 {"pts", NULL, 0, FF_OPT_TYPE_CONST, FF_DEBUG_PTS, INT_MIN, INT_MAX, V|D, "debug"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
626 {"er", NULL, 0, FF_OPT_TYPE_CONST, FF_DEBUG_ER, INT_MIN, INT_MAX, V|D, "debug"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
627 {"mmco", NULL, 0, FF_OPT_TYPE_CONST, FF_DEBUG_MMCO, INT_MIN, INT_MAX, V|D, "debug"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
628 {"bugs", NULL, 0, FF_OPT_TYPE_CONST, FF_DEBUG_BUGS, INT_MIN, INT_MAX, V|D, "debug"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
629 {"vis_qp", NULL, 0, FF_OPT_TYPE_CONST, FF_DEBUG_VIS_QP, INT_MIN, INT_MAX, V|D, "debug"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
630 {"vis_mb_type", NULL, 0, FF_OPT_TYPE_CONST, FF_DEBUG_VIS_MB_TYPE, INT_MIN, INT_MAX, V|D, "debug"},
2877
b447caeb6978 convert some options in ffmpeg.c to AVOptions
michael
parents: 2874
diff changeset
631 {"vismv", "visualize motion vectors", OFFSET(debug_mv), FF_OPT_TYPE_INT, DEFAULT, 0, INT_MAX, V|D, "debug_mv"},
2881
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
632 {"pf", NULL, 0, FF_OPT_TYPE_CONST, FF_DEBUG_VIS_MV_P_FOR, INT_MIN, INT_MAX, V|D, "debug_mv"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
633 {"bf", NULL, 0, FF_OPT_TYPE_CONST, FF_DEBUG_VIS_MV_B_FOR, INT_MIN, INT_MAX, V|D, "debug_mv"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
634 {"bb", NULL, 0, FF_OPT_TYPE_CONST, FF_DEBUG_VIS_MV_B_BACK, INT_MIN, INT_MAX, V|D, "debug_mv"},
2873
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
635 {"mb_qmin", NULL, OFFSET(mb_qmin), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
636 {"mb_qmax", NULL, OFFSET(mb_qmax), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
2881
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
637 {"cmp", "full pel me compare function", OFFSET(me_cmp), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E, "cmp_func"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
638 {"subcmp", "sub pel me compare function", OFFSET(me_sub_cmp), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E, "cmp_func"},
2878
71644f84e79d converting a few more options to AVOptions
michael
parents: 2877
diff changeset
639 {"mbcmp", "macroblock compare function", OFFSET(mb_cmp), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E, "cmp_func"},
71644f84e79d converting a few more options to AVOptions
michael
parents: 2877
diff changeset
640 {"ildctcmp", "interlaced dct compare function", OFFSET(ildct_cmp), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E, "cmp_func"},
71644f84e79d converting a few more options to AVOptions
michael
parents: 2877
diff changeset
641 {"dia_size", NULL, OFFSET(dia_size), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
2873
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
642 {"last_pred", NULL, OFFSET(last_predictor_count), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
2877
b447caeb6978 convert some options in ffmpeg.c to AVOptions
michael
parents: 2874
diff changeset
643 {"preme", NULL, OFFSET(pre_me), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
2878
71644f84e79d converting a few more options to AVOptions
michael
parents: 2877
diff changeset
644 {"precmp", "pre motion estimation compare function", OFFSET(me_pre_cmp), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E, "cmp_func"},
2881
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
645 {"sad", NULL, 0, FF_OPT_TYPE_CONST, FF_CMP_SAD, INT_MIN, INT_MAX, V|E, "cmp_func"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
646 {"sse", NULL, 0, FF_OPT_TYPE_CONST, FF_CMP_SSE, INT_MIN, INT_MAX, V|E, "cmp_func"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
647 {"satd", NULL, 0, FF_OPT_TYPE_CONST, FF_CMP_SATD, INT_MIN, INT_MAX, V|E, "cmp_func"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
648 {"dct", NULL, 0, FF_OPT_TYPE_CONST, FF_CMP_DCT, INT_MIN, INT_MAX, V|E, "cmp_func"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
649 {"psnr", NULL, 0, FF_OPT_TYPE_CONST, FF_CMP_PSNR, INT_MIN, INT_MAX, V|E, "cmp_func"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
650 {"bit", NULL, 0, FF_OPT_TYPE_CONST, FF_CMP_BIT, INT_MIN, INT_MAX, V|E, "cmp_func"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
651 {"rd", NULL, 0, FF_OPT_TYPE_CONST, FF_CMP_RD, INT_MIN, INT_MAX, V|E, "cmp_func"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
652 {"zero", NULL, 0, FF_OPT_TYPE_CONST, FF_CMP_ZERO, INT_MIN, INT_MAX, V|E, "cmp_func"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
653 {"vsad", NULL, 0, FF_OPT_TYPE_CONST, FF_CMP_VSAD, INT_MIN, INT_MAX, V|E, "cmp_func"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
654 {"vsse", NULL, 0, FF_OPT_TYPE_CONST, FF_CMP_VSSE, INT_MIN, INT_MAX, V|E, "cmp_func"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
655 {"nsse", NULL, 0, FF_OPT_TYPE_CONST, FF_CMP_NSSE, INT_MIN, INT_MAX, V|E, "cmp_func"},
3373
b8996cc5ccae Disable w53 and w97 cmp methods when snow encoder is disabled
gpoirier
parents: 3372
diff changeset
656 #ifdef CONFIG_SNOW_ENCODER
2881
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
657 {"w53", NULL, 0, FF_OPT_TYPE_CONST, FF_CMP_W53, INT_MIN, INT_MAX, V|E, "cmp_func"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
658 {"w97", NULL, 0, FF_OPT_TYPE_CONST, FF_CMP_W97, INT_MIN, INT_MAX, V|E, "cmp_func"},
3373
b8996cc5ccae Disable w53 and w97 cmp methods when snow encoder is disabled
gpoirier
parents: 3372
diff changeset
659 #endif
2881
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
660 {"dctmax", NULL, 0, FF_OPT_TYPE_CONST, FF_CMP_DCTMAX, INT_MIN, INT_MAX, V|E, "cmp_func"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
661 {"chroma", NULL, 0, FF_OPT_TYPE_CONST, FF_CMP_CHROMA, INT_MIN, INT_MAX, V|E, "cmp_func"},
2873
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
662 {"pre_dia_size", NULL, OFFSET(pre_dia_size), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
2890
8c9eee3fb35d changing a few options to AVOptions
michael
parents: 2884
diff changeset
663 {"subq", "sub pel motion estimation quality", OFFSET(me_subpel_quality), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
2862
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
664 {"dtg_active_format", NULL, OFFSET(dtg_active_format), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX},
2873
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
665 {"me_range", NULL, OFFSET(me_range), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
666 {"ibias", NULL, OFFSET(intra_quant_bias), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
667 {"pbias", NULL, OFFSET(inter_quant_bias), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
2862
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
668 {"color_table_id", NULL, OFFSET(color_table_id), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX},
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
669 {"internal_buffer_count", NULL, OFFSET(internal_buffer_count), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX},
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
670 {"global_quality", NULL, OFFSET(global_quality), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX},
2878
71644f84e79d converting a few more options to AVOptions
michael
parents: 2877
diff changeset
671 {"coder", NULL, OFFSET(coder_type), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E, "coder"},
2890
8c9eee3fb35d changing a few options to AVOptions
michael
parents: 2884
diff changeset
672 {"vlc", "variable length coder / huffman coder", 0, FF_OPT_TYPE_CONST, FF_CODER_TYPE_VLC, INT_MIN, INT_MAX, V|E, "coder"},
8c9eee3fb35d changing a few options to AVOptions
michael
parents: 2884
diff changeset
673 {"ac", "arithmetic coder", 0, FF_OPT_TYPE_CONST, FF_CODER_TYPE_AC, INT_MIN, INT_MAX, V|E, "coder"},
8c9eee3fb35d changing a few options to AVOptions
michael
parents: 2884
diff changeset
674 {"context", "context model", OFFSET(context_model), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
2862
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
675 {"slice_flags", NULL, OFFSET(slice_flags), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX},
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
676 {"xvmc_acceleration", NULL, OFFSET(xvmc_acceleration), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX},
2878
71644f84e79d converting a few more options to AVOptions
michael
parents: 2877
diff changeset
677 {"mbd", NULL, OFFSET(mb_decision), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E, "mbd"},
2881
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
678 {"simple", NULL, 0, FF_OPT_TYPE_CONST, FF_MB_DECISION_SIMPLE, INT_MIN, INT_MAX, V|E, "mbd"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
679 {"bits", NULL, 0, FF_OPT_TYPE_CONST, FF_MB_DECISION_BITS, INT_MIN, INT_MAX, V|E, "mbd"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
680 {"rd", NULL, 0, FF_OPT_TYPE_CONST, FF_MB_DECISION_RD, INT_MIN, INT_MAX, V|E, "mbd"},
2862
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
681 {"stream_codec_tag", NULL, OFFSET(stream_codec_tag), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX},
2873
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
682 {"sc_threshold", NULL, OFFSET(scenechange_threshold), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
2877
b447caeb6978 convert some options in ffmpeg.c to AVOptions
michael
parents: 2874
diff changeset
683 {"lmin", "min lagrange factor", OFFSET(lmin), FF_OPT_TYPE_INT, 2*FF_QP2LAMBDA, 0, INT_MAX, V|E},
b447caeb6978 convert some options in ffmpeg.c to AVOptions
michael
parents: 2874
diff changeset
684 {"lmax", "max lagrange factor", OFFSET(lmax), FF_OPT_TYPE_INT, 31*FF_QP2LAMBDA, 0, INT_MAX, V|E},
2890
8c9eee3fb35d changing a few options to AVOptions
michael
parents: 2884
diff changeset
685 {"nr", "noise reduction", OFFSET(noise_reduction), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
2873
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
686 {"rc_init_occupancy", NULL, OFFSET(rc_initial_buffer_occupancy), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
687 {"inter_threshold", NULL, OFFSET(inter_threshold), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
2996
bf34de4233a0 update x264 wrapper.
lorenm
parents: 2990
diff changeset
688 {"flags2", NULL, OFFSET(flags2), FF_OPT_TYPE_FLAGS, DEFAULT, INT_MIN, INT_MAX, V|A|E|D, "flags2"},
2862
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
689 {"error_rate", NULL, OFFSET(error_rate), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX},
2878
71644f84e79d converting a few more options to AVOptions
michael
parents: 2877
diff changeset
690 {"antialias", NULL, OFFSET(antialias_algo), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|D, "aa"},
2881
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
691 {"auto", NULL, 0, FF_OPT_TYPE_CONST, FF_AA_AUTO, INT_MIN, INT_MAX, V|D, "aa"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
692 {"fastint", NULL, 0, FF_OPT_TYPE_CONST, FF_AA_FASTINT, INT_MIN, INT_MAX, V|D, "aa"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
693 {"int", NULL, 0, FF_OPT_TYPE_CONST, FF_AA_INT, INT_MIN, INT_MAX, V|D, "aa"},
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
694 {"float", NULL, 0, FF_OPT_TYPE_CONST, FF_AA_FLOAT, INT_MIN, INT_MAX, V|D, "aa"},
2890
8c9eee3fb35d changing a few options to AVOptions
michael
parents: 2884
diff changeset
695 {"qns", "quantizer noise shaping", OFFSET(quantizer_noise_shaping), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
2873
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
696 {"thread_count", NULL, OFFSET(thread_count), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E|D},
2877
b447caeb6978 convert some options in ffmpeg.c to AVOptions
michael
parents: 2874
diff changeset
697 {"me_threshold", "motion estimaton threshold", OFFSET(me_threshold), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX},
2862
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
698 {"mb_threshold", NULL, OFFSET(mb_threshold), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX},
2873
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
699 {"dc", NULL, OFFSET(intra_dc_precision), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
2890
8c9eee3fb35d changing a few options to AVOptions
michael
parents: 2884
diff changeset
700 {"nssew", "nsse weight", OFFSET(nsse_weight), FF_OPT_TYPE_INT, 8, INT_MIN, INT_MAX, V|E},
2873
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
701 {"skip_top", NULL, OFFSET(skip_top), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|D},
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
702 {"skip_bottom", NULL, OFFSET(skip_bottom), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|D},
2878
71644f84e79d converting a few more options to AVOptions
michael
parents: 2877
diff changeset
703 {"profile", NULL, OFFSET(profile), FF_OPT_TYPE_INT, FF_PROFILE_UNKNOWN, INT_MIN, INT_MAX, V|A|E, "profile"},
2881
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
704 {"unknown", NULL, 0, FF_OPT_TYPE_CONST, FF_PROFILE_UNKNOWN, INT_MIN, INT_MAX, V|A|E, "profile"},
2878
71644f84e79d converting a few more options to AVOptions
michael
parents: 2877
diff changeset
705 {"level", NULL, OFFSET(level), FF_OPT_TYPE_INT, FF_LEVEL_UNKNOWN, INT_MIN, INT_MAX, V|A|E, "level"},
2881
c2cb03ea51ac the people want lower case ...
michael
parents: 2880
diff changeset
706 {"unknown", NULL, 0, FF_OPT_TYPE_CONST, FF_LEVEL_UNKNOWN, INT_MIN, INT_MAX, V|A|E, "level"},
2877
b447caeb6978 convert some options in ffmpeg.c to AVOptions
michael
parents: 2874
diff changeset
707 {"lowres", NULL, OFFSET(lowres), FF_OPT_TYPE_INT, 0, 0, INT_MAX, V|D},
2873
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
708 {"frame_skip_threshold", NULL, OFFSET(frame_skip_threshold), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
709 {"frame_skip_factor", NULL, OFFSET(frame_skip_factor), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
710 {"frame_skip_exp", NULL, OFFSET(frame_skip_exp), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
2927
d268a7c6c91d Typo fix
gpoirier
parents: 2890
diff changeset
711 {"skipcmp", "frame skip compare function", OFFSET(frame_skip_cmp), FF_OPT_TYPE_INT, FF_CMP_DCTMAX, INT_MIN, INT_MAX, V|E, "cmp_func"},
2873
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
712 {"border_mask", NULL, OFFSET(border_masking), FF_OPT_TYPE_FLOAT, DEFAULT, FLT_MIN, FLT_MAX, V|E},
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
713 {"mb_lmin", NULL, OFFSET(mb_lmin), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
714 {"mb_lmax", NULL, OFFSET(mb_lmax), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
715 {"me_penalty_compensation", NULL, OFFSET(me_penalty_compensation), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
2983
9d7d2bb70fd6 bidir refine support
michael
parents: 2979
diff changeset
716 {"bidir_refine", NULL, OFFSET(bidir_refine), FF_OPT_TYPE_INT, DEFAULT, 0, 4, V|E},
2990
0300c2647bc3 support downscaling frames for dynamic b frame decission
michael
parents: 2989
diff changeset
717 {"brd_scale", NULL, OFFSET(brd_scale), FF_OPT_TYPE_INT, DEFAULT, 0, 10, V|E},
2996
bf34de4233a0 update x264 wrapper.
lorenm
parents: 2990
diff changeset
718 {"crf", NULL, OFFSET(crf), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
bf34de4233a0 update x264 wrapper.
lorenm
parents: 2990
diff changeset
719 {"cqp", NULL, OFFSET(cqp), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
bf34de4233a0 update x264 wrapper.
lorenm
parents: 2990
diff changeset
720 {"keyint_min", NULL, OFFSET(keyint_min), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
bf34de4233a0 update x264 wrapper.
lorenm
parents: 2990
diff changeset
721 {"refs", NULL, OFFSET(refs), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
bf34de4233a0 update x264 wrapper.
lorenm
parents: 2990
diff changeset
722 {"chromaoffset", NULL, OFFSET(chromaoffset), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
bf34de4233a0 update x264 wrapper.
lorenm
parents: 2990
diff changeset
723 {"bframebias", NULL, OFFSET(bframebias), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
3336
4d807145f29a ADPCM: trellis quantization
lorenm
parents: 3335
diff changeset
724 {"trellis", NULL, OFFSET(trellis), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|A|E},
2996
bf34de4233a0 update x264 wrapper.
lorenm
parents: 2990
diff changeset
725 {"directpred", NULL, OFFSET(directpred), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
bf34de4233a0 update x264 wrapper.
lorenm
parents: 2990
diff changeset
726 {"bpyramid", NULL, 0, FF_OPT_TYPE_CONST, CODEC_FLAG2_BPYRAMID, INT_MIN, INT_MAX, V|E, "flags2"},
bf34de4233a0 update x264 wrapper.
lorenm
parents: 2990
diff changeset
727 {"wpred", NULL, 0, FF_OPT_TYPE_CONST, CODEC_FLAG2_WPRED, INT_MIN, INT_MAX, V|E, "flags2"},
bf34de4233a0 update x264 wrapper.
lorenm
parents: 2990
diff changeset
728 {"mixed_refs", NULL, 0, FF_OPT_TYPE_CONST, CODEC_FLAG2_MIXED_REFS, INT_MIN, INT_MAX, V|E, "flags2"},
bf34de4233a0 update x264 wrapper.
lorenm
parents: 2990
diff changeset
729 {"8x8dct", NULL, 0, FF_OPT_TYPE_CONST, CODEC_FLAG2_8X8DCT, INT_MIN, INT_MAX, V|E, "flags2"},
bf34de4233a0 update x264 wrapper.
lorenm
parents: 2990
diff changeset
730 {"fastpskip", NULL, 0, FF_OPT_TYPE_CONST, CODEC_FLAG2_FASTPSKIP, INT_MIN, INT_MAX, V|E, "flags2"},
bf34de4233a0 update x264 wrapper.
lorenm
parents: 2990
diff changeset
731 {"aud", NULL, 0, FF_OPT_TYPE_CONST, CODEC_FLAG2_AUD, INT_MIN, INT_MAX, V|E, "flags2"},
bf34de4233a0 update x264 wrapper.
lorenm
parents: 2990
diff changeset
732 {"brdo", NULL, 0, FF_OPT_TYPE_CONST, CODEC_FLAG2_BRDO, INT_MIN, INT_MAX, V|E, "flags2"},
bf34de4233a0 update x264 wrapper.
lorenm
parents: 2990
diff changeset
733 {"complexityblur", NULL, OFFSET(complexityblur), FF_OPT_TYPE_FLOAT, DEFAULT, FLT_MIN, FLT_MAX, V|E},
bf34de4233a0 update x264 wrapper.
lorenm
parents: 2990
diff changeset
734 {"deblockalpha", NULL, OFFSET(deblockalpha), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
bf34de4233a0 update x264 wrapper.
lorenm
parents: 2990
diff changeset
735 {"deblockbeta", NULL, OFFSET(deblockbeta), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, V|E},
bf34de4233a0 update x264 wrapper.
lorenm
parents: 2990
diff changeset
736 {"partitions", NULL, OFFSET(partitions), FF_OPT_TYPE_FLAGS, DEFAULT, INT_MIN, INT_MAX, V|E, "partitions"},
bf34de4233a0 update x264 wrapper.
lorenm
parents: 2990
diff changeset
737 {"parti4x4", NULL, 0, FF_OPT_TYPE_CONST, X264_PART_I4X4, INT_MIN, INT_MAX, V|E, "partitions"},
bf34de4233a0 update x264 wrapper.
lorenm
parents: 2990
diff changeset
738 {"parti8x8", NULL, 0, FF_OPT_TYPE_CONST, X264_PART_I8X8, INT_MIN, INT_MAX, V|E, "partitions"},
bf34de4233a0 update x264 wrapper.
lorenm
parents: 2990
diff changeset
739 {"partp4x4", NULL, 0, FF_OPT_TYPE_CONST, X264_PART_P4X4, INT_MIN, INT_MAX, V|E, "partitions"},
bf34de4233a0 update x264 wrapper.
lorenm
parents: 2990
diff changeset
740 {"partp8x8", NULL, 0, FF_OPT_TYPE_CONST, X264_PART_P8X8, INT_MIN, INT_MAX, V|E, "partitions"},
bf34de4233a0 update x264 wrapper.
lorenm
parents: 2990
diff changeset
741 {"partb8x8", NULL, 0, FF_OPT_TYPE_CONST, X264_PART_B8X8, INT_MIN, INT_MAX, V|E, "partitions"},
3061
259fed5adf5d sc_factor support for encoding.
corey
parents: 3036
diff changeset
742 {"sc_factor", NULL, OFFSET(scenechange_factor), FF_OPT_TYPE_INT, 6, 0, INT_MAX, V|E},
3293
f1bcb9ae510b make zero motion vector threshold user setable
michael
parents: 3233
diff changeset
743 {"mv0_threshold", NULL, OFFSET(mv0_threshold), FF_OPT_TYPE_INT, 256, 0, INT_MAX, V|E},
3305
ceb221c4eca7 add MPEG-2 intra vlc support
bcoudurier
parents: 3293
diff changeset
744 {"ivlc", "intra vlc table", 0, FF_OPT_TYPE_CONST, CODEC_FLAG2_INTRA_VLC, INT_MIN, INT_MAX, V|E, "flags2"},
3335
97af1b315f59 Make B-frame reduction sensitivity by b_strategy/vb_strategy = 1
corey
parents: 3305
diff changeset
745 {"b_sensitivity", NULL, OFFSET(b_sensitivity), FF_OPT_TYPE_INT, 40, 1, INT_MAX, V|E},
3385
340e5d35b326 flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents: 3373
diff changeset
746 {"compression_level", NULL, OFFSET(compression_level), FF_OPT_TYPE_INT, FF_COMPRESSION_DEFAULT, INT_MIN, INT_MAX, V|A|E},
340e5d35b326 flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents: 3373
diff changeset
747 {"use_lpc", NULL, OFFSET(use_lpc), FF_OPT_TYPE_INT, -1, INT_MIN, INT_MAX, A|E},
340e5d35b326 flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents: 3373
diff changeset
748 {"lpc_coeff_precision", NULL, OFFSET(lpc_coeff_precision), FF_OPT_TYPE_INT, DEFAULT, 0, INT_MAX, A|E},
340e5d35b326 flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents: 3373
diff changeset
749 {"min_prediction_order", NULL, OFFSET(min_prediction_order), FF_OPT_TYPE_INT, -1, INT_MIN, INT_MAX, A|E},
340e5d35b326 flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents: 3373
diff changeset
750 {"max_prediction_order", NULL, OFFSET(max_prediction_order), FF_OPT_TYPE_INT, -1, INT_MIN, INT_MAX, A|E},
340e5d35b326 flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents: 3373
diff changeset
751 {"prediction_order_method", NULL, OFFSET(prediction_order_method), FF_OPT_TYPE_INT, -1, INT_MIN, INT_MAX, A|E},
340e5d35b326 flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents: 3373
diff changeset
752 {"min_partition_order", NULL, OFFSET(min_partition_order), FF_OPT_TYPE_INT, -1, INT_MIN, INT_MAX, A|E},
340e5d35b326 flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents: 3373
diff changeset
753 {"max_partition_order", NULL, OFFSET(max_partition_order), FF_OPT_TYPE_INT, -1, INT_MIN, INT_MAX, A|E},
2862
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
754 {NULL},
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
755 };
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
756
2873
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
757 #undef A
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
758 #undef V
55809f38eb63 AVOption API improvments
michael
parents: 2862
diff changeset
759
2862
f4aea2c316cc AVOption first try
michael
parents: 2856
diff changeset
760 static AVClass av_codec_context_class = { "AVCodecContext", context_to_name, options };
1856
ed6eb3e304cc av_log() cleanup
michael
parents: 1855
diff changeset
761
681
b3869ffff47a avcodec_alloc_context()
michaelni
parents: 583
diff changeset
762 void avcodec_get_context_defaults(AVCodecContext *s){
1831
cd2d7fcfab7a use AVFrame.pts=AV_NOPTS_VALUE instead of AVFrame.pts=0
michael
parents: 1823
diff changeset
763 memset(s, 0, sizeof(AVCodecContext));
cd2d7fcfab7a use AVFrame.pts=AV_NOPTS_VALUE instead of AVFrame.pts=0
michael
parents: 1823
diff changeset
764
1856
ed6eb3e304cc av_log() cleanup
michael
parents: 1855
diff changeset
765 s->av_class= &av_codec_context_class;
685
44a1dab0205c fixing apiexample
michaelni
parents: 681
diff changeset
766 s->bit_rate= 800*1000;
44a1dab0205c fixing apiexample
michaelni
parents: 681
diff changeset
767 s->bit_rate_tolerance= s->bit_rate*10;
681
b3869ffff47a avcodec_alloc_context()
michaelni
parents: 583
diff changeset
768 s->qmin= 2;
b3869ffff47a avcodec_alloc_context()
michaelni
parents: 583
diff changeset
769 s->qmax= 31;
2494
36d70fbb31c5 mb_lmin/max to limit the per mb quality for the ratecontrol independant from the frame limits
michael
parents: 2488
diff changeset
770 s->mb_lmin= FF_QP2LAMBDA * 2;
36d70fbb31c5 mb_lmin/max to limit the per mb quality for the ratecontrol independant from the frame limits
michael
parents: 2488
diff changeset
771 s->mb_lmax= FF_QP2LAMBDA * 31;
681
b3869ffff47a avcodec_alloc_context()
michaelni
parents: 583
diff changeset
772 s->rc_eq= "tex^qComp";
2996
bf34de4233a0 update x264 wrapper.
lorenm
parents: 2990
diff changeset
773 s->cqp = -1;
bf34de4233a0 update x264 wrapper.
lorenm
parents: 2990
diff changeset
774 s->refs = 1;
bf34de4233a0 update x264 wrapper.
lorenm
parents: 2990
diff changeset
775 s->directpred = 2;
681
b3869ffff47a avcodec_alloc_context()
michaelni
parents: 583
diff changeset
776 s->qcompress= 0.5;
2996
bf34de4233a0 update x264 wrapper.
lorenm
parents: 2990
diff changeset
777 s->complexityblur = 20.0;
bf34de4233a0 update x264 wrapper.
lorenm
parents: 2990
diff changeset
778 s->keyint_min = 25;
bf34de4233a0 update x264 wrapper.
lorenm
parents: 2990
diff changeset
779 s->flags2 = CODEC_FLAG2_FASTPSKIP;
685
44a1dab0205c fixing apiexample
michaelni
parents: 681
diff changeset
780 s->max_qdiff= 3;
44a1dab0205c fixing apiexample
michaelni
parents: 681
diff changeset
781 s->b_quant_factor=1.25;
44a1dab0205c fixing apiexample
michaelni
parents: 681
diff changeset
782 s->b_quant_offset=1.25;
686
83d2c9d50d7d fixing i_quant_factor, this should finally fix the bitrate bug with ffserver hopefully
michaelni
parents: 685
diff changeset
783 s->i_quant_factor=-0.8;
685
44a1dab0205c fixing apiexample
michaelni
parents: 681
diff changeset
784 s->i_quant_offset=0.0;
745
25d7fb7c89be better/cleaner error resilience (done in a 2nd pass after decoding)
michaelni
parents: 742
diff changeset
785 s->error_concealment= 3;
762
5da504c8c90e more defaults
michaelni
parents: 745
diff changeset
786 s->error_resilience= 1;
745
25d7fb7c89be better/cleaner error resilience (done in a 2nd pass after decoding)
michaelni
parents: 742
diff changeset
787 s->workaround_bugs= FF_BUG_AUTODETECT;
2637
ef44d24680d1 switch to native time bases
michael
parents: 2636
diff changeset
788 s->time_base= (AVRational){0,1};
762
5da504c8c90e more defaults
michaelni
parents: 745
diff changeset
789 s->gop_size= 50;
5da504c8c90e more defaults
michaelni
parents: 745
diff changeset
790 s->me_method= ME_EPZS;
903
22ee74da2cd3 cleanup
michaelni
parents: 902
diff changeset
791 s->get_buffer= avcodec_default_get_buffer;
22ee74da2cd3 cleanup
michaelni
parents: 902
diff changeset
792 s->release_buffer= avcodec_default_release_buffer;
998
6129c88a6393 get_format()
michaelni
parents: 992
diff changeset
793 s->get_format= avcodec_default_get_format;
1799
95612d423fde multithreaded/SMP motion estimation
michael
parents: 1798
diff changeset
794 s->execute= avcodec_default_execute;
95612d423fde multithreaded/SMP motion estimation
michael
parents: 1798
diff changeset
795 s->thread_count=1;
954
13aec7e50c52 qpel in mmx2/3dnow
michaelni
parents: 932
diff changeset
796 s->me_subpel_quality=8;
1505
010f76d07a27 use lagrange multipler instead of qp for ratecontrol, this may break some things, tell me ASAP if u notice anything broken
michaelni
parents: 1456
diff changeset
797 s->lmin= FF_QP2LAMBDA * s->qmin;
010f76d07a27 use lagrange multipler instead of qp for ratecontrol, this may break some things, tell me ASAP if u notice anything broken
michaelni
parents: 1456
diff changeset
798 s->lmax= FF_QP2LAMBDA * s->qmax;
1548
dd544554ed42 AVRational
michael
parents: 1541
diff changeset
799 s->sample_aspect_ratio= (AVRational){0,1};
1730
michael
parents: 1630
diff changeset
800 s->ildct_cmp= FF_CMP_VSAD;
2167
76334bbb5038 user overrideable level & profile
michael
parents: 2137
diff changeset
801 s->profile= FF_PROFILE_UNKNOWN;
76334bbb5038 user overrideable level & profile
michael
parents: 2137
diff changeset
802 s->level= FF_LEVEL_UNKNOWN;
2584
c07be5590462 motion estimation bitrate penalty compensation
michael
parents: 2522
diff changeset
803 s->me_penalty_compensation= 256;
2635
eaa57c3336fc PIX_FMT_NONE and related fixes
michael
parents: 2584
diff changeset
804 s->pix_fmt= PIX_FMT_NONE;
2878
71644f84e79d converting a few more options to AVOptions
michael
parents: 2877
diff changeset
805 s->frame_skip_cmp= FF_CMP_DCTMAX;
2890
8c9eee3fb35d changing a few options to AVOptions
michael
parents: 2884
diff changeset
806 s->nsse_weight= 8;
3136
ddf6d81a6369 added none/8bit/24bit audio formats and defaulting to s16 for now (once the system works like pix_fmt, the defaulting should be changed to SAMPLE_FMT_NONE)
alex
parents: 3075
diff changeset
807 s->sample_fmt= SAMPLE_FMT_S16; // FIXME: set to NONE
3293
f1bcb9ae510b make zero motion vector threshold user setable
michael
parents: 3233
diff changeset
808 s->mv0_threshold= 256;
3335
97af1b315f59 Make B-frame reduction sensitivity by b_strategy/vb_strategy = 1
corey
parents: 3305
diff changeset
809 s->b_sensitivity= 40;
3385
340e5d35b326 flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents: 3373
diff changeset
810 s->compression_level = FF_COMPRESSION_DEFAULT;
340e5d35b326 flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents: 3373
diff changeset
811 s->use_lpc = -1;
340e5d35b326 flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents: 3373
diff changeset
812 s->min_prediction_order = -1;
340e5d35b326 flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents: 3373
diff changeset
813 s->max_prediction_order = -1;
340e5d35b326 flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents: 3373
diff changeset
814 s->prediction_order_method = -1;
340e5d35b326 flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents: 3373
diff changeset
815 s->min_partition_order = -1;
340e5d35b326 flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents: 3373
diff changeset
816 s->max_partition_order = -1;
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
817
1150
dde68a430ba9 user setable quantizer bias
michaelni
parents: 1139
diff changeset
818 s->intra_quant_bias= FF_DEFAULT_QUANT_BIAS;
dde68a430ba9 user setable quantizer bias
michaelni
parents: 1139
diff changeset
819 s->inter_quant_bias= FF_DEFAULT_QUANT_BIAS;
1585
6b224ca24033 revised palette API, courtesy of Roberto Togni (rtogni at freemail.it)
melanson
parents: 1582
diff changeset
820 s->palctrl = NULL;
1630
586b5c08863c - Add reget_buffer() function to AVCodecContext
rtognimp
parents: 1606
diff changeset
821 s->reget_buffer= avcodec_default_reget_buffer;
681
b3869ffff47a avcodec_alloc_context()
michaelni
parents: 583
diff changeset
822 }
b3869ffff47a avcodec_alloc_context()
michaelni
parents: 583
diff changeset
823
b3869ffff47a avcodec_alloc_context()
michaelni
parents: 583
diff changeset
824 /**
b3869ffff47a avcodec_alloc_context()
michaelni
parents: 583
diff changeset
825 * allocates a AVCodecContext and set it to defaults.
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
826 * this can be deallocated by simply calling free()
681
b3869ffff47a avcodec_alloc_context()
michaelni
parents: 583
diff changeset
827 */
703
65f9e32225ba Minor warning fix.
mellum
parents: 686
diff changeset
828 AVCodecContext *avcodec_alloc_context(void){
1831
cd2d7fcfab7a use AVFrame.pts=AV_NOPTS_VALUE instead of AVFrame.pts=0
michael
parents: 1823
diff changeset
829 AVCodecContext *avctx= av_malloc(sizeof(AVCodecContext));
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
830
681
b3869ffff47a avcodec_alloc_context()
michaelni
parents: 583
diff changeset
831 if(avctx==NULL) return NULL;
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
832
681
b3869ffff47a avcodec_alloc_context()
michaelni
parents: 583
diff changeset
833 avcodec_get_context_defaults(avctx);
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
834
681
b3869ffff47a avcodec_alloc_context()
michaelni
parents: 583
diff changeset
835 return avctx;
b3869ffff47a avcodec_alloc_context()
michaelni
parents: 583
diff changeset
836 }
b3869ffff47a avcodec_alloc_context()
michaelni
parents: 583
diff changeset
837
1831
cd2d7fcfab7a use AVFrame.pts=AV_NOPTS_VALUE instead of AVFrame.pts=0
michael
parents: 1823
diff changeset
838 void avcodec_get_frame_defaults(AVFrame *pic){
cd2d7fcfab7a use AVFrame.pts=AV_NOPTS_VALUE instead of AVFrame.pts=0
michael
parents: 1823
diff changeset
839 memset(pic, 0, sizeof(AVFrame));
cd2d7fcfab7a use AVFrame.pts=AV_NOPTS_VALUE instead of AVFrame.pts=0
michael
parents: 1823
diff changeset
840
cd2d7fcfab7a use AVFrame.pts=AV_NOPTS_VALUE instead of AVFrame.pts=0
michael
parents: 1823
diff changeset
841 pic->pts= AV_NOPTS_VALUE;
2488
8dd4672b9f74 make keyframe default for AVFrames
michael
parents: 2453
diff changeset
842 pic->key_frame= 1;
1831
cd2d7fcfab7a use AVFrame.pts=AV_NOPTS_VALUE instead of AVFrame.pts=0
michael
parents: 1823
diff changeset
843 }
cd2d7fcfab7a use AVFrame.pts=AV_NOPTS_VALUE instead of AVFrame.pts=0
michael
parents: 1823
diff changeset
844
903
22ee74da2cd3 cleanup
michaelni
parents: 902
diff changeset
845 /**
925
7fccaa0d699d AVVideoFrame -> AVFrame
michaelni
parents: 924
diff changeset
846 * allocates a AVPFrame and set it to defaults.
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
847 * this can be deallocated by simply calling free()
903
22ee74da2cd3 cleanup
michaelni
parents: 902
diff changeset
848 */
925
7fccaa0d699d AVVideoFrame -> AVFrame
michaelni
parents: 924
diff changeset
849 AVFrame *avcodec_alloc_frame(void){
1831
cd2d7fcfab7a use AVFrame.pts=AV_NOPTS_VALUE instead of AVFrame.pts=0
michael
parents: 1823
diff changeset
850 AVFrame *pic= av_malloc(sizeof(AVFrame));
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
851
1831
cd2d7fcfab7a use AVFrame.pts=AV_NOPTS_VALUE instead of AVFrame.pts=0
michael
parents: 1823
diff changeset
852 if(pic==NULL) return NULL;
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
853
1831
cd2d7fcfab7a use AVFrame.pts=AV_NOPTS_VALUE instead of AVFrame.pts=0
michael
parents: 1823
diff changeset
854 avcodec_get_frame_defaults(pic);
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
855
903
22ee74da2cd3 cleanup
michaelni
parents: 902
diff changeset
856 return pic;
22ee74da2cd3 cleanup
michaelni
parents: 902
diff changeset
857 }
22ee74da2cd3 cleanup
michaelni
parents: 902
diff changeset
858
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
859 int avcodec_open(AVCodecContext *avctx, AVCodec *codec)
986e461dc072 Initial revision
glantau
parents:
diff changeset
860 {
2806
af3a36e20010 thread mess check for avcodec_open/close()
michael
parents: 2800
diff changeset
861 int ret= -1;
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
862
2806
af3a36e20010 thread mess check for avcodec_open/close()
michael
parents: 2800
diff changeset
863 entangled_thread_counter++;
af3a36e20010 thread mess check for avcodec_open/close()
michael
parents: 2800
diff changeset
864 if(entangled_thread_counter != 1){
af3a36e20010 thread mess check for avcodec_open/close()
michael
parents: 2800
diff changeset
865 av_log(avctx, AV_LOG_ERROR, "insufficient thread locking around avcodec_open/close()\n");
af3a36e20010 thread mess check for avcodec_open/close()
michael
parents: 2800
diff changeset
866 goto end;
af3a36e20010 thread mess check for avcodec_open/close()
michael
parents: 2800
diff changeset
867 }
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
868
1456
670fca257a69 detect avcodec_open() on an already opened AVCodecContext
michaelni
parents: 1455
diff changeset
869 if(avctx->codec)
2806
af3a36e20010 thread mess check for avcodec_open/close()
michael
parents: 2800
diff changeset
870 goto end;
1456
670fca257a69 detect avcodec_open() on an already opened AVCodecContext
michaelni
parents: 1455
diff changeset
871
374
02147e22f8c8 * Don't allocate 0 bytes of memory. It upsets electricFence!
philipjsg
parents: 362
diff changeset
872 if (codec->priv_data_size > 0) {
02147e22f8c8 * Don't allocate 0 bytes of memory. It upsets electricFence!
philipjsg
parents: 362
diff changeset
873 avctx->priv_data = av_mallocz(codec->priv_data_size);
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
874 if (!avctx->priv_data)
2806
af3a36e20010 thread mess check for avcodec_open/close()
michael
parents: 2800
diff changeset
875 goto end;
374
02147e22f8c8 * Don't allocate 0 bytes of memory. It upsets electricFence!
philipjsg
parents: 362
diff changeset
876 } else {
02147e22f8c8 * Don't allocate 0 bytes of memory. It upsets electricFence!
philipjsg
parents: 362
diff changeset
877 avctx->priv_data = NULL;
02147e22f8c8 * Don't allocate 0 bytes of memory. It upsets electricFence!
philipjsg
parents: 362
diff changeset
878 }
2270
21f450be6cb5 lowres width/height cleanup 3rd try
michael
parents: 2242
diff changeset
879
21f450be6cb5 lowres width/height cleanup 3rd try
michael
parents: 2242
diff changeset
880 if(avctx->coded_width && avctx->coded_height)
21f450be6cb5 lowres width/height cleanup 3rd try
michael
parents: 2242
diff changeset
881 avcodec_set_dimensions(avctx, avctx->coded_width, avctx->coded_height);
21f450be6cb5 lowres width/height cleanup 3rd try
michael
parents: 2242
diff changeset
882 else if(avctx->width && avctx->height)
21f450be6cb5 lowres width/height cleanup 3rd try
michael
parents: 2242
diff changeset
883 avcodec_set_dimensions(avctx, avctx->width, avctx->height);
21f450be6cb5 lowres width/height cleanup 3rd try
michael
parents: 2242
diff changeset
884
2422
18b8b2dcc037 various security fixes and precautionary checks
michael
parents: 2418
diff changeset
885 if((avctx->coded_width||avctx->coded_height) && avcodec_check_dimensions(avctx,avctx->coded_width,avctx->coded_height)){
18b8b2dcc037 various security fixes and precautionary checks
michael
parents: 2418
diff changeset
886 av_freep(&avctx->priv_data);
2806
af3a36e20010 thread mess check for avcodec_open/close()
michael
parents: 2800
diff changeset
887 goto end;
2422
18b8b2dcc037 various security fixes and precautionary checks
michael
parents: 2418
diff changeset
888 }
18b8b2dcc037 various security fixes and precautionary checks
michael
parents: 2418
diff changeset
889
3159
e1157712c1d5 fix segfault with BLUR8.AVI
michael
parents: 3136
diff changeset
890 avctx->codec = codec;
e1157712c1d5 fix segfault with BLUR8.AVI
michael
parents: 3136
diff changeset
891 avctx->codec_id = codec->id;
e1157712c1d5 fix segfault with BLUR8.AVI
michael
parents: 3136
diff changeset
892 avctx->frame_number = 0;
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
893 ret = avctx->codec->init(avctx);
986e461dc072 Initial revision
glantau
parents:
diff changeset
894 if (ret < 0) {
394
e2cb8a4ee0c5 proper memory handling functions
glantau
parents: 379
diff changeset
895 av_freep(&avctx->priv_data);
3159
e1157712c1d5 fix segfault with BLUR8.AVI
michael
parents: 3136
diff changeset
896 avctx->codec= NULL;
2806
af3a36e20010 thread mess check for avcodec_open/close()
michael
parents: 2800
diff changeset
897 goto end;
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
898 }
2806
af3a36e20010 thread mess check for avcodec_open/close()
michael
parents: 2800
diff changeset
899 ret=0;
af3a36e20010 thread mess check for avcodec_open/close()
michael
parents: 2800
diff changeset
900 end:
af3a36e20010 thread mess check for avcodec_open/close()
michael
parents: 2800
diff changeset
901 entangled_thread_counter--;
af3a36e20010 thread mess check for avcodec_open/close()
michael
parents: 2800
diff changeset
902 return ret;
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
903 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
904
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
905 int avcodec_encode_audio(AVCodecContext *avctx, uint8_t *buf, int buf_size,
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
906 const short *samples)
986e461dc072 Initial revision
glantau
parents:
diff changeset
907 {
2422
18b8b2dcc037 various security fixes and precautionary checks
michael
parents: 2418
diff changeset
908 if(buf_size < FF_MIN_BUFFER_SIZE && 0){
18b8b2dcc037 various security fixes and precautionary checks
michael
parents: 2418
diff changeset
909 av_log(avctx, AV_LOG_ERROR, "buffer smaller then minimum size\n");
18b8b2dcc037 various security fixes and precautionary checks
michael
parents: 2418
diff changeset
910 return -1;
18b8b2dcc037 various security fixes and precautionary checks
michael
parents: 2418
diff changeset
911 }
2091
02a4fd7c606c flush audio encoder buffers at the end
michael
parents: 2032
diff changeset
912 if((avctx->codec->capabilities & CODEC_CAP_DELAY) || samples){
02a4fd7c606c flush audio encoder buffers at the end
michael
parents: 2032
diff changeset
913 int ret = avctx->codec->encode(avctx, buf, buf_size, (void *)samples);
02a4fd7c606c flush audio encoder buffers at the end
michael
parents: 2032
diff changeset
914 avctx->frame_number++;
02a4fd7c606c flush audio encoder buffers at the end
michael
parents: 2032
diff changeset
915 return ret;
02a4fd7c606c flush audio encoder buffers at the end
michael
parents: 2032
diff changeset
916 }else
02a4fd7c606c flush audio encoder buffers at the end
michael
parents: 2032
diff changeset
917 return 0;
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
918 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
919
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
920 int avcodec_encode_video(AVCodecContext *avctx, uint8_t *buf, int buf_size,
925
7fccaa0d699d AVVideoFrame -> AVFrame
michaelni
parents: 924
diff changeset
921 const AVFrame *pict)
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
922 {
2422
18b8b2dcc037 various security fixes and precautionary checks
michael
parents: 2418
diff changeset
923 if(buf_size < FF_MIN_BUFFER_SIZE){
18b8b2dcc037 various security fixes and precautionary checks
michael
parents: 2418
diff changeset
924 av_log(avctx, AV_LOG_ERROR, "buffer smaller then minimum size\n");
18b8b2dcc037 various security fixes and precautionary checks
michael
parents: 2418
diff changeset
925 return -1;
18b8b2dcc037 various security fixes and precautionary checks
michael
parents: 2418
diff changeset
926 }
18b8b2dcc037 various security fixes and precautionary checks
michael
parents: 2418
diff changeset
927 if(avcodec_check_dimensions(avctx,avctx->width,avctx->height))
18b8b2dcc037 various security fixes and precautionary checks
michael
parents: 2418
diff changeset
928 return -1;
2091
02a4fd7c606c flush audio encoder buffers at the end
michael
parents: 2032
diff changeset
929 if((avctx->codec->capabilities & CODEC_CAP_DELAY) || pict){
02a4fd7c606c flush audio encoder buffers at the end
michael
parents: 2032
diff changeset
930 int ret = avctx->codec->encode(avctx, buf, buf_size, (void *)pict);
02a4fd7c606c flush audio encoder buffers at the end
michael
parents: 2032
diff changeset
931 avctx->frame_number++;
2764
2b37bcabe608 spelling fixes
diego
parents: 2756
diff changeset
932 emms_c(); //needed to avoid an emms_c() call before every return;
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
933
2091
02a4fd7c606c flush audio encoder buffers at the end
michael
parents: 2032
diff changeset
934 return ret;
02a4fd7c606c flush audio encoder buffers at the end
michael
parents: 2032
diff changeset
935 }else
02a4fd7c606c flush audio encoder buffers at the end
michael
parents: 2032
diff changeset
936 return 0;
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
937 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
938
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
939 int avcodec_encode_subtitle(AVCodecContext *avctx, uint8_t *buf, int buf_size,
2756
d8874c8749ec subtitle codec type support
bellard
parents: 2733
diff changeset
940 const AVSubtitle *sub)
d8874c8749ec subtitle codec type support
bellard
parents: 2733
diff changeset
941 {
d8874c8749ec subtitle codec type support
bellard
parents: 2733
diff changeset
942 int ret;
d8874c8749ec subtitle codec type support
bellard
parents: 2733
diff changeset
943 ret = avctx->codec->encode(avctx, buf, buf_size, (void *)sub);
d8874c8749ec subtitle codec type support
bellard
parents: 2733
diff changeset
944 avctx->frame_number++;
d8874c8749ec subtitle codec type support
bellard
parents: 2733
diff changeset
945 return ret;
d8874c8749ec subtitle codec type support
bellard
parents: 2733
diff changeset
946 }
d8874c8749ec subtitle codec type support
bellard
parents: 2733
diff changeset
947
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
948 /**
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
949 * decode a frame.
1249
7ac0a77e5973 100l (document buffer padding requirements)
michaelni
parents: 1217
diff changeset
950 * @param buf bitstream buffer, must be FF_INPUT_BUFFER_PADDING_SIZE larger then the actual read bytes
7ac0a77e5973 100l (document buffer padding requirements)
michaelni
parents: 1217
diff changeset
951 * because some optimized bitstream readers read 32 or 64 bit at once and could read over the end
7ac0a77e5973 100l (document buffer padding requirements)
michaelni
parents: 1217
diff changeset
952 * @param buf_size the size of the buffer in bytes
7ac0a77e5973 100l (document buffer padding requirements)
michaelni
parents: 1217
diff changeset
953 * @param got_picture_ptr zero if no frame could be decompressed, Otherwise, it is non zero
7ac0a77e5973 100l (document buffer padding requirements)
michaelni
parents: 1217
diff changeset
954 * @return -1 if error, otherwise return the number of
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
955 * bytes used.
1249
7ac0a77e5973 100l (document buffer padding requirements)
michaelni
parents: 1217
diff changeset
956 */
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
957 int avcodec_decode_video(AVCodecContext *avctx, AVFrame *picture,
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
958 int *got_picture_ptr,
1064
b32afefe7d33 * UINTX -> uintx_t INTX -> intx_t
kabi
parents: 1057
diff changeset
959 uint8_t *buf, int buf_size)
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
960 {
986e461dc072 Initial revision
glantau
parents:
diff changeset
961 int ret;
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
962
2028
141a9539e270 data_size = 0 cleanup
michael
parents: 2013
diff changeset
963 *got_picture_ptr= 0;
2422
18b8b2dcc037 various security fixes and precautionary checks
michael
parents: 2418
diff changeset
964 if((avctx->coded_width||avctx->coded_height) && avcodec_check_dimensions(avctx,avctx->coded_width,avctx->coded_height))
18b8b2dcc037 various security fixes and precautionary checks
michael
parents: 2418
diff changeset
965 return -1;
2453
f67b63ed036d avoid buf_size == 0 checks in every decoder
michael
parents: 2426
diff changeset
966 if((avctx->codec->capabilities & CODEC_CAP_DELAY) || buf_size){
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
967 ret = avctx->codec->decode(avctx, picture, got_picture_ptr,
2453
f67b63ed036d avoid buf_size == 0 checks in every decoder
michael
parents: 2426
diff changeset
968 buf, buf_size);
814
8f31ed5bacd1 dont call emms_c() for each MB
michaelni
parents: 762
diff changeset
969
2764
2b37bcabe608 spelling fixes
diego
parents: 2756
diff changeset
970 emms_c(); //needed to avoid an emms_c() call before every return;
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
971
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
972 if (*got_picture_ptr)
2453
f67b63ed036d avoid buf_size == 0 checks in every decoder
michael
parents: 2426
diff changeset
973 avctx->frame_number++;
f67b63ed036d avoid buf_size == 0 checks in every decoder
michael
parents: 2426
diff changeset
974 }else
f67b63ed036d avoid buf_size == 0 checks in every decoder
michael
parents: 2426
diff changeset
975 ret= 0;
f67b63ed036d avoid buf_size == 0 checks in every decoder
michael
parents: 2426
diff changeset
976
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
977 return ret;
986e461dc072 Initial revision
glantau
parents:
diff changeset
978 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
979
986e461dc072 Initial revision
glantau
parents:
diff changeset
980 /* decode an audio frame. return -1 if error, otherwise return the
986e461dc072 Initial revision
glantau
parents:
diff changeset
981 *number of bytes used. If no frame could be decompressed,
986e461dc072 Initial revision
glantau
parents:
diff changeset
982 *frame_size_ptr is zero. Otherwise, it is the decompressed frame
986e461dc072 Initial revision
glantau
parents:
diff changeset
983 *size in BYTES. */
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
984 int avcodec_decode_audio(AVCodecContext *avctx, int16_t *samples,
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
985 int *frame_size_ptr,
1064
b32afefe7d33 * UINTX -> uintx_t INTX -> intx_t
kabi
parents: 1057
diff changeset
986 uint8_t *buf, int buf_size)
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
987 {
986e461dc072 Initial revision
glantau
parents:
diff changeset
988 int ret;
986e461dc072 Initial revision
glantau
parents:
diff changeset
989
2028
141a9539e270 data_size = 0 cleanup
michael
parents: 2013
diff changeset
990 *frame_size_ptr= 0;
2791
f191093dc8fe check for CODEC_CAP_DELAY in audio decoders too
michael
parents: 2764
diff changeset
991 if((avctx->codec->capabilities & CODEC_CAP_DELAY) || buf_size){
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
992 ret = avctx->codec->decode(avctx, samples, frame_size_ptr,
2791
f191093dc8fe check for CODEC_CAP_DELAY in audio decoders too
michael
parents: 2764
diff changeset
993 buf, buf_size);
f191093dc8fe check for CODEC_CAP_DELAY in audio decoders too
michael
parents: 2764
diff changeset
994 avctx->frame_number++;
f191093dc8fe check for CODEC_CAP_DELAY in audio decoders too
michael
parents: 2764
diff changeset
995 }else
f191093dc8fe check for CODEC_CAP_DELAY in audio decoders too
michael
parents: 2764
diff changeset
996 ret= 0;
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
997 return ret;
986e461dc072 Initial revision
glantau
parents:
diff changeset
998 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
999
2756
d8874c8749ec subtitle codec type support
bellard
parents: 2733
diff changeset
1000 /* decode a subtitle message. return -1 if error, otherwise return the
d8874c8749ec subtitle codec type support
bellard
parents: 2733
diff changeset
1001 *number of bytes used. If no subtitle could be decompressed,
d8874c8749ec subtitle codec type support
bellard
parents: 2733
diff changeset
1002 *got_sub_ptr is zero. Otherwise, the subtitle is stored in *sub. */
d8874c8749ec subtitle codec type support
bellard
parents: 2733
diff changeset
1003 int avcodec_decode_subtitle(AVCodecContext *avctx, AVSubtitle *sub,
d8874c8749ec subtitle codec type support
bellard
parents: 2733
diff changeset
1004 int *got_sub_ptr,
d8874c8749ec subtitle codec type support
bellard
parents: 2733
diff changeset
1005 const uint8_t *buf, int buf_size)
d8874c8749ec subtitle codec type support
bellard
parents: 2733
diff changeset
1006 {
d8874c8749ec subtitle codec type support
bellard
parents: 2733
diff changeset
1007 int ret;
d8874c8749ec subtitle codec type support
bellard
parents: 2733
diff changeset
1008
d8874c8749ec subtitle codec type support
bellard
parents: 2733
diff changeset
1009 *got_sub_ptr = 0;
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
1010 ret = avctx->codec->decode(avctx, sub, got_sub_ptr,
2756
d8874c8749ec subtitle codec type support
bellard
parents: 2733
diff changeset
1011 (uint8_t *)buf, buf_size);
d8874c8749ec subtitle codec type support
bellard
parents: 2733
diff changeset
1012 if (*got_sub_ptr)
d8874c8749ec subtitle codec type support
bellard
parents: 2733
diff changeset
1013 avctx->frame_number++;
d8874c8749ec subtitle codec type support
bellard
parents: 2733
diff changeset
1014 return ret;
d8874c8749ec subtitle codec type support
bellard
parents: 2733
diff changeset
1015 }
d8874c8749ec subtitle codec type support
bellard
parents: 2733
diff changeset
1016
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
1017 int avcodec_close(AVCodecContext *avctx)
986e461dc072 Initial revision
glantau
parents:
diff changeset
1018 {
2806
af3a36e20010 thread mess check for avcodec_open/close()
michael
parents: 2800
diff changeset
1019 entangled_thread_counter++;
af3a36e20010 thread mess check for avcodec_open/close()
michael
parents: 2800
diff changeset
1020 if(entangled_thread_counter != 1){
af3a36e20010 thread mess check for avcodec_open/close()
michael
parents: 2800
diff changeset
1021 av_log(avctx, AV_LOG_ERROR, "insufficient thread locking around avcodec_open/close()\n");
af3a36e20010 thread mess check for avcodec_open/close()
michael
parents: 2800
diff changeset
1022 entangled_thread_counter--;
af3a36e20010 thread mess check for avcodec_open/close()
michael
parents: 2800
diff changeset
1023 return -1;
af3a36e20010 thread mess check for avcodec_open/close()
michael
parents: 2800
diff changeset
1024 }
af3a36e20010 thread mess check for avcodec_open/close()
michael
parents: 2800
diff changeset
1025
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
1026 if (avctx->codec->close)
986e461dc072 Initial revision
glantau
parents:
diff changeset
1027 avctx->codec->close(avctx);
1994
8d3540dddd1b cleanup & memleak fix
michael
parents: 1901
diff changeset
1028 avcodec_default_free_buffers(avctx);
394
e2cb8a4ee0c5 proper memory handling functions
glantau
parents: 379
diff changeset
1029 av_freep(&avctx->priv_data);
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
1030 avctx->codec = NULL;
2806
af3a36e20010 thread mess check for avcodec_open/close()
michael
parents: 2800
diff changeset
1031 entangled_thread_counter--;
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
1032 return 0;
986e461dc072 Initial revision
glantau
parents:
diff changeset
1033 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
1034
986e461dc072 Initial revision
glantau
parents:
diff changeset
1035 AVCodec *avcodec_find_encoder(enum CodecID id)
986e461dc072 Initial revision
glantau
parents:
diff changeset
1036 {
986e461dc072 Initial revision
glantau
parents:
diff changeset
1037 AVCodec *p;
986e461dc072 Initial revision
glantau
parents:
diff changeset
1038 p = first_avcodec;
986e461dc072 Initial revision
glantau
parents:
diff changeset
1039 while (p) {
986e461dc072 Initial revision
glantau
parents:
diff changeset
1040 if (p->encode != NULL && p->id == id)
986e461dc072 Initial revision
glantau
parents:
diff changeset
1041 return p;
986e461dc072 Initial revision
glantau
parents:
diff changeset
1042 p = p->next;
986e461dc072 Initial revision
glantau
parents:
diff changeset
1043 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
1044 return NULL;
986e461dc072 Initial revision
glantau
parents:
diff changeset
1045 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
1046
177
53da914d6f46 avcodec_find_encoder_by_name() patch by Alex
arpi_esp
parents: 94
diff changeset
1047 AVCodec *avcodec_find_encoder_by_name(const char *name)
53da914d6f46 avcodec_find_encoder_by_name() patch by Alex
arpi_esp
parents: 94
diff changeset
1048 {
53da914d6f46 avcodec_find_encoder_by_name() patch by Alex
arpi_esp
parents: 94
diff changeset
1049 AVCodec *p;
53da914d6f46 avcodec_find_encoder_by_name() patch by Alex
arpi_esp
parents: 94
diff changeset
1050 p = first_avcodec;
53da914d6f46 avcodec_find_encoder_by_name() patch by Alex
arpi_esp
parents: 94
diff changeset
1051 while (p) {
53da914d6f46 avcodec_find_encoder_by_name() patch by Alex
arpi_esp
parents: 94
diff changeset
1052 if (p->encode != NULL && strcmp(name,p->name) == 0)
53da914d6f46 avcodec_find_encoder_by_name() patch by Alex
arpi_esp
parents: 94
diff changeset
1053 return p;
53da914d6f46 avcodec_find_encoder_by_name() patch by Alex
arpi_esp
parents: 94
diff changeset
1054 p = p->next;
53da914d6f46 avcodec_find_encoder_by_name() patch by Alex
arpi_esp
parents: 94
diff changeset
1055 }
53da914d6f46 avcodec_find_encoder_by_name() patch by Alex
arpi_esp
parents: 94
diff changeset
1056 return NULL;
53da914d6f46 avcodec_find_encoder_by_name() patch by Alex
arpi_esp
parents: 94
diff changeset
1057 }
53da914d6f46 avcodec_find_encoder_by_name() patch by Alex
arpi_esp
parents: 94
diff changeset
1058
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
1059 AVCodec *avcodec_find_decoder(enum CodecID id)
986e461dc072 Initial revision
glantau
parents:
diff changeset
1060 {
986e461dc072 Initial revision
glantau
parents:
diff changeset
1061 AVCodec *p;
986e461dc072 Initial revision
glantau
parents:
diff changeset
1062 p = first_avcodec;
986e461dc072 Initial revision
glantau
parents:
diff changeset
1063 while (p) {
986e461dc072 Initial revision
glantau
parents:
diff changeset
1064 if (p->decode != NULL && p->id == id)
986e461dc072 Initial revision
glantau
parents:
diff changeset
1065 return p;
986e461dc072 Initial revision
glantau
parents:
diff changeset
1066 p = p->next;
986e461dc072 Initial revision
glantau
parents:
diff changeset
1067 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
1068 return NULL;
986e461dc072 Initial revision
glantau
parents:
diff changeset
1069 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
1070
986e461dc072 Initial revision
glantau
parents:
diff changeset
1071 AVCodec *avcodec_find_decoder_by_name(const char *name)
986e461dc072 Initial revision
glantau
parents:
diff changeset
1072 {
986e461dc072 Initial revision
glantau
parents:
diff changeset
1073 AVCodec *p;
986e461dc072 Initial revision
glantau
parents:
diff changeset
1074 p = first_avcodec;
986e461dc072 Initial revision
glantau
parents:
diff changeset
1075 while (p) {
986e461dc072 Initial revision
glantau
parents:
diff changeset
1076 if (p->decode != NULL && strcmp(name,p->name) == 0)
986e461dc072 Initial revision
glantau
parents:
diff changeset
1077 return p;
986e461dc072 Initial revision
glantau
parents:
diff changeset
1078 p = p->next;
986e461dc072 Initial revision
glantau
parents:
diff changeset
1079 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
1080 return NULL;
986e461dc072 Initial revision
glantau
parents:
diff changeset
1081 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
1082
986e461dc072 Initial revision
glantau
parents:
diff changeset
1083 void avcodec_string(char *buf, int buf_size, AVCodecContext *enc, int encode)
986e461dc072 Initial revision
glantau
parents:
diff changeset
1084 {
986e461dc072 Initial revision
glantau
parents:
diff changeset
1085 const char *codec_name;
986e461dc072 Initial revision
glantau
parents:
diff changeset
1086 AVCodec *p;
986e461dc072 Initial revision
glantau
parents:
diff changeset
1087 char buf1[32];
337
8899c3b35b57 * using some small char buffer - needed for sprintf
kabi
parents: 322
diff changeset
1088 char channels_str[100];
92
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
1089 int bitrate;
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
1090
986e461dc072 Initial revision
glantau
parents:
diff changeset
1091 if (encode)
986e461dc072 Initial revision
glantau
parents:
diff changeset
1092 p = avcodec_find_encoder(enc->codec_id);
986e461dc072 Initial revision
glantau
parents:
diff changeset
1093 else
986e461dc072 Initial revision
glantau
parents:
diff changeset
1094 p = avcodec_find_decoder(enc->codec_id);
986e461dc072 Initial revision
glantau
parents:
diff changeset
1095
986e461dc072 Initial revision
glantau
parents:
diff changeset
1096 if (p) {
986e461dc072 Initial revision
glantau
parents:
diff changeset
1097 codec_name = p->name;
1449
7fbe89a76b73 update sub_id in mpegaudio decoding (might need same method as MPEG2VIDEO too ?)
bellard
parents: 1396
diff changeset
1098 if (!encode && enc->codec_id == CODEC_ID_MP3) {
7fbe89a76b73 update sub_id in mpegaudio decoding (might need same method as MPEG2VIDEO too ?)
bellard
parents: 1396
diff changeset
1099 if (enc->sub_id == 2)
7fbe89a76b73 update sub_id in mpegaudio decoding (might need same method as MPEG2VIDEO too ?)
bellard
parents: 1396
diff changeset
1100 codec_name = "mp2";
7fbe89a76b73 update sub_id in mpegaudio decoding (might need same method as MPEG2VIDEO too ?)
bellard
parents: 1396
diff changeset
1101 else if (enc->sub_id == 1)
7fbe89a76b73 update sub_id in mpegaudio decoding (might need same method as MPEG2VIDEO too ?)
bellard
parents: 1396
diff changeset
1102 codec_name = "mp1";
7fbe89a76b73 update sub_id in mpegaudio decoding (might need same method as MPEG2VIDEO too ?)
bellard
parents: 1396
diff changeset
1103 }
1582
ece0ad14a35d added fake codec CODEC_ID_MPEG2TS of type CODEC_TYPE_DATA (needed for simpler handling of raw transport streams in ffserver and RTP - better solutions are welcomed)
bellard
parents: 1549
diff changeset
1104 } else if (enc->codec_id == CODEC_ID_MPEG2TS) {
ece0ad14a35d added fake codec CODEC_ID_MPEG2TS of type CODEC_TYPE_DATA (needed for simpler handling of raw transport streams in ffserver and RTP - better solutions are welcomed)
bellard
parents: 1549
diff changeset
1105 /* fake mpeg2 transport stream codec (currently not
ece0ad14a35d added fake codec CODEC_ID_MPEG2TS of type CODEC_TYPE_DATA (needed for simpler handling of raw transport streams in ffserver and RTP - better solutions are welcomed)
bellard
parents: 1549
diff changeset
1106 registered) */
ece0ad14a35d added fake codec CODEC_ID_MPEG2TS of type CODEC_TYPE_DATA (needed for simpler handling of raw transport streams in ffserver and RTP - better solutions are welcomed)
bellard
parents: 1549
diff changeset
1107 codec_name = "mpeg2ts";
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
1108 } else if (enc->codec_name[0] != '\0') {
986e461dc072 Initial revision
glantau
parents:
diff changeset
1109 codec_name = enc->codec_name;
986e461dc072 Initial revision
glantau
parents:
diff changeset
1110 } else {
986e461dc072 Initial revision
glantau
parents:
diff changeset
1111 /* output avi tags */
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
1112 if( isprint(enc->codec_tag&0xFF) && isprint((enc->codec_tag>>8)&0xFF)
2856
9211043e0784 print fourcc in a readable form if possible
michael
parents: 2852
diff changeset
1113 && isprint((enc->codec_tag>>16)&0xFF) && isprint((enc->codec_tag>>24)&0xFF)){
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
1114 snprintf(buf1, sizeof(buf1), "%c%c%c%c / 0x%04X",
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
1115 enc->codec_tag & 0xff,
986e461dc072 Initial revision
glantau
parents:
diff changeset
1116 (enc->codec_tag >> 8) & 0xff,
986e461dc072 Initial revision
glantau
parents:
diff changeset
1117 (enc->codec_tag >> 16) & 0xff,
2856
9211043e0784 print fourcc in a readable form if possible
michael
parents: 2852
diff changeset
1118 (enc->codec_tag >> 24) & 0xff,
9211043e0784 print fourcc in a readable form if possible
michael
parents: 2852
diff changeset
1119 enc->codec_tag);
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
1120 } else {
986e461dc072 Initial revision
glantau
parents:
diff changeset
1121 snprintf(buf1, sizeof(buf1), "0x%04x", enc->codec_tag);
986e461dc072 Initial revision
glantau
parents:
diff changeset
1122 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
1123 codec_name = buf1;
986e461dc072 Initial revision
glantau
parents:
diff changeset
1124 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
1125
986e461dc072 Initial revision
glantau
parents:
diff changeset
1126 switch(enc->codec_type) {
986e461dc072 Initial revision
glantau
parents:
diff changeset
1127 case CODEC_TYPE_VIDEO:
986e461dc072 Initial revision
glantau
parents:
diff changeset
1128 snprintf(buf, buf_size,
986e461dc072 Initial revision
glantau
parents:
diff changeset
1129 "Video: %s%s",
1389
da0b3a50d209 rate distortion mb decision support
michaelni
parents: 1368
diff changeset
1130 codec_name, enc->mb_decision ? " (hq)" : "");
2636
2344c6713011 print pix_fmt if its known instead of if the raw codec is used
michael
parents: 2635
diff changeset
1131 if (enc->pix_fmt != PIX_FMT_NONE) {
55
6064342168f4 picture utils
glantau
parents: 24
diff changeset
1132 snprintf(buf + strlen(buf), buf_size - strlen(buf),
6064342168f4 picture utils
glantau
parents: 24
diff changeset
1133 ", %s",
988
001b7d3045e5 moved avcodec_get_chroma_sub_sample() to imgconvert.c
bellard
parents: 963
diff changeset
1134 avcodec_get_pix_fmt_name(enc->pix_fmt));
55
6064342168f4 picture utils
glantau
parents: 24
diff changeset
1135 }
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
1136 if (enc->width) {
986e461dc072 Initial revision
glantau
parents:
diff changeset
1137 snprintf(buf + strlen(buf), buf_size - strlen(buf),
2884
a332778dfa06 print more time_base fps stuff if av_log level is at debug or above
michael
parents: 2881
diff changeset
1138 ", %dx%d",
a332778dfa06 print more time_base fps stuff if av_log level is at debug or above
michael
parents: 2881
diff changeset
1139 enc->width, enc->height);
a332778dfa06 print more time_base fps stuff if av_log level is at debug or above
michael
parents: 2881
diff changeset
1140 if(av_log_get_level() >= AV_LOG_DEBUG){
a332778dfa06 print more time_base fps stuff if av_log level is at debug or above
michael
parents: 2881
diff changeset
1141 int g= ff_gcd(enc->time_base.num, enc->time_base.den);
a332778dfa06 print more time_base fps stuff if av_log level is at debug or above
michael
parents: 2881
diff changeset
1142 snprintf(buf + strlen(buf), buf_size - strlen(buf),
a332778dfa06 print more time_base fps stuff if av_log level is at debug or above
michael
parents: 2881
diff changeset
1143 ", %d/%d",
a332778dfa06 print more time_base fps stuff if av_log level is at debug or above
michael
parents: 2881
diff changeset
1144 enc->time_base.num/g, enc->time_base.den/g);
a332778dfa06 print more time_base fps stuff if av_log level is at debug or above
michael
parents: 2881
diff changeset
1145 }
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
1146 }
741
3be57e506f01 added two pass info
bellard
parents: 703
diff changeset
1147 if (encode) {
3be57e506f01 added two pass info
bellard
parents: 703
diff changeset
1148 snprintf(buf + strlen(buf), buf_size - strlen(buf),
3be57e506f01 added two pass info
bellard
parents: 703
diff changeset
1149 ", q=%d-%d", enc->qmin, enc->qmax);
3be57e506f01 added two pass info
bellard
parents: 703
diff changeset
1150 }
92
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
1151 bitrate = enc->bit_rate;
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
1152 break;
986e461dc072 Initial revision
glantau
parents:
diff changeset
1153 case CODEC_TYPE_AUDIO:
986e461dc072 Initial revision
glantau
parents:
diff changeset
1154 snprintf(buf, buf_size,
986e461dc072 Initial revision
glantau
parents:
diff changeset
1155 "Audio: %s",
986e461dc072 Initial revision
glantau
parents:
diff changeset
1156 codec_name);
318
21697f35a9ca - Fixed AC3 decoding for 5:1 AC3 streams. Now when calling av_audio_decode for
pulento
parents: 315
diff changeset
1157 switch (enc->channels) {
21697f35a9ca - Fixed AC3 decoding for 5:1 AC3 streams. Now when calling av_audio_decode for
pulento
parents: 315
diff changeset
1158 case 1:
337
8899c3b35b57 * using some small char buffer - needed for sprintf
kabi
parents: 322
diff changeset
1159 strcpy(channels_str, "mono");
318
21697f35a9ca - Fixed AC3 decoding for 5:1 AC3 streams. Now when calling av_audio_decode for
pulento
parents: 315
diff changeset
1160 break;
21697f35a9ca - Fixed AC3 decoding for 5:1 AC3 streams. Now when calling av_audio_decode for
pulento
parents: 315
diff changeset
1161 case 2:
337
8899c3b35b57 * using some small char buffer - needed for sprintf
kabi
parents: 322
diff changeset
1162 strcpy(channels_str, "stereo");
318
21697f35a9ca - Fixed AC3 decoding for 5:1 AC3 streams. Now when calling av_audio_decode for
pulento
parents: 315
diff changeset
1163 break;
21697f35a9ca - Fixed AC3 decoding for 5:1 AC3 streams. Now when calling av_audio_decode for
pulento
parents: 315
diff changeset
1164 case 6:
337
8899c3b35b57 * using some small char buffer - needed for sprintf
kabi
parents: 322
diff changeset
1165 strcpy(channels_str, "5:1");
318
21697f35a9ca - Fixed AC3 decoding for 5:1 AC3 streams. Now when calling av_audio_decode for
pulento
parents: 315
diff changeset
1166 break;
21697f35a9ca - Fixed AC3 decoding for 5:1 AC3 streams. Now when calling av_audio_decode for
pulento
parents: 315
diff changeset
1167 default:
2423
87b7fbed8609 dissallow sprintf
michael
parents: 2422
diff changeset
1168 snprintf(channels_str, sizeof(channels_str), "%d channels", enc->channels);
318
21697f35a9ca - Fixed AC3 decoding for 5:1 AC3 streams. Now when calling av_audio_decode for
pulento
parents: 315
diff changeset
1169 break;
21697f35a9ca - Fixed AC3 decoding for 5:1 AC3 streams. Now when calling av_audio_decode for
pulento
parents: 315
diff changeset
1170 }
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
1171 if (enc->sample_rate) {
986e461dc072 Initial revision
glantau
parents:
diff changeset
1172 snprintf(buf + strlen(buf), buf_size - strlen(buf),
986e461dc072 Initial revision
glantau
parents:
diff changeset
1173 ", %d Hz, %s",
986e461dc072 Initial revision
glantau
parents:
diff changeset
1174 enc->sample_rate,
318
21697f35a9ca - Fixed AC3 decoding for 5:1 AC3 streams. Now when calling av_audio_decode for
pulento
parents: 315
diff changeset
1175 channels_str);
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
1176 }
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
1177
92
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
1178 /* for PCM codecs, compute bitrate directly */
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
1179 switch(enc->codec_id) {
2852
6f7428adc6ad Support de-/encoding of 24 and 32 bit PCM (from and to internal 16 bit).
reimar
parents: 2840
diff changeset
1180 case CODEC_ID_PCM_S32LE:
6f7428adc6ad Support de-/encoding of 24 and 32 bit PCM (from and to internal 16 bit).
reimar
parents: 2840
diff changeset
1181 case CODEC_ID_PCM_S32BE:
6f7428adc6ad Support de-/encoding of 24 and 32 bit PCM (from and to internal 16 bit).
reimar
parents: 2840
diff changeset
1182 case CODEC_ID_PCM_U32LE:
6f7428adc6ad Support de-/encoding of 24 and 32 bit PCM (from and to internal 16 bit).
reimar
parents: 2840
diff changeset
1183 case CODEC_ID_PCM_U32BE:
6f7428adc6ad Support de-/encoding of 24 and 32 bit PCM (from and to internal 16 bit).
reimar
parents: 2840
diff changeset
1184 bitrate = enc->sample_rate * enc->channels * 32;
6f7428adc6ad Support de-/encoding of 24 and 32 bit PCM (from and to internal 16 bit).
reimar
parents: 2840
diff changeset
1185 break;
6f7428adc6ad Support de-/encoding of 24 and 32 bit PCM (from and to internal 16 bit).
reimar
parents: 2840
diff changeset
1186 case CODEC_ID_PCM_S24LE:
6f7428adc6ad Support de-/encoding of 24 and 32 bit PCM (from and to internal 16 bit).
reimar
parents: 2840
diff changeset
1187 case CODEC_ID_PCM_S24BE:
6f7428adc6ad Support de-/encoding of 24 and 32 bit PCM (from and to internal 16 bit).
reimar
parents: 2840
diff changeset
1188 case CODEC_ID_PCM_U24LE:
6f7428adc6ad Support de-/encoding of 24 and 32 bit PCM (from and to internal 16 bit).
reimar
parents: 2840
diff changeset
1189 case CODEC_ID_PCM_U24BE:
6f7428adc6ad Support de-/encoding of 24 and 32 bit PCM (from and to internal 16 bit).
reimar
parents: 2840
diff changeset
1190 case CODEC_ID_PCM_S24DAUD:
6f7428adc6ad Support de-/encoding of 24 and 32 bit PCM (from and to internal 16 bit).
reimar
parents: 2840
diff changeset
1191 bitrate = enc->sample_rate * enc->channels * 24;
6f7428adc6ad Support de-/encoding of 24 and 32 bit PCM (from and to internal 16 bit).
reimar
parents: 2840
diff changeset
1192 break;
92
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
1193 case CODEC_ID_PCM_S16LE:
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
1194 case CODEC_ID_PCM_S16BE:
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
1195 case CODEC_ID_PCM_U16LE:
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
1196 case CODEC_ID_PCM_U16BE:
94
7e263a256a6f fixed pcm bitrate
glantau
parents: 92
diff changeset
1197 bitrate = enc->sample_rate * enc->channels * 16;
92
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
1198 break;
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
1199 case CODEC_ID_PCM_S8:
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
1200 case CODEC_ID_PCM_U8:
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
1201 case CODEC_ID_PCM_ALAW:
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
1202 case CODEC_ID_PCM_MULAW:
94
7e263a256a6f fixed pcm bitrate
glantau
parents: 92
diff changeset
1203 bitrate = enc->sample_rate * enc->channels * 8;
92
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
1204 break;
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
1205 default:
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
1206 bitrate = enc->bit_rate;
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
1207 break;
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
1208 }
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
1209 break;
1582
ece0ad14a35d added fake codec CODEC_ID_MPEG2TS of type CODEC_TYPE_DATA (needed for simpler handling of raw transport streams in ffserver and RTP - better solutions are welcomed)
bellard
parents: 1549
diff changeset
1210 case CODEC_TYPE_DATA:
ece0ad14a35d added fake codec CODEC_ID_MPEG2TS of type CODEC_TYPE_DATA (needed for simpler handling of raw transport streams in ffserver and RTP - better solutions are welcomed)
bellard
parents: 1549
diff changeset
1211 snprintf(buf, buf_size, "Data: %s", codec_name);
ece0ad14a35d added fake codec CODEC_ID_MPEG2TS of type CODEC_TYPE_DATA (needed for simpler handling of raw transport streams in ffserver and RTP - better solutions are welcomed)
bellard
parents: 1549
diff changeset
1212 bitrate = enc->bit_rate;
ece0ad14a35d added fake codec CODEC_ID_MPEG2TS of type CODEC_TYPE_DATA (needed for simpler handling of raw transport streams in ffserver and RTP - better solutions are welcomed)
bellard
parents: 1549
diff changeset
1213 break;
2756
d8874c8749ec subtitle codec type support
bellard
parents: 2733
diff changeset
1214 case CODEC_TYPE_SUBTITLE:
d8874c8749ec subtitle codec type support
bellard
parents: 2733
diff changeset
1215 snprintf(buf, buf_size, "Subtitle: %s", codec_name);
d8874c8749ec subtitle codec type support
bellard
parents: 2733
diff changeset
1216 bitrate = enc->bit_rate;
d8874c8749ec subtitle codec type support
bellard
parents: 2733
diff changeset
1217 break;
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
1218 default:
2281
7b345b735ac7 do not call (av_)abort()
michael
parents: 2270
diff changeset
1219 snprintf(buf, buf_size, "Invalid Codec type %d", enc->codec_type);
7b345b735ac7 do not call (av_)abort()
michael
parents: 2270
diff changeset
1220 return;
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
1221 }
741
3be57e506f01 added two pass info
bellard
parents: 703
diff changeset
1222 if (encode) {
3be57e506f01 added two pass info
bellard
parents: 703
diff changeset
1223 if (enc->flags & CODEC_FLAG_PASS1)
3be57e506f01 added two pass info
bellard
parents: 703
diff changeset
1224 snprintf(buf + strlen(buf), buf_size - strlen(buf),
3be57e506f01 added two pass info
bellard
parents: 703
diff changeset
1225 ", pass 1");
3be57e506f01 added two pass info
bellard
parents: 703
diff changeset
1226 if (enc->flags & CODEC_FLAG_PASS2)
3be57e506f01 added two pass info
bellard
parents: 703
diff changeset
1227 snprintf(buf + strlen(buf), buf_size - strlen(buf),
3be57e506f01 added two pass info
bellard
parents: 703
diff changeset
1228 ", pass 2");
3be57e506f01 added two pass info
bellard
parents: 703
diff changeset
1229 }
92
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
1230 if (bitrate != 0) {
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
1231 snprintf(buf + strlen(buf), buf_size - strlen(buf),
92
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
1232 ", %d kb/s", bitrate / 1000);
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
1233 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
1234 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
1235
362
1ee4ba4ca783 version info
nickols_k
parents: 341
diff changeset
1236 unsigned avcodec_version( void )
1ee4ba4ca783 version info
nickols_k
parents: 341
diff changeset
1237 {
1ee4ba4ca783 version info
nickols_k
parents: 341
diff changeset
1238 return LIBAVCODEC_VERSION_INT;
1ee4ba4ca783 version info
nickols_k
parents: 341
diff changeset
1239 }
55
6064342168f4 picture utils
glantau
parents: 24
diff changeset
1240
379
47c878305986 build info for ABI
nickols_k
parents: 374
diff changeset
1241 unsigned avcodec_build( void )
47c878305986 build info for ABI
nickols_k
parents: 374
diff changeset
1242 {
47c878305986 build info for ABI
nickols_k
parents: 374
diff changeset
1243 return LIBAVCODEC_BUILD;
47c878305986 build info for ABI
nickols_k
parents: 374
diff changeset
1244 }
47c878305986 build info for ABI
nickols_k
parents: 374
diff changeset
1245
3169
53f0b29ff865 generic crc calculation code
michael
parents: 3159
diff changeset
1246 static void init_crcs(void){
53f0b29ff865 generic crc calculation code
michael
parents: 3159
diff changeset
1247 av_crc04C11DB7= av_mallocz_static(sizeof(AVCRC) * 257);
3170
1475eb5f8649 switch ac3enc to av_crc
michael
parents: 3169
diff changeset
1248 av_crc8005 = av_mallocz_static(sizeof(AVCRC) * 257);
3171
47f2f56a6a28 switch flac to av_crc
michael
parents: 3170
diff changeset
1249 av_crc07 = av_mallocz_static(sizeof(AVCRC) * 257);
3169
53f0b29ff865 generic crc calculation code
michael
parents: 3159
diff changeset
1250 av_crc_init(av_crc04C11DB7, 0, 32, 0x04c11db7, sizeof(AVCRC)*257);
3170
1475eb5f8649 switch ac3enc to av_crc
michael
parents: 3169
diff changeset
1251 av_crc_init(av_crc8005 , 0, 16, 0x8005 , sizeof(AVCRC)*257);
3171
47f2f56a6a28 switch flac to av_crc
michael
parents: 3170
diff changeset
1252 av_crc_init(av_crc07 , 0, 8, 0x07 , sizeof(AVCRC)*257);
3169
53f0b29ff865 generic crc calculation code
michael
parents: 3159
diff changeset
1253 }
53f0b29ff865 generic crc calculation code
michael
parents: 3159
diff changeset
1254
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
1255 /* must be called before any other functions */
986e461dc072 Initial revision
glantau
parents:
diff changeset
1256 void avcodec_init(void)
986e461dc072 Initial revision
glantau
parents:
diff changeset
1257 {
303
9a931fd8d06c multiple init bugfix (patch by Alex Beregszaszi <alex@naxine.org>)
michaelni
parents: 267
diff changeset
1258 static int inited = 0;
9a931fd8d06c multiple init bugfix (patch by Alex Beregszaszi <alex@naxine.org>)
michaelni
parents: 267
diff changeset
1259
9a931fd8d06c multiple init bugfix (patch by Alex Beregszaszi <alex@naxine.org>)
michaelni
parents: 267
diff changeset
1260 if (inited != 0)
2979
bfabfdf9ce55 COSMETICS: tabs --> spaces, some prettyprinting
diego
parents: 2969
diff changeset
1261 return;
303
9a931fd8d06c multiple init bugfix (patch by Alex Beregszaszi <alex@naxine.org>)
michaelni
parents: 267
diff changeset
1262 inited = 1;
9a931fd8d06c multiple init bugfix (patch by Alex Beregszaszi <alex@naxine.org>)
michaelni
parents: 267
diff changeset
1263
1201
e0fc95a6eb4e fixed static init
bellard
parents: 1165
diff changeset
1264 dsputil_static_init();
3169
53f0b29ff865 generic crc calculation code
michael
parents: 3159
diff changeset
1265 init_crcs();
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
1266 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
1267
1368
0fd38b711f06 AVCodec.flush()
michaelni
parents: 1353
diff changeset
1268 /**
0fd38b711f06 AVCodec.flush()
michaelni
parents: 1353
diff changeset
1269 * Flush buffers, should be called when seeking or when swicthing to a different stream.
0fd38b711f06 AVCodec.flush()
michaelni
parents: 1353
diff changeset
1270 */
341
bf26081c373c avcodec_flush_buffers()
michaelni
parents: 337
diff changeset
1271 void avcodec_flush_buffers(AVCodecContext *avctx)
bf26081c373c avcodec_flush_buffers()
michaelni
parents: 337
diff changeset
1272 {
1368
0fd38b711f06 AVCodec.flush()
michaelni
parents: 1353
diff changeset
1273 if(avctx->codec->flush)
0fd38b711f06 AVCodec.flush()
michaelni
parents: 1353
diff changeset
1274 avctx->codec->flush(avctx);
341
bf26081c373c avcodec_flush_buffers()
michaelni
parents: 337
diff changeset
1275 }
bf26081c373c avcodec_flush_buffers()
michaelni
parents: 337
diff changeset
1276
2231
c87bab25f89f changing size segfault fix
michael
parents: 2169
diff changeset
1277 void avcodec_default_free_buffers(AVCodecContext *s){
1214
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
1278 int i, j;
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
1279
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
1280 if(s->internal_buffer==NULL) return;
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
1281
1214
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
1282 for(i=0; i<INTERNAL_BUFFER_SIZE; i++){
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
1283 InternalBuffer *buf= &((InternalBuffer*)s->internal_buffer)[i];
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
1284 for(j=0; j<4; j++){
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
1285 av_freep(&buf->base[j]);
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
1286 buf->data[j]= NULL;
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
1287 }
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
1288 }
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
1289 av_freep(&s->internal_buffer);
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
1290
1214
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
1291 s->internal_buffer_count=0;
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
1292 }
327c5a36dfe7 fixing mixed dr1 + internal buffers
michaelni
parents: 1201
diff changeset
1293
1264
2fa34e615c76 cleanup
michaelni
parents: 1249
diff changeset
1294 char av_get_pict_type_char(int pict_type){
2fa34e615c76 cleanup
michaelni
parents: 1249
diff changeset
1295 switch(pict_type){
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
1296 case I_TYPE: return 'I';
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
1297 case P_TYPE: return 'P';
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
1298 case B_TYPE: return 'B';
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
1299 case S_TYPE: return 'S';
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
1300 case SI_TYPE:return 'i';
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2950
diff changeset
1301 case SP_TYPE:return 'p';
1264
2fa34e615c76 cleanup
michaelni
parents: 1249
diff changeset
1302 default: return '?';
2fa34e615c76 cleanup
michaelni
parents: 1249
diff changeset
1303 }
2fa34e615c76 cleanup
michaelni
parents: 1249
diff changeset
1304 }
2fa34e615c76 cleanup
michaelni
parents: 1249
diff changeset
1305
3433
e1906b2f1daf av_get_bits_per_sample and due simplifications
bcoudurier
parents: 3420
diff changeset
1306 int av_get_bits_per_sample(enum CodecID codec_id){
e1906b2f1daf av_get_bits_per_sample and due simplifications
bcoudurier
parents: 3420
diff changeset
1307 switch(codec_id){
3435
ffa9e863f3be simplify the voc demuxer using av_get_bits_per_sample()
aurel
parents: 3433
diff changeset
1308 case CODEC_ID_ADPCM_SBPRO_2:
3438
fbf61a160154 set proper bits_per_sample value for ADPCM codecs
aurel
parents: 3435
diff changeset
1309 return 2;
3435
ffa9e863f3be simplify the voc demuxer using av_get_bits_per_sample()
aurel
parents: 3433
diff changeset
1310 case CODEC_ID_ADPCM_SBPRO_3:
3438
fbf61a160154 set proper bits_per_sample value for ADPCM codecs
aurel
parents: 3435
diff changeset
1311 return 3;
3435
ffa9e863f3be simplify the voc demuxer using av_get_bits_per_sample()
aurel
parents: 3433
diff changeset
1312 case CODEC_ID_ADPCM_SBPRO_4:
3438
fbf61a160154 set proper bits_per_sample value for ADPCM codecs
aurel
parents: 3435
diff changeset
1313 case CODEC_ID_ADPCM_CT:
fbf61a160154 set proper bits_per_sample value for ADPCM codecs
aurel
parents: 3435
diff changeset
1314 return 4;
3433
e1906b2f1daf av_get_bits_per_sample and due simplifications
bcoudurier
parents: 3420
diff changeset
1315 case CODEC_ID_PCM_ALAW:
e1906b2f1daf av_get_bits_per_sample and due simplifications
bcoudurier
parents: 3420
diff changeset
1316 case CODEC_ID_PCM_MULAW:
e1906b2f1daf av_get_bits_per_sample and due simplifications
bcoudurier
parents: 3420
diff changeset
1317 case CODEC_ID_PCM_S8:
e1906b2f1daf av_get_bits_per_sample and due simplifications
bcoudurier
parents: 3420
diff changeset
1318 case CODEC_ID_PCM_U8:
e1906b2f1daf av_get_bits_per_sample and due simplifications
bcoudurier
parents: 3420
diff changeset
1319 return 8;
e1906b2f1daf av_get_bits_per_sample and due simplifications
bcoudurier
parents: 3420
diff changeset
1320 case CODEC_ID_PCM_S16BE:
e1906b2f1daf av_get_bits_per_sample and due simplifications
bcoudurier
parents: 3420
diff changeset
1321 case CODEC_ID_PCM_S16LE:
e1906b2f1daf av_get_bits_per_sample and due simplifications
bcoudurier
parents: 3420
diff changeset
1322 case CODEC_ID_PCM_U16BE:
e1906b2f1daf av_get_bits_per_sample and due simplifications
bcoudurier
parents: 3420
diff changeset
1323 case CODEC_ID_PCM_U16LE:
e1906b2f1daf av_get_bits_per_sample and due simplifications
bcoudurier
parents: 3420
diff changeset
1324 return 16;
e1906b2f1daf av_get_bits_per_sample and due simplifications
bcoudurier
parents: 3420
diff changeset
1325 case CODEC_ID_PCM_S24DAUD:
e1906b2f1daf av_get_bits_per_sample and due simplifications
bcoudurier
parents: 3420
diff changeset
1326 case CODEC_ID_PCM_S24BE:
e1906b2f1daf av_get_bits_per_sample and due simplifications
bcoudurier
parents: 3420
diff changeset
1327 case CODEC_ID_PCM_S24LE:
e1906b2f1daf av_get_bits_per_sample and due simplifications
bcoudurier
parents: 3420
diff changeset
1328 case CODEC_ID_PCM_U24BE:
e1906b2f1daf av_get_bits_per_sample and due simplifications
bcoudurier
parents: 3420
diff changeset
1329 case CODEC_ID_PCM_U24LE:
e1906b2f1daf av_get_bits_per_sample and due simplifications
bcoudurier
parents: 3420
diff changeset
1330 return 24;
e1906b2f1daf av_get_bits_per_sample and due simplifications
bcoudurier
parents: 3420
diff changeset
1331 case CODEC_ID_PCM_S32BE:
e1906b2f1daf av_get_bits_per_sample and due simplifications
bcoudurier
parents: 3420
diff changeset
1332 case CODEC_ID_PCM_S32LE:
e1906b2f1daf av_get_bits_per_sample and due simplifications
bcoudurier
parents: 3420
diff changeset
1333 case CODEC_ID_PCM_U32BE:
e1906b2f1daf av_get_bits_per_sample and due simplifications
bcoudurier
parents: 3420
diff changeset
1334 case CODEC_ID_PCM_U32LE:
e1906b2f1daf av_get_bits_per_sample and due simplifications
bcoudurier
parents: 3420
diff changeset
1335 return 32;
e1906b2f1daf av_get_bits_per_sample and due simplifications
bcoudurier
parents: 3420
diff changeset
1336 default:
e1906b2f1daf av_get_bits_per_sample and due simplifications
bcoudurier
parents: 3420
diff changeset
1337 return 0;
e1906b2f1daf av_get_bits_per_sample and due simplifications
bcoudurier
parents: 3420
diff changeset
1338 }
e1906b2f1daf av_get_bits_per_sample and due simplifications
bcoudurier
parents: 3420
diff changeset
1339 }
e1906b2f1daf av_get_bits_per_sample and due simplifications
bcoudurier
parents: 3420
diff changeset
1340
2362
7a6ff8cc7c95 BeOS threading support. changed some "if FOO_THREAD||BAR_THREAD" to a more generic "if HAVE_THREADS"
mmu_man
parents: 2324
diff changeset
1341 #if !defined(HAVE_THREADS)
2013
85e547a18d87 dummy avcodec_thread_init() to avoid linking issues
michael
parents: 2002
diff changeset
1342 int avcodec_thread_init(AVCodecContext *s, int thread_count){
85e547a18d87 dummy avcodec_thread_init() to avoid linking issues
michael
parents: 2002
diff changeset
1343 return -1;
85e547a18d87 dummy avcodec_thread_init() to avoid linking issues
michael
parents: 2002
diff changeset
1344 }
85e547a18d87 dummy avcodec_thread_init() to avoid linking issues
michael
parents: 2002
diff changeset
1345 #endif
2676
0975710cf7f4 change extradata format for vorbis
mru
parents: 2652
diff changeset
1346
0975710cf7f4 change extradata format for vorbis
mru
parents: 2652
diff changeset
1347 unsigned int av_xiphlacing(unsigned char *s, unsigned int v)
0975710cf7f4 change extradata format for vorbis
mru
parents: 2652
diff changeset
1348 {
0975710cf7f4 change extradata format for vorbis
mru
parents: 2652
diff changeset
1349 unsigned int n = 0;
0975710cf7f4 change extradata format for vorbis
mru
parents: 2652
diff changeset
1350
0975710cf7f4 change extradata format for vorbis
mru
parents: 2652
diff changeset
1351 while(v >= 0xff) {
0975710cf7f4 change extradata format for vorbis
mru
parents: 2652
diff changeset
1352 *s++ = 0xff;
0975710cf7f4 change extradata format for vorbis
mru
parents: 2652
diff changeset
1353 v -= 0xff;
0975710cf7f4 change extradata format for vorbis
mru
parents: 2652
diff changeset
1354 n++;
0975710cf7f4 change extradata format for vorbis
mru
parents: 2652
diff changeset
1355 }
0975710cf7f4 change extradata format for vorbis
mru
parents: 2652
diff changeset
1356 *s = v;
0975710cf7f4 change extradata format for vorbis
mru
parents: 2652
diff changeset
1357 n++;
0975710cf7f4 change extradata format for vorbis
mru
parents: 2652
diff changeset
1358 return n;
0975710cf7f4 change extradata format for vorbis
mru
parents: 2652
diff changeset
1359 }
3233
18af2f7788c6 - Add new file internal.h for common internal-use-only functions.
corey
parents: 3171
diff changeset
1360
18af2f7788c6 - Add new file internal.h for common internal-use-only functions.
corey
parents: 3171
diff changeset
1361 /* Wrapper to work around the lack of mkstemp() on mingw/cygin.
18af2f7788c6 - Add new file internal.h for common internal-use-only functions.
corey
parents: 3171
diff changeset
1362 * Also, tries to create file in /tmp first, if possible.
18af2f7788c6 - Add new file internal.h for common internal-use-only functions.
corey
parents: 3171
diff changeset
1363 * *prefix can be a character constant; *filename will be allocated internally.
18af2f7788c6 - Add new file internal.h for common internal-use-only functions.
corey
parents: 3171
diff changeset
1364 * Returns file descriptor of opened file (or -1 on error)
18af2f7788c6 - Add new file internal.h for common internal-use-only functions.
corey
parents: 3171
diff changeset
1365 * and opened file name in **filename. */
18af2f7788c6 - Add new file internal.h for common internal-use-only functions.
corey
parents: 3171
diff changeset
1366 int av_tempfile(char *prefix, char **filename) {
18af2f7788c6 - Add new file internal.h for common internal-use-only functions.
corey
parents: 3171
diff changeset
1367 int fd=-1;
3461
7581658de3d1 CONFIG_WIN32 implies MinGW and Cygwin and possibly more, so use just
diego
parents: 3442
diff changeset
1368 #ifdef __MINGW32__
3233
18af2f7788c6 - Add new file internal.h for common internal-use-only functions.
corey
parents: 3171
diff changeset
1369 *filename = tempnam(".", prefix);
18af2f7788c6 - Add new file internal.h for common internal-use-only functions.
corey
parents: 3171
diff changeset
1370 #else
18af2f7788c6 - Add new file internal.h for common internal-use-only functions.
corey
parents: 3171
diff changeset
1371 size_t len = strlen(prefix) + 12; /* room for "/tmp/" and "XXXXXX\0" */
3372
055f0405c523 anothe useless sizeof(char)
reynaldo
parents: 3336
diff changeset
1372 *filename = av_malloc(len);
3233
18af2f7788c6 - Add new file internal.h for common internal-use-only functions.
corey
parents: 3171
diff changeset
1373 #endif
18af2f7788c6 - Add new file internal.h for common internal-use-only functions.
corey
parents: 3171
diff changeset
1374 /* -----common section-----*/
18af2f7788c6 - Add new file internal.h for common internal-use-only functions.
corey
parents: 3171
diff changeset
1375 if (*filename == NULL) {
18af2f7788c6 - Add new file internal.h for common internal-use-only functions.
corey
parents: 3171
diff changeset
1376 av_log(NULL, AV_LOG_ERROR, "ff_tempfile: Cannot allocate file name\n");
18af2f7788c6 - Add new file internal.h for common internal-use-only functions.
corey
parents: 3171
diff changeset
1377 return -1;
18af2f7788c6 - Add new file internal.h for common internal-use-only functions.
corey
parents: 3171
diff changeset
1378 }
3461
7581658de3d1 CONFIG_WIN32 implies MinGW and Cygwin and possibly more, so use just
diego
parents: 3442
diff changeset
1379 #ifdef __MINGW32__
3233
18af2f7788c6 - Add new file internal.h for common internal-use-only functions.
corey
parents: 3171
diff changeset
1380 fd = open(*filename, _O_RDWR | _O_BINARY | _O_CREAT, 0444);
18af2f7788c6 - Add new file internal.h for common internal-use-only functions.
corey
parents: 3171
diff changeset
1381 #else
18af2f7788c6 - Add new file internal.h for common internal-use-only functions.
corey
parents: 3171
diff changeset
1382 snprintf(*filename, len, "/tmp/%sXXXXXX", prefix);
18af2f7788c6 - Add new file internal.h for common internal-use-only functions.
corey
parents: 3171
diff changeset
1383 fd = mkstemp(*filename);
18af2f7788c6 - Add new file internal.h for common internal-use-only functions.
corey
parents: 3171
diff changeset
1384 if (fd < 0) {
18af2f7788c6 - Add new file internal.h for common internal-use-only functions.
corey
parents: 3171
diff changeset
1385 snprintf(*filename, len, "./%sXXXXXX", prefix);
18af2f7788c6 - Add new file internal.h for common internal-use-only functions.
corey
parents: 3171
diff changeset
1386 fd = mkstemp(*filename);
18af2f7788c6 - Add new file internal.h for common internal-use-only functions.
corey
parents: 3171
diff changeset
1387 }
18af2f7788c6 - Add new file internal.h for common internal-use-only functions.
corey
parents: 3171
diff changeset
1388 #endif
18af2f7788c6 - Add new file internal.h for common internal-use-only functions.
corey
parents: 3171
diff changeset
1389 /* -----common section-----*/
18af2f7788c6 - Add new file internal.h for common internal-use-only functions.
corey
parents: 3171
diff changeset
1390 if (fd < 0) {
18af2f7788c6 - Add new file internal.h for common internal-use-only functions.
corey
parents: 3171
diff changeset
1391 av_log(NULL, AV_LOG_ERROR, "ff_tempfile: Cannot open temporary file %s\n", *filename);
18af2f7788c6 - Add new file internal.h for common internal-use-only functions.
corey
parents: 3171
diff changeset
1392 return -1;
18af2f7788c6 - Add new file internal.h for common internal-use-only functions.
corey
parents: 3171
diff changeset
1393 }
18af2f7788c6 - Add new file internal.h for common internal-use-only functions.
corey
parents: 3171
diff changeset
1394 return fd; /* success */
18af2f7788c6 - Add new file internal.h for common internal-use-only functions.
corey
parents: 3171
diff changeset
1395 }