Browse code

Alpha: move dsputil prototypes to a header file

Originally committed as revision 22308 to svn://svn.ffmpeg.org/ffmpeg/trunk

Måns Rullgård authored on 2010/03/08 11:36:03
Showing 4 changed files
... ...
@@ -20,33 +20,14 @@
20 20
  */
21 21
 
22 22
 #include "libavcodec/dsputil.h"
23
+#include "dsputil_alpha.h"
23 24
 #include "asm.h"
24 25
 
25
-void ff_simple_idct_axp(DCTELEM *block);
26
-void ff_simple_idct_put_axp(uint8_t *dest, int line_size, DCTELEM *block);
27
-void ff_simple_idct_add_axp(uint8_t *dest, int line_size, DCTELEM *block);
28
-
29
-void put_pixels_axp_asm(uint8_t *block, const uint8_t *pixels,
30
-                        int line_size, int h);
31
-void put_pixels_clamped_mvi_asm(const DCTELEM *block, uint8_t *pixels,
32
-                                int line_size);
33
-void add_pixels_clamped_mvi_asm(const DCTELEM *block, uint8_t *pixels,
34
-                                int line_size);
35 26
 void (*put_pixels_clamped_axp_p)(const DCTELEM *block, uint8_t *pixels,
36 27
                                  int line_size);
37 28
 void (*add_pixels_clamped_axp_p)(const DCTELEM *block, uint8_t *pixels,
38 29
                                  int line_size);
39 30
 
40
-void get_pixels_mvi(DCTELEM *restrict block,
41
-                    const uint8_t *restrict pixels, int line_size);
42
-void diff_pixels_mvi(DCTELEM *block, const uint8_t *s1, const uint8_t *s2,
43
-                     int stride);
44
-int pix_abs8x8_mvi(void *v, uint8_t *pix1, uint8_t *pix2, int line_size, int h);
45
-int pix_abs16x16_mvi_asm(void *v, uint8_t *pix1, uint8_t *pix2, int line_size, int h);
46
-int pix_abs16x16_x2_mvi(void *v, uint8_t *pix1, uint8_t *pix2, int line_size, int h);
47
-int pix_abs16x16_y2_mvi(void *v, uint8_t *pix1, uint8_t *pix2, int line_size, int h);
48
-int pix_abs16x16_xy2_mvi(void *v, uint8_t *pix1, uint8_t *pix2, int line_size, int h);
49
-
50 31
 #if 0
51 32
 /* These functions were the base for the optimized assembler routines,
52 33
    and remain here for documentation purposes.  */
... ...
@@ -280,8 +261,8 @@ PIXOP(put_no_rnd, STORE);
280 280
 #define STORE(l, b) stq(AVG2(l, ldq(b)), b);
281 281
 PIXOP(avg_no_rnd, STORE);
282 282
 
283
-void put_pixels16_axp_asm(uint8_t *block, const uint8_t *pixels,
284
-                          int line_size, int h)
283
+static void put_pixels16_axp_asm(uint8_t *block, const uint8_t *pixels,
284
+                                 int line_size, int h)
285 285
 {
286 286
     put_pixels_axp_asm(block,     pixels,     line_size, h);
287 287
     put_pixels_axp_asm(block + 8, pixels + 8, line_size, h);
288 288
new file mode 100644
... ...
@@ -0,0 +1,50 @@
0
+/*
1
+ * This file is part of FFmpeg.
2
+ *
3
+ * FFmpeg 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
+ * FFmpeg 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 FFmpeg; if not, write to the Free Software
15
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
16
+ */
17
+
18
+#ifndef AVCODEC_ALPHA_DSPUTIL_ALPHA_H
19
+#define AVCODEC_ALPHA_DSPUTIL_ALPHA_H
20
+
21
+#include "libavcodec/dsputil.h"
22
+
23
+void ff_simple_idct_axp(DCTELEM *block);
24
+void ff_simple_idct_put_axp(uint8_t *dest, int line_size, DCTELEM *block);
25
+void ff_simple_idct_add_axp(uint8_t *dest, int line_size, DCTELEM *block);
26
+
27
+void put_pixels_axp_asm(uint8_t *block, const uint8_t *pixels,
28
+                        int line_size, int h);
29
+void put_pixels_clamped_mvi_asm(const DCTELEM *block, uint8_t *pixels,
30
+                                int line_size);
31
+void add_pixels_clamped_mvi_asm(const DCTELEM *block, uint8_t *pixels,
32
+                                int line_size);
33
+extern void (*put_pixels_clamped_axp_p)(const DCTELEM *block, uint8_t *pixels,
34
+                                        int line_size);
35
+extern void (*add_pixels_clamped_axp_p)(const DCTELEM *block, uint8_t *pixels,
36
+                                        int line_size);
37
+
38
+void get_pixels_mvi(DCTELEM *restrict block,
39
+                    const uint8_t *restrict pixels, int line_size);
40
+void diff_pixels_mvi(DCTELEM *block, const uint8_t *s1, const uint8_t *s2,
41
+                     int stride);
42
+int pix_abs8x8_mvi(void *v, uint8_t *pix1, uint8_t *pix2, int line_size, int h);
43
+int pix_abs16x16_mvi_asm(void *v, uint8_t *pix1, uint8_t *pix2, int line_size, int h);
44
+int pix_abs16x16_x2_mvi(void *v, uint8_t *pix1, uint8_t *pix2, int line_size, int h);
45
+int pix_abs16x16_y2_mvi(void *v, uint8_t *pix1, uint8_t *pix2, int line_size, int h);
46
+int pix_abs16x16_xy2_mvi(void *v, uint8_t *pix1, uint8_t *pix2, int line_size, int h);
47
+
48
+
49
+#endif /* AVCODEC_ALPHA_DSPUTIL_ALPHA_H */
... ...
@@ -20,6 +20,7 @@
20 20
  */
21 21
 
22 22
 #include "libavcodec/dsputil.h"
23
+#include "dsputil_alpha.h"
23 24
 #include "asm.h"
24 25
 
25 26
 void get_pixels_mvi(DCTELEM *restrict block,
... ...
@@ -27,13 +27,9 @@
27 27
  */
28 28
 
29 29
 #include "libavcodec/dsputil.h"
30
+#include "dsputil_alpha.h"
30 31
 #include "asm.h"
31 32
 
32
-extern void (*put_pixels_clamped_axp_p)(const DCTELEM *block, uint8_t *pixels,
33
-                                        int line_size);
34
-extern void (*add_pixels_clamped_axp_p)(const DCTELEM *block, uint8_t *pixels,
35
-                                        int line_size);
36
-
37 33
 // cos(i * M_PI / 16) * sqrt(2) * (1 << 14)
38 34
 // W4 is actually exactly 16384, but using 16383 works around
39 35
 // accumulating rounding errors for some encoders