Mercurial > libavcodec.hg
annotate i386/dsputil_mmx.h @ 6485:949e4f444a50 libavcodec
Rename --enable-swscaler --> enable-swscale to be consistent with the
directory name and other option names. Also rename variables accordingly.
author | diego |
---|---|
date | Mon, 10 Mar 2008 17:54:24 +0000 |
parents | 9a736918fd90 |
children | e1208c4f8898 |
rev | line source |
---|---|
5946
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
1 /* |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
2 * MMX optimized DSP utils |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
3 * Copyright (c) 2007 Aurelien Jacobs <aurel@gnuage.org> |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
4 * |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
5 * This file is part of FFmpeg. |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
6 * |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
7 * FFmpeg is free software; you can redistribute it and/or |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
8 * modify it under the terms of the GNU Lesser General Public |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
9 * License as published by the Free Software Foundation; either |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
10 * version 2.1 of the License, or (at your option) any later version. |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
11 * |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
12 * FFmpeg is distributed in the hope that it will be useful, |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
15 * Lesser General Public License for more details. |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
16 * |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
17 * You should have received a copy of the GNU Lesser General Public |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
18 * License along with FFmpeg; if not, write to the Free Software |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
20 */ |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
21 |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
22 #ifndef FFMPEG_DSPUTIL_MMX_H |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
23 #define FFMPEG_DSPUTIL_MMX_H |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
24 |
6013
af8951e74098
add required include to make this file self-contained
aurel
parents:
5952
diff
changeset
|
25 #include <stdint.h> |
6403
9a736918fd90
split encoding part of dsputil_mmx into its own file
aurel
parents:
6331
diff
changeset
|
26 #include "dsputil.h" |
6013
af8951e74098
add required include to make this file self-contained
aurel
parents:
5952
diff
changeset
|
27 |
6329
5969caa9190d
clean up an ugliness introduced in r11826. this syntax will require fewer changes when adding future sse2 code.
lorenm
parents:
6320
diff
changeset
|
28 typedef struct { uint64_t a, b; } xmm_t; |
5969caa9190d
clean up an ugliness introduced in r11826. this syntax will require fewer changes when adding future sse2 code.
lorenm
parents:
6320
diff
changeset
|
29 |
5947 | 30 extern const uint64_t ff_bone; |
31 extern const uint64_t ff_wtwo; | |
5946
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
32 |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
33 extern const uint64_t ff_pdw_80000000[2]; |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
34 |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
35 extern const uint64_t ff_pw_3; |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
36 extern const uint64_t ff_pw_4; |
6331 | 37 extern const xmm_t ff_pw_5; |
5946
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
38 extern const uint64_t ff_pw_8; |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
39 extern const uint64_t ff_pw_15; |
6331 | 40 extern const xmm_t ff_pw_16; |
5946
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
41 extern const uint64_t ff_pw_20; |
6329
5969caa9190d
clean up an ugliness introduced in r11826. this syntax will require fewer changes when adding future sse2 code.
lorenm
parents:
6320
diff
changeset
|
42 extern const xmm_t ff_pw_32; |
5946
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
43 extern const uint64_t ff_pw_42; |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
44 extern const uint64_t ff_pw_64; |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
45 extern const uint64_t ff_pw_96; |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
46 extern const uint64_t ff_pw_128; |
6403
9a736918fd90
split encoding part of dsputil_mmx into its own file
aurel
parents:
6331
diff
changeset
|
47 extern const uint64_t ff_pw_255; |
5946
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
48 |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
49 extern const uint64_t ff_pb_1; |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
50 extern const uint64_t ff_pb_3; |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
51 extern const uint64_t ff_pb_7; |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
52 extern const uint64_t ff_pb_3F; |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
53 extern const uint64_t ff_pb_A1; |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
54 extern const uint64_t ff_pb_FC; |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
55 |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
56 extern const double ff_pd_1[2]; |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
57 extern const double ff_pd_2[2]; |
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
58 |
6135
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
59 /* in/out: mma=mma+mmb, mmb=mmb-mma */ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
60 #define SUMSUB_BA( a, b ) \ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
61 "paddw "#b", "#a" \n\t"\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
62 "paddw "#b", "#b" \n\t"\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
63 "psubw "#a", "#b" \n\t" |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
64 |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
65 #define SBUTTERFLY(a,b,t,n,m)\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
66 "mov" #m " " #a ", " #t " \n\t" /* abcd */\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
67 "punpckl" #n " " #b ", " #a " \n\t" /* aebf */\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
68 "punpckh" #n " " #b ", " #t " \n\t" /* cgdh */\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
69 |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
70 #define TRANSPOSE4(a,b,c,d,t)\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
71 SBUTTERFLY(a,b,t,wd,q) /* a=aebf t=cgdh */\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
72 SBUTTERFLY(c,d,b,wd,q) /* c=imjn b=kolp */\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
73 SBUTTERFLY(a,c,d,dq,q) /* a=aeim d=bfjn */\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
74 SBUTTERFLY(t,b,c,dq,q) /* t=cgko c=dhlp */ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
75 |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
76 #ifdef ARCH_X86_64 |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
77 // permutes 01234567 -> 05736421 |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
78 #define TRANSPOSE8(a,b,c,d,e,f,g,h,t)\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
79 SBUTTERFLY(a,b,%%xmm8,wd,dqa)\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
80 SBUTTERFLY(c,d,b,wd,dqa)\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
81 SBUTTERFLY(e,f,d,wd,dqa)\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
82 SBUTTERFLY(g,h,f,wd,dqa)\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
83 SBUTTERFLY(a,c,h,dq,dqa)\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
84 SBUTTERFLY(%%xmm8,b,c,dq,dqa)\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
85 SBUTTERFLY(e,g,b,dq,dqa)\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
86 SBUTTERFLY(d,f,g,dq,dqa)\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
87 SBUTTERFLY(a,e,f,qdq,dqa)\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
88 SBUTTERFLY(%%xmm8,d,e,qdq,dqa)\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
89 SBUTTERFLY(h,b,d,qdq,dqa)\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
90 SBUTTERFLY(c,g,b,qdq,dqa)\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
91 "movdqa %%xmm8, "#g" \n\t" |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
92 #else |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
93 #define TRANSPOSE8(a,b,c,d,e,f,g,h,t)\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
94 "movdqa "#h", "#t" \n\t"\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
95 SBUTTERFLY(a,b,h,wd,dqa)\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
96 "movdqa "#h", 16"#t" \n\t"\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
97 "movdqa "#t", "#h" \n\t"\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
98 SBUTTERFLY(c,d,b,wd,dqa)\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
99 SBUTTERFLY(e,f,d,wd,dqa)\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
100 SBUTTERFLY(g,h,f,wd,dqa)\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
101 SBUTTERFLY(a,c,h,dq,dqa)\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
102 "movdqa "#h", "#t" \n\t"\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
103 "movdqa 16"#t", "#h" \n\t"\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
104 SBUTTERFLY(h,b,c,dq,dqa)\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
105 SBUTTERFLY(e,g,b,dq,dqa)\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
106 SBUTTERFLY(d,f,g,dq,dqa)\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
107 SBUTTERFLY(a,e,f,qdq,dqa)\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
108 SBUTTERFLY(h,d,e,qdq,dqa)\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
109 "movdqa "#h", 16"#t" \n\t"\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
110 "movdqa "#t", "#h" \n\t"\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
111 SBUTTERFLY(h,b,d,qdq,dqa)\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
112 SBUTTERFLY(c,g,b,qdq,dqa)\ |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
113 "movdqa 16"#t", "#g" \n\t" |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
114 #endif |
1c67967d893b
Factorize some duplicated code from CAVS and H.264 into a common file.
diego
parents:
6013
diff
changeset
|
115 |
6403
9a736918fd90
split encoding part of dsputil_mmx into its own file
aurel
parents:
6331
diff
changeset
|
116 #define MOVQ_WONE(regd) \ |
9a736918fd90
split encoding part of dsputil_mmx into its own file
aurel
parents:
6331
diff
changeset
|
117 asm volatile ( \ |
9a736918fd90
split encoding part of dsputil_mmx into its own file
aurel
parents:
6331
diff
changeset
|
118 "pcmpeqd %%" #regd ", %%" #regd " \n\t" \ |
9a736918fd90
split encoding part of dsputil_mmx into its own file
aurel
parents:
6331
diff
changeset
|
119 "psrlw $15, %%" #regd ::) |
9a736918fd90
split encoding part of dsputil_mmx into its own file
aurel
parents:
6331
diff
changeset
|
120 |
9a736918fd90
split encoding part of dsputil_mmx into its own file
aurel
parents:
6331
diff
changeset
|
121 void dsputilenc_init_mmx(DSPContext* c, AVCodecContext *avctx); |
9a736918fd90
split encoding part of dsputil_mmx into its own file
aurel
parents:
6331
diff
changeset
|
122 |
5946
55251379b5b1
make ff_p* vars extern so that they can be used in various *_mmx.c files
aurel
parents:
diff
changeset
|
123 #endif /* FFMPEG_DSPUTIL_MMX_H */ |