Mercurial > mplayer.hg
annotate libswscale/x86/yuv2rgb_mmx.c @ 31151:944efc839c41
Change -vo md5sum to not interleave U and V lines when calculating
the MD5, thus making it match FFmpeg's -f framemd5.
author | reimar |
---|---|
date | Mon, 24 May 2010 17:51:15 +0000 |
parents | b11e3ae960ac |
children | e682d09f5e33 |
rev | line source |
---|---|
29028 | 1 /* |
2 * software YUV to RGB converter | |
3 * | |
4 * Copyright (C) 2009 Konstantin Shishkov | |
5 * | |
6 * MMX/MMX2 template stuff (needed for fast movntq support), | |
7 * 1,4,8bpp support and context / deglobalize stuff | |
8 * by Michael Niedermayer (michaelni@gmx.at) | |
9 * | |
10 * This file is part of FFmpeg. | |
11 * | |
12 * FFmpeg is free software; you can redistribute it and/or | |
13 * modify it under the terms of the GNU Lesser General Public | |
14 * License as published by the Free Software Foundation; either | |
15 * version 2.1 of the License, or (at your option) any later version. | |
16 * | |
17 * FFmpeg is distributed in the hope that it will be useful, | |
18 * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
19 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
20 * Lesser General Public License for more details. | |
21 * | |
22 * You should have received a copy of the GNU Lesser General Public | |
23 * License along with FFmpeg; if not, write to the Free Software | |
24 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA | |
25 */ | |
26 | |
27 #include <stdio.h> | |
28 #include <stdlib.h> | |
29 #include <inttypes.h> | |
30 #include <assert.h> | |
31 | |
32 #include "config.h" | |
33 #include "libswscale/rgb2rgb.h" | |
34 #include "libswscale/swscale.h" | |
35 #include "libswscale/swscale_internal.h" | |
36 #include "libavutil/x86_cpu.h" | |
37 | |
38 #define DITHER1XBPP // only for MMX | |
39 | |
40 /* hope these constant values are cache line aligned */ | |
41 DECLARE_ASM_CONST(8, uint64_t, mmx_00ffw) = 0x00ff00ff00ff00ffULL; | |
42 DECLARE_ASM_CONST(8, uint64_t, mmx_redmask) = 0xf8f8f8f8f8f8f8f8ULL; | |
43 DECLARE_ASM_CONST(8, uint64_t, mmx_grnmask) = 0xfcfcfcfcfcfcfcfcULL; | |
31124 | 44 DECLARE_ASM_CONST(8, uint64_t, pb_e0) = 0xe0e0e0e0e0e0e0e0ULL; |
45 DECLARE_ASM_CONST(8, uint64_t, pb_03) = 0x0303030303030303ULL; | |
46 DECLARE_ASM_CONST(8, uint64_t, pb_07) = 0x0707070707070707ULL; | |
29028 | 47 |
48 //MMX versions | |
49 #undef RENAME | |
50 #undef HAVE_MMX2 | |
51 #undef HAVE_AMD3DNOW | |
52 #define HAVE_MMX2 0 | |
53 #define HAVE_AMD3DNOW 0 | |
54 #define RENAME(a) a ## _MMX | |
31078
6502a6b24f9b
alternative LGPL-licensed, MMX-optimized YUV to RGB conversion routines
diego
parents:
30212
diff
changeset
|
55 #if CONFIG_GPL |
29028 | 56 #include "yuv2rgb_template.c" |
31078
6502a6b24f9b
alternative LGPL-licensed, MMX-optimized YUV to RGB conversion routines
diego
parents:
30212
diff
changeset
|
57 #else |
6502a6b24f9b
alternative LGPL-licensed, MMX-optimized YUV to RGB conversion routines
diego
parents:
30212
diff
changeset
|
58 #include "yuv2rgb_template2.c" |
6502a6b24f9b
alternative LGPL-licensed, MMX-optimized YUV to RGB conversion routines
diego
parents:
30212
diff
changeset
|
59 #endif |
29028 | 60 |
61 //MMX2 versions | |
62 #undef RENAME | |
63 #undef HAVE_MMX2 | |
64 #define HAVE_MMX2 1 | |
65 #define RENAME(a) a ## _MMX2 | |
31078
6502a6b24f9b
alternative LGPL-licensed, MMX-optimized YUV to RGB conversion routines
diego
parents:
30212
diff
changeset
|
66 #if CONFIG_GPL |
29028 | 67 #include "yuv2rgb_template.c" |
31078
6502a6b24f9b
alternative LGPL-licensed, MMX-optimized YUV to RGB conversion routines
diego
parents:
30212
diff
changeset
|
68 #else |
6502a6b24f9b
alternative LGPL-licensed, MMX-optimized YUV to RGB conversion routines
diego
parents:
30212
diff
changeset
|
69 #include "yuv2rgb_template2.c" |
6502a6b24f9b
alternative LGPL-licensed, MMX-optimized YUV to RGB conversion routines
diego
parents:
30212
diff
changeset
|
70 #endif |
29028 | 71 |
72 SwsFunc ff_yuv2rgb_init_mmx(SwsContext *c) | |
73 { | |
74 if (c->flags & SWS_CPU_CAPS_MMX2) { | |
75 switch (c->dstFormat) { | |
76 case PIX_FMT_RGB32: | |
29481 | 77 if (CONFIG_SWSCALE_ALPHA && c->srcFormat == PIX_FMT_YUVA420P) { |
29028 | 78 if (HAVE_7REGS) return yuva420_rgb32_MMX2; |
79 break; | |
29481 | 80 } else return yuv420_rgb32_MMX2; |
29473 | 81 case PIX_FMT_BGR32: |
29481 | 82 if (CONFIG_SWSCALE_ALPHA && c->srcFormat == PIX_FMT_YUVA420P) { |
29473 | 83 if (HAVE_7REGS) return yuva420_bgr32_MMX2; |
84 break; | |
29481 | 85 } else return yuv420_bgr32_MMX2; |
30212
c1531f608d76
MMX(2) accelerated yuv420->rgb24 routine, trivial as essentially as it just
zuxy
parents:
29481
diff
changeset
|
86 case PIX_FMT_RGB24: return yuv420_rgb24_MMX2; |
c1531f608d76
MMX(2) accelerated yuv420->rgb24 routine, trivial as essentially as it just
zuxy
parents:
29481
diff
changeset
|
87 case PIX_FMT_BGR24: return yuv420_bgr24_MMX2; |
29028 | 88 case PIX_FMT_RGB565: return yuv420_rgb16_MMX2; |
89 case PIX_FMT_RGB555: return yuv420_rgb15_MMX2; | |
90 } | |
91 } | |
92 if (c->flags & SWS_CPU_CAPS_MMX) { | |
93 switch (c->dstFormat) { | |
94 case PIX_FMT_RGB32: | |
29481 | 95 if (CONFIG_SWSCALE_ALPHA && c->srcFormat == PIX_FMT_YUVA420P) { |
29028 | 96 if (HAVE_7REGS) return yuva420_rgb32_MMX; |
97 break; | |
29481 | 98 } else return yuv420_rgb32_MMX; |
29473 | 99 case PIX_FMT_BGR32: |
29481 | 100 if (CONFIG_SWSCALE_ALPHA && c->srcFormat == PIX_FMT_YUVA420P) { |
29473 | 101 if (HAVE_7REGS) return yuva420_bgr32_MMX; |
102 break; | |
29481 | 103 } else return yuv420_bgr32_MMX; |
30212
c1531f608d76
MMX(2) accelerated yuv420->rgb24 routine, trivial as essentially as it just
zuxy
parents:
29481
diff
changeset
|
104 case PIX_FMT_RGB24: return yuv420_rgb24_MMX; |
c1531f608d76
MMX(2) accelerated yuv420->rgb24 routine, trivial as essentially as it just
zuxy
parents:
29481
diff
changeset
|
105 case PIX_FMT_BGR24: return yuv420_bgr24_MMX; |
29028 | 106 case PIX_FMT_RGB565: return yuv420_rgb16_MMX; |
107 case PIX_FMT_RGB555: return yuv420_rgb15_MMX; | |
108 } | |
109 } | |
110 | |
111 return NULL; | |
112 } |