Mercurial > libavutil.hg
annotate common.h @ 661:ac3fc6cb4781 libavutil
av_uninit() to suppress false uninitialized warnings from gcc without deoptimizing code.
author | michael |
---|---|
date | Mon, 09 Feb 2009 21:47:05 +0000 |
parents | 70bdd5501662 |
children | 1ed74ddc5e6b |
rev | line source |
---|---|
108
11be8e0d1344
Add official LGPL license headers to the files that were missing them.
diego
parents:
104
diff
changeset
|
1 /* |
11be8e0d1344
Add official LGPL license headers to the files that were missing them.
diego
parents:
104
diff
changeset
|
2 * copyright (c) 2006 Michael Niedermayer <michaelni@gmx.at> |
11be8e0d1344
Add official LGPL license headers to the files that were missing them.
diego
parents:
104
diff
changeset
|
3 * |
116
d76a36742464
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
113
diff
changeset
|
4 * This file is part of FFmpeg. |
d76a36742464
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
113
diff
changeset
|
5 * |
d76a36742464
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
113
diff
changeset
|
6 * FFmpeg is free software; you can redistribute it and/or |
108
11be8e0d1344
Add official LGPL license headers to the files that were missing them.
diego
parents:
104
diff
changeset
|
7 * modify it under the terms of the GNU Lesser General Public |
11be8e0d1344
Add official LGPL license headers to the files that were missing them.
diego
parents:
104
diff
changeset
|
8 * License as published by the Free Software Foundation; either |
116
d76a36742464
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
113
diff
changeset
|
9 * version 2.1 of the License, or (at your option) any later version. |
108
11be8e0d1344
Add official LGPL license headers to the files that were missing them.
diego
parents:
104
diff
changeset
|
10 * |
116
d76a36742464
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
113
diff
changeset
|
11 * FFmpeg is distributed in the hope that it will be useful, |
108
11be8e0d1344
Add official LGPL license headers to the files that were missing them.
diego
parents:
104
diff
changeset
|
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
11be8e0d1344
Add official LGPL license headers to the files that were missing them.
diego
parents:
104
diff
changeset
|
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
11be8e0d1344
Add official LGPL license headers to the files that were missing them.
diego
parents:
104
diff
changeset
|
14 * Lesser General Public License for more details. |
11be8e0d1344
Add official LGPL license headers to the files that were missing them.
diego
parents:
104
diff
changeset
|
15 * |
11be8e0d1344
Add official LGPL license headers to the files that were missing them.
diego
parents:
104
diff
changeset
|
16 * You should have received a copy of the GNU Lesser General Public |
116
d76a36742464
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
113
diff
changeset
|
17 * License along with FFmpeg; if not, write to the Free Software |
108
11be8e0d1344
Add official LGPL license headers to the files that were missing them.
diego
parents:
104
diff
changeset
|
18 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA |
11be8e0d1344
Add official LGPL license headers to the files that were missing them.
diego
parents:
104
diff
changeset
|
19 */ |
11be8e0d1344
Add official LGPL license headers to the files that were missing them.
diego
parents:
104
diff
changeset
|
20 |
0
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
21 /** |
642
70bdd5501662
Use full internal pathname in doxygen @file directives.
diego
parents:
633
diff
changeset
|
22 * @file libavutil/common.h |
466 | 23 * common internal and external API header |
0
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
24 */ |
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
25 |
567 | 26 #ifndef AVUTIL_COMMON_H |
27 #define AVUTIL_COMMON_H | |
0
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
28 |
630
fb04e2fc189c
Reorganize header #includes: Unconditionally #include standard C headers,
diego
parents:
619
diff
changeset
|
29 #include <ctype.h> |
fb04e2fc189c
Reorganize header #includes: Unconditionally #include standard C headers,
diego
parents:
619
diff
changeset
|
30 #include <errno.h> |
158 | 31 #include <inttypes.h> |
630
fb04e2fc189c
Reorganize header #includes: Unconditionally #include standard C headers,
diego
parents:
619
diff
changeset
|
32 #include <limits.h> |
fb04e2fc189c
Reorganize header #includes: Unconditionally #include standard C headers,
diego
parents:
619
diff
changeset
|
33 #include <math.h> |
fb04e2fc189c
Reorganize header #includes: Unconditionally #include standard C headers,
diego
parents:
619
diff
changeset
|
34 #include <stdio.h> |
fb04e2fc189c
Reorganize header #includes: Unconditionally #include standard C headers,
diego
parents:
619
diff
changeset
|
35 #include <stdlib.h> |
fb04e2fc189c
Reorganize header #includes: Unconditionally #include standard C headers,
diego
parents:
619
diff
changeset
|
36 #include <string.h> |
159
039198e96ee2
rename always_inline to av_always_inline and move to common.h
mru
parents:
158
diff
changeset
|
37 |
590
e9d89a89561a
Use AV_GCC_VERSION_AT_LEAST() to simplify gcc version checks.
cehoyos
parents:
580
diff
changeset
|
38 #define AV_GCC_VERSION_AT_LEAST(x,y) (defined(__GNUC__) && (__GNUC__ > x || __GNUC__ == x && __GNUC_MINOR__ >= y)) |
e9d89a89561a
Use AV_GCC_VERSION_AT_LEAST() to simplify gcc version checks.
cehoyos
parents:
580
diff
changeset
|
39 |
159
039198e96ee2
rename always_inline to av_always_inline and move to common.h
mru
parents:
158
diff
changeset
|
40 #ifndef av_always_inline |
590
e9d89a89561a
Use AV_GCC_VERSION_AT_LEAST() to simplify gcc version checks.
cehoyos
parents:
580
diff
changeset
|
41 #if AV_GCC_VERSION_AT_LEAST(3,1) |
159
039198e96ee2
rename always_inline to av_always_inline and move to common.h
mru
parents:
158
diff
changeset
|
42 # define av_always_inline __attribute__((always_inline)) inline |
372 | 43 #else |
44 # define av_always_inline inline | |
45 #endif | |
46 #endif | |
47 | |
48 #ifndef av_noinline | |
590
e9d89a89561a
Use AV_GCC_VERSION_AT_LEAST() to simplify gcc version checks.
cehoyos
parents:
580
diff
changeset
|
49 #if AV_GCC_VERSION_AT_LEAST(3,1) |
246 | 50 # define av_noinline __attribute__((noinline)) |
159
039198e96ee2
rename always_inline to av_always_inline and move to common.h
mru
parents:
158
diff
changeset
|
51 #else |
246 | 52 # define av_noinline |
159
039198e96ee2
rename always_inline to av_always_inline and move to common.h
mru
parents:
158
diff
changeset
|
53 #endif |
039198e96ee2
rename always_inline to av_always_inline and move to common.h
mru
parents:
158
diff
changeset
|
54 #endif |
039198e96ee2
rename always_inline to av_always_inline and move to common.h
mru
parents:
158
diff
changeset
|
55 |
481
f4187c1c15a6
Reapply r12489: Add pure, const and malloc attributes to proper functions
zuxy
parents:
478
diff
changeset
|
56 #ifndef av_pure |
590
e9d89a89561a
Use AV_GCC_VERSION_AT_LEAST() to simplify gcc version checks.
cehoyos
parents:
580
diff
changeset
|
57 #if AV_GCC_VERSION_AT_LEAST(3,1) |
481
f4187c1c15a6
Reapply r12489: Add pure, const and malloc attributes to proper functions
zuxy
parents:
478
diff
changeset
|
58 # define av_pure __attribute__((pure)) |
f4187c1c15a6
Reapply r12489: Add pure, const and malloc attributes to proper functions
zuxy
parents:
478
diff
changeset
|
59 #else |
f4187c1c15a6
Reapply r12489: Add pure, const and malloc attributes to proper functions
zuxy
parents:
478
diff
changeset
|
60 # define av_pure |
f4187c1c15a6
Reapply r12489: Add pure, const and malloc attributes to proper functions
zuxy
parents:
478
diff
changeset
|
61 #endif |
f4187c1c15a6
Reapply r12489: Add pure, const and malloc attributes to proper functions
zuxy
parents:
478
diff
changeset
|
62 #endif |
f4187c1c15a6
Reapply r12489: Add pure, const and malloc attributes to proper functions
zuxy
parents:
478
diff
changeset
|
63 |
f4187c1c15a6
Reapply r12489: Add pure, const and malloc attributes to proper functions
zuxy
parents:
478
diff
changeset
|
64 #ifndef av_const |
590
e9d89a89561a
Use AV_GCC_VERSION_AT_LEAST() to simplify gcc version checks.
cehoyos
parents:
580
diff
changeset
|
65 #if AV_GCC_VERSION_AT_LEAST(2,6) |
481
f4187c1c15a6
Reapply r12489: Add pure, const and malloc attributes to proper functions
zuxy
parents:
478
diff
changeset
|
66 # define av_const __attribute__((const)) |
f4187c1c15a6
Reapply r12489: Add pure, const and malloc attributes to proper functions
zuxy
parents:
478
diff
changeset
|
67 #else |
f4187c1c15a6
Reapply r12489: Add pure, const and malloc attributes to proper functions
zuxy
parents:
478
diff
changeset
|
68 # define av_const |
f4187c1c15a6
Reapply r12489: Add pure, const and malloc attributes to proper functions
zuxy
parents:
478
diff
changeset
|
69 #endif |
f4187c1c15a6
Reapply r12489: Add pure, const and malloc attributes to proper functions
zuxy
parents:
478
diff
changeset
|
70 #endif |
f4187c1c15a6
Reapply r12489: Add pure, const and malloc attributes to proper functions
zuxy
parents:
478
diff
changeset
|
71 |
486
2e4747b3d034
Apply 'cold' attribute to init/uninit functions in libavcodec
zuxy
parents:
481
diff
changeset
|
72 #ifndef av_cold |
591 | 73 #if (!defined(__ICC) || __ICC > 1100) && AV_GCC_VERSION_AT_LEAST(4,3) |
486
2e4747b3d034
Apply 'cold' attribute to init/uninit functions in libavcodec
zuxy
parents:
481
diff
changeset
|
74 # define av_cold __attribute__((cold)) |
2e4747b3d034
Apply 'cold' attribute to init/uninit functions in libavcodec
zuxy
parents:
481
diff
changeset
|
75 #else |
2e4747b3d034
Apply 'cold' attribute to init/uninit functions in libavcodec
zuxy
parents:
481
diff
changeset
|
76 # define av_cold |
2e4747b3d034
Apply 'cold' attribute to init/uninit functions in libavcodec
zuxy
parents:
481
diff
changeset
|
77 #endif |
2e4747b3d034
Apply 'cold' attribute to init/uninit functions in libavcodec
zuxy
parents:
481
diff
changeset
|
78 #endif |
2e4747b3d034
Apply 'cold' attribute to init/uninit functions in libavcodec
zuxy
parents:
481
diff
changeset
|
79 |
100 | 80 #ifndef attribute_deprecated |
590
e9d89a89561a
Use AV_GCC_VERSION_AT_LEAST() to simplify gcc version checks.
cehoyos
parents:
580
diff
changeset
|
81 #if AV_GCC_VERSION_AT_LEAST(3,1) |
100 | 82 # define attribute_deprecated __attribute__((deprecated)) |
83 #else | |
84 # define attribute_deprecated | |
85 #endif | |
86 #endif | |
87 | |
339
8829032777d5
rename attribute_unused to av_unused and moves its declaration to common.h
benoit
parents:
286
diff
changeset
|
88 #ifndef av_unused |
8829032777d5
rename attribute_unused to av_unused and moves its declaration to common.h
benoit
parents:
286
diff
changeset
|
89 #if defined(__GNUC__) |
8829032777d5
rename attribute_unused to av_unused and moves its declaration to common.h
benoit
parents:
286
diff
changeset
|
90 # define av_unused __attribute__((unused)) |
8829032777d5
rename attribute_unused to av_unused and moves its declaration to common.h
benoit
parents:
286
diff
changeset
|
91 #else |
8829032777d5
rename attribute_unused to av_unused and moves its declaration to common.h
benoit
parents:
286
diff
changeset
|
92 # define av_unused |
8829032777d5
rename attribute_unused to av_unused and moves its declaration to common.h
benoit
parents:
286
diff
changeset
|
93 #endif |
8829032777d5
rename attribute_unused to av_unused and moves its declaration to common.h
benoit
parents:
286
diff
changeset
|
94 #endif |
8829032777d5
rename attribute_unused to av_unused and moves its declaration to common.h
benoit
parents:
286
diff
changeset
|
95 |
661
ac3fc6cb4781
av_uninit() to suppress false uninitialized warnings from gcc without deoptimizing code.
michael
parents:
642
diff
changeset
|
96 #ifndef av_uninit |
ac3fc6cb4781
av_uninit() to suppress false uninitialized warnings from gcc without deoptimizing code.
michael
parents:
642
diff
changeset
|
97 #if defined(__GNUC__) |
ac3fc6cb4781
av_uninit() to suppress false uninitialized warnings from gcc without deoptimizing code.
michael
parents:
642
diff
changeset
|
98 # define av_uninit(x) x=x |
ac3fc6cb4781
av_uninit() to suppress false uninitialized warnings from gcc without deoptimizing code.
michael
parents:
642
diff
changeset
|
99 #else |
ac3fc6cb4781
av_uninit() to suppress false uninitialized warnings from gcc without deoptimizing code.
michael
parents:
642
diff
changeset
|
100 # define av_uninit(x) x |
ac3fc6cb4781
av_uninit() to suppress false uninitialized warnings from gcc without deoptimizing code.
michael
parents:
642
diff
changeset
|
101 #endif |
ac3fc6cb4781
av_uninit() to suppress false uninitialized warnings from gcc without deoptimizing code.
michael
parents:
642
diff
changeset
|
102 #endif |
ac3fc6cb4781
av_uninit() to suppress false uninitialized warnings from gcc without deoptimizing code.
michael
parents:
642
diff
changeset
|
103 |
633 | 104 //rounded division & shift |
0
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
105 #define RSHIFT(a,b) ((a) > 0 ? ((a) + ((1<<(b))>>1))>>(b) : ((a) + ((1<<(b))>>1)-1)>>(b)) |
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
106 /* assume b>0 */ |
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
107 #define ROUNDED_DIV(a,b) (((a)>0 ? (a) + ((b)>>1) : (a) - ((b)>>1))/(b)) |
120 | 108 #define FFABS(a) ((a) >= 0 ? (a) : (-(a))) |
119
7d5463d9530a
Rename SIGN macro to FFSIGN to avoid clashes with system headers.
diego
parents:
117
diff
changeset
|
109 #define FFSIGN(a) ((a) > 0 ? 1 : -1) |
0
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
110 |
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
111 #define FFMAX(a,b) ((a) > (b) ? (a) : (b)) |
498
2ae1cc70b1c4
Implement FFMAX3(a,b,c) - maximum over three arguments.
voroshil
parents:
496
diff
changeset
|
112 #define FFMAX3(a,b,c) FFMAX(FFMAX(a,b),c) |
0
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
113 #define FFMIN(a,b) ((a) > (b) ? (b) : (a)) |
501 | 114 #define FFMIN3(a,b,c) FFMIN(FFMIN(a,b),c) |
0
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
115 |
126 | 116 #define FFSWAP(type,a,b) do{type SWAP_tmp= b; b= a; a= SWAP_tmp;}while(0) |
576
481638df1e8b
Add a macro to get the number of elements in a table.
benoit
parents:
567
diff
changeset
|
117 #define FF_ARRAY_ELEMS(a) (sizeof(a) / sizeof((a)[0])) |
99 | 118 |
0
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
119 /* misc math functions */ |
157 | 120 extern const uint8_t ff_log2_tab[256]; |
0
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
121 |
481
f4187c1c15a6
Reapply r12489: Add pure, const and malloc attributes to proper functions
zuxy
parents:
478
diff
changeset
|
122 static inline av_const int av_log2(unsigned int v) |
0
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
123 { |
443 | 124 int n = 0; |
0
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
125 if (v & 0xffff0000) { |
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
126 v >>= 16; |
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
127 n += 16; |
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
128 } |
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
129 if (v & 0xff00) { |
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
130 v >>= 8; |
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
131 n += 8; |
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
132 } |
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
133 n += ff_log2_tab[v]; |
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
134 |
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
135 return n; |
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
136 } |
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
137 |
481
f4187c1c15a6
Reapply r12489: Add pure, const and malloc attributes to proper functions
zuxy
parents:
478
diff
changeset
|
138 static inline av_const int av_log2_16bit(unsigned int v) |
0
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
139 { |
443 | 140 int n = 0; |
0
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
141 if (v & 0xff00) { |
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
142 v >>= 8; |
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
143 n += 8; |
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
144 } |
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
145 n += ff_log2_tab[v]; |
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
146 |
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
147 return n; |
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
148 } |
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
149 |
39 | 150 /** |
633 | 151 * Clips a signed integer value into the amin-amax range. |
39 | 152 * @param a value to clip |
153 * @param amin minimum value of the clip range | |
154 * @param amax maximum value of the clip range | |
151 | 155 * @return clipped value |
39 | 156 */ |
481
f4187c1c15a6
Reapply r12489: Add pure, const and malloc attributes to proper functions
zuxy
parents:
478
diff
changeset
|
157 static inline av_const int av_clip(int a, int amin, int amax) |
0
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
158 { |
452 | 159 if (a < amin) return amin; |
63 | 160 else if (a > amax) return amax; |
161 else return a; | |
0
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
162 } |
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
163 |
39 | 164 /** |
633 | 165 * Clips a signed integer value into the 0-255 range. |
39 | 166 * @param a value to clip |
151 | 167 * @return clipped value |
39 | 168 */ |
481
f4187c1c15a6
Reapply r12489: Add pure, const and malloc attributes to proper functions
zuxy
parents:
478
diff
changeset
|
169 static inline av_const uint8_t av_clip_uint8(int a) |
0
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
170 { |
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
171 if (a&(~255)) return (-a)>>31; |
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
172 else return a; |
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
173 } |
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
174 |
373 | 175 /** |
633 | 176 * Clips a signed integer value into the -32768,32767 range. |
373 | 177 * @param a value to clip |
178 * @return clipped value | |
179 */ | |
481
f4187c1c15a6
Reapply r12489: Add pure, const and malloc attributes to proper functions
zuxy
parents:
478
diff
changeset
|
180 static inline av_const int16_t av_clip_int16(int a) |
373 | 181 { |
182 if ((a+32768) & ~65535) return (a>>31) ^ 32767; | |
183 else return a; | |
184 } | |
185 | |
519
5cdb952bd09a
Add av_clipf() function to common.h and use it in ra288.c
vitor
parents:
516
diff
changeset
|
186 /** |
633 | 187 * Clips a float value into the amin-amax range. |
519
5cdb952bd09a
Add av_clipf() function to common.h and use it in ra288.c
vitor
parents:
516
diff
changeset
|
188 * @param a value to clip |
5cdb952bd09a
Add av_clipf() function to common.h and use it in ra288.c
vitor
parents:
516
diff
changeset
|
189 * @param amin minimum value of the clip range |
5cdb952bd09a
Add av_clipf() function to common.h and use it in ra288.c
vitor
parents:
516
diff
changeset
|
190 * @param amax maximum value of the clip range |
5cdb952bd09a
Add av_clipf() function to common.h and use it in ra288.c
vitor
parents:
516
diff
changeset
|
191 * @return clipped value |
5cdb952bd09a
Add av_clipf() function to common.h and use it in ra288.c
vitor
parents:
516
diff
changeset
|
192 */ |
5cdb952bd09a
Add av_clipf() function to common.h and use it in ra288.c
vitor
parents:
516
diff
changeset
|
193 static inline av_const float av_clipf(float a, float amin, float amax) |
5cdb952bd09a
Add av_clipf() function to common.h and use it in ra288.c
vitor
parents:
516
diff
changeset
|
194 { |
5cdb952bd09a
Add av_clipf() function to common.h and use it in ra288.c
vitor
parents:
516
diff
changeset
|
195 if (a < amin) return amin; |
5cdb952bd09a
Add av_clipf() function to common.h and use it in ra288.c
vitor
parents:
516
diff
changeset
|
196 else if (a > amax) return amax; |
5cdb952bd09a
Add av_clipf() function to common.h and use it in ra288.c
vitor
parents:
516
diff
changeset
|
197 else return a; |
5cdb952bd09a
Add av_clipf() function to common.h and use it in ra288.c
vitor
parents:
516
diff
changeset
|
198 } |
5cdb952bd09a
Add av_clipf() function to common.h and use it in ra288.c
vitor
parents:
516
diff
changeset
|
199 |
0
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
200 #define MKTAG(a,b,c,d) (a | (b << 8) | (c << 16) | (d << 24)) |
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
201 #define MKBETAG(a,b,c,d) (d | (c << 8) | (b << 16) | (a << 24)) |
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
202 |
132 | 203 /*! |
204 * \def GET_UTF8(val, GET_BYTE, ERROR) | |
633 | 205 * Converts a UTF-8 character (up to 4 bytes long) to its 32-bit UCS-4 encoded form |
132 | 206 * \param val is the output and should be of type uint32_t. It holds the converted |
341 | 207 * UCS-4 character and should be a left value. |
208 * \param GET_BYTE gets UTF-8 encoded bytes from any proper source. It can be | |
132 | 209 * a function or a statement whose return value or evaluated value is of type |
341 | 210 * uint8_t. It will be executed up to 4 times for values in the valid UTF-8 range, |
147
7e143f348a72
Correct GET/PUT_UTF8 comment: the get/put functions might be called up
reimar
parents:
146
diff
changeset
|
211 * and up to 7 times in the general case. |
341 | 212 * \param ERROR action that should be taken when an invalid UTF-8 byte is returned |
132 | 213 * from GET_BYTE. It should be a statement that jumps out of the macro, |
214 * like exit(), goto, return, break, or continue. | |
215 */ | |
130 | 216 #define GET_UTF8(val, GET_BYTE, ERROR)\ |
217 val= GET_BYTE;\ | |
218 {\ | |
219 int ones= 7 - av_log2(val ^ 255);\ | |
220 if(ones==1)\ | |
221 ERROR\ | |
222 val&= 127>>ones;\ | |
223 while(--ones > 0){\ | |
224 int tmp= GET_BYTE - 128;\ | |
225 if(tmp>>6)\ | |
226 ERROR\ | |
227 val= (val<<6) + tmp;\ | |
228 }\ | |
229 } | |
230 | |
129
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
231 /*! |
131 | 232 * \def PUT_UTF8(val, tmp, PUT_BYTE) |
633 | 233 * Converts a 32-bit Unicode character to its UTF-8 encoded form (up to 4 bytes long). |
234 * \param val is an input-only argument and should be of type uint32_t. It holds | |
235 * a UCS-4 encoded Unicode character that is to be converted to UTF-8. If | |
236 * val is given as a function it is executed only once. | |
129
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
237 * \param tmp is a temporary variable and should be of type uint8_t. It |
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
238 * represents an intermediate value during conversion that is to be |
633 | 239 * output by PUT_BYTE. |
341 | 240 * \param PUT_BYTE writes the converted UTF-8 bytes to any proper destination. |
129
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
241 * It could be a function or a statement, and uses tmp as the input byte. |
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
242 * For example, PUT_BYTE could be "*output++ = tmp;" PUT_BYTE will be |
341 | 243 * executed up to 4 times for values in the valid UTF-8 range and up to |
147
7e143f348a72
Correct GET/PUT_UTF8 comment: the get/put functions might be called up
reimar
parents:
146
diff
changeset
|
244 * 7 times in the general case, depending on the length of the converted |
633 | 245 * Unicode character. |
129
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
246 */ |
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
247 #define PUT_UTF8(val, tmp, PUT_BYTE)\ |
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
248 {\ |
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
249 int bytes, shift;\ |
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
250 uint32_t in = val;\ |
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
251 if (in < 0x80) {\ |
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
252 tmp = in;\ |
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
253 PUT_BYTE\ |
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
254 } else {\ |
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
255 bytes = (av_log2(in) + 4) / 5;\ |
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
256 shift = (bytes - 1) * 6;\ |
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
257 tmp = (256 - (256 >> bytes)) | (in >> shift);\ |
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
258 PUT_BYTE\ |
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
259 while (shift >= 6) {\ |
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
260 shift -= 6;\ |
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
261 tmp = 0x80 | ((in >> shift) & 0x3f);\ |
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
262 PUT_BYTE\ |
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
263 }\ |
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
264 }\ |
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
265 } |
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
266 |
630
fb04e2fc189c
Reorganize header #includes: Unconditionally #include standard C headers,
diego
parents:
619
diff
changeset
|
267 #include "mem.h" |
fb04e2fc189c
Reorganize header #includes: Unconditionally #include standard C headers,
diego
parents:
619
diff
changeset
|
268 |
619
c309f86c05a2
Move internal.h #include to the end of the file so that it is after
diego
parents:
610
diff
changeset
|
269 #ifdef HAVE_AV_CONFIG_H |
630
fb04e2fc189c
Reorganize header #includes: Unconditionally #include standard C headers,
diego
parents:
619
diff
changeset
|
270 # include "config.h" |
619
c309f86c05a2
Move internal.h #include to the end of the file so that it is after
diego
parents:
610
diff
changeset
|
271 # include "internal.h" |
c309f86c05a2
Move internal.h #include to the end of the file so that it is after
diego
parents:
610
diff
changeset
|
272 #endif /* HAVE_AV_CONFIG_H */ |
c309f86c05a2
Move internal.h #include to the end of the file so that it is after
diego
parents:
610
diff
changeset
|
273 |
567 | 274 #endif /* AVUTIL_COMMON_H */ |