Mercurial > mplayer.hg
annotate libswscale/utils.c @ 30814:9257c04720ed
Avoid duplication of usePal() macro.
author | stefano |
---|---|
date | Sat, 06 Mar 2010 11:50:54 +0000 |
parents | c5a49657b3e4 |
children | d59dfdf82fca |
rev | line source |
---|---|
18861 | 1 /* |
20094
aca9e9783f67
Change license headers to say 'FFmpeg' instead of 'this program'.
diego
parents:
19987
diff
changeset
|
2 * Copyright (C) 2001-2003 Michael Niedermayer <michaelni@gmx.at> |
aca9e9783f67
Change license headers to say 'FFmpeg' instead of 'this program'.
diego
parents:
19987
diff
changeset
|
3 * |
aca9e9783f67
Change license headers to say 'FFmpeg' instead of 'this program'.
diego
parents:
19987
diff
changeset
|
4 * This file is part of FFmpeg. |
aca9e9783f67
Change license headers to say 'FFmpeg' instead of 'this program'.
diego
parents:
19987
diff
changeset
|
5 * |
aca9e9783f67
Change license headers to say 'FFmpeg' instead of 'this program'.
diego
parents:
19987
diff
changeset
|
6 * FFmpeg is free software; you can redistribute it and/or modify |
aca9e9783f67
Change license headers to say 'FFmpeg' instead of 'this program'.
diego
parents:
19987
diff
changeset
|
7 * it under the terms of the GNU General Public License as published by |
aca9e9783f67
Change license headers to say 'FFmpeg' instead of 'this program'.
diego
parents:
19987
diff
changeset
|
8 * the Free Software Foundation; either version 2 of the License, or |
aca9e9783f67
Change license headers to say 'FFmpeg' instead of 'this program'.
diego
parents:
19987
diff
changeset
|
9 * (at your option) any later version. |
aca9e9783f67
Change license headers to say 'FFmpeg' instead of 'this program'.
diego
parents:
19987
diff
changeset
|
10 * |
aca9e9783f67
Change license headers to say 'FFmpeg' instead of 'this program'.
diego
parents:
19987
diff
changeset
|
11 * FFmpeg is distributed in the hope that it will be useful, |
aca9e9783f67
Change license headers to say 'FFmpeg' instead of 'this program'.
diego
parents:
19987
diff
changeset
|
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
aca9e9783f67
Change license headers to say 'FFmpeg' instead of 'this program'.
diego
parents:
19987
diff
changeset
|
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
aca9e9783f67
Change license headers to say 'FFmpeg' instead of 'this program'.
diego
parents:
19987
diff
changeset
|
14 * GNU General Public License for more details. |
aca9e9783f67
Change license headers to say 'FFmpeg' instead of 'this program'.
diego
parents:
19987
diff
changeset
|
15 * |
aca9e9783f67
Change license headers to say 'FFmpeg' instead of 'this program'.
diego
parents:
19987
diff
changeset
|
16 * You should have received a copy of the GNU General Public License |
aca9e9783f67
Change license headers to say 'FFmpeg' instead of 'this program'.
diego
parents:
19987
diff
changeset
|
17 * along with FFmpeg; if not, write to the Free Software |
23702 | 18 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA |
20094
aca9e9783f67
Change license headers to say 'FFmpeg' instead of 'this program'.
diego
parents:
19987
diff
changeset
|
19 * |
21029
1f2ba24b4e47
Clarify that some of the non-SIMD code is now LGPLed.
lucabe
parents:
20943
diff
changeset
|
20 * the C code (not assembly, mmx, ...) of this file can be used |
1f2ba24b4e47
Clarify that some of the non-SIMD code is now LGPLed.
lucabe
parents:
20943
diff
changeset
|
21 * under the LGPL license too |
20094
aca9e9783f67
Change license headers to say 'FFmpeg' instead of 'this program'.
diego
parents:
19987
diff
changeset
|
22 */ |
18861 | 23 |
27511 | 24 #define _SVID_SOURCE //needed for MAP_ANONYMOUS |
18861 | 25 #include <inttypes.h> |
26 #include <string.h> | |
27 #include <math.h> | |
28 #include <stdio.h> | |
29 #include "config.h" | |
30 #include <assert.h> | |
28276 | 31 #if HAVE_SYS_MMAN_H |
18861 | 32 #include <sys/mman.h> |
33 #if defined(MAP_ANON) && !defined(MAP_ANONYMOUS) | |
34 #define MAP_ANONYMOUS MAP_ANON | |
35 #endif | |
36 #endif | |
28971
b8e356a9dbb1
Allocate executable memory with VirtualAlloc() in Windows.
ramiro
parents:
28970
diff
changeset
|
37 #if HAVE_VIRTUALALLOC |
b8e356a9dbb1
Allocate executable memory with VirtualAlloc() in Windows.
ramiro
parents:
28970
diff
changeset
|
38 #define WIN32_LEAN_AND_MEAN |
b8e356a9dbb1
Allocate executable memory with VirtualAlloc() in Windows.
ramiro
parents:
28970
diff
changeset
|
39 #include <windows.h> |
b8e356a9dbb1
Allocate executable memory with VirtualAlloc() in Windows.
ramiro
parents:
28970
diff
changeset
|
40 #endif |
18861 | 41 #include "swscale.h" |
42 #include "swscale_internal.h" | |
43 #include "rgb2rgb.h" | |
29475 | 44 #include "libavutil/intreadwrite.h" |
26670
e6774798e913
Use full path for #includes from another directory.
diego
parents:
26238
diff
changeset
|
45 #include "libavutil/x86_cpu.h" |
29542 | 46 #include "libavutil/avutil.h" |
26670
e6774798e913
Use full path for #includes from another directory.
diego
parents:
26238
diff
changeset
|
47 #include "libavutil/bswap.h" |
29926
916134a82d74
Make sws_format_name() use av_pix_fmt_descriptors.
stefano
parents:
29890
diff
changeset
|
48 #include "libavutil/pixdesc.h" |
18861 | 49 |
27460 | 50 unsigned swscale_version(void) |
51 { | |
52 return LIBSWSCALE_VERSION_INT; | |
53 } | |
54 | |
30138 | 55 const char *swscale_configuration(void) |
29890
e8e1f8cc7c5b
Add functions to return library license and library configuration.
diego
parents:
29843
diff
changeset
|
56 { |
e8e1f8cc7c5b
Add functions to return library license and library configuration.
diego
parents:
29843
diff
changeset
|
57 return FFMPEG_CONFIGURATION; |
e8e1f8cc7c5b
Add functions to return library license and library configuration.
diego
parents:
29843
diff
changeset
|
58 } |
e8e1f8cc7c5b
Add functions to return library license and library configuration.
diego
parents:
29843
diff
changeset
|
59 |
30138 | 60 const char *swscale_license(void) |
29890
e8e1f8cc7c5b
Add functions to return library license and library configuration.
diego
parents:
29843
diff
changeset
|
61 { |
e8e1f8cc7c5b
Add functions to return library license and library configuration.
diego
parents:
29843
diff
changeset
|
62 #define LICENSE_PREFIX "libswscale license: " |
e8e1f8cc7c5b
Add functions to return library license and library configuration.
diego
parents:
29843
diff
changeset
|
63 return LICENSE_PREFIX FFMPEG_LICENSE + sizeof(LICENSE_PREFIX) - 1; |
e8e1f8cc7c5b
Add functions to return library license and library configuration.
diego
parents:
29843
diff
changeset
|
64 } |
e8e1f8cc7c5b
Add functions to return library license and library configuration.
diego
parents:
29843
diff
changeset
|
65 |
28316 | 66 #define RET 0xC3 //near return opcode for x86 |
18861 | 67 |
23278 | 68 #define isSupportedIn(x) ( \ |
69 (x)==PIX_FMT_YUV420P \ | |
24581
a7fe1ee84511
add support for yuva420p colorspace (yuv420p + alpha)
aurel
parents:
24289
diff
changeset
|
70 || (x)==PIX_FMT_YUVA420P \ |
23278 | 71 || (x)==PIX_FMT_YUYV422 \ |
72 || (x)==PIX_FMT_UYVY422 \ | |
29299
24954ec81529
Partial (low bits ignored, no direct transcoding into other RGB formats) support
kostya
parents:
29278
diff
changeset
|
73 || (x)==PIX_FMT_RGB48BE \ |
24954ec81529
Partial (low bits ignored, no direct transcoding into other RGB formats) support
kostya
parents:
29278
diff
changeset
|
74 || (x)==PIX_FMT_RGB48LE \ |
23278 | 75 || (x)==PIX_FMT_RGB32 \ |
27490 | 76 || (x)==PIX_FMT_RGB32_1 \ |
23278 | 77 || (x)==PIX_FMT_BGR24 \ |
78 || (x)==PIX_FMT_BGR565 \ | |
79 || (x)==PIX_FMT_BGR555 \ | |
80 || (x)==PIX_FMT_BGR32 \ | |
27490 | 81 || (x)==PIX_FMT_BGR32_1 \ |
23278 | 82 || (x)==PIX_FMT_RGB24 \ |
83 || (x)==PIX_FMT_RGB565 \ | |
84 || (x)==PIX_FMT_RGB555 \ | |
85 || (x)==PIX_FMT_GRAY8 \ | |
86 || (x)==PIX_FMT_YUV410P \ | |
27557 | 87 || (x)==PIX_FMT_YUV440P \ |
29932 | 88 || (x)==PIX_FMT_NV12 \ |
89 || (x)==PIX_FMT_NV21 \ | |
23278 | 90 || (x)==PIX_FMT_GRAY16BE \ |
91 || (x)==PIX_FMT_GRAY16LE \ | |
92 || (x)==PIX_FMT_YUV444P \ | |
93 || (x)==PIX_FMT_YUV422P \ | |
94 || (x)==PIX_FMT_YUV411P \ | |
30432 | 95 || (x)==PIX_FMT_YUVJ420P \ |
96 || (x)==PIX_FMT_YUVJ422P \ | |
97 || (x)==PIX_FMT_YUVJ440P \ | |
98 || (x)==PIX_FMT_YUVJ444P \ | |
23278 | 99 || (x)==PIX_FMT_PAL8 \ |
100 || (x)==PIX_FMT_BGR8 \ | |
101 || (x)==PIX_FMT_RGB8 \ | |
102 || (x)==PIX_FMT_BGR4_BYTE \ | |
103 || (x)==PIX_FMT_RGB4_BYTE \ | |
23791 | 104 || (x)==PIX_FMT_YUV440P \ |
27555 | 105 || (x)==PIX_FMT_MONOWHITE \ |
106 || (x)==PIX_FMT_MONOBLACK \ | |
29608
ff34398b14b1
Make 16bit YUV formats compatible with NE avcodec_get_pix_fmt().
ramiro
parents:
29545
diff
changeset
|
107 || (x)==PIX_FMT_YUV420P16LE \ |
ff34398b14b1
Make 16bit YUV formats compatible with NE avcodec_get_pix_fmt().
ramiro
parents:
29545
diff
changeset
|
108 || (x)==PIX_FMT_YUV422P16LE \ |
ff34398b14b1
Make 16bit YUV formats compatible with NE avcodec_get_pix_fmt().
ramiro
parents:
29545
diff
changeset
|
109 || (x)==PIX_FMT_YUV444P16LE \ |
ff34398b14b1
Make 16bit YUV formats compatible with NE avcodec_get_pix_fmt().
ramiro
parents:
29545
diff
changeset
|
110 || (x)==PIX_FMT_YUV420P16BE \ |
ff34398b14b1
Make 16bit YUV formats compatible with NE avcodec_get_pix_fmt().
ramiro
parents:
29545
diff
changeset
|
111 || (x)==PIX_FMT_YUV422P16BE \ |
ff34398b14b1
Make 16bit YUV formats compatible with NE avcodec_get_pix_fmt().
ramiro
parents:
29545
diff
changeset
|
112 || (x)==PIX_FMT_YUV444P16BE \ |
23278 | 113 ) |
30194
bd9db1814611
Implement sws_isSupportedInput() and sws_isSupportedOutput().
stefano
parents:
30142
diff
changeset
|
114 |
bd9db1814611
Implement sws_isSupportedInput() and sws_isSupportedOutput().
stefano
parents:
30142
diff
changeset
|
115 int sws_isSupportedInput(enum PixelFormat pix_fmt) |
bd9db1814611
Implement sws_isSupportedInput() and sws_isSupportedOutput().
stefano
parents:
30142
diff
changeset
|
116 { |
bd9db1814611
Implement sws_isSupportedInput() and sws_isSupportedOutput().
stefano
parents:
30142
diff
changeset
|
117 return isSupportedIn(pix_fmt); |
bd9db1814611
Implement sws_isSupportedInput() and sws_isSupportedOutput().
stefano
parents:
30142
diff
changeset
|
118 } |
bd9db1814611
Implement sws_isSupportedInput() and sws_isSupportedOutput().
stefano
parents:
30142
diff
changeset
|
119 |
23278 | 120 #define isSupportedOut(x) ( \ |
121 (x)==PIX_FMT_YUV420P \ | |
28977 | 122 || (x)==PIX_FMT_YUVA420P \ |
23278 | 123 || (x)==PIX_FMT_YUYV422 \ |
124 || (x)==PIX_FMT_UYVY422 \ | |
125 || (x)==PIX_FMT_YUV444P \ | |
126 || (x)==PIX_FMT_YUV422P \ | |
127 || (x)==PIX_FMT_YUV411P \ | |
30432 | 128 || (x)==PIX_FMT_YUVJ420P \ |
129 || (x)==PIX_FMT_YUVJ422P \ | |
130 || (x)==PIX_FMT_YUVJ440P \ | |
131 || (x)==PIX_FMT_YUVJ444P \ | |
30393 | 132 || isAnyRGB(x) \ |
23278 | 133 || (x)==PIX_FMT_NV12 \ |
134 || (x)==PIX_FMT_NV21 \ | |
135 || (x)==PIX_FMT_GRAY16BE \ | |
136 || (x)==PIX_FMT_GRAY16LE \ | |
137 || (x)==PIX_FMT_GRAY8 \ | |
138 || (x)==PIX_FMT_YUV410P \ | |
27557 | 139 || (x)==PIX_FMT_YUV440P \ |
29608
ff34398b14b1
Make 16bit YUV formats compatible with NE avcodec_get_pix_fmt().
ramiro
parents:
29545
diff
changeset
|
140 || (x)==PIX_FMT_YUV420P16LE \ |
ff34398b14b1
Make 16bit YUV formats compatible with NE avcodec_get_pix_fmt().
ramiro
parents:
29545
diff
changeset
|
141 || (x)==PIX_FMT_YUV422P16LE \ |
ff34398b14b1
Make 16bit YUV formats compatible with NE avcodec_get_pix_fmt().
ramiro
parents:
29545
diff
changeset
|
142 || (x)==PIX_FMT_YUV444P16LE \ |
ff34398b14b1
Make 16bit YUV formats compatible with NE avcodec_get_pix_fmt().
ramiro
parents:
29545
diff
changeset
|
143 || (x)==PIX_FMT_YUV420P16BE \ |
ff34398b14b1
Make 16bit YUV formats compatible with NE avcodec_get_pix_fmt().
ramiro
parents:
29545
diff
changeset
|
144 || (x)==PIX_FMT_YUV422P16BE \ |
ff34398b14b1
Make 16bit YUV formats compatible with NE avcodec_get_pix_fmt().
ramiro
parents:
29545
diff
changeset
|
145 || (x)==PIX_FMT_YUV444P16BE \ |
23278 | 146 ) |
30194
bd9db1814611
Implement sws_isSupportedInput() and sws_isSupportedOutput().
stefano
parents:
30142
diff
changeset
|
147 |
bd9db1814611
Implement sws_isSupportedInput() and sws_isSupportedOutput().
stefano
parents:
30142
diff
changeset
|
148 int sws_isSupportedOutput(enum PixelFormat pix_fmt) |
bd9db1814611
Implement sws_isSupportedInput() and sws_isSupportedOutput().
stefano
parents:
30142
diff
changeset
|
149 { |
bd9db1814611
Implement sws_isSupportedInput() and sws_isSupportedOutput().
stefano
parents:
30142
diff
changeset
|
150 return isSupportedOut(pix_fmt); |
bd9db1814611
Implement sws_isSupportedInput() and sws_isSupportedOutput().
stefano
parents:
30142
diff
changeset
|
151 } |
bd9db1814611
Implement sws_isSupportedInput() and sws_isSupportedOutput().
stefano
parents:
30142
diff
changeset
|
152 |
28460 | 153 extern const int32_t ff_yuv2rgb_coeffs[8][4]; |
18861 | 154 |
26151
5884743208b6
change sws_format_name to return const char*, supress many warnings
bcoudurier
parents:
26150
diff
changeset
|
155 const char *sws_format_name(enum PixelFormat format) |
19143
c4dac777b44c
Use libavutil in libswscale, and allow it to be built out of the mplayer tree
lucabe
parents:
18861
diff
changeset
|
156 { |
29926
916134a82d74
Make sws_format_name() use av_pix_fmt_descriptors.
stefano
parents:
29890
diff
changeset
|
157 if ((unsigned)format < PIX_FMT_NB && av_pix_fmt_descriptors[format].name) |
916134a82d74
Make sws_format_name() use av_pix_fmt_descriptors.
stefano
parents:
29890
diff
changeset
|
158 return av_pix_fmt_descriptors[format].name; |
916134a82d74
Make sws_format_name() use av_pix_fmt_descriptors.
stefano
parents:
29890
diff
changeset
|
159 else |
29480 | 160 return "Unknown format"; |
19143
c4dac777b44c
Use libavutil in libswscale, and allow it to be built out of the mplayer tree
lucabe
parents:
18861
diff
changeset
|
161 } |
c4dac777b44c
Use libavutil in libswscale, and allow it to be built out of the mplayer tree
lucabe
parents:
18861
diff
changeset
|
162 |
18861 | 163 static double getSplineCoeff(double a, double b, double c, double d, double dist) |
164 { | |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
165 // printf("%f %f %f %f %f\n", a,b,c,d,dist); |
29480 | 166 if (dist<=1.0) return ((d*dist + c)*dist + b)*dist +a; |
167 else return getSplineCoeff( 0.0, | |
168 b+ 2.0*c + 3.0*d, | |
169 c + 3.0*d, | |
170 -b- 3.0*c - 6.0*d, | |
171 dist-1.0); | |
18861 | 172 } |
173 | |
30307 | 174 static int initFilter(int16_t **outFilter, int16_t **filterPos, int *outFilterSize, int xInc, |
30308 | 175 int srcW, int dstW, int filterAlign, int one, int flags, |
176 SwsVector *srcFilter, SwsVector *dstFilter, double param[2]) | |
18861 | 177 { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
178 int i; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
179 int filterSize; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
180 int filter2Size; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
181 int minFilterSize; |
27580
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
182 int64_t *filter=NULL; |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
183 int64_t *filter2=NULL; |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
184 const int64_t fone= 1LL<<54; |
27300 | 185 int ret= -1; |
28276 | 186 #if ARCH_X86 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
187 if (flags & SWS_CPU_CAPS_MMX) |
27744 | 188 __asm__ volatile("emms\n\t"::: "memory"); //FIXME this should not be required but it IS (even for non-MMX versions) |
18861 | 189 #endif |
190 | |
28316 | 191 // NOTE: the +1 is for the MMX scaler which reads over the end |
29610
c35359578f8d
Rename CHECKED_ALLOC(Z) to FF_ALLOC(Z)_OR_GOTO and add context and label
ramiro
parents:
29609
diff
changeset
|
192 FF_ALLOC_OR_GOTO(NULL, *filterPos, (dstW+1)*sizeof(int16_t), fail); |
18861 | 193 |
29481 | 194 if (FFABS(xInc - 0x10000) <10) { // unscaled |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
195 int i; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
196 filterSize= 1; |
29610
c35359578f8d
Rename CHECKED_ALLOC(Z) to FF_ALLOC(Z)_OR_GOTO and add context and label
ramiro
parents:
29609
diff
changeset
|
197 FF_ALLOCZ_OR_GOTO(NULL, filter, dstW*sizeof(*filter)*filterSize, fail); |
18861 | 198 |
29481 | 199 for (i=0; i<dstW; i++) { |
27580
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
200 filter[i*filterSize]= fone; |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
201 (*filterPos)[i]=i; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
202 } |
18861 | 203 |
29481 | 204 } else if (flags&SWS_POINT) { // lame looking point sampling mode |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
205 int i; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
206 int xDstInSrc; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
207 filterSize= 1; |
29610
c35359578f8d
Rename CHECKED_ALLOC(Z) to FF_ALLOC(Z)_OR_GOTO and add context and label
ramiro
parents:
29609
diff
changeset
|
208 FF_ALLOC_OR_GOTO(NULL, filter, dstW*sizeof(*filter)*filterSize, fail); |
23129 | 209 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
210 xDstInSrc= xInc/2 - 0x8000; |
29481 | 211 for (i=0; i<dstW; i++) { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
212 int xx= (xDstInSrc - ((filterSize-1)<<15) + (1<<15))>>16; |
18861 | 213 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
214 (*filterPos)[i]= xx; |
27580
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
215 filter[i]= fone; |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
216 xDstInSrc+= xInc; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
217 } |
29481 | 218 } else if ((xInc <= (1<<16) && (flags&SWS_AREA)) || (flags&SWS_FAST_BILINEAR)) { // bilinear upscale |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
219 int i; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
220 int xDstInSrc; |
29407 | 221 filterSize= 2; |
29610
c35359578f8d
Rename CHECKED_ALLOC(Z) to FF_ALLOC(Z)_OR_GOTO and add context and label
ramiro
parents:
29609
diff
changeset
|
222 FF_ALLOC_OR_GOTO(NULL, filter, dstW*sizeof(*filter)*filterSize, fail); |
18861 | 223 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
224 xDstInSrc= xInc/2 - 0x8000; |
29481 | 225 for (i=0; i<dstW; i++) { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
226 int xx= (xDstInSrc - ((filterSize-1)<<15) + (1<<15))>>16; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
227 int j; |
18861 | 228 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
229 (*filterPos)[i]= xx; |
29480 | 230 //bilinear upscale / linear interpolate / area averaging |
29481 | 231 for (j=0; j<filterSize; j++) { |
29480 | 232 int64_t coeff= fone - FFABS((xx<<16) - xDstInSrc)*(fone>>16); |
233 if (coeff<0) coeff=0; | |
234 filter[i*filterSize + j]= coeff; | |
235 xx++; | |
236 } | |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
237 xDstInSrc+= xInc; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
238 } |
29481 | 239 } else { |
27580
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
240 int xDstInSrc; |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
241 int sizeFactor; |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
242 |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
243 if (flags&SWS_BICUBIC) sizeFactor= 4; |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
244 else if (flags&SWS_X) sizeFactor= 8; |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
245 else if (flags&SWS_AREA) sizeFactor= 1; //downscale only, for upscale it is bilinear |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
246 else if (flags&SWS_GAUSS) sizeFactor= 8; // infinite ;) |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
247 else if (flags&SWS_LANCZOS) sizeFactor= param[0] != SWS_PARAM_DEFAULT ? ceil(2*param[0]) : 6; |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
248 else if (flags&SWS_SINC) sizeFactor= 20; // infinite ;) |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
249 else if (flags&SWS_SPLINE) sizeFactor= 20; // infinite ;) |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
250 else if (flags&SWS_BILINEAR) sizeFactor= 2; |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
251 else { |
27580
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
252 sizeFactor= 0; //GCC warning killer |
27182
f7b6d1014b6b
Remove ASSERT() macro. SoC Patch from Keiji Costantini
lu_zero
parents:
27181
diff
changeset
|
253 assert(0); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
254 } |
23129 | 255 |
27580
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
256 if (xInc <= 1<<16) filterSize= 1 + sizeFactor; // upscale |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
257 else filterSize= 1 + (sizeFactor*srcW + dstW - 1)/ dstW; |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
258 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
259 if (filterSize > srcW-2) filterSize=srcW-2; |
18861 | 260 |
29610
c35359578f8d
Rename CHECKED_ALLOC(Z) to FF_ALLOC(Z)_OR_GOTO and add context and label
ramiro
parents:
29609
diff
changeset
|
261 FF_ALLOC_OR_GOTO(NULL, filter, dstW*sizeof(*filter)*filterSize, fail); |
18861 | 262 |
27580
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
263 xDstInSrc= xInc - 0x10000; |
29481 | 264 for (i=0; i<dstW; i++) { |
27580
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
265 int xx= (xDstInSrc - ((filterSize-2)<<16)) / (1<<17); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
266 int j; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
267 (*filterPos)[i]= xx; |
29481 | 268 for (j=0; j<filterSize; j++) { |
27580
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
269 int64_t d= ((int64_t)FFABS((xx<<17) - xDstInSrc))<<13; |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
270 double floatd; |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
271 int64_t coeff; |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
272 |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
273 if (xInc > 1<<16) |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
274 d= d*dstW/srcW; |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
275 floatd= d * (1.0/(1<<30)); |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
276 |
29481 | 277 if (flags & SWS_BICUBIC) { |
27580
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
278 int64_t B= (param[0] != SWS_PARAM_DEFAULT ? param[0] : 0) * (1<<24); |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
279 int64_t C= (param[1] != SWS_PARAM_DEFAULT ? param[1] : 0.6) * (1<<24); |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
280 int64_t dd = ( d*d)>>30; |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
281 int64_t ddd= (dd*d)>>30; |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
282 |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
283 if (d < 1LL<<30) |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
284 coeff = (12*(1<<24)-9*B-6*C)*ddd + (-18*(1<<24)+12*B+6*C)*dd + (6*(1<<24)-2*B)*(1<<30); |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
285 else if (d < 1LL<<31) |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
286 coeff = (-B-6*C)*ddd + (6*B+30*C)*dd + (-12*B-48*C)*d + (8*B+24*C)*(1<<30); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
287 else |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
288 coeff=0.0; |
27580
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
289 coeff *= fone>>(30+24); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
290 } |
29481 | 291 /* else if (flags & SWS_X) { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
292 double p= param ? param*0.01 : 0.3; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
293 coeff = d ? sin(d*PI)/(d*PI) : 1.0; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
294 coeff*= pow(2.0, - p*d*d); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
295 }*/ |
29481 | 296 else if (flags & SWS_X) { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
297 double A= param[0] != SWS_PARAM_DEFAULT ? param[0] : 1.0; |
27580
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
298 double c; |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
299 |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
300 if (floatd<1.0) |
30370
a8c94e9dc653
Don't redefine M_PI. It is already defined from libavutil/mathematics.h.
ramiro
parents:
30369
diff
changeset
|
301 c = cos(floatd*M_PI); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
302 else |
27580
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
303 c=-1.0; |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
304 if (c<0.0) c= -pow(-c, A); |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
305 else c= pow( c, A); |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
306 coeff= (c*0.5 + 0.5)*fone; |
29481 | 307 } else if (flags & SWS_AREA) { |
27580
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
308 int64_t d2= d - (1<<29); |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
309 if (d2*xInc < -(1LL<<(29+16))) coeff= 1.0 * (1LL<<(30+16)); |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
310 else if (d2*xInc < (1LL<<(29+16))) coeff= -d2*xInc + (1LL<<(29+16)); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
311 else coeff=0.0; |
27580
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
312 coeff *= fone>>(30+16); |
29481 | 313 } else if (flags & SWS_GAUSS) { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
314 double p= param[0] != SWS_PARAM_DEFAULT ? param[0] : 3.0; |
27580
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
315 coeff = (pow(2.0, - p*floatd*floatd))*fone; |
29481 | 316 } else if (flags & SWS_SINC) { |
30370
a8c94e9dc653
Don't redefine M_PI. It is already defined from libavutil/mathematics.h.
ramiro
parents:
30369
diff
changeset
|
317 coeff = (d ? sin(floatd*M_PI)/(floatd*M_PI) : 1.0)*fone; |
29481 | 318 } else if (flags & SWS_LANCZOS) { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
319 double p= param[0] != SWS_PARAM_DEFAULT ? param[0] : 3.0; |
30370
a8c94e9dc653
Don't redefine M_PI. It is already defined from libavutil/mathematics.h.
ramiro
parents:
30369
diff
changeset
|
320 coeff = (d ? sin(floatd*M_PI)*sin(floatd*M_PI/p)/(floatd*floatd*M_PI*M_PI/p) : 1.0)*fone; |
27580
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
321 if (floatd>p) coeff=0; |
29481 | 322 } else if (flags & SWS_BILINEAR) { |
27580
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
323 coeff= (1<<30) - d; |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
324 if (coeff<0) coeff=0; |
27580
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
325 coeff *= fone >> 30; |
29481 | 326 } else if (flags & SWS_SPLINE) { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
327 double p=-2.196152422706632; |
27637
5abf906c09c8
Fix infinite loop with spline, bug was introduced in r27612 by me.
michael
parents:
27596
diff
changeset
|
328 coeff = getSplineCoeff(1.0, 0.0, p, -p-1.0, floatd) * fone; |
29481 | 329 } else { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
330 coeff= 0.0; //GCC warning killer |
27182
f7b6d1014b6b
Remove ASSERT() macro. SoC Patch from Keiji Costantini
lu_zero
parents:
27181
diff
changeset
|
331 assert(0); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
332 } |
18861 | 333 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
334 filter[i*filterSize + j]= coeff; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
335 xx++; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
336 } |
27580
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
337 xDstInSrc+= 2*xInc; |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
338 } |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
339 } |
18861 | 340 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
341 /* apply src & dst Filter to filter -> filter2 |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
342 av_free(filter); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
343 */ |
27182
f7b6d1014b6b
Remove ASSERT() macro. SoC Patch from Keiji Costantini
lu_zero
parents:
27181
diff
changeset
|
344 assert(filterSize>0); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
345 filter2Size= filterSize; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
346 if (srcFilter) filter2Size+= srcFilter->length - 1; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
347 if (dstFilter) filter2Size+= dstFilter->length - 1; |
27182
f7b6d1014b6b
Remove ASSERT() macro. SoC Patch from Keiji Costantini
lu_zero
parents:
27181
diff
changeset
|
348 assert(filter2Size>0); |
29610
c35359578f8d
Rename CHECKED_ALLOC(Z) to FF_ALLOC(Z)_OR_GOTO and add context and label
ramiro
parents:
29609
diff
changeset
|
349 FF_ALLOCZ_OR_GOTO(NULL, filter2, filter2Size*dstW*sizeof(*filter2), fail); |
18861 | 350 |
29481 | 351 for (i=0; i<dstW; i++) { |
27580
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
352 int j, k; |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
353 |
29481 | 354 if(srcFilter) { |
355 for (k=0; k<srcFilter->length; k++) { | |
27580
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
356 for (j=0; j<filterSize; j++) |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
357 filter2[i*filter2Size + k + j] += srcFilter->coeff[k]*filter[i*filterSize + j]; |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
358 } |
29481 | 359 } else { |
27580
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
360 for (j=0; j<filterSize; j++) |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
361 filter2[i*filter2Size + j]= filter[i*filterSize + j]; |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
362 } |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
363 //FIXME dstFilter |
18861 | 364 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
365 (*filterPos)[i]+= (filterSize-1)/2 - (filter2Size-1)/2; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
366 } |
27299
4e57d47ee5db
Cleanup, use av_freep() instead of av_free(x); x=NULL
michael
parents:
27286
diff
changeset
|
367 av_freep(&filter); |
18861 | 368 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
369 /* try to reduce the filter-size (step1 find size and shift left) */ |
23536 | 370 // Assume it is near normalized (*0.5 or *2.0 is OK but * 0.001 is not). |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
371 minFilterSize= 0; |
29481 | 372 for (i=dstW-1; i>=0; i--) { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
373 int min= filter2Size; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
374 int j; |
27580
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
375 int64_t cutOff=0.0; |
18861 | 376 |
30296 | 377 /* get rid of near zero elements on the left by shifting left */ |
29481 | 378 for (j=0; j<filter2Size; j++) { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
379 int k; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
380 cutOff += FFABS(filter2[i*filter2Size]); |
18861 | 381 |
27580
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
382 if (cutOff > SWS_MAX_REDUCE_CUTOFF*fone) break; |
18861 | 383 |
23536 | 384 /* preserve monotonicity because the core can't handle the filter otherwise */ |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
385 if (i<dstW-1 && (*filterPos)[i] >= (*filterPos)[i+1]) break; |
18861 | 386 |
28316 | 387 // move filter coefficients left |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
388 for (k=1; k<filter2Size; k++) |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
389 filter2[i*filter2Size + k - 1]= filter2[i*filter2Size + k]; |
27580
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
390 filter2[i*filter2Size + k - 1]= 0; |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
391 (*filterPos)[i]++; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
392 } |
18861 | 393 |
27580
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
394 cutOff=0; |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
395 /* count near zeros on the right */ |
29481 | 396 for (j=filter2Size-1; j>0; j--) { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
397 cutOff += FFABS(filter2[i*filter2Size + j]); |
18861 | 398 |
27580
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
399 if (cutOff > SWS_MAX_REDUCE_CUTOFF*fone) break; |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
400 min--; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
401 } |
18861 | 402 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
403 if (min>minFilterSize) minFilterSize= min; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
404 } |
18861 | 405 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
406 if (flags & SWS_CPU_CAPS_ALTIVEC) { |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
407 // we can handle the special case 4, |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
408 // so we don't want to go to the full 8 |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
409 if (minFilterSize < 5) |
18861 | 410 filterAlign = 4; |
411 | |
28316 | 412 // We really don't want to waste our time |
413 // doing useless computation, so fall back on | |
414 // the scalar C code for very small filters. | |
415 // Vectorizing is worth it only if you have a | |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
416 // decent-sized vector. |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
417 if (minFilterSize < 3) |
18861 | 418 filterAlign = 1; |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
419 } |
18861 | 420 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
421 if (flags & SWS_CPU_CAPS_MMX) { |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
422 // special case for unscaled vertical filtering |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
423 if (minFilterSize == 1 && filterAlign == 2) |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
424 filterAlign= 1; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
425 } |
19172
bae6c99a99cc
vertical scaler with accurate rounding, some people on doom9 can see +-1 errors
michael
parents:
19169
diff
changeset
|
426 |
27182
f7b6d1014b6b
Remove ASSERT() macro. SoC Patch from Keiji Costantini
lu_zero
parents:
27181
diff
changeset
|
427 assert(minFilterSize > 0); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
428 filterSize= (minFilterSize +(filterAlign-1)) & (~(filterAlign-1)); |
27182
f7b6d1014b6b
Remove ASSERT() macro. SoC Patch from Keiji Costantini
lu_zero
parents:
27181
diff
changeset
|
429 assert(filterSize > 0); |
27579 | 430 filter= av_malloc(filterSize*dstW*sizeof(*filter)); |
27513 | 431 if (filterSize >= MAX_FILTER_SIZE*16/((flags&SWS_ACCURATE_RND) ? APCK_SIZE : 16) || !filter) |
29542 | 432 goto fail; |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
433 *outFilterSize= filterSize; |
18861 | 434 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
435 if (flags&SWS_PRINT_INFO) |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
436 av_log(NULL, AV_LOG_VERBOSE, "SwScaler: reducing / aligning filtersize %d -> %d\n", filter2Size, filterSize); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
437 /* try to reduce the filter-size (step2 reduce it) */ |
29481 | 438 for (i=0; i<dstW; i++) { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
439 int j; |
18861 | 440 |
29481 | 441 for (j=0; j<filterSize; j++) { |
27580
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
442 if (j>=filter2Size) filter[i*filterSize + j]= 0; |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
443 else filter[i*filterSize + j]= filter2[i*filter2Size + j]; |
27563
39c8d234b98e
Ensure that additional filter coeffs that exist due to alignment
michael
parents:
27562
diff
changeset
|
444 if((flags & SWS_BITEXACT) && j>=minFilterSize) |
27580
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
445 filter[i*filterSize + j]= 0; |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
446 } |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
447 } |
23129 | 448 |
28316 | 449 //FIXME try to align filterPos if possible |
18861 | 450 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
451 //fix borders |
29481 | 452 for (i=0; i<dstW; i++) { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
453 int j; |
29481 | 454 if ((*filterPos)[i] < 0) { |
28316 | 455 // move filter coefficients left to compensate for filterPos |
29481 | 456 for (j=1; j<filterSize; j++) { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
457 int left= FFMAX(j + (*filterPos)[i], 0); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
458 filter[i*filterSize + left] += filter[i*filterSize + j]; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
459 filter[i*filterSize + j]=0; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
460 } |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
461 (*filterPos)[i]= 0; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
462 } |
18861 | 463 |
29481 | 464 if ((*filterPos)[i] + filterSize > srcW) { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
465 int shift= (*filterPos)[i] + filterSize - srcW; |
28316 | 466 // move filter coefficients right to compensate for filterPos |
29481 | 467 for (j=filterSize-2; j>=0; j--) { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
468 int right= FFMIN(j + shift, filterSize-1); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
469 filter[i*filterSize +right] += filter[i*filterSize +j]; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
470 filter[i*filterSize +j]=0; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
471 } |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
472 (*filterPos)[i]= srcW - filterSize; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
473 } |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
474 } |
18861 | 475 |
28316 | 476 // Note the +1 is for the MMX scaler which reads over the end |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
477 /* align at 16 for AltiVec (needed by hScale_altivec_real) */ |
29610
c35359578f8d
Rename CHECKED_ALLOC(Z) to FF_ALLOC(Z)_OR_GOTO and add context and label
ramiro
parents:
29609
diff
changeset
|
478 FF_ALLOCZ_OR_GOTO(NULL, *outFilter, *outFilterSize*(dstW+1)*sizeof(int16_t), fail); |
18861 | 479 |
28316 | 480 /* normalize & store in outFilter */ |
29481 | 481 for (i=0; i<dstW; i++) { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
482 int j; |
27580
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
483 int64_t error=0; |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
484 int64_t sum=0; |
18861 | 485 |
29481 | 486 for (j=0; j<filterSize; j++) { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
487 sum+= filter[i*filterSize + j]; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
488 } |
27580
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
489 sum= (sum + one/2)/ one; |
29481 | 490 for (j=0; j<*outFilterSize; j++) { |
27580
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
491 int64_t v= filter[i*filterSize + j] + error; |
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
492 int intV= ROUNDED_DIV(v, sum); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
493 (*outFilter)[i*(*outFilterSize) + j]= intV; |
27580
9ff7a64a51fa
Avoid using floating point for calculating filter coefficients.
michael
parents:
27579
diff
changeset
|
494 error= v - intV*sum; |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
495 } |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
496 } |
23129 | 497 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
498 (*filterPos)[dstW]= (*filterPos)[dstW-1]; // the MMX scaler will read over the end |
29481 | 499 for (i=0; i<*outFilterSize; i++) { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
500 int j= dstW*(*outFilterSize); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
501 (*outFilter)[j + i]= (*outFilter)[j + i - (*outFilterSize)]; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
502 } |
18861 | 503 |
27300 | 504 ret=0; |
29542 | 505 fail: |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
506 av_free(filter); |
27300 | 507 av_free(filter2); |
508 return ret; | |
18861 | 509 } |
510 | |
30369
8c479cb29c7a
Split swscale.c into scaler code (swscale.c) and utility code (utils.c).
ramiro
parents:
30343
diff
changeset
|
511 #if ARCH_X86 && (HAVE_MMX2 || CONFIG_RUNTIME_CPUDETECT) && CONFIG_GPL |
29468
947a942221c4
MMX2 horizontal scaler: Determine code size at runtime.
ramiro
parents:
29467
diff
changeset
|
512 static int initMMX2HScaler(int dstW, int xInc, uint8_t *filterCode, int16_t *filter, int32_t *filterPos, int numSplits) |
18861 | 513 { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
514 uint8_t *fragmentA; |
28957 | 515 x86_reg imm8OfPShufW1A; |
516 x86_reg imm8OfPShufW2A; | |
517 x86_reg fragmentLengthA; | |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
518 uint8_t *fragmentB; |
28957 | 519 x86_reg imm8OfPShufW1B; |
520 x86_reg imm8OfPShufW2B; | |
521 x86_reg fragmentLengthB; | |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
522 int fragmentPos; |
18861 | 523 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
524 int xpos, i; |
18861 | 525 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
526 // create an optimized horizontal scaling routine |
29936
f43f03c00402
Document the differences between the two asm fragments in initMMX2HScaler().
ramiro
parents:
29932
diff
changeset
|
527 /* This scaler is made of runtime-generated MMX2 code using specially |
f43f03c00402
Document the differences between the two asm fragments in initMMX2HScaler().
ramiro
parents:
29932
diff
changeset
|
528 * tuned pshufw instructions. For every four output pixels, if four |
f43f03c00402
Document the differences between the two asm fragments in initMMX2HScaler().
ramiro
parents:
29932
diff
changeset
|
529 * input pixels are enough for the fast bilinear scaling, then a chunk |
f43f03c00402
Document the differences between the two asm fragments in initMMX2HScaler().
ramiro
parents:
29932
diff
changeset
|
530 * of fragmentB is used. If five input pixels are needed, then a chunk |
f43f03c00402
Document the differences between the two asm fragments in initMMX2HScaler().
ramiro
parents:
29932
diff
changeset
|
531 * of fragmentA is used. |
f43f03c00402
Document the differences between the two asm fragments in initMMX2HScaler().
ramiro
parents:
29932
diff
changeset
|
532 */ |
18861 | 533 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
534 //code fragment |
18861 | 535 |
27744 | 536 __asm__ volatile( |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
537 "jmp 9f \n\t" |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
538 // Begin |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
539 "0: \n\t" |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
540 "movq (%%"REG_d", %%"REG_a"), %%mm3 \n\t" |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
541 "movd (%%"REG_c", %%"REG_S"), %%mm0 \n\t" |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
542 "movd 1(%%"REG_c", %%"REG_S"), %%mm1 \n\t" |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
543 "punpcklbw %%mm7, %%mm1 \n\t" |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
544 "punpcklbw %%mm7, %%mm0 \n\t" |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
545 "pshufw $0xFF, %%mm1, %%mm1 \n\t" |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
546 "1: \n\t" |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
547 "pshufw $0xFF, %%mm0, %%mm0 \n\t" |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
548 "2: \n\t" |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
549 "psubw %%mm1, %%mm0 \n\t" |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
550 "movl 8(%%"REG_b", %%"REG_a"), %%esi \n\t" |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
551 "pmullw %%mm3, %%mm0 \n\t" |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
552 "psllw $7, %%mm1 \n\t" |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
553 "paddw %%mm1, %%mm0 \n\t" |
18861 | 554 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
555 "movq %%mm0, (%%"REG_D", %%"REG_a") \n\t" |
18861 | 556 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
557 "add $8, %%"REG_a" \n\t" |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
558 // End |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
559 "9: \n\t" |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
560 // "int $3 \n\t" |
26238
726b915c2b45
Fix 64 bit shared library compilation with MMX2 by properly using PIC mangling.
diego
parents:
26232
diff
changeset
|
561 "lea " LOCAL_MANGLE(0b) ", %0 \n\t" |
726b915c2b45
Fix 64 bit shared library compilation with MMX2 by properly using PIC mangling.
diego
parents:
26232
diff
changeset
|
562 "lea " LOCAL_MANGLE(1b) ", %1 \n\t" |
726b915c2b45
Fix 64 bit shared library compilation with MMX2 by properly using PIC mangling.
diego
parents:
26232
diff
changeset
|
563 "lea " LOCAL_MANGLE(2b) ", %2 \n\t" |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
564 "dec %1 \n\t" |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
565 "dec %2 \n\t" |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
566 "sub %0, %1 \n\t" |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
567 "sub %0, %2 \n\t" |
26238
726b915c2b45
Fix 64 bit shared library compilation with MMX2 by properly using PIC mangling.
diego
parents:
26232
diff
changeset
|
568 "lea " LOCAL_MANGLE(9b) ", %3 \n\t" |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
569 "sub %0, %3 \n\t" |
18861 | 570 |
571 | |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
572 :"=r" (fragmentA), "=r" (imm8OfPShufW1A), "=r" (imm8OfPShufW2A), |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
573 "=r" (fragmentLengthA) |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
574 ); |
18861 | 575 |
27744 | 576 __asm__ volatile( |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
577 "jmp 9f \n\t" |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
578 // Begin |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
579 "0: \n\t" |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
580 "movq (%%"REG_d", %%"REG_a"), %%mm3 \n\t" |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
581 "movd (%%"REG_c", %%"REG_S"), %%mm0 \n\t" |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
582 "punpcklbw %%mm7, %%mm0 \n\t" |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
583 "pshufw $0xFF, %%mm0, %%mm1 \n\t" |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
584 "1: \n\t" |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
585 "pshufw $0xFF, %%mm0, %%mm0 \n\t" |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
586 "2: \n\t" |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
587 "psubw %%mm1, %%mm0 \n\t" |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
588 "movl 8(%%"REG_b", %%"REG_a"), %%esi \n\t" |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
589 "pmullw %%mm3, %%mm0 \n\t" |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
590 "psllw $7, %%mm1 \n\t" |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
591 "paddw %%mm1, %%mm0 \n\t" |
18861 | 592 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
593 "movq %%mm0, (%%"REG_D", %%"REG_a") \n\t" |
18861 | 594 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
595 "add $8, %%"REG_a" \n\t" |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
596 // End |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
597 "9: \n\t" |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
598 // "int $3 \n\t" |
26238
726b915c2b45
Fix 64 bit shared library compilation with MMX2 by properly using PIC mangling.
diego
parents:
26232
diff
changeset
|
599 "lea " LOCAL_MANGLE(0b) ", %0 \n\t" |
726b915c2b45
Fix 64 bit shared library compilation with MMX2 by properly using PIC mangling.
diego
parents:
26232
diff
changeset
|
600 "lea " LOCAL_MANGLE(1b) ", %1 \n\t" |
726b915c2b45
Fix 64 bit shared library compilation with MMX2 by properly using PIC mangling.
diego
parents:
26232
diff
changeset
|
601 "lea " LOCAL_MANGLE(2b) ", %2 \n\t" |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
602 "dec %1 \n\t" |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
603 "dec %2 \n\t" |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
604 "sub %0, %1 \n\t" |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
605 "sub %0, %2 \n\t" |
26238
726b915c2b45
Fix 64 bit shared library compilation with MMX2 by properly using PIC mangling.
diego
parents:
26232
diff
changeset
|
606 "lea " LOCAL_MANGLE(9b) ", %3 \n\t" |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
607 "sub %0, %3 \n\t" |
18861 | 608 |
609 | |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
610 :"=r" (fragmentB), "=r" (imm8OfPShufW1B), "=r" (imm8OfPShufW2B), |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
611 "=r" (fragmentLengthB) |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
612 ); |
18861 | 613 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
614 xpos= 0; //lumXInc/2 - 0x8000; // difference between pixel centers |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
615 fragmentPos=0; |
23129 | 616 |
29481 | 617 for (i=0; i<dstW/numSplits; i++) { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
618 int xx=xpos>>16; |
18861 | 619 |
29481 | 620 if ((i&3) == 0) { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
621 int a=0; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
622 int b=((xpos+xInc)>>16) - xx; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
623 int c=((xpos+xInc*2)>>16) - xx; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
624 int d=((xpos+xInc*3)>>16) - xx; |
29410
fd9b0bd6c908
MMX2 scaler: add variable to ease factorization of initMMX2Scaler().
ramiro
parents:
29407
diff
changeset
|
625 int inc = (d+1<4); |
29411 | 626 uint8_t *fragment = (d+1<4) ? fragmentB : fragmentA; |
627 x86_reg imm8OfPShufW1 = (d+1<4) ? imm8OfPShufW1B : imm8OfPShufW1A; | |
628 x86_reg imm8OfPShufW2 = (d+1<4) ? imm8OfPShufW2B : imm8OfPShufW2A; | |
629 x86_reg fragmentLength = (d+1<4) ? fragmentLengthB : fragmentLengthA; | |
29412
139af822b6ce
MMX2 scaler: Remove {} block leftover from factorization in initMMX2Scaler().
ramiro
parents:
29411
diff
changeset
|
630 int maxShift= 3-(d+inc); |
139af822b6ce
MMX2 scaler: Remove {} block leftover from factorization in initMMX2Scaler().
ramiro
parents:
29411
diff
changeset
|
631 int shift=0; |
18861 | 632 |
29468
947a942221c4
MMX2 horizontal scaler: Determine code size at runtime.
ramiro
parents:
29467
diff
changeset
|
633 if (filterCode) { |
29470 | 634 filter[i ] = (( xpos & 0xFFFF) ^ 0xFFFF)>>9; |
635 filter[i+1] = (((xpos+xInc ) & 0xFFFF) ^ 0xFFFF)>>9; | |
636 filter[i+2] = (((xpos+xInc*2) & 0xFFFF) ^ 0xFFFF)>>9; | |
637 filter[i+3] = (((xpos+xInc*3) & 0xFFFF) ^ 0xFFFF)>>9; | |
638 filterPos[i/2]= xx; | |
639 | |
640 memcpy(filterCode + fragmentPos, fragment, fragmentLength); | |
641 | |
642 filterCode[fragmentPos + imm8OfPShufW1]= | |
643 (a+inc) | ((b+inc)<<2) | ((c+inc)<<4) | ((d+inc)<<6); | |
644 filterCode[fragmentPos + imm8OfPShufW2]= | |
645 a | (b<<2) | (c<<4) | (d<<6); | |
646 | |
647 if (i+4-inc>=dstW) shift=maxShift; //avoid overread | |
648 else if ((filterPos[i/2]&3) <= maxShift) shift=filterPos[i/2]&3; //Align | |
649 | |
29481 | 650 if (shift && i>=shift) { |
29470 | 651 filterCode[fragmentPos + imm8OfPShufW1]+= 0x55*shift; |
652 filterCode[fragmentPos + imm8OfPShufW2]+= 0x55*shift; | |
653 filterPos[i/2]-=shift; | |
654 } | |
29468
947a942221c4
MMX2 horizontal scaler: Determine code size at runtime.
ramiro
parents:
29467
diff
changeset
|
655 } |
18861 | 656 |
29412
139af822b6ce
MMX2 scaler: Remove {} block leftover from factorization in initMMX2Scaler().
ramiro
parents:
29411
diff
changeset
|
657 fragmentPos+= fragmentLength; |
139af822b6ce
MMX2 scaler: Remove {} block leftover from factorization in initMMX2Scaler().
ramiro
parents:
29411
diff
changeset
|
658 |
29468
947a942221c4
MMX2 horizontal scaler: Determine code size at runtime.
ramiro
parents:
29467
diff
changeset
|
659 if (filterCode) |
29470 | 660 filterCode[fragmentPos]= RET; |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
661 } |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
662 xpos+=xInc; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
663 } |
29468
947a942221c4
MMX2 horizontal scaler: Determine code size at runtime.
ramiro
parents:
29467
diff
changeset
|
664 if (filterCode) |
29470 | 665 filterPos[((i/2)+1)&(~1)]= xpos>>16; // needed to jump to the next part |
29468
947a942221c4
MMX2 horizontal scaler: Determine code size at runtime.
ramiro
parents:
29467
diff
changeset
|
666 |
947a942221c4
MMX2 horizontal scaler: Determine code size at runtime.
ramiro
parents:
29467
diff
changeset
|
667 return fragmentPos + 1; |
18861 | 668 } |
30369
8c479cb29c7a
Split swscale.c into scaler code (swscale.c) and utility code (utils.c).
ramiro
parents:
30343
diff
changeset
|
669 #endif /* ARCH_X86 && (HAVE_MMX2 || CONFIG_RUNTIME_CPUDETECT) && CONFIG_GPL */ |
18861 | 670 |
30142
bd5ab02f84f8
Prefer enum PixelFormat over int for the type of the format parameter
stefano
parents:
30138
diff
changeset
|
671 static void getSubSampleFactors(int *h, int *v, enum PixelFormat format) |
29481 | 672 { |
30129
a8283bcc8d2e
Simplify getSubSampleFactors(), make it use the values provided by
stefano
parents:
30045
diff
changeset
|
673 *h = av_pix_fmt_descriptors[format].log2_chroma_w; |
a8283bcc8d2e
Simplify getSubSampleFactors(), make it use the values provided by
stefano
parents:
30045
diff
changeset
|
674 *v = av_pix_fmt_descriptors[format].log2_chroma_h; |
18861 | 675 } |
676 | |
29481 | 677 static uint16_t roundToInt16(int64_t f) |
678 { | |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
679 int r= (f + (1<<15))>>16; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
680 if (r<-0x7FFF) return 0x8000; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
681 else if (r> 0x7FFF) return 0x7FFF; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
682 else return r; |
18861 | 683 } |
684 | |
29481 | 685 int sws_setColorspaceDetails(SwsContext *c, const int inv_table[4], int srcRange, const int table[4], int dstRange, int brightness, int contrast, int saturation) |
686 { | |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
687 int64_t crv = inv_table[0]; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
688 int64_t cbu = inv_table[1]; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
689 int64_t cgu = -inv_table[2]; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
690 int64_t cgv = -inv_table[3]; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
691 int64_t cy = 1<<16; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
692 int64_t oy = 0; |
18861 | 693 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
694 memcpy(c->srcColorspaceTable, inv_table, sizeof(int)*4); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
695 memcpy(c->dstColorspaceTable, table, sizeof(int)*4); |
18861 | 696 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
697 c->brightness= brightness; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
698 c->contrast = contrast; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
699 c->saturation= saturation; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
700 c->srcRange = srcRange; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
701 c->dstRange = dstRange; |
29146
d6d87abb137f
Make sws_setColorspaceDetails() return -1 if the destination format is
stefano
parents:
29145
diff
changeset
|
702 if (isYUV(c->dstFormat) || isGray(c->dstFormat)) return -1; |
18861 | 703 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
704 c->uOffset= 0x0400040004000400LL; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
705 c->vOffset= 0x0400040004000400LL; |
18861 | 706 |
29481 | 707 if (!srcRange) { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
708 cy= (cy*255) / 219; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
709 oy= 16<<16; |
29481 | 710 } else { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
711 crv= (crv*224) / 255; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
712 cbu= (cbu*224) / 255; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
713 cgu= (cgu*224) / 255; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
714 cgv= (cgv*224) / 255; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
715 } |
18861 | 716 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
717 cy = (cy *contrast )>>16; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
718 crv= (crv*contrast * saturation)>>32; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
719 cbu= (cbu*contrast * saturation)>>32; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
720 cgu= (cgu*contrast * saturation)>>32; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
721 cgv= (cgv*contrast * saturation)>>32; |
18861 | 722 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
723 oy -= 256*brightness; |
18861 | 724 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
725 c->yCoeff= roundToInt16(cy *8192) * 0x0001000100010001ULL; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
726 c->vrCoeff= roundToInt16(crv*8192) * 0x0001000100010001ULL; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
727 c->ubCoeff= roundToInt16(cbu*8192) * 0x0001000100010001ULL; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
728 c->vgCoeff= roundToInt16(cgv*8192) * 0x0001000100010001ULL; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
729 c->ugCoeff= roundToInt16(cgu*8192) * 0x0001000100010001ULL; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
730 c->yOffset= roundToInt16(oy * 8) * 0x0001000100010001ULL; |
18861 | 731 |
27567
203ac2c7f613
Rename yuv2rgb variables to avoid name clashes with the ones used by bfin asm.
michael
parents:
27563
diff
changeset
|
732 c->yuv2rgb_y_coeff = (int16_t)roundToInt16(cy <<13); |
203ac2c7f613
Rename yuv2rgb variables to avoid name clashes with the ones used by bfin asm.
michael
parents:
27563
diff
changeset
|
733 c->yuv2rgb_y_offset = (int16_t)roundToInt16(oy << 9); |
203ac2c7f613
Rename yuv2rgb variables to avoid name clashes with the ones used by bfin asm.
michael
parents:
27563
diff
changeset
|
734 c->yuv2rgb_v2r_coeff= (int16_t)roundToInt16(crv<<13); |
203ac2c7f613
Rename yuv2rgb variables to avoid name clashes with the ones used by bfin asm.
michael
parents:
27563
diff
changeset
|
735 c->yuv2rgb_v2g_coeff= (int16_t)roundToInt16(cgv<<13); |
203ac2c7f613
Rename yuv2rgb variables to avoid name clashes with the ones used by bfin asm.
michael
parents:
27563
diff
changeset
|
736 c->yuv2rgb_u2g_coeff= (int16_t)roundToInt16(cgu<<13); |
203ac2c7f613
Rename yuv2rgb variables to avoid name clashes with the ones used by bfin asm.
michael
parents:
27563
diff
changeset
|
737 c->yuv2rgb_u2b_coeff= (int16_t)roundToInt16(cbu<<13); |
27548
78da4c8b2293
Implement full horizontal chroma for rgb/bgr24/32 output.
michael
parents:
27547
diff
changeset
|
738 |
28953
1e56ea9937ce
Consistently use ff_ prefixes for internal symbols.
diego
parents:
28951
diff
changeset
|
739 ff_yuv2rgb_c_init_tables(c, inv_table, srcRange, brightness, contrast, saturation); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
740 //FIXME factorize |
18861 | 741 |
30369
8c479cb29c7a
Split swscale.c into scaler code (swscale.c) and utility code (utils.c).
ramiro
parents:
30343
diff
changeset
|
742 #if ARCH_PPC && (HAVE_ALTIVEC || CONFIG_RUNTIME_CPUDETECT) |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
743 if (c->flags & SWS_CPU_CAPS_ALTIVEC) |
28953
1e56ea9937ce
Consistently use ff_ prefixes for internal symbols.
diego
parents:
28951
diff
changeset
|
744 ff_yuv2rgb_init_tables_altivec(c, inv_table, brightness, contrast, saturation); |
23129 | 745 #endif |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
746 return 0; |
18861 | 747 } |
748 | |
29481 | 749 int sws_getColorspaceDetails(SwsContext *c, int **inv_table, int *srcRange, int **table, int *dstRange, int *brightness, int *contrast, int *saturation) |
750 { | |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
751 if (isYUV(c->dstFormat) || isGray(c->dstFormat)) return -1; |
18861 | 752 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
753 *inv_table = c->srcColorspaceTable; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
754 *table = c->dstColorspaceTable; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
755 *srcRange = c->srcRange; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
756 *dstRange = c->dstRange; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
757 *brightness= c->brightness; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
758 *contrast = c->contrast; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
759 *saturation= c->saturation; |
23129 | 760 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
761 return 0; |
18861 | 762 } |
763 | |
27696
0c2dc440984b
Change one more variable type from int to enum PixelFormat.
aurel
parents:
27695
diff
changeset
|
764 static int handle_jpeg(enum PixelFormat *format) |
19987 | 765 { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
766 switch (*format) { |
29480 | 767 case PIX_FMT_YUVJ420P: |
768 *format = PIX_FMT_YUV420P; | |
769 return 1; | |
770 case PIX_FMT_YUVJ422P: | |
771 *format = PIX_FMT_YUV422P; | |
772 return 1; | |
773 case PIX_FMT_YUVJ444P: | |
774 *format = PIX_FMT_YUV444P; | |
775 return 1; | |
776 case PIX_FMT_YUVJ440P: | |
777 *format = PIX_FMT_YUV440P; | |
778 return 1; | |
779 default: | |
780 return 0; | |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
781 } |
19987 | 782 } |
783 | |
30336 | 784 SwsContext *sws_getContext(int srcW, int srcH, enum PixelFormat srcFormat, |
785 int dstW, int dstH, enum PixelFormat dstFormat, int flags, | |
29246
8861e08033eb
Add const qualifier to param argument of sws_getContext() and
diego
parents:
29245
diff
changeset
|
786 SwsFilter *srcFilter, SwsFilter *dstFilter, const double *param) |
8861e08033eb
Add const qualifier to param argument of sws_getContext() and
diego
parents:
29245
diff
changeset
|
787 { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
788 SwsContext *c; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
789 int i; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
790 int usesVFilter, usesHFilter; |
30369
8c479cb29c7a
Split swscale.c into scaler code (swscale.c) and utility code (utils.c).
ramiro
parents:
30343
diff
changeset
|
791 int unscaled; |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
792 int srcRange, dstRange; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
793 SwsFilter dummyFilter= {NULL, NULL, NULL, NULL}; |
28276 | 794 #if ARCH_X86 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
795 if (flags & SWS_CPU_CAPS_MMX) |
27744 | 796 __asm__ volatile("emms\n\t"::: "memory"); |
18861 | 797 #endif |
798 | |
29348
1ee2b495f09b
AltiVec code and runtime cpudetect do not require CONFIG_GPL.
diego
parents:
29347
diff
changeset
|
799 #if !CONFIG_RUNTIME_CPUDETECT //ensure that the flags match the compiled variant if cpudetect is off |
23289
786823779b67
Blackfin optimized YUV420 to RGB CSC Color Space Converters.
gpoirier
parents:
23278
diff
changeset
|
800 flags &= ~(SWS_CPU_CAPS_MMX|SWS_CPU_CAPS_MMX2|SWS_CPU_CAPS_3DNOW|SWS_CPU_CAPS_ALTIVEC|SWS_CPU_CAPS_BFIN); |
30369
8c479cb29c7a
Split swscale.c into scaler code (swscale.c) and utility code (utils.c).
ramiro
parents:
30343
diff
changeset
|
801 flags |= ff_hardcodedcpuflags(); |
29114
06540eb5ef6a
Rename RUNTIME_CPUDETECT to CONFIG_RUNTIME_CPUDETECT and always define it.
ramiro
parents:
29109
diff
changeset
|
802 #endif /* CONFIG_RUNTIME_CPUDETECT */ |
25752
559b0e9d47fb
Change (a == NULL) condition to (!a) and (a != NULL) condition to (a).
benoit
parents:
25750
diff
changeset
|
803 if (!rgb15to16) sws_rgb2rgb_init(flags); |
18861 | 804 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
805 unscaled = (srcW == dstW && srcH == dstH); |
18861 | 806 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
807 srcRange = handle_jpeg(&srcFormat); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
808 dstRange = handle_jpeg(&dstFormat); |
19987 | 809 |
29481 | 810 if (!isSupportedIn(srcFormat)) { |
25967
87331ea89425
More explicit unsupported pixel format error messages.
benoit
parents:
25935
diff
changeset
|
811 av_log(NULL, AV_LOG_ERROR, "swScaler: %s is not supported as input pixel format\n", sws_format_name(srcFormat)); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
812 return NULL; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
813 } |
29481 | 814 if (!isSupportedOut(dstFormat)) { |
25967
87331ea89425
More explicit unsupported pixel format error messages.
benoit
parents:
25935
diff
changeset
|
815 av_log(NULL, AV_LOG_ERROR, "swScaler: %s is not supported as output pixel format\n", sws_format_name(dstFormat)); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
816 return NULL; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
817 } |
18861 | 818 |
27285 | 819 i= flags & ( SWS_POINT |
820 |SWS_AREA | |
27286 | 821 |SWS_BILINEAR |
27285 | 822 |SWS_FAST_BILINEAR |
823 |SWS_BICUBIC | |
824 |SWS_X | |
825 |SWS_GAUSS | |
826 |SWS_LANCZOS | |
827 |SWS_SINC | |
828 |SWS_SPLINE | |
829 |SWS_BICUBLIN); | |
29481 | 830 if(!i || (i & (i-1))) { |
28316 | 831 av_log(NULL, AV_LOG_ERROR, "swScaler: Exactly one scaler algorithm must be chosen\n"); |
27285 | 832 return NULL; |
833 } | |
834 | |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
835 /* sanity check */ |
29481 | 836 if (srcW<4 || srcH<1 || dstW<8 || dstH<1) { //FIXME check if these are enough and try to lowwer them after fixing the relevant parts of the code |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
837 av_log(NULL, AV_LOG_ERROR, "swScaler: %dx%d -> %dx%d is invalid scaling dimension\n", |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
838 srcW, srcH, dstW, dstH); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
839 return NULL; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
840 } |
29481 | 841 if(srcW > VOFW || dstW > VOFW) { |
28316 | 842 av_log(NULL, AV_LOG_ERROR, "swScaler: Compile-time maximum width is "AV_STRINGIFY(VOFW)" change VOF/VOFW and recompile\n"); |
26133
94cc4bac8cd0
Turn ancient V offset numerical constants into named ones.
michael
parents:
26028
diff
changeset
|
843 return NULL; |
94cc4bac8cd0
Turn ancient V offset numerical constants into named ones.
michael
parents:
26028
diff
changeset
|
844 } |
18861 | 845 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
846 if (!dstFilter) dstFilter= &dummyFilter; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
847 if (!srcFilter) srcFilter= &dummyFilter; |
18861 | 848 |
29610
c35359578f8d
Rename CHECKED_ALLOC(Z) to FF_ALLOC(Z)_OR_GOTO and add context and label
ramiro
parents:
29609
diff
changeset
|
849 FF_ALLOCZ_OR_GOTO(NULL, c, sizeof(SwsContext), fail); |
18861 | 850 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
851 c->av_class = &sws_context_class; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
852 c->srcW= srcW; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
853 c->srcH= srcH; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
854 c->dstW= dstW; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
855 c->dstH= dstH; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
856 c->lumXInc= ((srcW<<16) + (dstW>>1))/dstW; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
857 c->lumYInc= ((srcH<<16) + (dstH>>1))/dstH; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
858 c->flags= flags; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
859 c->dstFormat= dstFormat; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
860 c->srcFormat= srcFormat; |
30377
2eea1f09e2c5
Use av_get_bits_per_pixel() for computing the bits per pixel of the
stefano
parents:
30370
diff
changeset
|
861 c->dstFormatBpp = av_get_bits_per_pixel(&av_pix_fmt_descriptors[dstFormat]); |
2eea1f09e2c5
Use av_get_bits_per_pixel() for computing the bits per pixel of the
stefano
parents:
30370
diff
changeset
|
862 c->srcFormatBpp = av_get_bits_per_pixel(&av_pix_fmt_descriptors[srcFormat]); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
863 c->vRounder= 4* 0x0001000100010001ULL; |
18861 | 864 |
30478
838bbf6bc6ff
Simplify how usesVFilter and usesHFilter are set.
stefano
parents:
30432
diff
changeset
|
865 usesVFilter = (srcFilter->lumV && srcFilter->lumV->length>1) || |
838bbf6bc6ff
Simplify how usesVFilter and usesHFilter are set.
stefano
parents:
30432
diff
changeset
|
866 (srcFilter->chrV && srcFilter->chrV->length>1) || |
838bbf6bc6ff
Simplify how usesVFilter and usesHFilter are set.
stefano
parents:
30432
diff
changeset
|
867 (dstFilter->lumV && dstFilter->lumV->length>1) || |
838bbf6bc6ff
Simplify how usesVFilter and usesHFilter are set.
stefano
parents:
30432
diff
changeset
|
868 (dstFilter->chrV && dstFilter->chrV->length>1); |
838bbf6bc6ff
Simplify how usesVFilter and usesHFilter are set.
stefano
parents:
30432
diff
changeset
|
869 usesHFilter = (srcFilter->lumH && srcFilter->lumH->length>1) || |
838bbf6bc6ff
Simplify how usesVFilter and usesHFilter are set.
stefano
parents:
30432
diff
changeset
|
870 (srcFilter->chrH && srcFilter->chrH->length>1) || |
838bbf6bc6ff
Simplify how usesVFilter and usesHFilter are set.
stefano
parents:
30432
diff
changeset
|
871 (dstFilter->lumH && dstFilter->lumH->length>1) || |
838bbf6bc6ff
Simplify how usesVFilter and usesHFilter are set.
stefano
parents:
30432
diff
changeset
|
872 (dstFilter->chrH && dstFilter->chrH->length>1); |
18861 | 873 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
874 getSubSampleFactors(&c->chrSrcHSubSample, &c->chrSrcVSubSample, srcFormat); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
875 getSubSampleFactors(&c->chrDstHSubSample, &c->chrDstVSubSample, dstFormat); |
18861 | 876 |
28316 | 877 // reuse chroma for 2 pixels RGB/BGR unless user wants full chroma interpolation |
30393 | 878 if (isAnyRGB(dstFormat) && !(flags&SWS_FULL_CHR_H_INT)) c->chrDstHSubSample=1; |
18861 | 879 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
880 // drop some chroma lines if the user wants it |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
881 c->vChrDrop= (flags&SWS_SRC_V_CHR_DROP_MASK)>>SWS_SRC_V_CHR_DROP_SHIFT; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
882 c->chrSrcVSubSample+= c->vChrDrop; |
18861 | 883 |
28316 | 884 // drop every other pixel for chroma calculation unless user wants full chroma |
30393 | 885 if (isAnyRGB(srcFormat) && !(flags&SWS_FULL_CHR_H_INP) |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
886 && srcFormat!=PIX_FMT_RGB8 && srcFormat!=PIX_FMT_BGR8 |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
887 && srcFormat!=PIX_FMT_RGB4 && srcFormat!=PIX_FMT_BGR4 |
27529
ffb573fae5e8
Rewrite bgr24->yuv mmx code, the new code is cleaner, more accurate,
michael
parents:
27526
diff
changeset
|
888 && srcFormat!=PIX_FMT_RGB4_BYTE && srcFormat!=PIX_FMT_BGR4_BYTE |
27532 | 889 && ((dstW>>c->chrDstHSubSample) <= (srcW>>1) || (flags&(SWS_FAST_BILINEAR|SWS_POINT)))) |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
890 c->chrSrcHSubSample=1; |
18861 | 891 |
29481 | 892 if (param) { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
893 c->param[0] = param[0]; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
894 c->param[1] = param[1]; |
29481 | 895 } else { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
896 c->param[0] = |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
897 c->param[1] = SWS_PARAM_DEFAULT; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
898 } |
18861 | 899 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
900 // Note the -((-x)>>y) is so that we always round toward +inf. |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
901 c->chrSrcW= -((-srcW) >> c->chrSrcHSubSample); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
902 c->chrSrcH= -((-srcH) >> c->chrSrcVSubSample); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
903 c->chrDstW= -((-dstW) >> c->chrDstHSubSample); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
904 c->chrDstH= -((-dstH) >> c->chrDstVSubSample); |
18861 | 905 |
28460 | 906 sws_setColorspaceDetails(c, ff_yuv2rgb_coeffs[SWS_CS_DEFAULT], srcRange, ff_yuv2rgb_coeffs[SWS_CS_DEFAULT] /* FIXME*/, dstRange, 0, 1<<16, 1<<16); |
18861 | 907 |
28316 | 908 /* unscaled special cases */ |
30393 | 909 if (unscaled && !usesHFilter && !usesVFilter && (srcRange == dstRange || isAnyRGB(dstFormat))) { |
30369
8c479cb29c7a
Split swscale.c into scaler code (swscale.c) and utility code (utils.c).
ramiro
parents:
30343
diff
changeset
|
910 ff_get_unscaled_swscale(c); |
23585
d3ae6979d3df
integrating ff_bfin_get_unscaled_swscale into the system
mhoffman
parents:
23536
diff
changeset
|
911 |
29481 | 912 if (c->swScale) { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
913 if (flags&SWS_PRINT_INFO) |
26150
1df4a811aa9c
remove redundant SwScaler text since av_log uses AVClass context
bcoudurier
parents:
26134
diff
changeset
|
914 av_log(c, AV_LOG_INFO, "using unscaled %s -> %s special converter\n", |
29480 | 915 sws_format_name(srcFormat), sws_format_name(dstFormat)); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
916 return c; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
917 } |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
918 } |
18861 | 919 |
29481 | 920 if (flags & SWS_CPU_CAPS_MMX2) { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
921 c->canMMX2BeUsed= (dstW >=srcW && (dstW&31)==0 && (srcW&15)==0) ? 1 : 0; |
29481 | 922 if (!c->canMMX2BeUsed && dstW >=srcW && (srcW&15)==0 && (flags&SWS_FAST_BILINEAR)) { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
923 if (flags&SWS_PRINT_INFO) |
28316 | 924 av_log(c, AV_LOG_INFO, "output width is not a multiple of 32 -> no MMX2 scaler\n"); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
925 } |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
926 if (usesHFilter) c->canMMX2BeUsed=0; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
927 } |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
928 else |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
929 c->canMMX2BeUsed=0; |
18861 | 930 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
931 c->chrXInc= ((c->chrSrcW<<16) + (c->chrDstW>>1))/c->chrDstW; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
932 c->chrYInc= ((c->chrSrcH<<16) + (c->chrDstH>>1))/c->chrDstH; |
18861 | 933 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
934 // match pixel 0 of the src to pixel 0 of dst and match pixel n-2 of src to pixel n-2 of dst |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
935 // but only for the FAST_BILINEAR mode otherwise do correct scaling |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
936 // n-2 is the last chrominance sample available |
23536 | 937 // this is not perfect, but no one should notice the difference, the more correct variant |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
938 // would be like the vertical one, but that would require some special code for the |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
939 // first and last pixel |
29481 | 940 if (flags&SWS_FAST_BILINEAR) { |
941 if (c->canMMX2BeUsed) { | |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
942 c->lumXInc+= 20; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
943 c->chrXInc+= 20; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
944 } |
28316 | 945 //we don't use the x86 asm scaler if MMX is available |
29481 | 946 else if (flags & SWS_CPU_CAPS_MMX) { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
947 c->lumXInc = ((srcW-2)<<16)/(dstW-2) - 20; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
948 c->chrXInc = ((c->chrSrcW-2)<<16)/(c->chrDstW-2) - 20; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
949 } |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
950 } |
18861 | 951 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
952 /* precalculate horizontal scaler filter coefficients */ |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
953 { |
30369
8c479cb29c7a
Split swscale.c into scaler code (swscale.c) and utility code (utils.c).
ramiro
parents:
30343
diff
changeset
|
954 #if ARCH_X86 && (HAVE_MMX2 || CONFIG_RUNTIME_CPUDETECT) && CONFIG_GPL |
18861 | 955 // can't downscale !!! |
29481 | 956 if (c->canMMX2BeUsed && (flags & SWS_FAST_BILINEAR)) { |
29468
947a942221c4
MMX2 horizontal scaler: Determine code size at runtime.
ramiro
parents:
29467
diff
changeset
|
957 c->lumMmx2FilterCodeSize = initMMX2HScaler( dstW, c->lumXInc, NULL, NULL, NULL, 8); |
947a942221c4
MMX2 horizontal scaler: Determine code size at runtime.
ramiro
parents:
29467
diff
changeset
|
958 c->chrMmx2FilterCodeSize = initMMX2HScaler(c->chrDstW, c->chrXInc, NULL, NULL, NULL, 4); |
947a942221c4
MMX2 horizontal scaler: Determine code size at runtime.
ramiro
parents:
29467
diff
changeset
|
959 |
18861 | 960 #ifdef MAP_ANONYMOUS |
29468
947a942221c4
MMX2 horizontal scaler: Determine code size at runtime.
ramiro
parents:
29467
diff
changeset
|
961 c->lumMmx2FilterCode = mmap(NULL, c->lumMmx2FilterCodeSize, PROT_READ | PROT_WRITE, MAP_PRIVATE | MAP_ANONYMOUS, 0, 0); |
947a942221c4
MMX2 horizontal scaler: Determine code size at runtime.
ramiro
parents:
29467
diff
changeset
|
962 c->chrMmx2FilterCode = mmap(NULL, c->chrMmx2FilterCodeSize, PROT_READ | PROT_WRITE, MAP_PRIVATE | MAP_ANONYMOUS, 0, 0); |
28971
b8e356a9dbb1
Allocate executable memory with VirtualAlloc() in Windows.
ramiro
parents:
28970
diff
changeset
|
963 #elif HAVE_VIRTUALALLOC |
29468
947a942221c4
MMX2 horizontal scaler: Determine code size at runtime.
ramiro
parents:
29467
diff
changeset
|
964 c->lumMmx2FilterCode = VirtualAlloc(NULL, c->lumMmx2FilterCodeSize, MEM_COMMIT, PAGE_EXECUTE_READWRITE); |
947a942221c4
MMX2 horizontal scaler: Determine code size at runtime.
ramiro
parents:
29467
diff
changeset
|
965 c->chrMmx2FilterCode = VirtualAlloc(NULL, c->chrMmx2FilterCodeSize, MEM_COMMIT, PAGE_EXECUTE_READWRITE); |
18861 | 966 #else |
29468
947a942221c4
MMX2 horizontal scaler: Determine code size at runtime.
ramiro
parents:
29467
diff
changeset
|
967 c->lumMmx2FilterCode = av_malloc(c->lumMmx2FilterCodeSize); |
947a942221c4
MMX2 horizontal scaler: Determine code size at runtime.
ramiro
parents:
29467
diff
changeset
|
968 c->chrMmx2FilterCode = av_malloc(c->chrMmx2FilterCodeSize); |
18861 | 969 #endif |
970 | |
30285
042ec58ab0e2
Reuse h{lum,chr}Filter{,Pos} variables for MMX2 fast_bilinear horizontal scaler.
ramiro
parents:
30284
diff
changeset
|
971 FF_ALLOCZ_OR_GOTO(c, c->hLumFilter , (dstW /8+8)*sizeof(int16_t), fail); |
042ec58ab0e2
Reuse h{lum,chr}Filter{,Pos} variables for MMX2 fast_bilinear horizontal scaler.
ramiro
parents:
30284
diff
changeset
|
972 FF_ALLOCZ_OR_GOTO(c, c->hChrFilter , (c->chrDstW /4+8)*sizeof(int16_t), fail); |
042ec58ab0e2
Reuse h{lum,chr}Filter{,Pos} variables for MMX2 fast_bilinear horizontal scaler.
ramiro
parents:
30284
diff
changeset
|
973 FF_ALLOCZ_OR_GOTO(c, c->hLumFilterPos, (dstW /2/8+8)*sizeof(int32_t), fail); |
042ec58ab0e2
Reuse h{lum,chr}Filter{,Pos} variables for MMX2 fast_bilinear horizontal scaler.
ramiro
parents:
30284
diff
changeset
|
974 FF_ALLOCZ_OR_GOTO(c, c->hChrFilterPos, (c->chrDstW/2/4+8)*sizeof(int32_t), fail); |
042ec58ab0e2
Reuse h{lum,chr}Filter{,Pos} variables for MMX2 fast_bilinear horizontal scaler.
ramiro
parents:
30284
diff
changeset
|
975 |
042ec58ab0e2
Reuse h{lum,chr}Filter{,Pos} variables for MMX2 fast_bilinear horizontal scaler.
ramiro
parents:
30284
diff
changeset
|
976 initMMX2HScaler( dstW, c->lumXInc, c->lumMmx2FilterCode, c->hLumFilter, c->hLumFilterPos, 8); |
042ec58ab0e2
Reuse h{lum,chr}Filter{,Pos} variables for MMX2 fast_bilinear horizontal scaler.
ramiro
parents:
30284
diff
changeset
|
977 initMMX2HScaler(c->chrDstW, c->chrXInc, c->chrMmx2FilterCode, c->hChrFilter, c->hChrFilterPos, 4); |
29467
1acbe8b170ed
Protect mmx2 filter code buffers so they are not executable and writeable at
ramiro
parents:
29465
diff
changeset
|
978 |
1acbe8b170ed
Protect mmx2 filter code buffers so they are not executable and writeable at
ramiro
parents:
29465
diff
changeset
|
979 #ifdef MAP_ANONYMOUS |
29468
947a942221c4
MMX2 horizontal scaler: Determine code size at runtime.
ramiro
parents:
29467
diff
changeset
|
980 mprotect(c->lumMmx2FilterCode, c->lumMmx2FilterCodeSize, PROT_EXEC | PROT_READ); |
947a942221c4
MMX2 horizontal scaler: Determine code size at runtime.
ramiro
parents:
29467
diff
changeset
|
981 mprotect(c->chrMmx2FilterCode, c->chrMmx2FilterCodeSize, PROT_EXEC | PROT_READ); |
29467
1acbe8b170ed
Protect mmx2 filter code buffers so they are not executable and writeable at
ramiro
parents:
29465
diff
changeset
|
982 #endif |
30271
2fad32dd128c
Don't initialize normal horizontal filter if MMX2 filter is used.
ramiro
parents:
30264
diff
changeset
|
983 } else |
30369
8c479cb29c7a
Split swscale.c into scaler code (swscale.c) and utility code (utils.c).
ramiro
parents:
30343
diff
changeset
|
984 #endif /* ARCH_X86 && (HAVE_MMX2 || CONFIG_RUNTIME_CPUDETECT) && CONFIG_GPL */ |
30271
2fad32dd128c
Don't initialize normal horizontal filter if MMX2 filter is used.
ramiro
parents:
30264
diff
changeset
|
985 { |
2fad32dd128c
Don't initialize normal horizontal filter if MMX2 filter is used.
ramiro
parents:
30264
diff
changeset
|
986 const int filterAlign= |
2fad32dd128c
Don't initialize normal horizontal filter if MMX2 filter is used.
ramiro
parents:
30264
diff
changeset
|
987 (flags & SWS_CPU_CAPS_MMX) ? 4 : |
2fad32dd128c
Don't initialize normal horizontal filter if MMX2 filter is used.
ramiro
parents:
30264
diff
changeset
|
988 (flags & SWS_CPU_CAPS_ALTIVEC) ? 8 : |
2fad32dd128c
Don't initialize normal horizontal filter if MMX2 filter is used.
ramiro
parents:
30264
diff
changeset
|
989 1; |
2fad32dd128c
Don't initialize normal horizontal filter if MMX2 filter is used.
ramiro
parents:
30264
diff
changeset
|
990 |
2fad32dd128c
Don't initialize normal horizontal filter if MMX2 filter is used.
ramiro
parents:
30264
diff
changeset
|
991 if (initFilter(&c->hLumFilter, &c->hLumFilterPos, &c->hLumFilterSize, c->lumXInc, |
2fad32dd128c
Don't initialize normal horizontal filter if MMX2 filter is used.
ramiro
parents:
30264
diff
changeset
|
992 srcW , dstW, filterAlign, 1<<14, |
2fad32dd128c
Don't initialize normal horizontal filter if MMX2 filter is used.
ramiro
parents:
30264
diff
changeset
|
993 (flags&SWS_BICUBLIN) ? (flags|SWS_BICUBIC) : flags, |
2fad32dd128c
Don't initialize normal horizontal filter if MMX2 filter is used.
ramiro
parents:
30264
diff
changeset
|
994 srcFilter->lumH, dstFilter->lumH, c->param) < 0) |
2fad32dd128c
Don't initialize normal horizontal filter if MMX2 filter is used.
ramiro
parents:
30264
diff
changeset
|
995 goto fail; |
2fad32dd128c
Don't initialize normal horizontal filter if MMX2 filter is used.
ramiro
parents:
30264
diff
changeset
|
996 if (initFilter(&c->hChrFilter, &c->hChrFilterPos, &c->hChrFilterSize, c->chrXInc, |
2fad32dd128c
Don't initialize normal horizontal filter if MMX2 filter is used.
ramiro
parents:
30264
diff
changeset
|
997 c->chrSrcW, c->chrDstW, filterAlign, 1<<14, |
2fad32dd128c
Don't initialize normal horizontal filter if MMX2 filter is used.
ramiro
parents:
30264
diff
changeset
|
998 (flags&SWS_BICUBLIN) ? (flags|SWS_BILINEAR) : flags, |
2fad32dd128c
Don't initialize normal horizontal filter if MMX2 filter is used.
ramiro
parents:
30264
diff
changeset
|
999 srcFilter->chrH, dstFilter->chrH, c->param) < 0) |
2fad32dd128c
Don't initialize normal horizontal filter if MMX2 filter is used.
ramiro
parents:
30264
diff
changeset
|
1000 goto fail; |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1001 } |
28316 | 1002 } // initialize horizontal stuff |
18861 | 1003 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1004 /* precalculate vertical scaler filter coefficients */ |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1005 { |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1006 const int filterAlign= |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1007 (flags & SWS_CPU_CAPS_MMX) && (flags & SWS_ACCURATE_RND) ? 2 : |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1008 (flags & SWS_CPU_CAPS_ALTIVEC) ? 8 : |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1009 1; |
18861 | 1010 |
29544 | 1011 if (initFilter(&c->vLumFilter, &c->vLumFilterPos, &c->vLumFilterSize, c->lumYInc, |
30045 | 1012 srcH , dstH, filterAlign, (1<<12), |
1013 (flags&SWS_BICUBLIN) ? (flags|SWS_BICUBIC) : flags, | |
1014 srcFilter->lumV, dstFilter->lumV, c->param) < 0) | |
29544 | 1015 goto fail; |
1016 if (initFilter(&c->vChrFilter, &c->vChrFilterPos, &c->vChrFilterSize, c->chrYInc, | |
30045 | 1017 c->chrSrcH, c->chrDstH, filterAlign, (1<<12), |
1018 (flags&SWS_BICUBLIN) ? (flags|SWS_BILINEAR) : flags, | |
1019 srcFilter->chrV, dstFilter->chrV, c->param) < 0) | |
29544 | 1020 goto fail; |
18861 | 1021 |
30369
8c479cb29c7a
Split swscale.c into scaler code (swscale.c) and utility code (utils.c).
ramiro
parents:
30343
diff
changeset
|
1022 #if ARCH_PPC && (HAVE_ALTIVEC || CONFIG_RUNTIME_CPUDETECT) |
29610
c35359578f8d
Rename CHECKED_ALLOC(Z) to FF_ALLOC(Z)_OR_GOTO and add context and label
ramiro
parents:
29609
diff
changeset
|
1023 FF_ALLOC_OR_GOTO(c, c->vYCoeffsBank, sizeof (vector signed short)*c->vLumFilterSize*c->dstH, fail); |
c35359578f8d
Rename CHECKED_ALLOC(Z) to FF_ALLOC(Z)_OR_GOTO and add context and label
ramiro
parents:
29609
diff
changeset
|
1024 FF_ALLOC_OR_GOTO(c, c->vCCoeffsBank, sizeof (vector signed short)*c->vChrFilterSize*c->chrDstH, fail); |
18861 | 1025 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1026 for (i=0;i<c->vLumFilterSize*c->dstH;i++) { |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1027 int j; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1028 short *p = (short *)&c->vYCoeffsBank[i]; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1029 for (j=0;j<8;j++) |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1030 p[j] = c->vLumFilter[i]; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1031 } |
18861 | 1032 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1033 for (i=0;i<c->vChrFilterSize*c->chrDstH;i++) { |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1034 int j; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1035 short *p = (short *)&c->vCCoeffsBank[i]; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1036 for (j=0;j<8;j++) |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1037 p[j] = c->vChrFilter[i]; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1038 } |
18861 | 1039 #endif |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1040 } |
18861 | 1041 |
28316 | 1042 // calculate buffer sizes so that they won't run out while handling these damn slices |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1043 c->vLumBufSize= c->vLumFilterSize; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1044 c->vChrBufSize= c->vChrFilterSize; |
29481 | 1045 for (i=0; i<dstH; i++) { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1046 int chrI= i*c->chrDstH / dstH; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1047 int nextSlice= FFMAX(c->vLumFilterPos[i ] + c->vLumFilterSize - 1, |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1048 ((c->vChrFilterPos[chrI] + c->vChrFilterSize - 1)<<c->chrSrcVSubSample)); |
18861 | 1049 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1050 nextSlice>>= c->chrSrcVSubSample; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1051 nextSlice<<= c->chrSrcVSubSample; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1052 if (c->vLumFilterPos[i ] + c->vLumBufSize < nextSlice) |
25749 | 1053 c->vLumBufSize= nextSlice - c->vLumFilterPos[i]; |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1054 if (c->vChrFilterPos[chrI] + c->vChrBufSize < (nextSlice>>c->chrSrcVSubSample)) |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1055 c->vChrBufSize= (nextSlice>>c->chrSrcVSubSample) - c->vChrFilterPos[chrI]; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1056 } |
18861 | 1057 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1058 // allocate pixbufs (we use dynamic allocation because otherwise we would need to |
29540 | 1059 // allocate several megabytes to handle all possible cases) |
29610
c35359578f8d
Rename CHECKED_ALLOC(Z) to FF_ALLOC(Z)_OR_GOTO and add context and label
ramiro
parents:
29609
diff
changeset
|
1060 FF_ALLOC_OR_GOTO(c, c->lumPixBuf, c->vLumBufSize*2*sizeof(int16_t*), fail); |
c35359578f8d
Rename CHECKED_ALLOC(Z) to FF_ALLOC(Z)_OR_GOTO and add context and label
ramiro
parents:
29609
diff
changeset
|
1061 FF_ALLOC_OR_GOTO(c, c->chrPixBuf, c->vChrBufSize*2*sizeof(int16_t*), fail); |
28976 | 1062 if (CONFIG_SWSCALE_ALPHA && isALPHA(c->srcFormat) && isALPHA(c->dstFormat)) |
29610
c35359578f8d
Rename CHECKED_ALLOC(Z) to FF_ALLOC(Z)_OR_GOTO and add context and label
ramiro
parents:
29609
diff
changeset
|
1063 FF_ALLOCZ_OR_GOTO(c, c->alpPixBuf, c->vLumBufSize*2*sizeof(int16_t*), fail); |
28316 | 1064 //Note we need at least one pixel more at the end because of the MMX code (just in case someone wanna replace the 4000/8000) |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1065 /* align at 16 bytes for AltiVec */ |
29545 | 1066 for (i=0; i<c->vLumBufSize; i++) { |
29610
c35359578f8d
Rename CHECKED_ALLOC(Z) to FF_ALLOC(Z)_OR_GOTO and add context and label
ramiro
parents:
29609
diff
changeset
|
1067 FF_ALLOCZ_OR_GOTO(c, c->lumPixBuf[i+c->vLumBufSize], VOF+1, fail); |
29542 | 1068 c->lumPixBuf[i] = c->lumPixBuf[i+c->vLumBufSize]; |
1069 } | |
29545 | 1070 for (i=0; i<c->vChrBufSize; i++) { |
29610
c35359578f8d
Rename CHECKED_ALLOC(Z) to FF_ALLOC(Z)_OR_GOTO and add context and label
ramiro
parents:
29609
diff
changeset
|
1071 FF_ALLOC_OR_GOTO(c, c->chrPixBuf[i+c->vChrBufSize], (VOF+1)*2, fail); |
29542 | 1072 c->chrPixBuf[i] = c->chrPixBuf[i+c->vChrBufSize]; |
1073 } | |
28976 | 1074 if (CONFIG_SWSCALE_ALPHA && c->alpPixBuf) |
29545 | 1075 for (i=0; i<c->vLumBufSize; i++) { |
29610
c35359578f8d
Rename CHECKED_ALLOC(Z) to FF_ALLOC(Z)_OR_GOTO and add context and label
ramiro
parents:
29609
diff
changeset
|
1076 FF_ALLOCZ_OR_GOTO(c, c->alpPixBuf[i+c->vLumBufSize], VOF+1, fail); |
29542 | 1077 c->alpPixBuf[i] = c->alpPixBuf[i+c->vLumBufSize]; |
1078 } | |
18861 | 1079 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1080 //try to avoid drawing green stuff between the right end and the stride end |
26133
94cc4bac8cd0
Turn ancient V offset numerical constants into named ones.
michael
parents:
26028
diff
changeset
|
1081 for (i=0; i<c->vChrBufSize; i++) memset(c->chrPixBuf[i], 64, (VOF+1)*2); |
94cc4bac8cd0
Turn ancient V offset numerical constants into named ones.
michael
parents:
26028
diff
changeset
|
1082 |
26225 | 1083 assert(2*VOFW == VOF); |
18861 | 1084 |
27182
f7b6d1014b6b
Remove ASSERT() macro. SoC Patch from Keiji Costantini
lu_zero
parents:
27181
diff
changeset
|
1085 assert(c->chrDstH <= dstH); |
18861 | 1086 |
29481 | 1087 if (flags&SWS_PRINT_INFO) { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1088 if (flags&SWS_FAST_BILINEAR) |
26150
1df4a811aa9c
remove redundant SwScaler text since av_log uses AVClass context
bcoudurier
parents:
26134
diff
changeset
|
1089 av_log(c, AV_LOG_INFO, "FAST_BILINEAR scaler, "); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1090 else if (flags&SWS_BILINEAR) |
26150
1df4a811aa9c
remove redundant SwScaler text since av_log uses AVClass context
bcoudurier
parents:
26134
diff
changeset
|
1091 av_log(c, AV_LOG_INFO, "BILINEAR scaler, "); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1092 else if (flags&SWS_BICUBIC) |
26150
1df4a811aa9c
remove redundant SwScaler text since av_log uses AVClass context
bcoudurier
parents:
26134
diff
changeset
|
1093 av_log(c, AV_LOG_INFO, "BICUBIC scaler, "); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1094 else if (flags&SWS_X) |
26150
1df4a811aa9c
remove redundant SwScaler text since av_log uses AVClass context
bcoudurier
parents:
26134
diff
changeset
|
1095 av_log(c, AV_LOG_INFO, "Experimental scaler, "); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1096 else if (flags&SWS_POINT) |
26150
1df4a811aa9c
remove redundant SwScaler text since av_log uses AVClass context
bcoudurier
parents:
26134
diff
changeset
|
1097 av_log(c, AV_LOG_INFO, "Nearest Neighbor / POINT scaler, "); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1098 else if (flags&SWS_AREA) |
30262 | 1099 av_log(c, AV_LOG_INFO, "Area Averaging scaler, "); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1100 else if (flags&SWS_BICUBLIN) |
26150
1df4a811aa9c
remove redundant SwScaler text since av_log uses AVClass context
bcoudurier
parents:
26134
diff
changeset
|
1101 av_log(c, AV_LOG_INFO, "luma BICUBIC / chroma BILINEAR scaler, "); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1102 else if (flags&SWS_GAUSS) |
26150
1df4a811aa9c
remove redundant SwScaler text since av_log uses AVClass context
bcoudurier
parents:
26134
diff
changeset
|
1103 av_log(c, AV_LOG_INFO, "Gaussian scaler, "); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1104 else if (flags&SWS_SINC) |
26150
1df4a811aa9c
remove redundant SwScaler text since av_log uses AVClass context
bcoudurier
parents:
26134
diff
changeset
|
1105 av_log(c, AV_LOG_INFO, "Sinc scaler, "); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1106 else if (flags&SWS_LANCZOS) |
26150
1df4a811aa9c
remove redundant SwScaler text since av_log uses AVClass context
bcoudurier
parents:
26134
diff
changeset
|
1107 av_log(c, AV_LOG_INFO, "Lanczos scaler, "); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1108 else if (flags&SWS_SPLINE) |
26150
1df4a811aa9c
remove redundant SwScaler text since av_log uses AVClass context
bcoudurier
parents:
26134
diff
changeset
|
1109 av_log(c, AV_LOG_INFO, "Bicubic spline scaler, "); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1110 else |
26150
1df4a811aa9c
remove redundant SwScaler text since av_log uses AVClass context
bcoudurier
parents:
26134
diff
changeset
|
1111 av_log(c, AV_LOG_INFO, "ehh flags invalid?! "); |
18861 | 1112 |
30288
4ee0cedb32f2
Prefer "to %s%s" over "to%s %s", slightly more readable.
stefano
parents:
30287
diff
changeset
|
1113 av_log(c, AV_LOG_INFO, "from %s to %s%s ", |
30284
03f99130b7c3
Factorize code which logs the source and destination formats in
stefano
parents:
30275
diff
changeset
|
1114 sws_format_name(srcFormat), |
30287
67cace3e3df7
Simplify code in sws_getContext() which logs if the destination format
stefano
parents:
30285
diff
changeset
|
1115 #ifdef DITHER1XBPP |
30288
4ee0cedb32f2
Prefer "to %s%s" over "to%s %s", slightly more readable.
stefano
parents:
30287
diff
changeset
|
1116 dstFormat == PIX_FMT_BGR555 || dstFormat == PIX_FMT_BGR565 ? "dithered " : "", |
30287
67cace3e3df7
Simplify code in sws_getContext() which logs if the destination format
stefano
parents:
30285
diff
changeset
|
1117 #else |
67cace3e3df7
Simplify code in sws_getContext() which logs if the destination format
stefano
parents:
30285
diff
changeset
|
1118 "", |
67cace3e3df7
Simplify code in sws_getContext() which logs if the destination format
stefano
parents:
30285
diff
changeset
|
1119 #endif |
30284
03f99130b7c3
Factorize code which logs the source and destination formats in
stefano
parents:
30275
diff
changeset
|
1120 sws_format_name(dstFormat)); |
18861 | 1121 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1122 if (flags & SWS_CPU_CAPS_MMX2) |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1123 av_log(c, AV_LOG_INFO, "using MMX2\n"); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1124 else if (flags & SWS_CPU_CAPS_3DNOW) |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1125 av_log(c, AV_LOG_INFO, "using 3DNOW\n"); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1126 else if (flags & SWS_CPU_CAPS_MMX) |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1127 av_log(c, AV_LOG_INFO, "using MMX\n"); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1128 else if (flags & SWS_CPU_CAPS_ALTIVEC) |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1129 av_log(c, AV_LOG_INFO, "using AltiVec\n"); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1130 else |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1131 av_log(c, AV_LOG_INFO, "using C\n"); |
18861 | 1132 |
29481 | 1133 if (flags & SWS_CPU_CAPS_MMX) { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1134 if (c->canMMX2BeUsed && (flags&SWS_FAST_BILINEAR)) |
26150
1df4a811aa9c
remove redundant SwScaler text since av_log uses AVClass context
bcoudurier
parents:
26134
diff
changeset
|
1135 av_log(c, AV_LOG_VERBOSE, "using FAST_BILINEAR MMX2 scaler for horizontal scaling\n"); |
29481 | 1136 else { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1137 if (c->hLumFilterSize==4) |
26150
1df4a811aa9c
remove redundant SwScaler text since av_log uses AVClass context
bcoudurier
parents:
26134
diff
changeset
|
1138 av_log(c, AV_LOG_VERBOSE, "using 4-tap MMX scaler for horizontal luminance scaling\n"); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1139 else if (c->hLumFilterSize==8) |
26150
1df4a811aa9c
remove redundant SwScaler text since av_log uses AVClass context
bcoudurier
parents:
26134
diff
changeset
|
1140 av_log(c, AV_LOG_VERBOSE, "using 8-tap MMX scaler for horizontal luminance scaling\n"); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1141 else |
26150
1df4a811aa9c
remove redundant SwScaler text since av_log uses AVClass context
bcoudurier
parents:
26134
diff
changeset
|
1142 av_log(c, AV_LOG_VERBOSE, "using n-tap MMX scaler for horizontal luminance scaling\n"); |
18861 | 1143 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1144 if (c->hChrFilterSize==4) |
26150
1df4a811aa9c
remove redundant SwScaler text since av_log uses AVClass context
bcoudurier
parents:
26134
diff
changeset
|
1145 av_log(c, AV_LOG_VERBOSE, "using 4-tap MMX scaler for horizontal chrominance scaling\n"); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1146 else if (c->hChrFilterSize==8) |
26150
1df4a811aa9c
remove redundant SwScaler text since av_log uses AVClass context
bcoudurier
parents:
26134
diff
changeset
|
1147 av_log(c, AV_LOG_VERBOSE, "using 8-tap MMX scaler for horizontal chrominance scaling\n"); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1148 else |
26150
1df4a811aa9c
remove redundant SwScaler text since av_log uses AVClass context
bcoudurier
parents:
26134
diff
changeset
|
1149 av_log(c, AV_LOG_VERBOSE, "using n-tap MMX scaler for horizontal chrominance scaling\n"); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1150 } |
29481 | 1151 } else { |
28276 | 1152 #if ARCH_X86 |
28316 | 1153 av_log(c, AV_LOG_VERBOSE, "using x86 asm scaler for horizontal scaling\n"); |
18861 | 1154 #else |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1155 if (flags & SWS_FAST_BILINEAR) |
26150
1df4a811aa9c
remove redundant SwScaler text since av_log uses AVClass context
bcoudurier
parents:
26134
diff
changeset
|
1156 av_log(c, AV_LOG_VERBOSE, "using FAST_BILINEAR C scaler for horizontal scaling\n"); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1157 else |
26150
1df4a811aa9c
remove redundant SwScaler text since av_log uses AVClass context
bcoudurier
parents:
26134
diff
changeset
|
1158 av_log(c, AV_LOG_VERBOSE, "using C scaler for horizontal scaling\n"); |
18861 | 1159 #endif |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1160 } |
29481 | 1161 if (isPlanarYUV(dstFormat)) { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1162 if (c->vLumFilterSize==1) |
26150
1df4a811aa9c
remove redundant SwScaler text since av_log uses AVClass context
bcoudurier
parents:
26134
diff
changeset
|
1163 av_log(c, AV_LOG_VERBOSE, "using 1-tap %s \"scaler\" for vertical scaling (YV12 like)\n", (flags & SWS_CPU_CAPS_MMX) ? "MMX" : "C"); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1164 else |
26150
1df4a811aa9c
remove redundant SwScaler text since av_log uses AVClass context
bcoudurier
parents:
26134
diff
changeset
|
1165 av_log(c, AV_LOG_VERBOSE, "using n-tap %s scaler for vertical scaling (YV12 like)\n", (flags & SWS_CPU_CAPS_MMX) ? "MMX" : "C"); |
29481 | 1166 } else { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1167 if (c->vLumFilterSize==1 && c->vChrFilterSize==2) |
26150
1df4a811aa9c
remove redundant SwScaler text since av_log uses AVClass context
bcoudurier
parents:
26134
diff
changeset
|
1168 av_log(c, AV_LOG_VERBOSE, "using 1-tap %s \"scaler\" for vertical luminance scaling (BGR)\n" |
1df4a811aa9c
remove redundant SwScaler text since av_log uses AVClass context
bcoudurier
parents:
26134
diff
changeset
|
1169 " 2-tap scaler for vertical chrominance scaling (BGR)\n", (flags & SWS_CPU_CAPS_MMX) ? "MMX" : "C"); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1170 else if (c->vLumFilterSize==2 && c->vChrFilterSize==2) |
26150
1df4a811aa9c
remove redundant SwScaler text since av_log uses AVClass context
bcoudurier
parents:
26134
diff
changeset
|
1171 av_log(c, AV_LOG_VERBOSE, "using 2-tap linear %s scaler for vertical scaling (BGR)\n", (flags & SWS_CPU_CAPS_MMX) ? "MMX" : "C"); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1172 else |
26150
1df4a811aa9c
remove redundant SwScaler text since av_log uses AVClass context
bcoudurier
parents:
26134
diff
changeset
|
1173 av_log(c, AV_LOG_VERBOSE, "using n-tap %s scaler for vertical scaling (BGR)\n", (flags & SWS_CPU_CAPS_MMX) ? "MMX" : "C"); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1174 } |
18861 | 1175 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1176 if (dstFormat==PIX_FMT_BGR24) |
28316 | 1177 av_log(c, AV_LOG_VERBOSE, "using %s YV12->BGR24 converter\n", |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1178 (flags & SWS_CPU_CAPS_MMX2) ? "MMX2" : ((flags & SWS_CPU_CAPS_MMX) ? "MMX" : "C")); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1179 else if (dstFormat==PIX_FMT_RGB32) |
28316 | 1180 av_log(c, AV_LOG_VERBOSE, "using %s YV12->BGR32 converter\n", (flags & SWS_CPU_CAPS_MMX) ? "MMX" : "C"); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1181 else if (dstFormat==PIX_FMT_BGR565) |
28316 | 1182 av_log(c, AV_LOG_VERBOSE, "using %s YV12->BGR16 converter\n", (flags & SWS_CPU_CAPS_MMX) ? "MMX" : "C"); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1183 else if (dstFormat==PIX_FMT_BGR555) |
28316 | 1184 av_log(c, AV_LOG_VERBOSE, "using %s YV12->BGR15 converter\n", (flags & SWS_CPU_CAPS_MMX) ? "MMX" : "C"); |
26150
1df4a811aa9c
remove redundant SwScaler text since av_log uses AVClass context
bcoudurier
parents:
26134
diff
changeset
|
1185 |
1df4a811aa9c
remove redundant SwScaler text since av_log uses AVClass context
bcoudurier
parents:
26134
diff
changeset
|
1186 av_log(c, AV_LOG_VERBOSE, "%dx%d -> %dx%d\n", srcW, srcH, dstW, dstH); |
28316 | 1187 av_log(c, AV_LOG_DEBUG, "lum srcW=%d srcH=%d dstW=%d dstH=%d xInc=%d yInc=%d\n", |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1188 c->srcW, c->srcH, c->dstW, c->dstH, c->lumXInc, c->lumYInc); |
28316 | 1189 av_log(c, AV_LOG_DEBUG, "chr srcW=%d srcH=%d dstW=%d dstH=%d xInc=%d yInc=%d\n", |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1190 c->chrSrcW, c->chrSrcH, c->chrDstW, c->chrDstH, c->chrXInc, c->chrYInc); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1191 } |
18861 | 1192 |
30369
8c479cb29c7a
Split swscale.c into scaler code (swscale.c) and utility code (utils.c).
ramiro
parents:
30343
diff
changeset
|
1193 c->swScale= ff_getSwsFunc(c); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1194 return c; |
29542 | 1195 |
1196 fail: | |
1197 sws_freeContext(c); | |
1198 return NULL; | |
18861 | 1199 } |
1200 | |
23129 | 1201 SwsFilter *sws_getDefaultFilter(float lumaGBlur, float chromaGBlur, |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1202 float lumaSharpen, float chromaSharpen, |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1203 float chromaHShift, float chromaVShift, |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1204 int verbose) |
18861 | 1205 { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1206 SwsFilter *filter= av_malloc(sizeof(SwsFilter)); |
29542 | 1207 if (!filter) |
1208 return NULL; | |
18861 | 1209 |
29481 | 1210 if (lumaGBlur!=0.0) { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1211 filter->lumH= sws_getGaussianVec(lumaGBlur, 3.0); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1212 filter->lumV= sws_getGaussianVec(lumaGBlur, 3.0); |
29481 | 1213 } else { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1214 filter->lumH= sws_getIdentityVec(); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1215 filter->lumV= sws_getIdentityVec(); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1216 } |
18861 | 1217 |
29481 | 1218 if (chromaGBlur!=0.0) { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1219 filter->chrH= sws_getGaussianVec(chromaGBlur, 3.0); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1220 filter->chrV= sws_getGaussianVec(chromaGBlur, 3.0); |
29481 | 1221 } else { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1222 filter->chrH= sws_getIdentityVec(); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1223 filter->chrV= sws_getIdentityVec(); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1224 } |
18861 | 1225 |
29481 | 1226 if (chromaSharpen!=0.0) { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1227 SwsVector *id= sws_getIdentityVec(); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1228 sws_scaleVec(filter->chrH, -chromaSharpen); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1229 sws_scaleVec(filter->chrV, -chromaSharpen); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1230 sws_addVec(filter->chrH, id); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1231 sws_addVec(filter->chrV, id); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1232 sws_freeVec(id); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1233 } |
18861 | 1234 |
29481 | 1235 if (lumaSharpen!=0.0) { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1236 SwsVector *id= sws_getIdentityVec(); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1237 sws_scaleVec(filter->lumH, -lumaSharpen); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1238 sws_scaleVec(filter->lumV, -lumaSharpen); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1239 sws_addVec(filter->lumH, id); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1240 sws_addVec(filter->lumV, id); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1241 sws_freeVec(id); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1242 } |
18861 | 1243 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1244 if (chromaHShift != 0.0) |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1245 sws_shiftVec(filter->chrH, (int)(chromaHShift+0.5)); |
18861 | 1246 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1247 if (chromaVShift != 0.0) |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1248 sws_shiftVec(filter->chrV, (int)(chromaVShift+0.5)); |
18861 | 1249 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1250 sws_normalizeVec(filter->chrH, 1.0); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1251 sws_normalizeVec(filter->chrV, 1.0); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1252 sws_normalizeVec(filter->lumH, 1.0); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1253 sws_normalizeVec(filter->lumV, 1.0); |
18861 | 1254 |
28532
e5a0c2f38f96
Use sws_printVec2() instead of the deprecated sws_printVec().
stefano
parents:
28531
diff
changeset
|
1255 if (verbose) sws_printVec2(filter->chrH, NULL, AV_LOG_DEBUG); |
e5a0c2f38f96
Use sws_printVec2() instead of the deprecated sws_printVec().
stefano
parents:
28531
diff
changeset
|
1256 if (verbose) sws_printVec2(filter->lumH, NULL, AV_LOG_DEBUG); |
18861 | 1257 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1258 return filter; |
18861 | 1259 } |
1260 | |
29494 | 1261 SwsVector *sws_allocVec(int length) |
1262 { | |
1263 SwsVector *vec = av_malloc(sizeof(SwsVector)); | |
1264 if (!vec) | |
1265 return NULL; | |
1266 vec->length = length; | |
1267 vec->coeff = av_malloc(sizeof(double) * length); | |
1268 if (!vec->coeff) | |
1269 av_freep(&vec); | |
1270 return vec; | |
1271 } | |
1272 | |
29481 | 1273 SwsVector *sws_getGaussianVec(double variance, double quality) |
1274 { | |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1275 const int length= (int)(variance*quality + 0.5) | 1; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1276 int i; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1277 double middle= (length-1)*0.5; |
29494 | 1278 SwsVector *vec= sws_allocVec(length); |
18861 | 1279 |
29501
a0ba51e33912
Check return values of sws_allocVec() and sws_getConstVec().
ramiro
parents:
29494
diff
changeset
|
1280 if (!vec) |
a0ba51e33912
Check return values of sws_allocVec() and sws_getConstVec().
ramiro
parents:
29494
diff
changeset
|
1281 return NULL; |
a0ba51e33912
Check return values of sws_allocVec() and sws_getConstVec().
ramiro
parents:
29494
diff
changeset
|
1282 |
29481 | 1283 for (i=0; i<length; i++) { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1284 double dist= i-middle; |
30370
a8c94e9dc653
Don't redefine M_PI. It is already defined from libavutil/mathematics.h.
ramiro
parents:
30369
diff
changeset
|
1285 vec->coeff[i]= exp(-dist*dist/(2*variance*variance)) / sqrt(2*variance*M_PI); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1286 } |
18861 | 1287 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1288 sws_normalizeVec(vec, 1.0); |
18861 | 1289 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1290 return vec; |
18861 | 1291 } |
1292 | |
29481 | 1293 SwsVector *sws_getConstVec(double c, int length) |
1294 { | |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1295 int i; |
29494 | 1296 SwsVector *vec= sws_allocVec(length); |
18861 | 1297 |
29501
a0ba51e33912
Check return values of sws_allocVec() and sws_getConstVec().
ramiro
parents:
29494
diff
changeset
|
1298 if (!vec) |
a0ba51e33912
Check return values of sws_allocVec() and sws_getConstVec().
ramiro
parents:
29494
diff
changeset
|
1299 return NULL; |
a0ba51e33912
Check return values of sws_allocVec() and sws_getConstVec().
ramiro
parents:
29494
diff
changeset
|
1300 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1301 for (i=0; i<length; i++) |
29494 | 1302 vec->coeff[i]= c; |
18861 | 1303 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1304 return vec; |
18861 | 1305 } |
1306 | |
29481 | 1307 SwsVector *sws_getIdentityVec(void) |
1308 { | |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1309 return sws_getConstVec(1.0, 1); |
18861 | 1310 } |
1311 | |
30745
c5a49657b3e4
Make sws_dcVec static: It is only used inside libswscale/utils.c.
cehoyos
parents:
30688
diff
changeset
|
1312 static double sws_dcVec(SwsVector *a) |
29481 | 1313 { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1314 int i; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1315 double sum=0; |
18861 | 1316 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1317 for (i=0; i<a->length; i++) |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1318 sum+= a->coeff[i]; |
18861 | 1319 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1320 return sum; |
18861 | 1321 } |
1322 | |
29481 | 1323 void sws_scaleVec(SwsVector *a, double scalar) |
1324 { | |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1325 int i; |
18861 | 1326 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1327 for (i=0; i<a->length; i++) |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1328 a->coeff[i]*= scalar; |
18861 | 1329 } |
1330 | |
29481 | 1331 void sws_normalizeVec(SwsVector *a, double height) |
1332 { | |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1333 sws_scaleVec(a, height/sws_dcVec(a)); |
18861 | 1334 } |
1335 | |
29481 | 1336 static SwsVector *sws_getConvVec(SwsVector *a, SwsVector *b) |
1337 { | |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1338 int length= a->length + b->length - 1; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1339 int i, j; |
29493 | 1340 SwsVector *vec= sws_getConstVec(0.0, length); |
18861 | 1341 |
29501
a0ba51e33912
Check return values of sws_allocVec() and sws_getConstVec().
ramiro
parents:
29494
diff
changeset
|
1342 if (!vec) |
a0ba51e33912
Check return values of sws_allocVec() and sws_getConstVec().
ramiro
parents:
29494
diff
changeset
|
1343 return NULL; |
a0ba51e33912
Check return values of sws_allocVec() and sws_getConstVec().
ramiro
parents:
29494
diff
changeset
|
1344 |
29481 | 1345 for (i=0; i<a->length; i++) { |
1346 for (j=0; j<b->length; j++) { | |
29493 | 1347 vec->coeff[i+j]+= a->coeff[i]*b->coeff[j]; |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1348 } |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1349 } |
18861 | 1350 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1351 return vec; |
18861 | 1352 } |
1353 | |
29481 | 1354 static SwsVector *sws_sumVec(SwsVector *a, SwsVector *b) |
1355 { | |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1356 int length= FFMAX(a->length, b->length); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1357 int i; |
29493 | 1358 SwsVector *vec= sws_getConstVec(0.0, length); |
1359 | |
29501
a0ba51e33912
Check return values of sws_allocVec() and sws_getConstVec().
ramiro
parents:
29494
diff
changeset
|
1360 if (!vec) |
a0ba51e33912
Check return values of sws_allocVec() and sws_getConstVec().
ramiro
parents:
29494
diff
changeset
|
1361 return NULL; |
a0ba51e33912
Check return values of sws_allocVec() and sws_getConstVec().
ramiro
parents:
29494
diff
changeset
|
1362 |
29493 | 1363 for (i=0; i<a->length; i++) vec->coeff[i + (length-1)/2 - (a->length-1)/2]+= a->coeff[i]; |
1364 for (i=0; i<b->length; i++) vec->coeff[i + (length-1)/2 - (b->length-1)/2]+= b->coeff[i]; | |
18861 | 1365 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1366 return vec; |
18861 | 1367 } |
1368 | |
29481 | 1369 static SwsVector *sws_diffVec(SwsVector *a, SwsVector *b) |
1370 { | |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1371 int length= FFMAX(a->length, b->length); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1372 int i; |
29493 | 1373 SwsVector *vec= sws_getConstVec(0.0, length); |
1374 | |
29501
a0ba51e33912
Check return values of sws_allocVec() and sws_getConstVec().
ramiro
parents:
29494
diff
changeset
|
1375 if (!vec) |
a0ba51e33912
Check return values of sws_allocVec() and sws_getConstVec().
ramiro
parents:
29494
diff
changeset
|
1376 return NULL; |
a0ba51e33912
Check return values of sws_allocVec() and sws_getConstVec().
ramiro
parents:
29494
diff
changeset
|
1377 |
29493 | 1378 for (i=0; i<a->length; i++) vec->coeff[i + (length-1)/2 - (a->length-1)/2]+= a->coeff[i]; |
1379 for (i=0; i<b->length; i++) vec->coeff[i + (length-1)/2 - (b->length-1)/2]-= b->coeff[i]; | |
18861 | 1380 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1381 return vec; |
18861 | 1382 } |
1383 | |
1384 /* shift left / or right if "shift" is negative */ | |
29481 | 1385 static SwsVector *sws_getShiftedVec(SwsVector *a, int shift) |
1386 { | |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1387 int length= a->length + FFABS(shift)*2; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1388 int i; |
29493 | 1389 SwsVector *vec= sws_getConstVec(0.0, length); |
18861 | 1390 |
29501
a0ba51e33912
Check return values of sws_allocVec() and sws_getConstVec().
ramiro
parents:
29494
diff
changeset
|
1391 if (!vec) |
a0ba51e33912
Check return values of sws_allocVec() and sws_getConstVec().
ramiro
parents:
29494
diff
changeset
|
1392 return NULL; |
a0ba51e33912
Check return values of sws_allocVec() and sws_getConstVec().
ramiro
parents:
29494
diff
changeset
|
1393 |
29481 | 1394 for (i=0; i<a->length; i++) { |
29493 | 1395 vec->coeff[i + (length-1)/2 - (a->length-1)/2 - shift]= a->coeff[i]; |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1396 } |
18861 | 1397 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1398 return vec; |
18861 | 1399 } |
1400 | |
29481 | 1401 void sws_shiftVec(SwsVector *a, int shift) |
1402 { | |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1403 SwsVector *shifted= sws_getShiftedVec(a, shift); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1404 av_free(a->coeff); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1405 a->coeff= shifted->coeff; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1406 a->length= shifted->length; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1407 av_free(shifted); |
18861 | 1408 } |
1409 | |
29481 | 1410 void sws_addVec(SwsVector *a, SwsVector *b) |
1411 { | |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1412 SwsVector *sum= sws_sumVec(a, b); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1413 av_free(a->coeff); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1414 a->coeff= sum->coeff; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1415 a->length= sum->length; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1416 av_free(sum); |
18861 | 1417 } |
1418 | |
29481 | 1419 void sws_subVec(SwsVector *a, SwsVector *b) |
1420 { | |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1421 SwsVector *diff= sws_diffVec(a, b); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1422 av_free(a->coeff); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1423 a->coeff= diff->coeff; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1424 a->length= diff->length; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1425 av_free(diff); |
18861 | 1426 } |
1427 | |
29481 | 1428 void sws_convVec(SwsVector *a, SwsVector *b) |
1429 { | |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1430 SwsVector *conv= sws_getConvVec(a, b); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1431 av_free(a->coeff); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1432 a->coeff= conv->coeff; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1433 a->length= conv->length; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1434 av_free(conv); |
18861 | 1435 } |
1436 | |
29481 | 1437 SwsVector *sws_cloneVec(SwsVector *a) |
1438 { | |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1439 int i; |
29494 | 1440 SwsVector *vec= sws_allocVec(a->length); |
1441 | |
29501
a0ba51e33912
Check return values of sws_allocVec() and sws_getConstVec().
ramiro
parents:
29494
diff
changeset
|
1442 if (!vec) |
a0ba51e33912
Check return values of sws_allocVec() and sws_getConstVec().
ramiro
parents:
29494
diff
changeset
|
1443 return NULL; |
a0ba51e33912
Check return values of sws_allocVec() and sws_getConstVec().
ramiro
parents:
29494
diff
changeset
|
1444 |
29494 | 1445 for (i=0; i<a->length; i++) vec->coeff[i]= a->coeff[i]; |
18861 | 1446 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1447 return vec; |
18861 | 1448 } |
1449 | |
29481 | 1450 void sws_printVec2(SwsVector *a, AVClass *log_ctx, int log_level) |
1451 { | |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1452 int i; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1453 double max=0; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1454 double min=0; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1455 double range; |
18861 | 1456 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1457 for (i=0; i<a->length; i++) |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1458 if (a->coeff[i]>max) max= a->coeff[i]; |
18861 | 1459 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1460 for (i=0; i<a->length; i++) |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1461 if (a->coeff[i]<min) min= a->coeff[i]; |
18861 | 1462 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1463 range= max - min; |
18861 | 1464 |
29481 | 1465 for (i=0; i<a->length; i++) { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1466 int x= (int)((a->coeff[i]-min)*60.0/range +0.5); |
28531
a14b65e14dc9
Implement sws_printVec2() and deprecate sws_printVec().
stefano
parents:
28520
diff
changeset
|
1467 av_log(log_ctx, log_level, "%1.3f ", a->coeff[i]); |
a14b65e14dc9
Implement sws_printVec2() and deprecate sws_printVec().
stefano
parents:
28520
diff
changeset
|
1468 for (;x>0; x--) av_log(log_ctx, log_level, " "); |
a14b65e14dc9
Implement sws_printVec2() and deprecate sws_printVec().
stefano
parents:
28520
diff
changeset
|
1469 av_log(log_ctx, log_level, "|\n"); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1470 } |
18861 | 1471 } |
1472 | |
28531
a14b65e14dc9
Implement sws_printVec2() and deprecate sws_printVec().
stefano
parents:
28520
diff
changeset
|
1473 #if LIBSWSCALE_VERSION_MAJOR < 1 |
29481 | 1474 void sws_printVec(SwsVector *a) |
1475 { | |
28531
a14b65e14dc9
Implement sws_printVec2() and deprecate sws_printVec().
stefano
parents:
28520
diff
changeset
|
1476 sws_printVec2(a, NULL, AV_LOG_DEBUG); |
a14b65e14dc9
Implement sws_printVec2() and deprecate sws_printVec().
stefano
parents:
28520
diff
changeset
|
1477 } |
a14b65e14dc9
Implement sws_printVec2() and deprecate sws_printVec().
stefano
parents:
28520
diff
changeset
|
1478 #endif |
a14b65e14dc9
Implement sws_printVec2() and deprecate sws_printVec().
stefano
parents:
28520
diff
changeset
|
1479 |
29481 | 1480 void sws_freeVec(SwsVector *a) |
1481 { | |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1482 if (!a) return; |
27299
4e57d47ee5db
Cleanup, use av_freep() instead of av_free(x); x=NULL
michael
parents:
27286
diff
changeset
|
1483 av_freep(&a->coeff); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1484 a->length=0; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1485 av_free(a); |
18861 | 1486 } |
1487 | |
29481 | 1488 void sws_freeFilter(SwsFilter *filter) |
1489 { | |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1490 if (!filter) return; |
18861 | 1491 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1492 if (filter->lumH) sws_freeVec(filter->lumH); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1493 if (filter->lumV) sws_freeVec(filter->lumV); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1494 if (filter->chrH) sws_freeVec(filter->chrH); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1495 if (filter->chrV) sws_freeVec(filter->chrV); |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1496 av_free(filter); |
18861 | 1497 } |
1498 | |
29481 | 1499 void sws_freeContext(SwsContext *c) |
1500 { | |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1501 int i; |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1502 if (!c) return; |
18861 | 1503 |
29481 | 1504 if (c->lumPixBuf) { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1505 for (i=0; i<c->vLumBufSize; i++) |
27299
4e57d47ee5db
Cleanup, use av_freep() instead of av_free(x); x=NULL
michael
parents:
27286
diff
changeset
|
1506 av_freep(&c->lumPixBuf[i]); |
4e57d47ee5db
Cleanup, use av_freep() instead of av_free(x); x=NULL
michael
parents:
27286
diff
changeset
|
1507 av_freep(&c->lumPixBuf); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1508 } |
18861 | 1509 |
29481 | 1510 if (c->chrPixBuf) { |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1511 for (i=0; i<c->vChrBufSize; i++) |
27299
4e57d47ee5db
Cleanup, use av_freep() instead of av_free(x); x=NULL
michael
parents:
27286
diff
changeset
|
1512 av_freep(&c->chrPixBuf[i]); |
4e57d47ee5db
Cleanup, use av_freep() instead of av_free(x); x=NULL
michael
parents:
27286
diff
changeset
|
1513 av_freep(&c->chrPixBuf); |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1514 } |
18861 | 1515 |
29481 | 1516 if (CONFIG_SWSCALE_ALPHA && c->alpPixBuf) { |
28976 | 1517 for (i=0; i<c->vLumBufSize; i++) |
1518 av_freep(&c->alpPixBuf[i]); | |
1519 av_freep(&c->alpPixBuf); | |
1520 } | |
1521 | |
27299
4e57d47ee5db
Cleanup, use av_freep() instead of av_free(x); x=NULL
michael
parents:
27286
diff
changeset
|
1522 av_freep(&c->vLumFilter); |
4e57d47ee5db
Cleanup, use av_freep() instead of av_free(x); x=NULL
michael
parents:
27286
diff
changeset
|
1523 av_freep(&c->vChrFilter); |
4e57d47ee5db
Cleanup, use av_freep() instead of av_free(x); x=NULL
michael
parents:
27286
diff
changeset
|
1524 av_freep(&c->hLumFilter); |
4e57d47ee5db
Cleanup, use av_freep() instead of av_free(x); x=NULL
michael
parents:
27286
diff
changeset
|
1525 av_freep(&c->hChrFilter); |
30369
8c479cb29c7a
Split swscale.c into scaler code (swscale.c) and utility code (utils.c).
ramiro
parents:
30343
diff
changeset
|
1526 #if ARCH_PPC && (HAVE_ALTIVEC || CONFIG_RUNTIME_CPUDETECT) |
27299
4e57d47ee5db
Cleanup, use av_freep() instead of av_free(x); x=NULL
michael
parents:
27286
diff
changeset
|
1527 av_freep(&c->vYCoeffsBank); |
4e57d47ee5db
Cleanup, use av_freep() instead of av_free(x); x=NULL
michael
parents:
27286
diff
changeset
|
1528 av_freep(&c->vCCoeffsBank); |
18861 | 1529 #endif |
1530 | |
27299
4e57d47ee5db
Cleanup, use av_freep() instead of av_free(x); x=NULL
michael
parents:
27286
diff
changeset
|
1531 av_freep(&c->vLumFilterPos); |
4e57d47ee5db
Cleanup, use av_freep() instead of av_free(x); x=NULL
michael
parents:
27286
diff
changeset
|
1532 av_freep(&c->vChrFilterPos); |
4e57d47ee5db
Cleanup, use av_freep() instead of av_free(x); x=NULL
michael
parents:
27286
diff
changeset
|
1533 av_freep(&c->hLumFilterPos); |
4e57d47ee5db
Cleanup, use av_freep() instead of av_free(x); x=NULL
michael
parents:
27286
diff
changeset
|
1534 av_freep(&c->hChrFilterPos); |
18861 | 1535 |
28276 | 1536 #if ARCH_X86 && CONFIG_GPL |
18861 | 1537 #ifdef MAP_ANONYMOUS |
29468
947a942221c4
MMX2 horizontal scaler: Determine code size at runtime.
ramiro
parents:
29467
diff
changeset
|
1538 if (c->lumMmx2FilterCode) munmap(c->lumMmx2FilterCode, c->lumMmx2FilterCodeSize); |
947a942221c4
MMX2 horizontal scaler: Determine code size at runtime.
ramiro
parents:
29467
diff
changeset
|
1539 if (c->chrMmx2FilterCode) munmap(c->chrMmx2FilterCode, c->chrMmx2FilterCodeSize); |
28971
b8e356a9dbb1
Allocate executable memory with VirtualAlloc() in Windows.
ramiro
parents:
28970
diff
changeset
|
1540 #elif HAVE_VIRTUALALLOC |
29468
947a942221c4
MMX2 horizontal scaler: Determine code size at runtime.
ramiro
parents:
29467
diff
changeset
|
1541 if (c->lumMmx2FilterCode) VirtualFree(c->lumMmx2FilterCode, c->lumMmx2FilterCodeSize, MEM_RELEASE); |
947a942221c4
MMX2 horizontal scaler: Determine code size at runtime.
ramiro
parents:
29467
diff
changeset
|
1542 if (c->chrMmx2FilterCode) VirtualFree(c->chrMmx2FilterCode, c->chrMmx2FilterCodeSize, MEM_RELEASE); |
18861 | 1543 #else |
29465 | 1544 av_free(c->lumMmx2FilterCode); |
1545 av_free(c->chrMmx2FilterCode); | |
18861 | 1546 #endif |
29465 | 1547 c->lumMmx2FilterCode=NULL; |
1548 c->chrMmx2FilterCode=NULL; | |
28315 | 1549 #endif /* ARCH_X86 && CONFIG_GPL */ |
18861 | 1550 |
27299
4e57d47ee5db
Cleanup, use av_freep() instead of av_free(x); x=NULL
michael
parents:
27286
diff
changeset
|
1551 av_freep(&c->yuvTable); |
18861 | 1552 |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1553 av_free(c); |
18861 | 1554 } |
1555 | |
19661
7b24faac56fd
Add sws_getCachedContext(), which checks if context is valid or reallocs a new one instead.
gpoirier
parents:
19594
diff
changeset
|
1556 struct SwsContext *sws_getCachedContext(struct SwsContext *context, |
27695
9cf6c7c5c7cd
Change variable types from int to enum PixelFormat.
cehoyos
parents:
27686
diff
changeset
|
1557 int srcW, int srcH, enum PixelFormat srcFormat, |
9cf6c7c5c7cd
Change variable types from int to enum PixelFormat.
cehoyos
parents:
27686
diff
changeset
|
1558 int dstW, int dstH, enum PixelFormat dstFormat, int flags, |
29246
8861e08033eb
Add const qualifier to param argument of sws_getContext() and
diego
parents:
29245
diff
changeset
|
1559 SwsFilter *srcFilter, SwsFilter *dstFilter, const double *param) |
19661
7b24faac56fd
Add sws_getCachedContext(), which checks if context is valid or reallocs a new one instead.
gpoirier
parents:
19594
diff
changeset
|
1560 { |
25747 | 1561 static const double default_param[2] = {SWS_PARAM_DEFAULT, SWS_PARAM_DEFAULT}; |
1562 | |
1563 if (!param) | |
1564 param = default_param; | |
1565 | |
30599
7c1fea45bfc8
Merge two if conditions, allow to decrese the level of indentation of
stefano
parents:
30478
diff
changeset
|
1566 if (context && |
30600
e2935c75f1aa
Vertically align a list of comparisons in sws_getCachedContext().
stefano
parents:
30599
diff
changeset
|
1567 (context->srcW != srcW || |
e2935c75f1aa
Vertically align a list of comparisons in sws_getCachedContext().
stefano
parents:
30599
diff
changeset
|
1568 context->srcH != srcH || |
e2935c75f1aa
Vertically align a list of comparisons in sws_getCachedContext().
stefano
parents:
30599
diff
changeset
|
1569 context->srcFormat != srcFormat || |
e2935c75f1aa
Vertically align a list of comparisons in sws_getCachedContext().
stefano
parents:
30599
diff
changeset
|
1570 context->dstW != dstW || |
e2935c75f1aa
Vertically align a list of comparisons in sws_getCachedContext().
stefano
parents:
30599
diff
changeset
|
1571 context->dstH != dstH || |
e2935c75f1aa
Vertically align a list of comparisons in sws_getCachedContext().
stefano
parents:
30599
diff
changeset
|
1572 context->dstFormat != dstFormat || |
e2935c75f1aa
Vertically align a list of comparisons in sws_getCachedContext().
stefano
parents:
30599
diff
changeset
|
1573 context->flags != flags || |
e2935c75f1aa
Vertically align a list of comparisons in sws_getCachedContext().
stefano
parents:
30599
diff
changeset
|
1574 context->param[0] != param[0] || |
30601 | 1575 context->param[1] != param[1])) { |
1576 sws_freeContext(context); | |
1577 context = NULL; | |
1578 } | |
30599
7c1fea45bfc8
Merge two if conditions, allow to decrese the level of indentation of
stefano
parents:
30478
diff
changeset
|
1579 |
25752
559b0e9d47fb
Change (a == NULL) condition to (!a) and (a != NULL) condition to (a).
benoit
parents:
25750
diff
changeset
|
1580 if (!context) { |
19661
7b24faac56fd
Add sws_getCachedContext(), which checks if context is valid or reallocs a new one instead.
gpoirier
parents:
19594
diff
changeset
|
1581 return sws_getContext(srcW, srcH, srcFormat, |
23155
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1582 dstW, dstH, dstFormat, flags, |
1befc8d767cd
cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents:
23129
diff
changeset
|
1583 srcFilter, dstFilter, param); |
19661
7b24faac56fd
Add sws_getCachedContext(), which checks if context is valid or reallocs a new one instead.
gpoirier
parents:
19594
diff
changeset
|
1584 } |
7b24faac56fd
Add sws_getCachedContext(), which checks if context is valid or reallocs a new one instead.
gpoirier
parents:
19594
diff
changeset
|
1585 return context; |
7b24faac56fd
Add sws_getCachedContext(), which checks if context is valid or reallocs a new one instead.
gpoirier
parents:
19594
diff
changeset
|
1586 } |
7b24faac56fd
Add sws_getCachedContext(), which checks if context is valid or reallocs a new one instead.
gpoirier
parents:
19594
diff
changeset
|
1587 |