Commit | Line | Data |
---|---|---|
04d7f601 DB |
1 | /* |
2 | * copyright (c) 2006 Michael Niedermayer <michaelni@gmx.at> | |
3 | * | |
b78e7197 DB |
4 | * This file is part of FFmpeg. |
5 | * | |
6 | * FFmpeg is free software; you can redistribute it and/or | |
04d7f601 DB |
7 | * modify it under the terms of the GNU Lesser General Public |
8 | * License as published by the Free Software Foundation; either | |
b78e7197 | 9 | * version 2.1 of the License, or (at your option) any later version. |
04d7f601 | 10 | * |
b78e7197 | 11 | * FFmpeg is distributed in the hope that it will be useful, |
04d7f601 DB |
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
14 | * Lesser General Public License for more details. | |
15 | * | |
16 | * You should have received a copy of the GNU Lesser General Public | |
b78e7197 | 17 | * License along with FFmpeg; if not, write to the Free Software |
04d7f601 DB |
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA |
19 | */ | |
20 | ||
05020c89 RD |
21 | /** |
22 | * @file internal.h | |
23 | * common internal api header. | |
24 | */ | |
25 | ||
98790382 SS |
26 | #ifndef AVUTIL_INTERNAL_H |
27 | #define AVUTIL_INTERNAL_H | |
05020c89 | 28 | |
318049b8 MR |
29 | #if !defined(DEBUG) && !defined(NDEBUG) |
30 | # define NDEBUG | |
31 | #endif | |
32 | ||
99545457 | 33 | #include <stdint.h> |
318049b8 MR |
34 | #include <stddef.h> |
35 | #include <assert.h> | |
99545457 | 36 | |
5e4c7ca2 RP |
37 | #ifndef attribute_align_arg |
38 | #if defined(__GNUC__) && (__GNUC__ > 4 || __GNUC__ == 4 && __GNUC_MINOR__>1) | |
39 | # define attribute_align_arg __attribute__((force_align_arg_pointer)) | |
40 | #else | |
41 | # define attribute_align_arg | |
42 | #endif | |
43 | #endif | |
44 | ||
5403f857 MR |
45 | #ifndef attribute_used |
46 | #if defined(__GNUC__) && (__GNUC__ > 3 || __GNUC__ == 3 && __GNUC_MINOR__ > 0) | |
47 | # define attribute_used __attribute__((used)) | |
48 | #else | |
49 | # define attribute_used | |
50 | #endif | |
51 | #endif | |
52 | ||
cd107896 MR |
53 | #ifndef INT16_MIN |
54 | #define INT16_MIN (-0x7fff-1) | |
55 | #endif | |
56 | ||
57 | #ifndef INT16_MAX | |
58 | #define INT16_MAX 0x7fff | |
59 | #endif | |
60 | ||
61 | #ifndef INT32_MIN | |
62 | #define INT32_MIN (-0x7fffffff-1) | |
63 | #endif | |
64 | ||
65 | #ifndef INT32_MAX | |
66 | #define INT32_MAX 0x7fffffff | |
67 | #endif | |
68 | ||
69 | #ifndef UINT32_MAX | |
70 | #define UINT32_MAX 0xffffffff | |
71 | #endif | |
72 | ||
73 | #ifndef INT64_MIN | |
74 | #define INT64_MIN (-0x7fffffffffffffffLL-1) | |
75 | #endif | |
76 | ||
77 | #ifndef INT64_MAX | |
8da9266c | 78 | #define INT64_MAX INT64_C(9223372036854775807) |
cd107896 MR |
79 | #endif |
80 | ||
81 | #ifndef UINT64_MAX | |
8da9266c | 82 | #define UINT64_MAX UINT64_C(0xFFFFFFFFFFFFFFFF) |
cd107896 MR |
83 | #endif |
84 | ||
85 | #ifndef INT_BIT | |
86 | # if INT_MAX != 2147483647 | |
87 | # define INT_BIT 64 | |
88 | # else | |
89 | # define INT_BIT 32 | |
90 | # endif | |
91 | #endif | |
92 | ||
05020c89 RD |
93 | #if ( defined(__PIC__) || defined(__pic__) ) && ! defined(PIC) |
94 | # define PIC | |
95 | #endif | |
96 | ||
a087028a | 97 | #include "config.h" |
cf1e119b | 98 | #include "intreadwrite.h" |
aab77159 RD |
99 | #include "bswap.h" |
100 | ||
05020c89 | 101 | #ifndef offsetof |
635eb0cc | 102 | # define offsetof(T,F) ((unsigned int)((char *)&((T *)0)->F)) |
05020c89 RD |
103 | #endif |
104 | ||
05020c89 | 105 | // Use rip-relative addressing if compiling PIC code on x86-64. |
b4d96ba2 | 106 | #if defined(ARCH_X86_64) && defined(PIC) |
df22c35d | 107 | # define LOCAL_MANGLE(a) #a "(%%rip)" |
edfd6975 | 108 | #else |
df22c35d | 109 | # define LOCAL_MANGLE(a) #a |
635eb0cc | 110 | #endif |
05020c89 | 111 | |
df22c35d AS |
112 | #define MANGLE(a) EXTERN_PREFIX LOCAL_MANGLE(a) |
113 | ||
05020c89 RD |
114 | /* debug stuff */ |
115 | ||
05020c89 | 116 | /* dprintf macros */ |
635eb0cc | 117 | #ifdef DEBUG |
318c5e05 | 118 | # define dprintf(pctx, ...) av_log(pctx, AV_LOG_DEBUG, __VA_ARGS__) |
635eb0cc | 119 | #else |
318c5e05 | 120 | # define dprintf(pctx, ...) |
635eb0cc | 121 | #endif |
05020c89 | 122 | |
635eb0cc | 123 | #define av_abort() do { av_log(NULL, AV_LOG_ERROR, "Abort at %s:%d\n", __FILE__, __LINE__); abort(); } while (0) |
05020c89 | 124 | |
7e5f82dc MR |
125 | /* math */ |
126 | ||
36cd3069 | 127 | extern const uint32_t ff_inverse[256]; |
05020c89 | 128 | |
3cd52279 | 129 | #if defined(ARCH_X86) |
05020c89 RD |
130 | # define FASTDIV(a,b) \ |
131 | ({\ | |
132 | int ret,dmy;\ | |
be449fca | 133 | __asm__ volatile(\ |
05020c89 RD |
134 | "mull %3"\ |
135 | :"=d"(ret),"=a"(dmy)\ | |
36cd3069 | 136 | :"1"(a),"g"(ff_inverse[b])\ |
05020c89 RD |
137 | );\ |
138 | ret;\ | |
139 | }) | |
6651ce17 MR |
140 | #elif defined(HAVE_ARMV6) |
141 | static inline av_const int FASTDIV(int a, int b) | |
142 | { | |
143 | int r; | |
be449fca | 144 | __asm__ volatile("cmp %2, #0 \n\t" |
c8fd5da4 MR |
145 | "smmul %0, %1, %2 \n\t" |
146 | "rsblt %0, %0, #0 \n\t" | |
147 | : "=r"(r) : "r"(a), "r"(ff_inverse[b])); | |
6651ce17 MR |
148 | return r; |
149 | } | |
eeebe6ad SS |
150 | #elif defined(ARCH_ARMV4L) |
151 | # define FASTDIV(a,b) \ | |
152 | ({\ | |
153 | int ret,dmy;\ | |
be449fca | 154 | __asm__ volatile(\ |
eeebe6ad SS |
155 | "umull %1, %0, %2, %3"\ |
156 | :"=&r"(ret),"=&r"(dmy)\ | |
36cd3069 | 157 | :"r"(a),"r"(ff_inverse[b])\ |
eeebe6ad SS |
158 | );\ |
159 | ret;\ | |
160 | }) | |
05020c89 | 161 | #elif defined(CONFIG_FASTDIV) |
36cd3069 | 162 | # define FASTDIV(a,b) ((uint32_t)((((uint64_t)a)*ff_inverse[b])>>32)) |
05020c89 RD |
163 | #else |
164 | # define FASTDIV(a,b) ((a)/(b)) | |
165 | #endif | |
166 | ||
c448a096 | 167 | extern const uint8_t ff_sqrt_tab[256]; |
05020c89 | 168 | |
c448a096 MN |
169 | static inline int av_log2_16bit(unsigned int v); |
170 | ||
85074d3c | 171 | static inline av_const unsigned int ff_sqrt(unsigned int a) |
05020c89 | 172 | { |
c448a096 MN |
173 | unsigned int b; |
174 | ||
175 | if(a<255) return (ff_sqrt_tab[a+1]-1)>>4; | |
176 | else if(a<(1<<12)) b= ff_sqrt_tab[a>>4 ]>>2; | |
177 | #ifndef CONFIG_SMALL | |
178 | else if(a<(1<<14)) b= ff_sqrt_tab[a>>6 ]>>1; | |
179 | else if(a<(1<<16)) b= ff_sqrt_tab[a>>8 ] ; | |
180 | #endif | |
181 | else{ | |
182 | int s= av_log2_16bit(a>>16)>>1; | |
183 | unsigned int c= a>>(s+2); | |
184 | b= ff_sqrt_tab[c>>(s+8)]; | |
185 | b= FASTDIV(c,b) + (b<<s); | |
05020c89 | 186 | } |
c448a096 MN |
187 | |
188 | return b - (a<b*b); | |
05020c89 RD |
189 | } |
190 | ||
3cd52279 | 191 | #if defined(ARCH_X86) |
05020c89 | 192 | #define MASK_ABS(mask, level)\ |
be449fca | 193 | __asm__ volatile(\ |
7e14b808 | 194 | "cltd \n\t"\ |
05020c89 RD |
195 | "xorl %1, %0 \n\t"\ |
196 | "subl %1, %0 \n\t"\ | |
197 | : "+a" (level), "=&d" (mask)\ | |
198 | ); | |
199 | #else | |
200 | #define MASK_ABS(mask, level)\ | |
201 | mask= level>>31;\ | |
202 | level= (level^mask)-mask; | |
203 | #endif | |
204 | ||
94e4c3a3 | 205 | #ifdef HAVE_CMOV |
05020c89 | 206 | #define COPY3_IF_LT(x,y,a,b,c,d)\ |
be449fca | 207 | __asm__ volatile (\ |
05020c89 RD |
208 | "cmpl %0, %3 \n\t"\ |
209 | "cmovl %3, %0 \n\t"\ | |
210 | "cmovl %4, %1 \n\t"\ | |
211 | "cmovl %5, %2 \n\t"\ | |
8c2e2040 | 212 | : "+&r" (x), "+&r" (a), "+r" (c)\ |
05020c89 RD |
213 | : "r" (y), "r" (b), "r" (d)\ |
214 | ); | |
215 | #else | |
216 | #define COPY3_IF_LT(x,y,a,b,c,d)\ | |
217 | if((y)<(x)){\ | |
218 | (x)=(y);\ | |
219 | (a)=(b);\ | |
220 | (c)=(d);\ | |
221 | } | |
222 | #endif | |
223 | ||
224 | /* avoid usage of various functions */ | |
84662c01 | 225 | #undef malloc |
05020c89 | 226 | #define malloc please_use_av_malloc |
84662c01 | 227 | #undef free |
05020c89 | 228 | #define free please_use_av_free |
84662c01 | 229 | #undef realloc |
05020c89 | 230 | #define realloc please_use_av_realloc |
84662c01 | 231 | #undef time |
05020c89 | 232 | #define time time_is_forbidden_due_to_security_issues |
84662c01 | 233 | #undef rand |
3299fb45 | 234 | #define rand rand_is_forbidden_due_to_state_trashing_use_av_random |
84662c01 | 235 | #undef srand |
3299fb45 | 236 | #define srand srand_is_forbidden_due_to_state_trashing_use_av_init_random |
84662c01 | 237 | #undef random |
3299fb45 | 238 | #define random random_is_forbidden_due_to_state_trashing_use_av_random |
84662c01 | 239 | #undef sprintf |
05020c89 | 240 | #define sprintf sprintf_is_forbidden_due_to_security_issues_use_snprintf |
84662c01 | 241 | #undef strcat |
272605c7 | 242 | #define strcat strcat_is_forbidden_due_to_security_issues_use_av_strlcat |
84662c01 | 243 | #undef exit |
c367d067 | 244 | #define exit exit_is_forbidden |
6123abad | 245 | #ifndef LIBAVFORMAT_BUILD |
84662c01 | 246 | #undef printf |
05020c89 | 247 | #define printf please_use_av_log |
84662c01 | 248 | #undef fprintf |
05020c89 | 249 | #define fprintf please_use_av_log |
59ec6991 DB |
250 | #undef puts |
251 | #define puts please_use_av_log | |
c5a2fe8f LA |
252 | #undef perror |
253 | #define perror please_use_av_log_instead_of_perror | |
05020c89 RD |
254 | #endif |
255 | ||
256 | #define CHECKED_ALLOCZ(p, size)\ | |
257 | {\ | |
258 | p= av_mallocz(size);\ | |
259 | if(p==NULL && (size)!=0){\ | |
7f0cd6a5 | 260 | av_log(NULL, AV_LOG_ERROR, "Cannot allocate memory.");\ |
05020c89 RD |
261 | goto fail;\ |
262 | }\ | |
263 | } | |
264 | ||
a33cab3a | 265 | #ifndef HAVE_LLRINT |
85074d3c | 266 | static av_always_inline av_const long long llrint(double x) |
a33cab3a MK |
267 | { |
268 | return rint(x); | |
269 | } | |
270 | #endif /* HAVE_LLRINT */ | |
271 | ||
272 | #ifndef HAVE_LRINT | |
85074d3c | 273 | static av_always_inline av_const long int lrint(double x) |
a33cab3a MK |
274 | { |
275 | return rint(x); | |
276 | } | |
277 | #endif /* HAVE_LRINT */ | |
278 | ||
05020c89 | 279 | #ifndef HAVE_LRINTF |
85074d3c | 280 | static av_always_inline av_const long int lrintf(float x) |
05020c89 | 281 | { |
05020c89 | 282 | return (int)(rint(x)); |
05020c89 RD |
283 | } |
284 | #endif /* HAVE_LRINTF */ | |
285 | ||
a33cab3a | 286 | #ifndef HAVE_ROUND |
85074d3c | 287 | static av_always_inline av_const double round(double x) |
a33cab3a MK |
288 | { |
289 | return (x > 0) ? floor(x + 0.5) : ceil(x - 0.5); | |
290 | } | |
291 | #endif /* HAVE_ROUND */ | |
292 | ||
293 | #ifndef HAVE_ROUNDF | |
85074d3c | 294 | static av_always_inline av_const float roundf(float x) |
a33cab3a MK |
295 | { |
296 | return (x > 0) ? floor(x + 0.5) : ceil(x - 0.5); | |
297 | } | |
298 | #endif /* HAVE_ROUNDF */ | |
299 | ||
98790382 | 300 | #endif /* AVUTIL_INTERNAL_H */ |