Mercurial > libavutil.hg
annotate common.h @ 848:f435d64fd243 libavutil
Add PUT_UTF16() macro.
Patch by Anton Khirnov <wyskas gmail com>.
| author | rbultje |
|---|---|
| date | Wed, 24 Feb 2010 18:08:30 +0000 |
| parents | 36cc11e07d9b |
| children | efba70214ef1 |
| 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 |
|
761
58d118a78f6d
Revert addition of '#undef av_always_inline' to config.h in the small case.
diego
parents:
743
diff
changeset
|
38 #ifdef HAVE_AV_CONFIG_H |
|
58d118a78f6d
Revert addition of '#undef av_always_inline' to config.h in the small case.
diego
parents:
743
diff
changeset
|
39 #include "config.h" |
|
58d118a78f6d
Revert addition of '#undef av_always_inline' to config.h in the small case.
diego
parents:
743
diff
changeset
|
40 #endif |
|
58d118a78f6d
Revert addition of '#undef av_always_inline' to config.h in the small case.
diego
parents:
743
diff
changeset
|
41 |
|
668
8adb1d368c25
Avoid warnings from AV_GCC_VERSION_AT_LEAST with some non-gcc compilers
mru
parents:
664
diff
changeset
|
42 #ifdef __GNUC__ |
|
8adb1d368c25
Avoid warnings from AV_GCC_VERSION_AT_LEAST with some non-gcc compilers
mru
parents:
664
diff
changeset
|
43 # define AV_GCC_VERSION_AT_LEAST(x,y) (__GNUC__ > x || __GNUC__ == x && __GNUC_MINOR__ >= y) |
|
8adb1d368c25
Avoid warnings from AV_GCC_VERSION_AT_LEAST with some non-gcc compilers
mru
parents:
664
diff
changeset
|
44 #else |
|
8adb1d368c25
Avoid warnings from AV_GCC_VERSION_AT_LEAST with some non-gcc compilers
mru
parents:
664
diff
changeset
|
45 # define AV_GCC_VERSION_AT_LEAST(x,y) 0 |
|
8adb1d368c25
Avoid warnings from AV_GCC_VERSION_AT_LEAST with some non-gcc compilers
mru
parents:
664
diff
changeset
|
46 #endif |
|
590
e9d89a89561a
Use AV_GCC_VERSION_AT_LEAST() to simplify gcc version checks.
cehoyos
parents:
580
diff
changeset
|
47 |
|
159
039198e96ee2
rename always_inline to av_always_inline and move to common.h
mru
parents:
158
diff
changeset
|
48 #ifndef av_always_inline |
|
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) |
|
159
039198e96ee2
rename always_inline to av_always_inline and move to common.h
mru
parents:
158
diff
changeset
|
50 # define av_always_inline __attribute__((always_inline)) inline |
| 372 | 51 #else |
| 52 # define av_always_inline inline | |
| 53 #endif | |
| 54 #endif | |
| 55 | |
| 56 #ifndef av_noinline | |
|
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) |
| 246 | 58 # define av_noinline __attribute__((noinline)) |
|
159
039198e96ee2
rename always_inline to av_always_inline and move to common.h
mru
parents:
158
diff
changeset
|
59 #else |
| 246 | 60 # define av_noinline |
|
159
039198e96ee2
rename always_inline to av_always_inline and move to common.h
mru
parents:
158
diff
changeset
|
61 #endif |
|
039198e96ee2
rename always_inline to av_always_inline and move to common.h
mru
parents:
158
diff
changeset
|
62 #endif |
|
039198e96ee2
rename always_inline to av_always_inline and move to common.h
mru
parents:
158
diff
changeset
|
63 |
|
481
f4187c1c15a6
Reapply r12489: Add pure, const and malloc attributes to proper functions
zuxy
parents:
478
diff
changeset
|
64 #ifndef av_pure |
|
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(3,1) |
|
481
f4187c1c15a6
Reapply r12489: Add pure, const and malloc attributes to proper functions
zuxy
parents:
478
diff
changeset
|
66 # define av_pure __attribute__((pure)) |
|
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_pure |
|
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 |
|
f4187c1c15a6
Reapply r12489: Add pure, const and malloc attributes to proper functions
zuxy
parents:
478
diff
changeset
|
72 #ifndef av_const |
|
590
e9d89a89561a
Use AV_GCC_VERSION_AT_LEAST() to simplify gcc version checks.
cehoyos
parents:
580
diff
changeset
|
73 #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
|
74 # define av_const __attribute__((const)) |
|
f4187c1c15a6
Reapply r12489: Add pure, const and malloc attributes to proper functions
zuxy
parents:
478
diff
changeset
|
75 #else |
|
f4187c1c15a6
Reapply r12489: Add pure, const and malloc attributes to proper functions
zuxy
parents:
478
diff
changeset
|
76 # define av_const |
|
f4187c1c15a6
Reapply r12489: Add pure, const and malloc attributes to proper functions
zuxy
parents:
478
diff
changeset
|
77 #endif |
|
f4187c1c15a6
Reapply r12489: Add pure, const and malloc attributes to proper functions
zuxy
parents:
478
diff
changeset
|
78 #endif |
|
f4187c1c15a6
Reapply r12489: Add pure, const and malloc attributes to proper functions
zuxy
parents:
478
diff
changeset
|
79 |
|
486
2e4747b3d034
Apply 'cold' attribute to init/uninit functions in libavcodec
zuxy
parents:
481
diff
changeset
|
80 #ifndef av_cold |
|
742
1091b120412e
Icc 11.1 does not support attributes force_align_arg_pointer, alloc_size and cold.
cehoyos
parents:
735
diff
changeset
|
81 #if (!defined(__ICC) || __ICC > 1110) && AV_GCC_VERSION_AT_LEAST(4,3) |
|
486
2e4747b3d034
Apply 'cold' attribute to init/uninit functions in libavcodec
zuxy
parents:
481
diff
changeset
|
82 # define av_cold __attribute__((cold)) |
|
2e4747b3d034
Apply 'cold' attribute to init/uninit functions in libavcodec
zuxy
parents:
481
diff
changeset
|
83 #else |
|
2e4747b3d034
Apply 'cold' attribute to init/uninit functions in libavcodec
zuxy
parents:
481
diff
changeset
|
84 # define av_cold |
|
2e4747b3d034
Apply 'cold' attribute to init/uninit functions in libavcodec
zuxy
parents:
481
diff
changeset
|
85 #endif |
|
2e4747b3d034
Apply 'cold' attribute to init/uninit functions in libavcodec
zuxy
parents:
481
diff
changeset
|
86 #endif |
|
2e4747b3d034
Apply 'cold' attribute to init/uninit functions in libavcodec
zuxy
parents:
481
diff
changeset
|
87 |
|
662
1ed74ddc5e6b
av_flatten to make the similarly named attribute available.
michael
parents:
661
diff
changeset
|
88 #ifndef av_flatten |
|
743
56349e517f04
Icc does not support attribute flatten, do not try to use it.
cehoyos
parents:
742
diff
changeset
|
89 #if (!defined(__ICC) || __ICC > 1110) && AV_GCC_VERSION_AT_LEAST(4,1) |
|
662
1ed74ddc5e6b
av_flatten to make the similarly named attribute available.
michael
parents:
661
diff
changeset
|
90 # define av_flatten __attribute__((flatten)) |
|
1ed74ddc5e6b
av_flatten to make the similarly named attribute available.
michael
parents:
661
diff
changeset
|
91 #else |
|
1ed74ddc5e6b
av_flatten to make the similarly named attribute available.
michael
parents:
661
diff
changeset
|
92 # define av_flatten |
|
1ed74ddc5e6b
av_flatten to make the similarly named attribute available.
michael
parents:
661
diff
changeset
|
93 #endif |
|
1ed74ddc5e6b
av_flatten to make the similarly named attribute available.
michael
parents:
661
diff
changeset
|
94 #endif |
|
1ed74ddc5e6b
av_flatten to make the similarly named attribute available.
michael
parents:
661
diff
changeset
|
95 |
| 100 | 96 #ifndef attribute_deprecated |
|
590
e9d89a89561a
Use AV_GCC_VERSION_AT_LEAST() to simplify gcc version checks.
cehoyos
parents:
580
diff
changeset
|
97 #if AV_GCC_VERSION_AT_LEAST(3,1) |
| 100 | 98 # define attribute_deprecated __attribute__((deprecated)) |
| 99 #else | |
| 100 # define attribute_deprecated | |
| 101 #endif | |
| 102 #endif | |
| 103 | |
|
339
8829032777d5
rename attribute_unused to av_unused and moves its declaration to common.h
benoit
parents:
286
diff
changeset
|
104 #ifndef av_unused |
|
8829032777d5
rename attribute_unused to av_unused and moves its declaration to common.h
benoit
parents:
286
diff
changeset
|
105 #if defined(__GNUC__) |
|
8829032777d5
rename attribute_unused to av_unused and moves its declaration to common.h
benoit
parents:
286
diff
changeset
|
106 # define av_unused __attribute__((unused)) |
|
8829032777d5
rename attribute_unused to av_unused and moves its declaration to common.h
benoit
parents:
286
diff
changeset
|
107 #else |
|
8829032777d5
rename attribute_unused to av_unused and moves its declaration to common.h
benoit
parents:
286
diff
changeset
|
108 # define av_unused |
|
8829032777d5
rename attribute_unused to av_unused and moves its declaration to common.h
benoit
parents:
286
diff
changeset
|
109 #endif |
|
8829032777d5
rename attribute_unused to av_unused and moves its declaration to common.h
benoit
parents:
286
diff
changeset
|
110 #endif |
|
8829032777d5
rename attribute_unused to av_unused and moves its declaration to common.h
benoit
parents:
286
diff
changeset
|
111 |
|
661
ac3fc6cb4781
av_uninit() to suppress false uninitialized warnings from gcc without deoptimizing code.
michael
parents:
642
diff
changeset
|
112 #ifndef av_uninit |
| 664 | 113 #if defined(__GNUC__) && !defined(__ICC) |
|
661
ac3fc6cb4781
av_uninit() to suppress false uninitialized warnings from gcc without deoptimizing code.
michael
parents:
642
diff
changeset
|
114 # define av_uninit(x) x=x |
|
ac3fc6cb4781
av_uninit() to suppress false uninitialized warnings from gcc without deoptimizing code.
michael
parents:
642
diff
changeset
|
115 #else |
|
ac3fc6cb4781
av_uninit() to suppress false uninitialized warnings from gcc without deoptimizing code.
michael
parents:
642
diff
changeset
|
116 # define av_uninit(x) x |
|
ac3fc6cb4781
av_uninit() to suppress false uninitialized warnings from gcc without deoptimizing code.
michael
parents:
642
diff
changeset
|
117 #endif |
|
ac3fc6cb4781
av_uninit() to suppress false uninitialized warnings from gcc without deoptimizing code.
michael
parents:
642
diff
changeset
|
118 #endif |
|
ac3fc6cb4781
av_uninit() to suppress false uninitialized warnings from gcc without deoptimizing code.
michael
parents:
642
diff
changeset
|
119 |
| 807 | 120 #ifdef HAVE_AV_CONFIG_H |
| 121 # include "intmath.h" | |
| 122 #endif | |
| 123 | |
| 633 | 124 //rounded division & shift |
|
0
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
125 #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
|
126 /* assume b>0 */ |
|
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
127 #define ROUNDED_DIV(a,b) (((a)>0 ? (a) + ((b)>>1) : (a) - ((b)>>1))/(b)) |
| 120 | 128 #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
|
129 #define FFSIGN(a) ((a) > 0 ? 1 : -1) |
|
0
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
130 |
|
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
131 #define FFMAX(a,b) ((a) > (b) ? (a) : (b)) |
|
498
2ae1cc70b1c4
Implement FFMAX3(a,b,c) - maximum over three arguments.
voroshil
parents:
496
diff
changeset
|
132 #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
|
133 #define FFMIN(a,b) ((a) > (b) ? (b) : (a)) |
| 501 | 134 #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
|
135 |
| 126 | 136 #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
|
137 #define FF_ARRAY_ELEMS(a) (sizeof(a) / sizeof((a)[0])) |
|
735
92180cbccda6
Move ALIGN macro to libavutil/common.h and use it in various places
conrad
parents:
668
diff
changeset
|
138 #define FFALIGN(x, a) (((x)+(a)-1)&~((a)-1)) |
| 99 | 139 |
|
0
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
140 /* misc math functions */ |
| 157 | 141 extern const uint8_t ff_log2_tab[256]; |
|
0
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
142 |
|
784
fd7a78f003e7
Move ff_reverse in libavcodec to av_reverse in libavutil.
cehoyos
parents:
780
diff
changeset
|
143 extern const uint8_t av_reverse[256]; |
|
fd7a78f003e7
Move ff_reverse in libavcodec to av_reverse in libavutil.
cehoyos
parents:
780
diff
changeset
|
144 |
| 807 | 145 #ifndef av_log2 |
|
481
f4187c1c15a6
Reapply r12489: Add pure, const and malloc attributes to proper functions
zuxy
parents:
478
diff
changeset
|
146 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
|
147 { |
| 443 | 148 int n = 0; |
|
0
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
149 if (v & 0xffff0000) { |
|
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
150 v >>= 16; |
|
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
151 n += 16; |
|
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
152 } |
|
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
153 if (v & 0xff00) { |
|
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
154 v >>= 8; |
|
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
155 n += 8; |
|
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
156 } |
|
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
157 n += ff_log2_tab[v]; |
|
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
158 |
|
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
159 return n; |
|
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
160 } |
| 807 | 161 #endif |
|
0
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
162 |
| 807 | 163 #ifndef av_log2_16bit |
|
481
f4187c1c15a6
Reapply r12489: Add pure, const and malloc attributes to proper functions
zuxy
parents:
478
diff
changeset
|
164 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
|
165 { |
| 443 | 166 int n = 0; |
|
0
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
167 if (v & 0xff00) { |
|
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
168 v >>= 8; |
|
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
169 n += 8; |
|
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 n += ff_log2_tab[v]; |
|
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
172 |
|
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
173 return n; |
|
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
174 } |
| 807 | 175 #endif |
|
0
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
176 |
| 39 | 177 /** |
| 633 | 178 * Clips a signed integer value into the amin-amax range. |
| 39 | 179 * @param a value to clip |
| 180 * @param amin minimum value of the clip range | |
| 181 * @param amax maximum value of the clip range | |
| 151 | 182 * @return clipped value |
| 39 | 183 */ |
|
481
f4187c1c15a6
Reapply r12489: Add pure, const and malloc attributes to proper functions
zuxy
parents:
478
diff
changeset
|
184 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
|
185 { |
| 452 | 186 if (a < amin) return amin; |
| 63 | 187 else if (a > amax) return amax; |
| 188 else return a; | |
|
0
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
189 } |
|
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
190 |
| 39 | 191 /** |
| 633 | 192 * Clips a signed integer value into the 0-255 range. |
| 39 | 193 * @param a value to clip |
| 151 | 194 * @return clipped value |
| 39 | 195 */ |
|
481
f4187c1c15a6
Reapply r12489: Add pure, const and malloc attributes to proper functions
zuxy
parents:
478
diff
changeset
|
196 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
|
197 { |
|
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
198 if (a&(~255)) return (-a)>>31; |
|
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
199 else return a; |
|
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
200 } |
|
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
201 |
| 373 | 202 /** |
| 764 | 203 * Clips a signed integer value into the 0-65535 range. |
| 204 * @param a value to clip | |
| 205 * @return clipped value | |
| 206 */ | |
| 207 static inline av_const uint16_t av_clip_uint16(int a) | |
| 208 { | |
| 209 if (a&(~65535)) return (-a)>>31; | |
| 210 else return a; | |
| 211 } | |
| 212 | |
| 213 /** | |
| 633 | 214 * Clips a signed integer value into the -32768,32767 range. |
| 373 | 215 * @param a value to clip |
| 216 * @return clipped value | |
| 217 */ | |
|
481
f4187c1c15a6
Reapply r12489: Add pure, const and malloc attributes to proper functions
zuxy
parents:
478
diff
changeset
|
218 static inline av_const int16_t av_clip_int16(int a) |
| 373 | 219 { |
| 220 if ((a+32768) & ~65535) return (a>>31) ^ 32767; | |
| 221 else return a; | |
| 222 } | |
| 223 | |
|
519
5cdb952bd09a
Add av_clipf() function to common.h and use it in ra288.c
vitor
parents:
516
diff
changeset
|
224 /** |
| 633 | 225 * 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
|
226 * @param a value to clip |
|
5cdb952bd09a
Add av_clipf() function to common.h and use it in ra288.c
vitor
parents:
516
diff
changeset
|
227 * @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
|
228 * @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
|
229 * @return clipped value |
|
5cdb952bd09a
Add av_clipf() function to common.h and use it in ra288.c
vitor
parents:
516
diff
changeset
|
230 */ |
|
5cdb952bd09a
Add av_clipf() function to common.h and use it in ra288.c
vitor
parents:
516
diff
changeset
|
231 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
|
232 { |
|
5cdb952bd09a
Add av_clipf() function to common.h and use it in ra288.c
vitor
parents:
516
diff
changeset
|
233 if (a < amin) return amin; |
|
5cdb952bd09a
Add av_clipf() function to common.h and use it in ra288.c
vitor
parents:
516
diff
changeset
|
234 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
|
235 else return a; |
|
5cdb952bd09a
Add av_clipf() function to common.h and use it in ra288.c
vitor
parents:
516
diff
changeset
|
236 } |
|
5cdb952bd09a
Add av_clipf() function to common.h and use it in ra288.c
vitor
parents:
516
diff
changeset
|
237 |
| 773 | 238 /** Computes ceil(log2(x)). |
| 239 * @param x value used to compute ceil(log2(x)) | |
| 240 * @return computed ceiling of log2(x) | |
| 241 */ | |
| 242 static inline av_const int av_ceil_log2(int x) | |
| 243 { | |
| 244 return av_log2((x - 1) << 1); | |
| 245 } | |
| 246 | |
|
0
ee8f44bb7c4d
libavutil: Utility code from libavcodec moved to a separate library.
al
parents:
diff
changeset
|
247 #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
|
248 #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
|
249 |
| 132 | 250 /*! |
| 251 * \def GET_UTF8(val, GET_BYTE, ERROR) | |
| 633 | 252 * Converts a UTF-8 character (up to 4 bytes long) to its 32-bit UCS-4 encoded form |
| 132 | 253 * \param val is the output and should be of type uint32_t. It holds the converted |
| 341 | 254 * UCS-4 character and should be a left value. |
| 255 * \param GET_BYTE gets UTF-8 encoded bytes from any proper source. It can be | |
| 132 | 256 * a function or a statement whose return value or evaluated value is of type |
| 341 | 257 * 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
|
258 * and up to 7 times in the general case. |
| 341 | 259 * \param ERROR action that should be taken when an invalid UTF-8 byte is returned |
| 132 | 260 * from GET_BYTE. It should be a statement that jumps out of the macro, |
| 261 * like exit(), goto, return, break, or continue. | |
| 262 */ | |
| 130 | 263 #define GET_UTF8(val, GET_BYTE, ERROR)\ |
| 264 val= GET_BYTE;\ | |
| 265 {\ | |
| 266 int ones= 7 - av_log2(val ^ 255);\ | |
| 267 if(ones==1)\ | |
| 268 ERROR\ | |
| 269 val&= 127>>ones;\ | |
| 270 while(--ones > 0){\ | |
| 271 int tmp= GET_BYTE - 128;\ | |
| 272 if(tmp>>6)\ | |
| 273 ERROR\ | |
| 274 val= (val<<6) + tmp;\ | |
| 275 }\ | |
| 276 } | |
| 277 | |
|
129
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
278 /*! |
| 780 | 279 * \def GET_UTF16(val, GET_16BIT, ERROR) |
| 280 * Converts a UTF-16 character (2 or 4 bytes) to its 32-bit UCS-4 encoded form | |
| 281 * \param val is the output and should be of type uint32_t. It holds the converted | |
| 282 * UCS-4 character and should be a left value. | |
| 283 * \param GET_16BIT gets two bytes of UTF-16 encoded data converted to native endianness. | |
| 284 * It can be a function or a statement whose return value or evaluated value is of type | |
| 285 * uint16_t. It will be executed up to 2 times. | |
| 286 * \param ERROR action that should be taken when an invalid UTF-16 surrogate is | |
| 287 * returned from GET_BYTE. It should be a statement that jumps out of the macro, | |
| 288 * like exit(), goto, return, break, or continue. | |
| 289 */ | |
| 290 #define GET_UTF16(val, GET_16BIT, ERROR)\ | |
| 291 val = GET_16BIT;\ | |
| 292 {\ | |
| 293 unsigned int hi = val - 0xD800;\ | |
| 294 if (hi < 0x800) {\ | |
| 295 val = GET_16BIT - 0xDC00;\ | |
| 296 if (val > 0x3FFU || hi > 0x3FFU)\ | |
| 297 ERROR\ | |
| 298 val += (hi<<10) + 0x10000;\ | |
| 299 }\ | |
| 300 }\ | |
| 301 | |
| 302 /*! | |
| 131 | 303 * \def PUT_UTF8(val, tmp, PUT_BYTE) |
| 633 | 304 * Converts a 32-bit Unicode character to its UTF-8 encoded form (up to 4 bytes long). |
| 305 * \param val is an input-only argument and should be of type uint32_t. It holds | |
| 306 * a UCS-4 encoded Unicode character that is to be converted to UTF-8. If | |
| 307 * 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
|
308 * \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
|
309 * represents an intermediate value during conversion that is to be |
| 633 | 310 * output by PUT_BYTE. |
| 341 | 311 * \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
|
312 * 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
|
313 * For example, PUT_BYTE could be "*output++ = tmp;" PUT_BYTE will be |
| 341 | 314 * 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
|
315 * 7 times in the general case, depending on the length of the converted |
| 633 | 316 * Unicode character. |
|
129
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
317 */ |
|
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
318 #define PUT_UTF8(val, tmp, PUT_BYTE)\ |
|
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
319 {\ |
|
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
320 int bytes, shift;\ |
|
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
321 uint32_t in = val;\ |
|
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
322 if (in < 0x80) {\ |
|
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
323 tmp = in;\ |
|
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
324 PUT_BYTE\ |
|
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
325 } else {\ |
|
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
326 bytes = (av_log2(in) + 4) / 5;\ |
|
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
327 shift = (bytes - 1) * 6;\ |
|
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
328 tmp = (256 - (256 >> bytes)) | (in >> shift);\ |
|
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
329 PUT_BYTE\ |
|
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
330 while (shift >= 6) {\ |
|
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
331 shift -= 6;\ |
|
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
332 tmp = 0x80 | ((in >> shift) & 0x3f);\ |
|
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
333 PUT_BYTE\ |
|
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
334 }\ |
|
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
335 }\ |
|
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
336 } |
|
ccae53673692
Fix ASF format parser's broken UTF-16 string handling
gpoirier
parents:
127
diff
changeset
|
337 |
| 848 | 338 /*! |
| 339 * \def PUT_UTF16(val, tmp, PUT_16BIT) | |
| 340 * Converts a 32-bit Unicode character to its UTF-16 encoded form (2 or 4 bytes). | |
| 341 * \param val is an input-only argument and should be of type uint32_t. It holds | |
| 342 * a UCS-4 encoded Unicode character that is to be converted to UTF-16. If | |
| 343 * val is given as a function it is executed only once. | |
| 344 * \param tmp is a temporary variable and should be of type uint16_t. It | |
| 345 * represents an intermediate value during conversion that is to be | |
| 346 * output by PUT_16BIT. | |
| 347 * \param PUT_16BIT writes the converted UTF-16 data to any proper destination | |
| 348 * in desired endianness. It could be a function or a statement, and uses tmp | |
| 349 * as the input byte. For example, PUT_BYTE could be "*output++ = tmp;" | |
| 350 * PUT_BYTE will be executed 1 or 2 times depending on input character. | |
| 351 */ | |
| 352 #define PUT_UTF16(val, tmp, PUT_16BIT)\ | |
| 353 {\ | |
| 354 uint32_t in = val;\ | |
| 355 if (in < 0x10000) {\ | |
| 356 tmp = in;\ | |
| 357 PUT_16BIT\ | |
| 358 } else {\ | |
| 359 tmp = 0xD800 | ((in - 0x10000) >> 10);\ | |
| 360 PUT_16BIT\ | |
| 361 tmp = 0xDC00 | ((in - 0x10000) & 0x3FF);\ | |
| 362 PUT_16BIT\ | |
| 363 }\ | |
| 364 }\ | |
| 365 | |
| 366 | |
| 367 | |
|
630
fb04e2fc189c
Reorganize header #includes: Unconditionally #include standard C headers,
diego
parents:
619
diff
changeset
|
368 #include "mem.h" |
|
fb04e2fc189c
Reorganize header #includes: Unconditionally #include standard C headers,
diego
parents:
619
diff
changeset
|
369 |
|
619
c309f86c05a2
Move internal.h #include to the end of the file so that it is after
diego
parents:
610
diff
changeset
|
370 #ifdef 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
|
371 # include "internal.h" |
|
c309f86c05a2
Move internal.h #include to the end of the file so that it is after
diego
parents:
610
diff
changeset
|
372 #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
|
373 |
| 567 | 374 #endif /* AVUTIL_COMMON_H */ |
