annotate libswscale/swscale_internal.h @ 32393:98fda5253e80

Extract code to read a pnm file into a separate function.
author reimar
date Sun, 10 Oct 2010 11:20:57 +0000
parents ecb8e52d4add
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
18861
8579acff875e Move postproc ---> libswscale
lucabe
parents:
diff changeset
1 /*
20094
aca9e9783f67 Change license headers to say 'FFmpeg' instead of 'this program'.
diego
parents: 19872
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: 19872
diff changeset
3 *
aca9e9783f67 Change license headers to say 'FFmpeg' instead of 'this program'.
diego
parents: 19872
diff changeset
4 * This file is part of FFmpeg.
aca9e9783f67 Change license headers to say 'FFmpeg' instead of 'this program'.
diego
parents: 19872
diff changeset
5 *
21029
1f2ba24b4e47 Clarify that some of the non-SIMD code is now LGPLed.
lucabe
parents: 20411
diff changeset
6 * FFmpeg is free software; you can redistribute it and/or
1f2ba24b4e47 Clarify that some of the non-SIMD code is now LGPLed.
lucabe
parents: 20411
diff changeset
7 * modify it under the terms of the GNU Lesser General Public
1f2ba24b4e47 Clarify that some of the non-SIMD code is now LGPLed.
lucabe
parents: 20411
diff changeset
8 * License as published by the Free Software Foundation; either
1f2ba24b4e47 Clarify that some of the non-SIMD code is now LGPLed.
lucabe
parents: 20411
diff changeset
9 * version 2.1 of the License, or (at your option) any later version.
20094
aca9e9783f67 Change license headers to say 'FFmpeg' instead of 'this program'.
diego
parents: 19872
diff changeset
10 *
aca9e9783f67 Change license headers to say 'FFmpeg' instead of 'this program'.
diego
parents: 19872
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: 19872
diff changeset
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
21029
1f2ba24b4e47 Clarify that some of the non-SIMD code is now LGPLed.
lucabe
parents: 20411
diff changeset
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
1f2ba24b4e47 Clarify that some of the non-SIMD code is now LGPLed.
lucabe
parents: 20411
diff changeset
14 * Lesser General Public License for more details.
20094
aca9e9783f67 Change license headers to say 'FFmpeg' instead of 'this program'.
diego
parents: 19872
diff changeset
15 *
21029
1f2ba24b4e47 Clarify that some of the non-SIMD code is now LGPLed.
lucabe
parents: 20411
diff changeset
16 * You should have received a copy of the GNU Lesser General Public
1f2ba24b4e47 Clarify that some of the non-SIMD code is now LGPLed.
lucabe
parents: 20411
diff changeset
17 * License along with FFmpeg; if not, write to the Free Software
23702
5159b5f8784e license header consistency cosmetics
diego
parents: 23536
diff changeset
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: 19872
diff changeset
19 */
18861
8579acff875e Move postproc ---> libswscale
lucabe
parents:
diff changeset
20
27467
239a049163eb Change header inclusion guard names in line with FFmpeg r15120.
stefano
parents: 27212
diff changeset
21 #ifndef SWSCALE_SWSCALE_INTERNAL_H
239a049163eb Change header inclusion guard names in line with FFmpeg r15120.
stefano
parents: 27212
diff changeset
22 #define SWSCALE_SWSCALE_INTERNAL_H
18861
8579acff875e Move postproc ---> libswscale
lucabe
parents:
diff changeset
23
25288
831fbe89f76b Fix 'make checkheaders' on AltiVec-enabled systems.
diego
parents: 24772
diff changeset
24 #include "config.h"
831fbe89f76b Fix 'make checkheaders' on AltiVec-enabled systems.
diego
parents: 24772
diff changeset
25
28276
877336d3c598 Change semantic of CONFIG_*, HAVE_* and ARCH_*.
aurel
parents: 27698
diff changeset
26 #if HAVE_ALTIVEC_H
18861
8579acff875e Move postproc ---> libswscale
lucabe
parents:
diff changeset
27 #include <altivec.h>
8579acff875e Move postproc ---> libswscale
lucabe
parents:
diff changeset
28 #endif
8579acff875e Move postproc ---> libswscale
lucabe
parents:
diff changeset
29
26670
e6774798e913 Use full path for #includes from another directory.
diego
parents: 26178
diff changeset
30 #include "libavutil/avutil.h"
19143
c4dac777b44c Use libavutil in libswscale, and allow it to be built out of the mplayer tree
lucabe
parents: 18861
diff changeset
31
27514
fa98d451036f Fix typo in comment.
michael
parents: 27513
diff changeset
32 #define STR(s) AV_TOSTRING(s) //AV_STRINGIFY is too long
27513
2550d0c5bcb6 Fix accurate rounding mode on x86_64.
michael
parents: 27490
diff changeset
33
18861
8579acff875e Move postproc ---> libswscale
lucabe
parents:
diff changeset
34 #define MAX_FILTER_SIZE 256
8579acff875e Move postproc ---> libswscale
lucabe
parents:
diff changeset
35
29214
a1abd8d51b81 Change VOFW for x86 to 5120, it allows larger images to be scaled and was
michael
parents: 29176
diff changeset
36 #if ARCH_X86
a1abd8d51b81 Change VOFW for x86 to 5120, it allows larger images to be scaled and was
michael
parents: 29176
diff changeset
37 #define VOFW 5120
a1abd8d51b81 Change VOFW for x86 to 5120, it allows larger images to be scaled and was
michael
parents: 29176
diff changeset
38 #else
a1abd8d51b81 Change VOFW for x86 to 5120, it allows larger images to be scaled and was
michael
parents: 29176
diff changeset
39 #define VOFW 2048 // faster on PPC and not tested on others
a1abd8d51b81 Change VOFW for x86 to 5120, it allows larger images to be scaled and was
michael
parents: 29176
diff changeset
40 #endif
a1abd8d51b81 Change VOFW for x86 to 5120, it allows larger images to be scaled and was
michael
parents: 29176
diff changeset
41
26177
9ca242299b22 define VOF as double of VOFW.
benoit
parents: 26151
diff changeset
42 #define VOF (VOFW*2)
26133
94cc4bac8cd0 Turn ancient V offset numerical constants into named ones.
michael
parents: 26028
diff changeset
43
29397
2d985cc879c9 Replace WORDS_BIGENDIAN with HAVE_BIGENDIAN
mru
parents: 29393
diff changeset
44 #if HAVE_BIGENDIAN
27490
651ebfa4b7db Support PIX_FMT_RGB32_1 and PIX_FMT_BGR32_1.
michael
parents: 27488
diff changeset
45 #define ALT32_CORR (-1)
651ebfa4b7db Support PIX_FMT_RGB32_1 and PIX_FMT_BGR32_1.
michael
parents: 27488
diff changeset
46 #else
651ebfa4b7db Support PIX_FMT_RGB32_1 and PIX_FMT_BGR32_1.
michael
parents: 27488
diff changeset
47 #define ALT32_CORR 1
651ebfa4b7db Support PIX_FMT_RGB32_1 and PIX_FMT_BGR32_1.
michael
parents: 27488
diff changeset
48 #endif
651ebfa4b7db Support PIX_FMT_RGB32_1 and PIX_FMT_BGR32_1.
michael
parents: 27488
diff changeset
49
28276
877336d3c598 Change semantic of CONFIG_*, HAVE_* and ARCH_*.
aurel
parents: 27698
diff changeset
50 #if ARCH_X86_64
27513
2550d0c5bcb6 Fix accurate rounding mode on x86_64.
michael
parents: 27490
diff changeset
51 # define APCK_PTR2 8
2550d0c5bcb6 Fix accurate rounding mode on x86_64.
michael
parents: 27490
diff changeset
52 # define APCK_COEF 16
2550d0c5bcb6 Fix accurate rounding mode on x86_64.
michael
parents: 27490
diff changeset
53 # define APCK_SIZE 24
2550d0c5bcb6 Fix accurate rounding mode on x86_64.
michael
parents: 27490
diff changeset
54 #else
2550d0c5bcb6 Fix accurate rounding mode on x86_64.
michael
parents: 27490
diff changeset
55 # define APCK_PTR2 4
2550d0c5bcb6 Fix accurate rounding mode on x86_64.
michael
parents: 27490
diff changeset
56 # define APCK_COEF 8
2550d0c5bcb6 Fix accurate rounding mode on x86_64.
michael
parents: 27490
diff changeset
57 # define APCK_SIZE 16
2550d0c5bcb6 Fix accurate rounding mode on x86_64.
michael
parents: 27490
diff changeset
58 #endif
2550d0c5bcb6 Fix accurate rounding mode on x86_64.
michael
parents: 27490
diff changeset
59
28318
6142aa6d6f38 Declare struct SwsContext before using it, fixes the checkheaders warning:
diego
parents: 28276
diff changeset
60 struct SwsContext;
6142aa6d6f38 Declare struct SwsContext before using it, fixes the checkheaders warning:
diego
parents: 28276
diff changeset
61
30264
1032ff2e83f1 Const correctness for src pointer. Remove all constness related warnings in
zuxy
parents: 30056
diff changeset
62 typedef int (*SwsFunc)(struct SwsContext *context, const uint8_t* src[],
29134
ede1c13e8865 whitespace cosmetics: Reindent a few lines and break a few excessively long lines.
diego
parents: 29105
diff changeset
63 int srcStride[], int srcSliceY, int srcSliceH,
ede1c13e8865 whitespace cosmetics: Reindent a few lines and break a few excessively long lines.
diego
parents: 29105
diff changeset
64 uint8_t* dst[], int dstStride[]);
18861
8579acff875e Move postproc ---> libswscale
lucabe
parents:
diff changeset
65
27158
65b8334df960 spelling/grammar/wording overhaul
diego
parents: 26670
diff changeset
66 /* This struct should be aligned on at least a 32-byte boundary. */
29481
c080f1f5c07e Cosmetics:
ramiro
parents: 29468
diff changeset
67 typedef struct SwsContext {
23155
1befc8d767cd cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents: 22914
diff changeset
68 /**
1befc8d767cd cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents: 22914
diff changeset
69 * info on struct for av_log
1befc8d767cd cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents: 22914
diff changeset
70 */
26178
5ba88511ec0a Make av_class a pointer to const.
benoit
parents: 26177
diff changeset
71 const AVClass *av_class;
21981
a14ddab18acd Pass a context to av_log(), when possible
lucabe
parents: 21755
diff changeset
72
23155
1befc8d767cd cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents: 22914
diff changeset
73 /**
25457
0926055fe5b8 comment typo fixes
diego
parents: 25291
diff changeset
74 * Note that src, dst, srcStride, dstStride will be copied in the
0926055fe5b8 comment typo fixes
diego
parents: 25291
diff changeset
75 * sws_scale() wrapper so they can be freely modified here.
23155
1befc8d767cd cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents: 22914
diff changeset
76 */
1befc8d767cd cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents: 22914
diff changeset
77 SwsFunc swScale;
30286
e6e5a84fdecb Document some of SwsContext.
ramiro
parents: 30285
diff changeset
78 int srcW; ///< Width of source luma/alpha planes.
e6e5a84fdecb Document some of SwsContext.
ramiro
parents: 30285
diff changeset
79 int srcH; ///< Height of source luma/alpha planes.
e6e5a84fdecb Document some of SwsContext.
ramiro
parents: 30285
diff changeset
80 int dstH; ///< Height of destination luma/alpha planes.
e6e5a84fdecb Document some of SwsContext.
ramiro
parents: 30285
diff changeset
81 int chrSrcW; ///< Width of source chroma planes.
e6e5a84fdecb Document some of SwsContext.
ramiro
parents: 30285
diff changeset
82 int chrSrcH; ///< Height of source chroma planes.
e6e5a84fdecb Document some of SwsContext.
ramiro
parents: 30285
diff changeset
83 int chrDstW; ///< Width of destination chroma planes.
e6e5a84fdecb Document some of SwsContext.
ramiro
parents: 30285
diff changeset
84 int chrDstH; ///< Height of destination chroma planes.
23155
1befc8d767cd cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents: 22914
diff changeset
85 int lumXInc, chrXInc;
1befc8d767cd cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents: 22914
diff changeset
86 int lumYInc, chrYInc;
30286
e6e5a84fdecb Document some of SwsContext.
ramiro
parents: 30285
diff changeset
87 enum PixelFormat dstFormat; ///< Destination pixel format.
e6e5a84fdecb Document some of SwsContext.
ramiro
parents: 30285
diff changeset
88 enum PixelFormat srcFormat; ///< Source pixel format.
30377
2eea1f09e2c5 Use av_get_bits_per_pixel() for computing the bits per pixel of the
stefano
parents: 30369
diff changeset
89 int dstFormatBpp; ///< Number of bits per pixel of the destination pixel format.
2eea1f09e2c5 Use av_get_bits_per_pixel() for computing the bits per pixel of the
stefano
parents: 30369
diff changeset
90 int srcFormatBpp; ///< Number of bits per pixel of the source pixel format.
30338
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
91 int chrSrcHSubSample; ///< Binary logarithm of horizontal subsampling factor between luma/alpha and chroma planes in source image.
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
92 int chrSrcVSubSample; ///< Binary logarithm of vertical subsampling factor between luma/alpha and chroma planes in source image.
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
93 int chrDstHSubSample; ///< Binary logarithm of horizontal subsampling factor between luma/alpha and chroma planes in destination image.
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
94 int chrDstVSubSample; ///< Binary logarithm of vertical subsampling factor between luma/alpha and chroma planes in destination image.
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
95 int vChrDrop; ///< Binary logarithm of extra vertical subsampling factor in source image chroma planes specified by user.
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
96 int sliceDir; ///< Direction that slices are fed to the scaler (1 = top-to-bottom, -1 = bottom-to-top).
30286
e6e5a84fdecb Document some of SwsContext.
ramiro
parents: 30285
diff changeset
97 double param[2]; ///< Input parameters for scaling algorithms that need them.
18861
8579acff875e Move postproc ---> libswscale
lucabe
parents:
diff changeset
98
27698
2b4929069763 Add a new unscaled PAL8 -> RGB converter.
vitor
parents: 27695
diff changeset
99 uint32_t pal_yuv[256];
2b4929069763 Add a new unscaled PAL8 -> RGB converter.
vitor
parents: 27695
diff changeset
100 uint32_t pal_rgb[256];
2b4929069763 Add a new unscaled PAL8 -> RGB converter.
vitor
parents: 27695
diff changeset
101
30338
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
102 /**
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
103 * @name Scaled horizontal lines ring buffer.
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
104 * The horizontal scaler keeps just enough scaled lines in a ring buffer
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
105 * so they may be passed to the vertical scaler. The pointers to the
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
106 * allocated buffers for each line are duplicated in sequence in the ring
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
107 * buffer to simplify indexing and avoid wrapping around between lines
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
108 * inside the vertical scaler code. The wrapping is done before the
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
109 * vertical scaler is called.
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
110 */
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
111 //@{
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
112 int16_t **lumPixBuf; ///< Ring buffer for scaled horizontal luma plane lines to be fed to the vertical scaler.
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
113 int16_t **chrPixBuf; ///< Ring buffer for scaled horizontal chroma plane lines to be fed to the vertical scaler.
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
114 int16_t **alpPixBuf; ///< Ring buffer for scaled horizontal alpha plane lines to be fed to the vertical scaler.
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
115 int vLumBufSize; ///< Number of vertical luma/alpha lines allocated in the ring buffer.
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
116 int vChrBufSize; ///< Number of vertical chroma lines allocated in the ring buffer.
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
117 int lastInLumBuf; ///< Last scaled horizontal luma/alpha line from source in the ring buffer.
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
118 int lastInChrBuf; ///< Last scaled horizontal chroma line from source in the ring buffer.
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
119 int lumBufIndex; ///< Index in ring buffer of the last scaled horizontal luma/alpha line from source.
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
120 int chrBufIndex; ///< Index in ring buffer of the last scaled horizontal chroma line from source.
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
121 //@}
18861
8579acff875e Move postproc ---> libswscale
lucabe
parents:
diff changeset
122
27158
65b8334df960 spelling/grammar/wording overhaul
diego
parents: 26670
diff changeset
123 uint8_t formatConvBuffer[VOF]; //FIXME dynamic allocation, but we have to change a lot of code for this to be useful
18861
8579acff875e Move postproc ---> libswscale
lucabe
parents:
diff changeset
124
30338
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
125 /**
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
126 * @name Horizontal and vertical filters.
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
127 * To better understand the following fields, here is a pseudo-code of
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
128 * their usage in filtering a horizontal line:
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
129 * @code
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
130 * for (i = 0; i < width; i++) {
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
131 * dst[i] = 0;
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
132 * for (j = 0; j < filterSize; j++)
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
133 * dst[i] += src[ filterPos[i] + j ] * filter[ filterSize * i + j ];
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
134 * dst[i] >>= FRAC_BITS; // The actual implementation is fixed-point.
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
135 * }
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
136 * @endcode
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
137 */
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
138 //@{
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
139 int16_t *hLumFilter; ///< Array of horizontal filter coefficients for luma/alpha planes.
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
140 int16_t *hChrFilter; ///< Array of horizontal filter coefficients for chroma planes.
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
141 int16_t *vLumFilter; ///< Array of vertical filter coefficients for luma/alpha planes.
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
142 int16_t *vChrFilter; ///< Array of vertical filter coefficients for chroma planes.
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
143 int16_t *hLumFilterPos; ///< Array of horizontal filter starting positions for each dst[i] for luma/alpha planes.
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
144 int16_t *hChrFilterPos; ///< Array of horizontal filter starting positions for each dst[i] for chroma planes.
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
145 int16_t *vLumFilterPos; ///< Array of vertical filter starting positions for each dst[i] for luma/alpha planes.
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
146 int16_t *vChrFilterPos; ///< Array of vertical filter starting positions for each dst[i] for chroma planes.
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
147 int hLumFilterSize; ///< Horizontal filter size for luma/alpha pixels.
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
148 int hChrFilterSize; ///< Horizontal filter size for chroma pixels.
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
149 int vLumFilterSize; ///< Vertical filter size for luma/alpha pixels.
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
150 int vChrFilterSize; ///< Vertical filter size for chroma pixels.
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
151 //@}
18861
8579acff875e Move postproc ---> libswscale
lucabe
parents:
diff changeset
152
30286
e6e5a84fdecb Document some of SwsContext.
ramiro
parents: 30285
diff changeset
153 int lumMmx2FilterCodeSize; ///< Runtime-generated MMX2 horizontal fast bilinear scaler code size for luma/alpha planes.
e6e5a84fdecb Document some of SwsContext.
ramiro
parents: 30285
diff changeset
154 int chrMmx2FilterCodeSize; ///< Runtime-generated MMX2 horizontal fast bilinear scaler code size for chroma planes.
e6e5a84fdecb Document some of SwsContext.
ramiro
parents: 30285
diff changeset
155 uint8_t *lumMmx2FilterCode; ///< Runtime-generated MMX2 horizontal fast bilinear scaler code for luma/alpha planes.
e6e5a84fdecb Document some of SwsContext.
ramiro
parents: 30285
diff changeset
156 uint8_t *chrMmx2FilterCode; ///< Runtime-generated MMX2 horizontal fast bilinear scaler code for chroma planes.
18861
8579acff875e Move postproc ---> libswscale
lucabe
parents:
diff changeset
157
23155
1befc8d767cd cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents: 22914
diff changeset
158 int canMMX2BeUsed;
18861
8579acff875e Move postproc ---> libswscale
lucabe
parents:
diff changeset
159
30286
e6e5a84fdecb Document some of SwsContext.
ramiro
parents: 30285
diff changeset
160 int dstY; ///< Last destination vertical line output from last slice.
e6e5a84fdecb Document some of SwsContext.
ramiro
parents: 30285
diff changeset
161 int flags; ///< Flags passed by the user to select scaler algorithm, optimizations, subsampling, etc...
23155
1befc8d767cd cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents: 22914
diff changeset
162 void * yuvTable; // pointer to the yuv->rgb table start so it can be freed()
1befc8d767cd cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents: 22914
diff changeset
163 uint8_t * table_rV[256];
1befc8d767cd cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents: 22914
diff changeset
164 uint8_t * table_gU[256];
1befc8d767cd cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents: 22914
diff changeset
165 int table_gV[256];
1befc8d767cd cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents: 22914
diff changeset
166 uint8_t * table_bU[256];
18861
8579acff875e Move postproc ---> libswscale
lucabe
parents:
diff changeset
167
23155
1befc8d767cd cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents: 22914
diff changeset
168 //Colorspace stuff
1befc8d767cd cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents: 22914
diff changeset
169 int contrast, brightness, saturation; // for sws_getColorspaceDetails
1befc8d767cd cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents: 22914
diff changeset
170 int srcColorspaceTable[4];
1befc8d767cd cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents: 22914
diff changeset
171 int dstColorspaceTable[4];
30286
e6e5a84fdecb Document some of SwsContext.
ramiro
parents: 30285
diff changeset
172 int srcRange; ///< 0 = MPG YUV range, 1 = JPG YUV range (source image).
e6e5a84fdecb Document some of SwsContext.
ramiro
parents: 30285
diff changeset
173 int dstRange; ///< 0 = MPG YUV range, 1 = JPG YUV range (destination image).
27567
203ac2c7f613 Rename yuv2rgb variables to avoid name clashes with the ones used by bfin asm.
michael
parents: 27554
diff changeset
174 int yuv2rgb_y_offset;
203ac2c7f613 Rename yuv2rgb variables to avoid name clashes with the ones used by bfin asm.
michael
parents: 27554
diff changeset
175 int yuv2rgb_y_coeff;
203ac2c7f613 Rename yuv2rgb variables to avoid name clashes with the ones used by bfin asm.
michael
parents: 27554
diff changeset
176 int yuv2rgb_v2r_coeff;
203ac2c7f613 Rename yuv2rgb variables to avoid name clashes with the ones used by bfin asm.
michael
parents: 27554
diff changeset
177 int yuv2rgb_v2g_coeff;
203ac2c7f613 Rename yuv2rgb variables to avoid name clashes with the ones used by bfin asm.
michael
parents: 27554
diff changeset
178 int yuv2rgb_u2g_coeff;
203ac2c7f613 Rename yuv2rgb variables to avoid name clashes with the ones used by bfin asm.
michael
parents: 27554
diff changeset
179 int yuv2rgb_u2b_coeff;
18861
8579acff875e Move postproc ---> libswscale
lucabe
parents:
diff changeset
180
23155
1befc8d767cd cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents: 22914
diff changeset
181 #define RED_DITHER "0*8"
1befc8d767cd cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents: 22914
diff changeset
182 #define GREEN_DITHER "1*8"
1befc8d767cd cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents: 22914
diff changeset
183 #define BLUE_DITHER "2*8"
1befc8d767cd cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents: 22914
diff changeset
184 #define Y_COEFF "3*8"
1befc8d767cd cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents: 22914
diff changeset
185 #define VR_COEFF "4*8"
1befc8d767cd cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents: 22914
diff changeset
186 #define UB_COEFF "5*8"
1befc8d767cd cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents: 22914
diff changeset
187 #define VG_COEFF "6*8"
1befc8d767cd cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents: 22914
diff changeset
188 #define UG_COEFF "7*8"
1befc8d767cd cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents: 22914
diff changeset
189 #define Y_OFFSET "8*8"
1befc8d767cd cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents: 22914
diff changeset
190 #define U_OFFSET "9*8"
1befc8d767cd cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents: 22914
diff changeset
191 #define V_OFFSET "10*8"
18861
8579acff875e Move postproc ---> libswscale
lucabe
parents:
diff changeset
192 #define LUM_MMX_FILTER_OFFSET "11*8"
8579acff875e Move postproc ---> libswscale
lucabe
parents:
diff changeset
193 #define CHR_MMX_FILTER_OFFSET "11*8+4*4*256"
27158
65b8334df960 spelling/grammar/wording overhaul
diego
parents: 26670
diff changeset
194 #define DSTW_OFFSET "11*8+4*4*256*2" //do not change, it is hardcoded in the ASM
23155
1befc8d767cd cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents: 22914
diff changeset
195 #define ESP_OFFSET "11*8+4*4*256*2+8"
1befc8d767cd cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents: 22914
diff changeset
196 #define VROUNDER_OFFSET "11*8+4*4*256*2+16"
1befc8d767cd cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents: 22914
diff changeset
197 #define U_TEMP "11*8+4*4*256*2+24"
1befc8d767cd cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents: 22914
diff changeset
198 #define V_TEMP "11*8+4*4*256*2+32"
28976
602c77c53923 Add alpha channel scaling
sdrik
parents: 28953
diff changeset
199 #define Y_TEMP "11*8+4*4*256*2+40"
602c77c53923 Add alpha channel scaling
sdrik
parents: 28953
diff changeset
200 #define ALP_MMX_FILTER_OFFSET "11*8+4*4*256*2+48"
19172
bae6c99a99cc vertical scaler with accurate rounding, some people on doom9 can see +-1 errors
michael
parents: 19143
diff changeset
201
29306
116ed5c6c367 Use DECLARE_ALIGNED macro instead of gcc __attribute__.
ramiro
parents: 29299
diff changeset
202 DECLARE_ALIGNED(8, uint64_t, redDither);
116ed5c6c367 Use DECLARE_ALIGNED macro instead of gcc __attribute__.
ramiro
parents: 29299
diff changeset
203 DECLARE_ALIGNED(8, uint64_t, greenDither);
116ed5c6c367 Use DECLARE_ALIGNED macro instead of gcc __attribute__.
ramiro
parents: 29299
diff changeset
204 DECLARE_ALIGNED(8, uint64_t, blueDither);
18861
8579acff875e Move postproc ---> libswscale
lucabe
parents:
diff changeset
205
29306
116ed5c6c367 Use DECLARE_ALIGNED macro instead of gcc __attribute__.
ramiro
parents: 29299
diff changeset
206 DECLARE_ALIGNED(8, uint64_t, yCoeff);
116ed5c6c367 Use DECLARE_ALIGNED macro instead of gcc __attribute__.
ramiro
parents: 29299
diff changeset
207 DECLARE_ALIGNED(8, uint64_t, vrCoeff);
116ed5c6c367 Use DECLARE_ALIGNED macro instead of gcc __attribute__.
ramiro
parents: 29299
diff changeset
208 DECLARE_ALIGNED(8, uint64_t, ubCoeff);
116ed5c6c367 Use DECLARE_ALIGNED macro instead of gcc __attribute__.
ramiro
parents: 29299
diff changeset
209 DECLARE_ALIGNED(8, uint64_t, vgCoeff);
116ed5c6c367 Use DECLARE_ALIGNED macro instead of gcc __attribute__.
ramiro
parents: 29299
diff changeset
210 DECLARE_ALIGNED(8, uint64_t, ugCoeff);
116ed5c6c367 Use DECLARE_ALIGNED macro instead of gcc __attribute__.
ramiro
parents: 29299
diff changeset
211 DECLARE_ALIGNED(8, uint64_t, yOffset);
116ed5c6c367 Use DECLARE_ALIGNED macro instead of gcc __attribute__.
ramiro
parents: 29299
diff changeset
212 DECLARE_ALIGNED(8, uint64_t, uOffset);
116ed5c6c367 Use DECLARE_ALIGNED macro instead of gcc __attribute__.
ramiro
parents: 29299
diff changeset
213 DECLARE_ALIGNED(8, uint64_t, vOffset);
23155
1befc8d767cd cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents: 22914
diff changeset
214 int32_t lumMmxFilter[4*MAX_FILTER_SIZE];
1befc8d767cd cosmetics attack, part II: Remove all tabs and prettyprint/reindent the code.
diego
parents: 22914
diff changeset
215 int32_t chrMmxFilter[4*MAX_FILTER_SIZE];
30338
4f25e4d519f4 Document some more of SwsContext.
ramiro
parents: 30291
diff changeset
216 int dstW; ///< Width of destination luma/alpha planes.
29306
116ed5c6c367 Use DECLARE_ALIGNED macro instead of gcc __attribute__.
ramiro
parents: 29299
diff changeset
217 DECLARE_ALIGNED(8, uint64_t, esp);
116ed5c6c367 Use DECLARE_ALIGNED macro instead of gcc __attribute__.
ramiro
parents: 29299
diff changeset
218 DECLARE_ALIGNED(8, uint64_t, vRounder);
116ed5c6c367 Use DECLARE_ALIGNED macro instead of gcc __attribute__.
ramiro
parents: 29299
diff changeset
219 DECLARE_ALIGNED(8, uint64_t, u_temp);
116ed5c6c367 Use DECLARE_ALIGNED macro instead of gcc __attribute__.
ramiro
parents: 29299
diff changeset
220 DECLARE_ALIGNED(8, uint64_t, v_temp);
116ed5c6c367 Use DECLARE_ALIGNED macro instead of gcc __attribute__.
ramiro
parents: 29299
diff changeset
221 DECLARE_ALIGNED(8, uint64_t, y_temp);
28976
602c77c53923 Add alpha channel scaling
sdrik
parents: 28953
diff changeset
222 int32_t alpMmxFilter[4*MAX_FILTER_SIZE];
18861
8579acff875e Move postproc ---> libswscale
lucabe
parents:
diff changeset
223
28276
877336d3c598 Change semantic of CONFIG_*, HAVE_* and ARCH_*.
aurel
parents: 27698
diff changeset
224 #if HAVE_ALTIVEC
30045
ddf16edcc048 Indentation.
ramiro
parents: 30040
diff changeset
225 vector signed short CY;
ddf16edcc048 Indentation.
ramiro
parents: 30040
diff changeset
226 vector signed short CRV;
ddf16edcc048 Indentation.
ramiro
parents: 30040
diff changeset
227 vector signed short CBU;
ddf16edcc048 Indentation.
ramiro
parents: 30040
diff changeset
228 vector signed short CGU;
ddf16edcc048 Indentation.
ramiro
parents: 30040
diff changeset
229 vector signed short CGV;
ddf16edcc048 Indentation.
ramiro
parents: 30040
diff changeset
230 vector signed short OY;
ddf16edcc048 Indentation.
ramiro
parents: 30040
diff changeset
231 vector unsigned short CSHIFT;
ddf16edcc048 Indentation.
ramiro
parents: 30040
diff changeset
232 vector signed short *vYCoeffsBank, *vCCoeffsBank;
18861
8579acff875e Move postproc ---> libswscale
lucabe
parents:
diff changeset
233 #endif
8579acff875e Move postproc ---> libswscale
lucabe
parents:
diff changeset
234
28276
877336d3c598 Change semantic of CONFIG_*, HAVE_* and ARCH_*.
aurel
parents: 27698
diff changeset
235 #if ARCH_BFIN
29306
116ed5c6c367 Use DECLARE_ALIGNED macro instead of gcc __attribute__.
ramiro
parents: 29299
diff changeset
236 DECLARE_ALIGNED(4, uint32_t, oy);
116ed5c6c367 Use DECLARE_ALIGNED macro instead of gcc __attribute__.
ramiro
parents: 29299
diff changeset
237 DECLARE_ALIGNED(4, uint32_t, oc);
116ed5c6c367 Use DECLARE_ALIGNED macro instead of gcc __attribute__.
ramiro
parents: 29299
diff changeset
238 DECLARE_ALIGNED(4, uint32_t, zero);
116ed5c6c367 Use DECLARE_ALIGNED macro instead of gcc __attribute__.
ramiro
parents: 29299
diff changeset
239 DECLARE_ALIGNED(4, uint32_t, cy);
116ed5c6c367 Use DECLARE_ALIGNED macro instead of gcc __attribute__.
ramiro
parents: 29299
diff changeset
240 DECLARE_ALIGNED(4, uint32_t, crv);
116ed5c6c367 Use DECLARE_ALIGNED macro instead of gcc __attribute__.
ramiro
parents: 29299
diff changeset
241 DECLARE_ALIGNED(4, uint32_t, rmask);
116ed5c6c367 Use DECLARE_ALIGNED macro instead of gcc __attribute__.
ramiro
parents: 29299
diff changeset
242 DECLARE_ALIGNED(4, uint32_t, cbu);
116ed5c6c367 Use DECLARE_ALIGNED macro instead of gcc __attribute__.
ramiro
parents: 29299
diff changeset
243 DECLARE_ALIGNED(4, uint32_t, bmask);
116ed5c6c367 Use DECLARE_ALIGNED macro instead of gcc __attribute__.
ramiro
parents: 29299
diff changeset
244 DECLARE_ALIGNED(4, uint32_t, cgu);
116ed5c6c367 Use DECLARE_ALIGNED macro instead of gcc __attribute__.
ramiro
parents: 29299
diff changeset
245 DECLARE_ALIGNED(4, uint32_t, cgv);
116ed5c6c367 Use DECLARE_ALIGNED macro instead of gcc __attribute__.
ramiro
parents: 29299
diff changeset
246 DECLARE_ALIGNED(4, uint32_t, gmask);
23289
786823779b67 Blackfin optimized YUV420 to RGB CSC Color Space Converters.
gpoirier
parents: 23278
diff changeset
247 #endif
786823779b67 Blackfin optimized YUV420 to RGB CSC Color Space Converters.
gpoirier
parents: 23278
diff changeset
248
28276
877336d3c598 Change semantic of CONFIG_*, HAVE_* and ARCH_*.
aurel
parents: 27698
diff changeset
249 #if HAVE_VIS
30343
4d50825554ee Move array specifiers outside DECLARE_ALIGNED() invocations
mru
parents: 30338
diff changeset
250 DECLARE_ALIGNED(8, uint64_t, sparc_coeffs)[10];
23805
3c6db57870ea UltraSPARC VIS yuv2rgb
benoit
parents: 23791
diff changeset
251 #endif
23289
786823779b67 Blackfin optimized YUV420 to RGB CSC Color Space Converters.
gpoirier
parents: 23278
diff changeset
252
29105
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
253 /* function pointers for swScale() */
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
254 void (*yuv2nv12X )(struct SwsContext *c,
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
255 const int16_t *lumFilter, const int16_t **lumSrc, int lumFilterSize,
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
256 const int16_t *chrFilter, const int16_t **chrSrc, int chrFilterSize,
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
257 uint8_t *dest, uint8_t *uDest,
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
258 int dstW, int chrDstW, int dstFormat);
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
259 void (*yuv2yuv1 )(struct SwsContext *c,
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
260 const int16_t *lumSrc, const int16_t *chrSrc, const int16_t *alpSrc,
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
261 uint8_t *dest,
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
262 uint8_t *uDest, uint8_t *vDest, uint8_t *aDest,
31113
1f7d0e9e2ebf Revert r31153. It failed to build on:
ramiro
parents: 31096
diff changeset
263 long dstW, long chrDstW);
29105
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
264 void (*yuv2yuvX )(struct SwsContext *c,
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
265 const int16_t *lumFilter, const int16_t **lumSrc, int lumFilterSize,
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
266 const int16_t *chrFilter, const int16_t **chrSrc, int chrFilterSize,
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
267 const int16_t **alpSrc,
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
268 uint8_t *dest,
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
269 uint8_t *uDest, uint8_t *vDest, uint8_t *aDest,
31113
1f7d0e9e2ebf Revert r31153. It failed to build on:
ramiro
parents: 31096
diff changeset
270 long dstW, long chrDstW);
29105
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
271 void (*yuv2packed1)(struct SwsContext *c,
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
272 const uint16_t *buf0,
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
273 const uint16_t *uvbuf0, const uint16_t *uvbuf1,
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
274 const uint16_t *abuf0,
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
275 uint8_t *dest,
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
276 int dstW, int uvalpha, int dstFormat, int flags, int y);
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
277 void (*yuv2packed2)(struct SwsContext *c,
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
278 const uint16_t *buf0, const uint16_t *buf1,
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
279 const uint16_t *uvbuf0, const uint16_t *uvbuf1,
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
280 const uint16_t *abuf0, const uint16_t *abuf1,
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
281 uint8_t *dest,
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
282 int dstW, int yalpha, int uvalpha, int y);
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
283 void (*yuv2packedX)(struct SwsContext *c,
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
284 const int16_t *lumFilter, const int16_t **lumSrc, int lumFilterSize,
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
285 const int16_t *chrFilter, const int16_t **chrSrc, int chrFilterSize,
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
286 const int16_t **alpSrc, uint8_t *dest,
31113
1f7d0e9e2ebf Revert r31153. It failed to build on:
ramiro
parents: 31096
diff changeset
287 long dstW, long dstY);
29105
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
288
30055
4c712237a601 Rename function pointers used to convert from the input pixel format to the
ramiro
parents: 30054
diff changeset
289 void (*lumToYV12)(uint8_t *dst, const uint8_t *src,
31113
1f7d0e9e2ebf Revert r31153. It failed to build on:
ramiro
parents: 31096
diff changeset
290 long width, uint32_t *pal); ///< Unscaled conversion of luma plane to YV12 for horizontal scaler.
30055
4c712237a601 Rename function pointers used to convert from the input pixel format to the
ramiro
parents: 30054
diff changeset
291 void (*alpToYV12)(uint8_t *dst, const uint8_t *src,
31113
1f7d0e9e2ebf Revert r31153. It failed to build on:
ramiro
parents: 31096
diff changeset
292 long width, uint32_t *pal); ///< Unscaled conversion of alpha plane to YV12 for horizontal scaler.
30055
4c712237a601 Rename function pointers used to convert from the input pixel format to the
ramiro
parents: 30054
diff changeset
293 void (*chrToYV12)(uint8_t *dstU, uint8_t *dstV,
4c712237a601 Rename function pointers used to convert from the input pixel format to the
ramiro
parents: 30054
diff changeset
294 const uint8_t *src1, const uint8_t *src2,
31113
1f7d0e9e2ebf Revert r31153. It failed to build on:
ramiro
parents: 31096
diff changeset
295 long width, uint32_t *pal); ///< Unscaled conversion of chroma planes to YV12 for horizontal scaler.
29105
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
296 void (*hyscale_fast)(struct SwsContext *c,
31113
1f7d0e9e2ebf Revert r31153. It failed to build on:
ramiro
parents: 31096
diff changeset
297 int16_t *dst, long dstWidth,
29105
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
298 const uint8_t *src, int srcW, int xInc);
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
299 void (*hcscale_fast)(struct SwsContext *c,
31113
1f7d0e9e2ebf Revert r31153. It failed to build on:
ramiro
parents: 31096
diff changeset
300 int16_t *dst, long dstWidth,
29134
ede1c13e8865 whitespace cosmetics: Reindent a few lines and break a few excessively long lines.
diego
parents: 29105
diff changeset
301 const uint8_t *src1, const uint8_t *src2,
ede1c13e8865 whitespace cosmetics: Reindent a few lines and break a few excessively long lines.
diego
parents: 29105
diff changeset
302 int srcW, int xInc);
29105
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
303
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
304 void (*hScale)(int16_t *dst, int dstW, const uint8_t *src, int srcW,
29134
ede1c13e8865 whitespace cosmetics: Reindent a few lines and break a few excessively long lines.
diego
parents: 29105
diff changeset
305 int xInc, const int16_t *filter, const int16_t *filterPos,
31113
1f7d0e9e2ebf Revert r31153. It failed to build on:
ramiro
parents: 31096
diff changeset
306 long filterSize);
29105
9502a8895e77 swscale: Use function pointers for swScale functions.
ramiro
parents: 29042
diff changeset
307
30040
79adcc3e4e83 Set horizontal scaler's range conversion in context in sws_init_swScale().
ramiro
parents: 30039
diff changeset
308 void (*lumConvertRange)(uint16_t *dst, int width); ///< Color range conversion function for luma plane if needed.
79adcc3e4e83 Set horizontal scaler's range conversion in context in sws_init_swScale().
ramiro
parents: 30039
diff changeset
309 void (*chrConvertRange)(uint16_t *dst, int width); ///< Color range conversion function for chroma planes if needed.
79adcc3e4e83 Set horizontal scaler's range conversion in context in sws_init_swScale().
ramiro
parents: 30039
diff changeset
310
30039
3b0026eb9c4d Set horizontal scaler's src offsets in context in sws_init_swScale().
ramiro
parents: 29608
diff changeset
311 int lumSrcOffset; ///< Offset given to luma src pointers passed to horizontal input functions.
3b0026eb9c4d Set horizontal scaler's src offsets in context in sws_init_swScale().
ramiro
parents: 29608
diff changeset
312 int chrSrcOffset; ///< Offset given to chroma src pointers passed to horizontal input functions.
3b0026eb9c4d Set horizontal scaler's src offsets in context in sws_init_swScale().
ramiro
parents: 29608
diff changeset
313 int alpSrcOffset; ///< Offset given to alpha src pointers passed to horizontal input functions.
3b0026eb9c4d Set horizontal scaler's src offsets in context in sws_init_swScale().
ramiro
parents: 29608
diff changeset
314
30054
67e244d32f1c Check if chroma horizontal scaler is needed in sws_init_swScale().
ramiro
parents: 30053
diff changeset
315 int needs_hcscale; ///< Set if there are chroma planes to be converted.
67e244d32f1c Check if chroma horizontal scaler is needed in sws_init_swScale().
ramiro
parents: 30053
diff changeset
316
18861
8579acff875e Move postproc ---> libswscale
lucabe
parents:
diff changeset
317 } SwsContext;
8579acff875e Move postproc ---> libswscale
lucabe
parents:
diff changeset
318 //FIXME check init (where 0)
8579acff875e Move postproc ---> libswscale
lucabe
parents:
diff changeset
319
28953
1e56ea9937ce Consistently use ff_ prefixes for internal symbols.
diego
parents: 28832
diff changeset
320 SwsFunc ff_yuv2rgb_get_func_ptr(SwsContext *c);
29134
ede1c13e8865 whitespace cosmetics: Reindent a few lines and break a few excessively long lines.
diego
parents: 29105
diff changeset
321 int ff_yuv2rgb_c_init_tables(SwsContext *c, const int inv_table[4],
ede1c13e8865 whitespace cosmetics: Reindent a few lines and break a few excessively long lines.
diego
parents: 29105
diff changeset
322 int fullRange, int brightness,
ede1c13e8865 whitespace cosmetics: Reindent a few lines and break a few excessively long lines.
diego
parents: 29105
diff changeset
323 int contrast, int saturation);
18861
8579acff875e Move postproc ---> libswscale
lucabe
parents:
diff changeset
324
29134
ede1c13e8865 whitespace cosmetics: Reindent a few lines and break a few excessively long lines.
diego
parents: 29105
diff changeset
325 void ff_yuv2rgb_init_tables_altivec(SwsContext *c, const int inv_table[4],
ede1c13e8865 whitespace cosmetics: Reindent a few lines and break a few excessively long lines.
diego
parents: 29105
diff changeset
326 int brightness, int contrast, int saturation);
29028
f8db50af4035 Move yuv2rgb code to subdirs.
ramiro
parents: 28976
diff changeset
327 SwsFunc ff_yuv2rgb_init_mmx(SwsContext *c);
f8db50af4035 Move yuv2rgb code to subdirs.
ramiro
parents: 28976
diff changeset
328 SwsFunc ff_yuv2rgb_init_vis(SwsContext *c);
f8db50af4035 Move yuv2rgb code to subdirs.
ramiro
parents: 28976
diff changeset
329 SwsFunc ff_yuv2rgb_init_mlib(SwsContext *c);
28953
1e56ea9937ce Consistently use ff_ prefixes for internal symbols.
diego
parents: 28832
diff changeset
330 SwsFunc ff_yuv2rgb_init_altivec(SwsContext *c);
29028
f8db50af4035 Move yuv2rgb code to subdirs.
ramiro
parents: 28976
diff changeset
331 SwsFunc ff_yuv2rgb_get_func_ptr_bfin(SwsContext *c);
29042
c198fbb7172e Move bfin specific code to its subdir.
ramiro
parents: 29028
diff changeset
332 void ff_bfin_get_unscaled_swscale(SwsContext *c);
28953
1e56ea9937ce Consistently use ff_ prefixes for internal symbols.
diego
parents: 28832
diff changeset
333 void ff_yuv2packedX_altivec(SwsContext *c,
31715
b90559772910 More const-correctness fixes to avoid warnings.
reimar
parents: 31692
diff changeset
334 const int16_t *lumFilter, const int16_t **lumSrc, int lumFilterSize,
b90559772910 More const-correctness fixes to avoid warnings.
reimar
parents: 31692
diff changeset
335 const int16_t *chrFilter, const int16_t **chrSrc, int chrFilterSize,
29134
ede1c13e8865 whitespace cosmetics: Reindent a few lines and break a few excessively long lines.
diego
parents: 29105
diff changeset
336 uint8_t *dest, int dstW, int dstY);
25291
c48b33da31d3 Add missing declarations for AltiVec functions, fixes the warnings:
diego
parents: 25288
diff changeset
337
29367
1d4dd0f12c98 Use enum PixelFormat in sws_format_name() prototype
mru
parents: 29311
diff changeset
338 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
339
19872
8e50cba9fe03 Remove the dependency of libswscale on img_format.h
lucabe
parents: 19594
diff changeset
340 //FIXME replace this with something faster
29174
d467f9cc89c6 Add macro to check for 16bit per sample.
michael
parents: 29171
diff changeset
341 #define is16BPS(x) ( \
d467f9cc89c6 Add macro to check for 16bit per sample.
michael
parents: 29171
diff changeset
342 (x)==PIX_FMT_GRAY16BE \
d467f9cc89c6 Add macro to check for 16bit per sample.
michael
parents: 29171
diff changeset
343 || (x)==PIX_FMT_GRAY16LE \
29275
bc48593c663e Let SwScaler know that RGB48 BE/LE is 16-bits per component format.
kostya
parents: 29274
diff changeset
344 || (x)==PIX_FMT_RGB48BE \
bc48593c663e Let SwScaler know that RGB48 BE/LE is 16-bits per component format.
kostya
parents: 29274
diff changeset
345 || (x)==PIX_FMT_RGB48LE \
31692
d9fd0266a6d3 Restore vertical alignment in some defines
ramiro
parents: 31113
diff changeset
346 || (x)==PIX_FMT_YUV420P16LE \
d9fd0266a6d3 Restore vertical alignment in some defines
ramiro
parents: 31113
diff changeset
347 || (x)==PIX_FMT_YUV422P16LE \
d9fd0266a6d3 Restore vertical alignment in some defines
ramiro
parents: 31113
diff changeset
348 || (x)==PIX_FMT_YUV444P16LE \
d9fd0266a6d3 Restore vertical alignment in some defines
ramiro
parents: 31113
diff changeset
349 || (x)==PIX_FMT_YUV420P16BE \
d9fd0266a6d3 Restore vertical alignment in some defines
ramiro
parents: 31113
diff changeset
350 || (x)==PIX_FMT_YUV422P16BE \
d9fd0266a6d3 Restore vertical alignment in some defines
ramiro
parents: 31113
diff changeset
351 || (x)==PIX_FMT_YUV444P16BE \
29174
d467f9cc89c6 Add macro to check for 16bit per sample.
michael
parents: 29171
diff changeset
352 )
29171
091f16266a60 add isBE()
michael
parents: 29139
diff changeset
353 #define isBE(x) ((x)&1)
29176
d18426e37f13 Planar 16bit 420 422 444 YUV support (output is only supported in some
michael
parents: 29174
diff changeset
354 #define isPlanar8YUV(x) ( \
23278
b745a8414f2c cosmetics; one test per line for all isXXX(x) macros
ivo
parents: 23155
diff changeset
355 (x)==PIX_FMT_YUV410P \
b745a8414f2c cosmetics; one test per line for all isXXX(x) macros
ivo
parents: 23155
diff changeset
356 || (x)==PIX_FMT_YUV420P \
28832
9ab5447ba67a YUVA420P is a planar YUV format
sdrik
parents: 28712
diff changeset
357 || (x)==PIX_FMT_YUVA420P \
23278
b745a8414f2c cosmetics; one test per line for all isXXX(x) macros
ivo
parents: 23155
diff changeset
358 || (x)==PIX_FMT_YUV411P \
b745a8414f2c cosmetics; one test per line for all isXXX(x) macros
ivo
parents: 23155
diff changeset
359 || (x)==PIX_FMT_YUV422P \
b745a8414f2c cosmetics; one test per line for all isXXX(x) macros
ivo
parents: 23155
diff changeset
360 || (x)==PIX_FMT_YUV444P \
23791
e4138d991107 use YUV440P in swscale
benoit
parents: 23702
diff changeset
361 || (x)==PIX_FMT_YUV440P \
23278
b745a8414f2c cosmetics; one test per line for all isXXX(x) macros
ivo
parents: 23155
diff changeset
362 || (x)==PIX_FMT_NV12 \
b745a8414f2c cosmetics; one test per line for all isXXX(x) macros
ivo
parents: 23155
diff changeset
363 || (x)==PIX_FMT_NV21 \
b745a8414f2c cosmetics; one test per line for all isXXX(x) macros
ivo
parents: 23155
diff changeset
364 )
29176
d18426e37f13 Planar 16bit 420 422 444 YUV support (output is only supported in some
michael
parents: 29174
diff changeset
365 #define isPlanarYUV(x) ( \
d18426e37f13 Planar 16bit 420 422 444 YUV support (output is only supported in some
michael
parents: 29174
diff changeset
366 isPlanar8YUV(x) \
31692
d9fd0266a6d3 Restore vertical alignment in some defines
ramiro
parents: 31113
diff changeset
367 || (x)==PIX_FMT_YUV420P16LE \
d9fd0266a6d3 Restore vertical alignment in some defines
ramiro
parents: 31113
diff changeset
368 || (x)==PIX_FMT_YUV422P16LE \
d9fd0266a6d3 Restore vertical alignment in some defines
ramiro
parents: 31113
diff changeset
369 || (x)==PIX_FMT_YUV444P16LE \
d9fd0266a6d3 Restore vertical alignment in some defines
ramiro
parents: 31113
diff changeset
370 || (x)==PIX_FMT_YUV420P16BE \
d9fd0266a6d3 Restore vertical alignment in some defines
ramiro
parents: 31113
diff changeset
371 || (x)==PIX_FMT_YUV422P16BE \
d9fd0266a6d3 Restore vertical alignment in some defines
ramiro
parents: 31113
diff changeset
372 || (x)==PIX_FMT_YUV444P16BE \
29176
d18426e37f13 Planar 16bit 420 422 444 YUV support (output is only supported in some
michael
parents: 29174
diff changeset
373 )
23278
b745a8414f2c cosmetics; one test per line for all isXXX(x) macros
ivo
parents: 23155
diff changeset
374 #define isYUV(x) ( \
b745a8414f2c cosmetics; one test per line for all isXXX(x) macros
ivo
parents: 23155
diff changeset
375 (x)==PIX_FMT_UYVY422 \
b745a8414f2c cosmetics; one test per line for all isXXX(x) macros
ivo
parents: 23155
diff changeset
376 || (x)==PIX_FMT_YUYV422 \
b745a8414f2c cosmetics; one test per line for all isXXX(x) macros
ivo
parents: 23155
diff changeset
377 || isPlanarYUV(x) \
b745a8414f2c cosmetics; one test per line for all isXXX(x) macros
ivo
parents: 23155
diff changeset
378 )
b745a8414f2c cosmetics; one test per line for all isXXX(x) macros
ivo
parents: 23155
diff changeset
379 #define isGray(x) ( \
b745a8414f2c cosmetics; one test per line for all isXXX(x) macros
ivo
parents: 23155
diff changeset
380 (x)==PIX_FMT_GRAY8 \
32308
ecb8e52d4add Y400A (gray alpha) input support in libswscale
bcoudurier
parents: 31715
diff changeset
381 || (x)==PIX_FMT_Y400A \
23278
b745a8414f2c cosmetics; one test per line for all isXXX(x) macros
ivo
parents: 23155
diff changeset
382 || (x)==PIX_FMT_GRAY16BE \
b745a8414f2c cosmetics; one test per line for all isXXX(x) macros
ivo
parents: 23155
diff changeset
383 || (x)==PIX_FMT_GRAY16LE \
b745a8414f2c cosmetics; one test per line for all isXXX(x) macros
ivo
parents: 23155
diff changeset
384 )
b745a8414f2c cosmetics; one test per line for all isXXX(x) macros
ivo
parents: 23155
diff changeset
385 #define isGray16(x) ( \
b745a8414f2c cosmetics; one test per line for all isXXX(x) macros
ivo
parents: 23155
diff changeset
386 (x)==PIX_FMT_GRAY16BE \
b745a8414f2c cosmetics; one test per line for all isXXX(x) macros
ivo
parents: 23155
diff changeset
387 || (x)==PIX_FMT_GRAY16LE \
b745a8414f2c cosmetics; one test per line for all isXXX(x) macros
ivo
parents: 23155
diff changeset
388 )
30391
2a33c1c37e6b Rename isRGB() and isBGR() as their meaning is confusing.
michael
parents: 30377
diff changeset
389 #define isRGBinInt(x) ( \
29299
24954ec81529 Partial (low bits ignored, no direct transcoding into other RGB formats) support
kostya
parents: 29275
diff changeset
390 (x)==PIX_FMT_RGB48BE \
24954ec81529 Partial (low bits ignored, no direct transcoding into other RGB formats) support
kostya
parents: 29275
diff changeset
391 || (x)==PIX_FMT_RGB48LE \
24954ec81529 Partial (low bits ignored, no direct transcoding into other RGB formats) support
kostya
parents: 29275
diff changeset
392 || (x)==PIX_FMT_RGB32 \
27490
651ebfa4b7db Support PIX_FMT_RGB32_1 and PIX_FMT_BGR32_1.
michael
parents: 27488
diff changeset
393 || (x)==PIX_FMT_RGB32_1 \
23278
b745a8414f2c cosmetics; one test per line for all isXXX(x) macros
ivo
parents: 23155
diff changeset
394 || (x)==PIX_FMT_RGB24 \
30798
91f90077acf6 Support BGR555, BGR565, RGB555 and RGB565 foreign endian output in
cehoyos
parents: 30392
diff changeset
395 || (x)==PIX_FMT_RGB565BE \
91f90077acf6 Support BGR555, BGR565, RGB555 and RGB565 foreign endian output in
cehoyos
parents: 30392
diff changeset
396 || (x)==PIX_FMT_RGB565LE \
91f90077acf6 Support BGR555, BGR565, RGB555 and RGB565 foreign endian output in
cehoyos
parents: 30392
diff changeset
397 || (x)==PIX_FMT_RGB555BE \
91f90077acf6 Support BGR555, BGR565, RGB555 and RGB565 foreign endian output in
cehoyos
parents: 30392
diff changeset
398 || (x)==PIX_FMT_RGB555LE \
30813
87acb5d9e4aa Add support to BGR444/RGB444 foreign endian output in libswscale.
stefano
parents: 30799
diff changeset
399 || (x)==PIX_FMT_RGB444BE \
87acb5d9e4aa Add support to BGR444/RGB444 foreign endian output in libswscale.
stefano
parents: 30799
diff changeset
400 || (x)==PIX_FMT_RGB444LE \
23278
b745a8414f2c cosmetics; one test per line for all isXXX(x) macros
ivo
parents: 23155
diff changeset
401 || (x)==PIX_FMT_RGB8 \
b745a8414f2c cosmetics; one test per line for all isXXX(x) macros
ivo
parents: 23155
diff changeset
402 || (x)==PIX_FMT_RGB4 \
b745a8414f2c cosmetics; one test per line for all isXXX(x) macros
ivo
parents: 23155
diff changeset
403 || (x)==PIX_FMT_RGB4_BYTE \
b745a8414f2c cosmetics; one test per line for all isXXX(x) macros
ivo
parents: 23155
diff changeset
404 || (x)==PIX_FMT_MONOBLACK \
27554
021a1889cc26 Add support for PIX_FMT_MONOWHITE as output format.
michael
parents: 27551
diff changeset
405 || (x)==PIX_FMT_MONOWHITE \
23278
b745a8414f2c cosmetics; one test per line for all isXXX(x) macros
ivo
parents: 23155
diff changeset
406 )
30391
2a33c1c37e6b Rename isRGB() and isBGR() as their meaning is confusing.
michael
parents: 30377
diff changeset
407 #define isBGRinInt(x) ( \
27488
92479ee7ad6e Remove workaround for rgb/bgr mess.
michael
parents: 27467
diff changeset
408 (x)==PIX_FMT_BGR32 \
27490
651ebfa4b7db Support PIX_FMT_RGB32_1 and PIX_FMT_BGR32_1.
michael
parents: 27488
diff changeset
409 || (x)==PIX_FMT_BGR32_1 \
23278
b745a8414f2c cosmetics; one test per line for all isXXX(x) macros
ivo
parents: 23155
diff changeset
410 || (x)==PIX_FMT_BGR24 \
30798
91f90077acf6 Support BGR555, BGR565, RGB555 and RGB565 foreign endian output in
cehoyos
parents: 30392
diff changeset
411 || (x)==PIX_FMT_BGR565BE \
91f90077acf6 Support BGR555, BGR565, RGB555 and RGB565 foreign endian output in
cehoyos
parents: 30392
diff changeset
412 || (x)==PIX_FMT_BGR565LE \
91f90077acf6 Support BGR555, BGR565, RGB555 and RGB565 foreign endian output in
cehoyos
parents: 30392
diff changeset
413 || (x)==PIX_FMT_BGR555BE \
91f90077acf6 Support BGR555, BGR565, RGB555 and RGB565 foreign endian output in
cehoyos
parents: 30392
diff changeset
414 || (x)==PIX_FMT_BGR555LE \
30813
87acb5d9e4aa Add support to BGR444/RGB444 foreign endian output in libswscale.
stefano
parents: 30799
diff changeset
415 || (x)==PIX_FMT_BGR444BE \
87acb5d9e4aa Add support to BGR444/RGB444 foreign endian output in libswscale.
stefano
parents: 30799
diff changeset
416 || (x)==PIX_FMT_BGR444LE \
23278
b745a8414f2c cosmetics; one test per line for all isXXX(x) macros
ivo
parents: 23155
diff changeset
417 || (x)==PIX_FMT_BGR8 \
b745a8414f2c cosmetics; one test per line for all isXXX(x) macros
ivo
parents: 23155
diff changeset
418 || (x)==PIX_FMT_BGR4 \
b745a8414f2c cosmetics; one test per line for all isXXX(x) macros
ivo
parents: 23155
diff changeset
419 || (x)==PIX_FMT_BGR4_BYTE \
b745a8414f2c cosmetics; one test per line for all isXXX(x) macros
ivo
parents: 23155
diff changeset
420 || (x)==PIX_FMT_MONOBLACK \
27554
021a1889cc26 Add support for PIX_FMT_MONOWHITE as output format.
michael
parents: 27551
diff changeset
421 || (x)==PIX_FMT_MONOWHITE \
23278
b745a8414f2c cosmetics; one test per line for all isXXX(x) macros
ivo
parents: 23155
diff changeset
422 )
30392
8d89e0052f84 Add 3 more RGB makros that allow specifying RGB in bytes and any rgb/bgr.
michael
parents: 30391
diff changeset
423 #define isRGBinBytes(x) ( \
8d89e0052f84 Add 3 more RGB makros that allow specifying RGB in bytes and any rgb/bgr.
michael
parents: 30391
diff changeset
424 (x)==PIX_FMT_RGB48BE \
8d89e0052f84 Add 3 more RGB makros that allow specifying RGB in bytes and any rgb/bgr.
michael
parents: 30391
diff changeset
425 || (x)==PIX_FMT_RGB48LE \
8d89e0052f84 Add 3 more RGB makros that allow specifying RGB in bytes and any rgb/bgr.
michael
parents: 30391
diff changeset
426 || (x)==PIX_FMT_RGBA \
8d89e0052f84 Add 3 more RGB makros that allow specifying RGB in bytes and any rgb/bgr.
michael
parents: 30391
diff changeset
427 || (x)==PIX_FMT_ARGB \
8d89e0052f84 Add 3 more RGB makros that allow specifying RGB in bytes and any rgb/bgr.
michael
parents: 30391
diff changeset
428 || (x)==PIX_FMT_RGB24 \
8d89e0052f84 Add 3 more RGB makros that allow specifying RGB in bytes and any rgb/bgr.
michael
parents: 30391
diff changeset
429 )
8d89e0052f84 Add 3 more RGB makros that allow specifying RGB in bytes and any rgb/bgr.
michael
parents: 30391
diff changeset
430 #define isBGRinBytes(x) ( \
8d89e0052f84 Add 3 more RGB makros that allow specifying RGB in bytes and any rgb/bgr.
michael
parents: 30391
diff changeset
431 (x)==PIX_FMT_BGRA \
8d89e0052f84 Add 3 more RGB makros that allow specifying RGB in bytes and any rgb/bgr.
michael
parents: 30391
diff changeset
432 || (x)==PIX_FMT_ABGR \
8d89e0052f84 Add 3 more RGB makros that allow specifying RGB in bytes and any rgb/bgr.
michael
parents: 30391
diff changeset
433 || (x)==PIX_FMT_BGR24 \
8d89e0052f84 Add 3 more RGB makros that allow specifying RGB in bytes and any rgb/bgr.
michael
parents: 30391
diff changeset
434 )
8d89e0052f84 Add 3 more RGB makros that allow specifying RGB in bytes and any rgb/bgr.
michael
parents: 30391
diff changeset
435 #define isAnyRGB(x) ( \
8d89e0052f84 Add 3 more RGB makros that allow specifying RGB in bytes and any rgb/bgr.
michael
parents: 30391
diff changeset
436 isRGBinInt(x) \
8d89e0052f84 Add 3 more RGB makros that allow specifying RGB in bytes and any rgb/bgr.
michael
parents: 30391
diff changeset
437 || isBGRinInt(x) \
8d89e0052f84 Add 3 more RGB makros that allow specifying RGB in bytes and any rgb/bgr.
michael
parents: 30391
diff changeset
438 )
28712
108abf7064d3 Add an isALPHA macro to check if pixel format has alpha channel
sdrik
parents: 28463
diff changeset
439 #define isALPHA(x) ( \
108abf7064d3 Add an isALPHA macro to check if pixel format has alpha channel
sdrik
parents: 28463
diff changeset
440 (x)==PIX_FMT_BGR32 \
108abf7064d3 Add an isALPHA macro to check if pixel format has alpha channel
sdrik
parents: 28463
diff changeset
441 || (x)==PIX_FMT_BGR32_1 \
108abf7064d3 Add an isALPHA macro to check if pixel format has alpha channel
sdrik
parents: 28463
diff changeset
442 || (x)==PIX_FMT_RGB32 \
108abf7064d3 Add an isALPHA macro to check if pixel format has alpha channel
sdrik
parents: 28463
diff changeset
443 || (x)==PIX_FMT_RGB32_1 \
32308
ecb8e52d4add Y400A (gray alpha) input support in libswscale
bcoudurier
parents: 31715
diff changeset
444 || (x)==PIX_FMT_Y400A \
28712
108abf7064d3 Add an isALPHA macro to check if pixel format has alpha channel
sdrik
parents: 28463
diff changeset
445 || (x)==PIX_FMT_YUVA420P \
108abf7064d3 Add an isALPHA macro to check if pixel format has alpha channel
sdrik
parents: 28463
diff changeset
446 )
32308
ecb8e52d4add Y400A (gray alpha) input support in libswscale
bcoudurier
parents: 31715
diff changeset
447 #define usePal(x) ((av_pix_fmt_descriptors[x].flags & PIX_FMT_PAL) || (x) == PIX_FMT_Y400A)
19872
8e50cba9fe03 Remove the dependency of libswscale on img_format.h
lucabe
parents: 19594
diff changeset
448
28463
4f01aa9c448f Drop DECLARE_ALIGNED from extern declarations. It creates trouble when
diego
parents: 28461
diff changeset
449 extern const uint64_t ff_dither4[2];
4f01aa9c448f Drop DECLARE_ALIGNED from extern declarations. It creates trouble when
diego
parents: 28461
diff changeset
450 extern const uint64_t ff_dither8[2];
26028
afd429e00184 Discard two symbols from libswscale.
cehoyos
parents: 25457
diff changeset
451
27212
18fc658de355 Split AVOption/AVClass in a separate file. SoC Patch from Keiji Costantini
lu_zero
parents: 27158
diff changeset
452 extern const AVClass sws_context_class;
18fc658de355 Split AVOption/AVClass in a separate file. SoC Patch from Keiji Costantini
lu_zero
parents: 27158
diff changeset
453
30369
8c479cb29c7a Split swscale.c into scaler code (swscale.c) and utility code (utils.c).
ramiro
parents: 30343
diff changeset
454 /**
8c479cb29c7a Split swscale.c into scaler code (swscale.c) and utility code (utils.c).
ramiro
parents: 30343
diff changeset
455 * Sets c->swScale to an unscaled converter if one exists for the specific
8c479cb29c7a Split swscale.c into scaler code (swscale.c) and utility code (utils.c).
ramiro
parents: 30343
diff changeset
456 * source and destination formats, bit depths, flags, etc.
8c479cb29c7a Split swscale.c into scaler code (swscale.c) and utility code (utils.c).
ramiro
parents: 30343
diff changeset
457 */
8c479cb29c7a Split swscale.c into scaler code (swscale.c) and utility code (utils.c).
ramiro
parents: 30343
diff changeset
458 void ff_get_unscaled_swscale(SwsContext *c);
8c479cb29c7a Split swscale.c into scaler code (swscale.c) and utility code (utils.c).
ramiro
parents: 30343
diff changeset
459
8c479cb29c7a Split swscale.c into scaler code (swscale.c) and utility code (utils.c).
ramiro
parents: 30343
diff changeset
460 /**
8c479cb29c7a Split swscale.c into scaler code (swscale.c) and utility code (utils.c).
ramiro
parents: 30343
diff changeset
461 * Returns the SWS_CPU_CAPS for the optimized code compiled into swscale.
8c479cb29c7a Split swscale.c into scaler code (swscale.c) and utility code (utils.c).
ramiro
parents: 30343
diff changeset
462 */
8c479cb29c7a Split swscale.c into scaler code (swscale.c) and utility code (utils.c).
ramiro
parents: 30343
diff changeset
463 int ff_hardcodedcpuflags(void);
8c479cb29c7a Split swscale.c into scaler code (swscale.c) and utility code (utils.c).
ramiro
parents: 30343
diff changeset
464
8c479cb29c7a Split swscale.c into scaler code (swscale.c) and utility code (utils.c).
ramiro
parents: 30343
diff changeset
465 /**
8c479cb29c7a Split swscale.c into scaler code (swscale.c) and utility code (utils.c).
ramiro
parents: 30343
diff changeset
466 * Returns function pointer to fastest main scaler path function depending
8c479cb29c7a Split swscale.c into scaler code (swscale.c) and utility code (utils.c).
ramiro
parents: 30343
diff changeset
467 * on architecture and available optimizations.
8c479cb29c7a Split swscale.c into scaler code (swscale.c) and utility code (utils.c).
ramiro
parents: 30343
diff changeset
468 */
8c479cb29c7a Split swscale.c into scaler code (swscale.c) and utility code (utils.c).
ramiro
parents: 30343
diff changeset
469 SwsFunc ff_getSwsFunc(SwsContext *c);
8c479cb29c7a Split swscale.c into scaler code (swscale.c) and utility code (utils.c).
ramiro
parents: 30343
diff changeset
470
27467
239a049163eb Change header inclusion guard names in line with FFmpeg r15120.
stefano
parents: 27212
diff changeset
471 #endif /* SWSCALE_SWSCALE_INTERNAL_H */