Browse code

Move avutil tables only used in libavcodec to libavcodec.

Diego Biurrun authored on 2012/10/11 08:16:05
Showing 15 changed files
... ...
@@ -22,6 +22,7 @@ OBJS = allcodecs.o                                                      \
22 22
        fmtconvert.o                                                     \
23 23
        imgconvert.o                                                     \
24 24
        jrevdct.o                                                        \
25
+       mathtables.o                                                     \
25 26
        options.o                                                        \
26 27
        parser.o                                                         \
27 28
        raw.o                                                            \
... ...
@@ -655,12 +656,6 @@ OBJS-$(CONFIG_TEXT2MOVSUB_BSF)            += movsub_bsf.o
655 655
 OBJS-$(HAVE_PTHREADS)                  += pthread.o
656 656
 OBJS-$(HAVE_W32THREADS)                += pthread.o
657 657
 
658
-# inverse.o contains the ff_inverse table definition, which is used by
659
-# the FASTDIV macro (from libavutil); since referencing the external
660
-# table has a negative effect on performance, copy it in libavcodec as
661
-# well.
662
-OBJS-$(!CONFIG_SMALL)                  += inverse.o
663
-
664 658
 SKIPHEADERS                            += %_tablegen.h                  \
665 659
                                           %_tables.h                    \
666 660
                                           aac_tablegen_decl.h           \
... ...
@@ -36,6 +36,30 @@ static inline av_const int MULH(int a, int b)
36 36
     __asm__ ("smmul %0, %1, %2" : "=r"(r) : "r"(a), "r"(b));
37 37
     return r;
38 38
 }
39
+
40
+#define FASTDIV FASTDIV
41
+static av_always_inline av_const int FASTDIV(int a, int b)
42
+{
43
+    int r;
44
+    __asm__ ("cmp     %2, #2               \n\t"
45
+             "ldr     %0, [%3, %2, lsl #2] \n\t"
46
+             "ite     le                   \n\t"
47
+             "lsrle   %0, %1, #1           \n\t"
48
+             "smmulgt %0, %0, %1           \n\t"
49
+             : "=&r"(r) : "r"(a), "r"(b), "r"(ff_inverse) : "cc");
50
+    return r;
51
+}
52
+
53
+#else /* HAVE_ARMV6 */
54
+
55
+#define FASTDIV FASTDIV
56
+static av_always_inline av_const int FASTDIV(int a, int b)
57
+{
58
+    int r, t;
59
+    __asm__ ("umull %1, %0, %2, %3"
60
+             : "=&r"(r), "=&r"(t) : "r"(a), "r"(ff_inverse[b]));
61
+    return r;
62
+}
39 63
 #endif
40 64
 
41 65
 #define MLS64(d, a, b) MAC64(d, -(a), b)
42 66
deleted file mode 100644
... ...
@@ -1 +0,0 @@
1
-#include "libavutil/inverse.c"
... ...
@@ -22,9 +22,14 @@
22 22
 #ifndef AVCODEC_MATHOPS_H
23 23
 #define AVCODEC_MATHOPS_H
24 24
 
25
+#include <stdint.h>
26
+
25 27
 #include "libavutil/common.h"
26 28
 #include "config.h"
27 29
 
30
+extern const uint32_t ff_inverse[257];
31
+extern const uint8_t ff_sqrt_tab[256];
32
+
28 33
 #if   ARCH_ARM
29 34
 #   include "arm/mathops.h"
30 35
 #elif ARCH_AVR32
... ...
@@ -185,4 +190,28 @@ if ((y) < (x)) {\
185 185
 #   define PACK_2S16(a,b)    PACK_2U16((a)&0xffff, (b)&0xffff)
186 186
 #endif
187 187
 
188
+#ifndef FASTDIV
189
+#   define FASTDIV(a,b) ((uint32_t)((((uint64_t)a) * ff_inverse[b]) >> 32))
190
+#endif /* FASTDIV */
191
+
192
+static inline av_const unsigned int ff_sqrt(unsigned int a)
193
+{
194
+    unsigned int b;
195
+
196
+    if (a < 255) return (ff_sqrt_tab[a + 1] - 1) >> 4;
197
+    else if (a < (1 << 12)) b = ff_sqrt_tab[a >> 4] >> 2;
198
+#if !CONFIG_SMALL
199
+    else if (a < (1 << 14)) b = ff_sqrt_tab[a >> 6] >> 1;
200
+    else if (a < (1 << 16)) b = ff_sqrt_tab[a >> 8]   ;
201
+#endif
202
+    else {
203
+        int s = av_log2_16bit(a >> 16) >> 1;
204
+        unsigned int c = a >> (s + 2);
205
+        b = ff_sqrt_tab[c >> (s + 8)];
206
+        b = FASTDIV(c,b) + (b << s);
207
+    }
208
+
209
+    return b - (a < b * b);
210
+}
211
+
188 212
 #endif /* AVCODEC_MATHOPS_H */
189 213
new file mode 100644
... ...
@@ -0,0 +1,68 @@
0
+/*
1
+ * This file is part of Libav.
2
+ *
3
+ * Libav is free software; you can redistribute it and/or
4
+ * modify it under the terms of the GNU Lesser General Public
5
+ * License as published by the Free Software Foundation; either
6
+ * version 2.1 of the License, or (at your option) any later version.
7
+ *
8
+ * Libav is distributed in the hope that it will be useful,
9
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
10
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
11
+ * Lesser General Public License for more details.
12
+ *
13
+ * You should have received a copy of the GNU Lesser General Public
14
+ * License along with Libav; if not, write to the Free Software
15
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
16
+ */
17
+
18
+#include <stdint.h>
19
+
20
+/* a*inverse[b]>>32 == a/b for all 0<=a<=16909558 && 2<=b<=256
21
+ * for a>16909558, is an overestimate by less than 1 part in 1<<24 */
22
+const uint32_t ff_inverse[257]={
23
+         0, 4294967295U,2147483648U,1431655766, 1073741824,  858993460,  715827883,  613566757,
24
+ 536870912,  477218589,  429496730,  390451573,  357913942,  330382100,  306783379,  286331154,
25
+ 268435456,  252645136,  238609295,  226050911,  214748365,  204522253,  195225787,  186737709,
26
+ 178956971,  171798692,  165191050,  159072863,  153391690,  148102321,  143165577,  138547333,
27
+ 134217728,  130150525,  126322568,  122713352,  119304648,  116080198,  113025456,  110127367,
28
+ 107374183,  104755300,  102261127,   99882961,   97612894,   95443718,   93368855,   91382283,
29
+  89478486,   87652394,   85899346,   84215046,   82595525,   81037119,   79536432,   78090315,
30
+  76695845,   75350304,   74051161,   72796056,   71582789,   70409300,   69273667,   68174085,
31
+  67108864,   66076420,   65075263,   64103990,   63161284,   62245903,   61356676,   60492498,
32
+  59652324,   58835169,   58040099,   57266231,   56512728,   55778797,   55063684,   54366675,
33
+  53687092,   53024288,   52377650,   51746594,   51130564,   50529028,   49941481,   49367441,
34
+  48806447,   48258060,   47721859,   47197443,   46684428,   46182445,   45691142,   45210183,
35
+  44739243,   44278014,   43826197,   43383509,   42949673,   42524429,   42107523,   41698712,
36
+  41297763,   40904451,   40518560,   40139882,   39768216,   39403370,   39045158,   38693400,
37
+  38347923,   38008561,   37675152,   37347542,   37025581,   36709123,   36398028,   36092163,
38
+  35791395,   35495598,   35204650,   34918434,   34636834,   34359739,   34087043,   33818641,
39
+  33554432,   33294321,   33038210,   32786010,   32537632,   32292988,   32051995,   31814573,
40
+  31580642,   31350127,   31122952,   30899046,   30678338,   30460761,   30246249,   30034737,
41
+  29826162,   29620465,   29417585,   29217465,   29020050,   28825284,   28633116,   28443493,
42
+  28256364,   28071682,   27889399,   27709467,   27531842,   27356480,   27183338,   27012373,
43
+  26843546,   26676816,   26512144,   26349493,   26188825,   26030105,   25873297,   25718368,
44
+  25565282,   25414008,   25264514,   25116768,   24970741,   24826401,   24683721,   24542671,
45
+  24403224,   24265352,   24129030,   23994231,   23860930,   23729102,   23598722,   23469767,
46
+  23342214,   23216040,   23091223,   22967740,   22845571,   22724695,   22605092,   22486740,
47
+  22369622,   22253717,   22139007,   22025474,   21913099,   21801865,   21691755,   21582751,
48
+  21474837,   21367997,   21262215,   21157475,   21053762,   20951060,   20849356,   20748635,
49
+  20648882,   20550083,   20452226,   20355296,   20259280,   20164166,   20069941,   19976593,
50
+  19884108,   19792477,   19701685,   19611723,   19522579,   19434242,   19346700,   19259944,
51
+  19173962,   19088744,   19004281,   18920561,   18837576,   18755316,   18673771,   18592933,
52
+  18512791,   18433337,   18354562,   18276457,   18199014,   18122225,   18046082,   17970575,
53
+  17895698,   17821442,   17747799,   17674763,   17602325,   17530479,   17459217,   17388532,
54
+  17318417,   17248865,   17179870,   17111424,   17043522,   16976156,   16909321,   16843010,
55
+  16777216
56
+};
57
+
58
+const uint8_t ff_sqrt_tab[256]={
59
+  0, 16, 23, 28, 32, 36, 40, 43, 46, 48, 51, 54, 56, 58, 60, 62, 64, 66, 68, 70, 72, 74, 76, 77, 79, 80, 82, 84, 85, 87, 88, 90,
60
+ 91, 92, 94, 95, 96, 98, 99,100,102,103,104,105,107,108,109,110,111,112,114,115,116,117,118,119,120,121,122,123,124,125,126,127,
61
+128,129,130,131,132,133,134,135,136,137,138,139,140,141,142,143,144,144,145,146,147,148,149,150,151,151,152,153,154,155,156,156,
62
+157,158,159,160,160,161,162,163,164,164,165,166,167,168,168,169,170,171,171,172,173,174,174,175,176,176,177,178,179,179,180,181,
63
+182,182,183,184,184,185,186,186,187,188,188,189,190,190,191,192,192,193,194,194,195,196,196,197,198,198,199,200,200,201,202,202,
64
+203,204,204,205,205,206,207,207,208,208,209,210,210,211,212,212,213,213,214,215,215,216,216,217,218,218,219,219,220,220,221,222,
65
+222,223,223,224,224,225,226,226,227,227,228,228,229,230,230,231,231,232,232,233,233,234,235,235,236,236,237,237,238,238,239,239,
66
+240,240,241,242,242,243,243,244,244,245,245,246,246,247,247,248,248,249,249,250,250,251,251,252,252,253,253,254,254,255,255,255
67
+};
... ...
@@ -30,7 +30,7 @@
30 30
 #include <stdlib.h>
31 31
 #include <stdio.h>
32 32
 #include <limits.h>
33
-#include "libavutil/intmath.h"
33
+
34 34
 #include "avcodec.h"
35 35
 #include "dsputil.h"
36 36
 #include "mathops.h"
... ...
@@ -27,11 +27,11 @@
27 27
  * The simplest mpeg encoder (well, it was the simplest!).
28 28
  */
29 29
 
30
-#include "libavutil/intmath.h"
31 30
 #include "libavutil/imgutils.h"
32 31
 #include "avcodec.h"
33 32
 #include "dsputil.h"
34 33
 #include "internal.h"
34
+#include "mathops.h"
35 35
 #include "mpegvideo.h"
36 36
 #include "mjpegenc.h"
37 37
 #include "msmpeg4.h"
... ...
@@ -34,6 +34,7 @@
34 34
 #include "dsputil.h"
35 35
 #include "mpegvideo.h"
36 36
 #include "h263.h"
37
+#include "mathops.h"
37 38
 #include "mjpegenc.h"
38 39
 #include "msmpeg4.h"
39 40
 #include "faandct.h"
... ...
@@ -22,8 +22,8 @@
22 22
 #include <stdint.h>
23 23
 #include "avcodec.h"
24 24
 #include "celp_filters.h"
25
+#include "mathops.h"
25 26
 #include "ra144.h"
26
-#include "libavutil/common.h"
27 27
 
28 28
 const int16_t ff_gain_val_tab[256][3] = {
29 29
     { 541, 956,  768}, { 877, 581,  568}, { 675,1574,  635}, {1248,1464,  668},
... ...
@@ -21,10 +21,10 @@
21 21
  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
22 22
  */
23 23
 
24
-#include "libavutil/intmath.h"
25 24
 #include "avcodec.h"
26 25
 #include "bytestream.h"
27 26
 #include "internal.h"
27
+#include "mathops.h"
28 28
 
29 29
 #define ROQ_FRAME_SIZE           735
30 30
 #define ROQ_HEADER_SIZE   8
... ...
@@ -66,7 +66,6 @@ OBJS = adler32.o                                                        \
66 66
        float_dsp.o                                                      \
67 67
        imgutils.o                                                       \
68 68
        intfloat_readwrite.o                                             \
69
-       inverse.o                                                        \
70 69
        lfg.o                                                            \
71 70
        lls.o                                                            \
72 71
        log.o                                                            \
... ...
@@ -30,19 +30,6 @@
30 30
 
31 31
 #if HAVE_ARMV6
32 32
 
33
-#define FASTDIV FASTDIV
34
-static av_always_inline av_const int FASTDIV(int a, int b)
35
-{
36
-    int r;
37
-    __asm__ ("cmp     %2, #2               \n\t"
38
-             "ldr     %0, [%3, %2, lsl #2] \n\t"
39
-             "ite     le                   \n\t"
40
-             "lsrle   %0, %1, #1           \n\t"
41
-             "smmulgt %0, %0, %1           \n\t"
42
-             : "=&r"(r) : "r"(a), "r"(b), "r"(ff_inverse) : "cc");
43
-    return r;
44
-}
45
-
46 33
 #define av_clip_uint8 av_clip_uint8_arm
47 34
 static av_always_inline av_const unsigned av_clip_uint8_arm(int a)
48 35
 {
... ...
@@ -99,17 +86,6 @@ static av_always_inline int av_sat_dadd32_arm(int a, int b)
99 99
     return r;
100 100
 }
101 101
 
102
-#else /* HAVE_ARMV6 */
103
-
104
-#define FASTDIV FASTDIV
105
-static av_always_inline av_const int FASTDIV(int a, int b)
106
-{
107
-    int r, t;
108
-    __asm__ ("umull %1, %0, %2, %3"
109
-             : "=&r"(r), "=&r"(t) : "r"(a), "r"(ff_inverse[b]));
110
-    return r;
111
-}
112
-
113 102
 #endif /* HAVE_ARMV6 */
114 103
 
115 104
 #if HAVE_ASM_MOD_Q
... ...
@@ -21,7 +21,6 @@
21 21
 #ifndef AVUTIL_INTMATH_H
22 22
 #define AVUTIL_INTMATH_H
23 23
 
24
-#include <stdint.h>
25 24
 #include "config.h"
26 25
 #include "attributes.h"
27 26
 
... ...
@@ -30,12 +29,6 @@
30 30
  * @{
31 31
  */
32 32
 
33
-extern const uint32_t ff_inverse[257];
34
-
35
-#if   ARCH_ARM
36
-#   include "arm/intmath.h"
37
-#endif
38
-
39 33
 #if HAVE_FAST_CLZ && AV_GCC_VERSION_AT_LEAST(3,4)
40 34
 
41 35
 #ifndef av_log2
... ...
@@ -47,34 +40,6 @@ extern const uint32_t ff_inverse[257];
47 47
 
48 48
 #endif /* AV_GCC_VERSION_AT_LEAST(3,4) */
49 49
 
50
-#ifndef FASTDIV
51
-#   define FASTDIV(a,b) ((uint32_t)((((uint64_t)a) * ff_inverse[b]) >> 32))
52
-#endif /* FASTDIV */
53
-
54
-#include "common.h"
55
-
56
-extern const uint8_t ff_sqrt_tab[256];
57
-
58
-static inline av_const unsigned int ff_sqrt(unsigned int a)
59
-{
60
-    unsigned int b;
61
-
62
-    if (a < 255) return (ff_sqrt_tab[a + 1] - 1) >> 4;
63
-    else if (a < (1 << 12)) b = ff_sqrt_tab[a >> 4] >> 2;
64
-#if !CONFIG_SMALL
65
-    else if (a < (1 << 14)) b = ff_sqrt_tab[a >> 6] >> 1;
66
-    else if (a < (1 << 16)) b = ff_sqrt_tab[a >> 8]   ;
67
-#endif
68
-    else {
69
-        int s = av_log2_16bit(a >> 16) >> 1;
70
-        unsigned int c = a >> (s + 2);
71
-        b = ff_sqrt_tab[c >> (s + 8)];
72
-        b = FASTDIV(c,b) + (b << s);
73
-    }
74
-
75
-    return b - (a < b * b);
76
-}
77
-
78 50
 /**
79 51
  * @}
80 52
  */
81 53
deleted file mode 100644
... ...
@@ -1,60 +0,0 @@
1
-/*
2
- * Inverse table
3
- * Copyright (c) 2002-2004 Michael Niedermayer <michaelni@gmx.at>
4
- *
5
- * This file is part of Libav.
6
- *
7
- * Libav is free software; you can redistribute it and/or
8
- * modify it under the terms of the GNU Lesser General Public
9
- * License as published by the Free Software Foundation; either
10
- * version 2.1 of the License, or (at your option) any later version.
11
- *
12
- * Libav is distributed in the hope that it will be useful,
13
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
14
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
15
- * Lesser General Public License for more details.
16
- *
17
- * You should have received a copy of the GNU Lesser General Public
18
- * License along with Libav; if not, write to the Free Software
19
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20
- */
21
-
22
-#include <stdint.h>
23
-
24
-/* a*inverse[b]>>32 == a/b for all 0<=a<=16909558 && 2<=b<=256
25
- * for a>16909558, is an overestimate by less than 1 part in 1<<24 */
26
-const uint32_t ff_inverse[257]={
27
-         0, 4294967295U,2147483648U,1431655766, 1073741824,  858993460,  715827883,  613566757,
28
- 536870912,  477218589,  429496730,  390451573,  357913942,  330382100,  306783379,  286331154,
29
- 268435456,  252645136,  238609295,  226050911,  214748365,  204522253,  195225787,  186737709,
30
- 178956971,  171798692,  165191050,  159072863,  153391690,  148102321,  143165577,  138547333,
31
- 134217728,  130150525,  126322568,  122713352,  119304648,  116080198,  113025456,  110127367,
32
- 107374183,  104755300,  102261127,   99882961,   97612894,   95443718,   93368855,   91382283,
33
-  89478486,   87652394,   85899346,   84215046,   82595525,   81037119,   79536432,   78090315,
34
-  76695845,   75350304,   74051161,   72796056,   71582789,   70409300,   69273667,   68174085,
35
-  67108864,   66076420,   65075263,   64103990,   63161284,   62245903,   61356676,   60492498,
36
-  59652324,   58835169,   58040099,   57266231,   56512728,   55778797,   55063684,   54366675,
37
-  53687092,   53024288,   52377650,   51746594,   51130564,   50529028,   49941481,   49367441,
38
-  48806447,   48258060,   47721859,   47197443,   46684428,   46182445,   45691142,   45210183,
39
-  44739243,   44278014,   43826197,   43383509,   42949673,   42524429,   42107523,   41698712,
40
-  41297763,   40904451,   40518560,   40139882,   39768216,   39403370,   39045158,   38693400,
41
-  38347923,   38008561,   37675152,   37347542,   37025581,   36709123,   36398028,   36092163,
42
-  35791395,   35495598,   35204650,   34918434,   34636834,   34359739,   34087043,   33818641,
43
-  33554432,   33294321,   33038210,   32786010,   32537632,   32292988,   32051995,   31814573,
44
-  31580642,   31350127,   31122952,   30899046,   30678338,   30460761,   30246249,   30034737,
45
-  29826162,   29620465,   29417585,   29217465,   29020050,   28825284,   28633116,   28443493,
46
-  28256364,   28071682,   27889399,   27709467,   27531842,   27356480,   27183338,   27012373,
47
-  26843546,   26676816,   26512144,   26349493,   26188825,   26030105,   25873297,   25718368,
48
-  25565282,   25414008,   25264514,   25116768,   24970741,   24826401,   24683721,   24542671,
49
-  24403224,   24265352,   24129030,   23994231,   23860930,   23729102,   23598722,   23469767,
50
-  23342214,   23216040,   23091223,   22967740,   22845571,   22724695,   22605092,   22486740,
51
-  22369622,   22253717,   22139007,   22025474,   21913099,   21801865,   21691755,   21582751,
52
-  21474837,   21367997,   21262215,   21157475,   21053762,   20951060,   20849356,   20748635,
53
-  20648882,   20550083,   20452226,   20355296,   20259280,   20164166,   20069941,   19976593,
54
-  19884108,   19792477,   19701685,   19611723,   19522579,   19434242,   19346700,   19259944,
55
-  19173962,   19088744,   19004281,   18920561,   18837576,   18755316,   18673771,   18592933,
56
-  18512791,   18433337,   18354562,   18276457,   18199014,   18122225,   18046082,   17970575,
57
-  17895698,   17821442,   17747799,   17674763,   17602325,   17530479,   17459217,   17388532,
58
-  17318417,   17248865,   17179870,   17111424,   17043522,   16976156,   16909321,   16843010,
59
-  16777216
60
-};
... ...
@@ -28,17 +28,6 @@
28 28
 #include <limits.h>
29 29
 #include "mathematics.h"
30 30
 
31
-const uint8_t ff_sqrt_tab[256]={
32
-  0, 16, 23, 28, 32, 36, 40, 43, 46, 48, 51, 54, 56, 58, 60, 62, 64, 66, 68, 70, 72, 74, 76, 77, 79, 80, 82, 84, 85, 87, 88, 90,
33
- 91, 92, 94, 95, 96, 98, 99,100,102,103,104,105,107,108,109,110,111,112,114,115,116,117,118,119,120,121,122,123,124,125,126,127,
34
-128,129,130,131,132,133,134,135,136,137,138,139,140,141,142,143,144,144,145,146,147,148,149,150,151,151,152,153,154,155,156,156,
35
-157,158,159,160,160,161,162,163,164,164,165,166,167,168,168,169,170,171,171,172,173,174,174,175,176,176,177,178,179,179,180,181,
36
-182,182,183,184,184,185,186,186,187,188,188,189,190,190,191,192,192,193,194,194,195,196,196,197,198,198,199,200,200,201,202,202,
37
-203,204,204,205,205,206,207,207,208,208,209,210,210,211,212,212,213,213,214,215,215,216,216,217,218,218,219,219,220,220,221,222,
38
-222,223,223,224,224,225,226,226,227,227,228,228,229,230,230,231,231,232,232,233,233,234,235,235,236,236,237,237,238,238,239,239,
39
-240,240,241,242,242,243,243,244,244,245,245,246,246,247,247,248,248,249,249,250,250,251,251,252,252,253,253,254,254,255,255,255
40
-};
41
-
42 31
 const uint8_t ff_log2_tab[256]={
43 32
         0,0,1,1,2,2,2,2,3,3,3,3,3,3,3,3,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,
44 33
         5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,