Mercurial > mplayer.hg
annotate libswscale/swscale_internal.h @ 21818:7bd48682de5f
woops, actually fix URL this time
author | gpoirier |
---|---|
date | Sat, 06 Jan 2007 13:31:16 +0000 |
parents | 5ee0b3c9e667 |
children | a14ddab18acd |
rev | line source |
---|---|
18861 | 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 |
20094
aca9e9783f67
Change license headers to say 'FFmpeg' instead of 'this program'.
diego
parents:
19872
diff
changeset
|
18 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA |
aca9e9783f67
Change license headers to say 'FFmpeg' instead of 'this program'.
diego
parents:
19872
diff
changeset
|
19 */ |
18861 | 20 |
21 #ifndef SWSCALE_INTERNAL_H | |
22 #define SWSCALE_INTERNAL_H | |
23 | |
24 #ifdef HAVE_ALTIVEC_H | |
25 #include <altivec.h> | |
26 #endif | |
27 | |
19143
c4dac777b44c
Use libavutil in libswscale, and allow it to be built out of the mplayer tree
lucabe
parents:
18861
diff
changeset
|
28 #include "avutil.h" |
c4dac777b44c
Use libavutil in libswscale, and allow it to be built out of the mplayer tree
lucabe
parents:
18861
diff
changeset
|
29 |
18861 | 30 #ifdef CONFIG_DARWIN |
31 #define AVV(x...) (x) | |
32 #else | |
33 #define AVV(x...) {x} | |
34 #endif | |
35 | |
19143
c4dac777b44c
Use libavutil in libswscale, and allow it to be built out of the mplayer tree
lucabe
parents:
18861
diff
changeset
|
36 #define MSG_WARN(args...) av_log(NULL, AV_LOG_DEBUG, ##args ) |
c4dac777b44c
Use libavutil in libswscale, and allow it to be built out of the mplayer tree
lucabe
parents:
18861
diff
changeset
|
37 #define MSG_FATAL(args...) av_log(NULL, AV_LOG_ERROR, ##args ) |
c4dac777b44c
Use libavutil in libswscale, and allow it to be built out of the mplayer tree
lucabe
parents:
18861
diff
changeset
|
38 #define MSG_ERR(args...) av_log(NULL, AV_LOG_ERROR, ##args ) |
c4dac777b44c
Use libavutil in libswscale, and allow it to be built out of the mplayer tree
lucabe
parents:
18861
diff
changeset
|
39 #define MSG_V(args...) av_log(NULL, AV_LOG_INFO, ##args ) |
c4dac777b44c
Use libavutil in libswscale, and allow it to be built out of the mplayer tree
lucabe
parents:
18861
diff
changeset
|
40 #define MSG_DBG2(args...) av_log(NULL, AV_LOG_DEBUG, ##args ) |
c4dac777b44c
Use libavutil in libswscale, and allow it to be built out of the mplayer tree
lucabe
parents:
18861
diff
changeset
|
41 #define MSG_INFO(args...) av_log(NULL, AV_LOG_INFO, ##args ) |
18861 | 42 |
43 #define MAX_FILTER_SIZE 256 | |
44 | |
45 typedef int (*SwsFunc)(struct SwsContext *context, uint8_t* src[], int srcStride[], int srcSliceY, | |
46 int srcSliceH, uint8_t* dst[], int dstStride[]); | |
47 | |
48 /* this struct should be aligned on at least 32-byte boundary */ | |
49 typedef struct SwsContext{ | |
50 /** | |
51 * | |
52 * Note the src,dst,srcStride,dstStride will be copied, in the sws_scale() warper so they can freely be modified here | |
53 */ | |
54 SwsFunc swScale; | |
55 int srcW, srcH, dstH; | |
56 int chrSrcW, chrSrcH, chrDstW, chrDstH; | |
57 int lumXInc, chrXInc; | |
58 int lumYInc, chrYInc; | |
59 int dstFormat, srcFormat; ///< format 4:2:0 type is allways YV12 | |
60 int origDstFormat, origSrcFormat; ///< format | |
61 int chrSrcHSubSample, chrSrcVSubSample; | |
62 int chrIntHSubSample, chrIntVSubSample; | |
63 int chrDstHSubSample, chrDstVSubSample; | |
64 int vChrDrop; | |
65 int sliceDir; | |
66 double param[2]; | |
67 | |
68 int16_t **lumPixBuf; | |
69 int16_t **chrPixBuf; | |
70 int16_t *hLumFilter; | |
71 int16_t *hLumFilterPos; | |
72 int16_t *hChrFilter; | |
73 int16_t *hChrFilterPos; | |
74 int16_t *vLumFilter; | |
75 int16_t *vLumFilterPos; | |
76 int16_t *vChrFilter; | |
77 int16_t *vChrFilterPos; | |
78 | |
79 uint8_t formatConvBuffer[4000]; //FIXME dynamic alloc, but we have to change alot of code for this to be usefull | |
80 | |
81 int hLumFilterSize; | |
82 int hChrFilterSize; | |
83 int vLumFilterSize; | |
84 int vChrFilterSize; | |
85 int vLumBufSize; | |
86 int vChrBufSize; | |
87 | |
88 uint8_t *funnyYCode; | |
89 uint8_t *funnyUVCode; | |
90 int32_t *lumMmx2FilterPos; | |
91 int32_t *chrMmx2FilterPos; | |
92 int16_t *lumMmx2Filter; | |
93 int16_t *chrMmx2Filter; | |
94 | |
95 int canMMX2BeUsed; | |
96 | |
97 int lastInLumBuf; | |
98 int lastInChrBuf; | |
99 int lumBufIndex; | |
100 int chrBufIndex; | |
101 int dstY; | |
102 int flags; | |
103 void * yuvTable; // pointer to the yuv->rgb table start so it can be freed() | |
21755 | 104 uint8_t * table_rV[256]; |
105 uint8_t * table_gU[256]; | |
18861 | 106 int table_gV[256]; |
21755 | 107 uint8_t * table_bU[256]; |
18861 | 108 |
109 //Colorspace stuff | |
110 int contrast, brightness, saturation; // for sws_getColorspaceDetails | |
111 int srcColorspaceTable[4]; | |
112 int dstColorspaceTable[4]; | |
113 int srcRange, dstRange; | |
114 | |
115 #define RED_DITHER "0*8" | |
116 #define GREEN_DITHER "1*8" | |
117 #define BLUE_DITHER "2*8" | |
118 #define Y_COEFF "3*8" | |
119 #define VR_COEFF "4*8" | |
120 #define UB_COEFF "5*8" | |
121 #define VG_COEFF "6*8" | |
122 #define UG_COEFF "7*8" | |
123 #define Y_OFFSET "8*8" | |
124 #define U_OFFSET "9*8" | |
125 #define V_OFFSET "10*8" | |
126 #define LUM_MMX_FILTER_OFFSET "11*8" | |
127 #define CHR_MMX_FILTER_OFFSET "11*8+4*4*256" | |
128 #define DSTW_OFFSET "11*8+4*4*256*2" //do not change, its hardcoded in the asm | |
129 #define ESP_OFFSET "11*8+4*4*256*2+8" | |
130 #define VROUNDER_OFFSET "11*8+4*4*256*2+16" | |
19172
bae6c99a99cc
vertical scaler with accurate rounding, some people on doom9 can see +-1 errors
michael
parents:
19143
diff
changeset
|
131 #define U_TEMP "11*8+4*4*256*2+24" |
bae6c99a99cc
vertical scaler with accurate rounding, some people on doom9 can see +-1 errors
michael
parents:
19143
diff
changeset
|
132 #define V_TEMP "11*8+4*4*256*2+32" |
bae6c99a99cc
vertical scaler with accurate rounding, some people on doom9 can see +-1 errors
michael
parents:
19143
diff
changeset
|
133 |
18861 | 134 uint64_t redDither __attribute__((aligned(8))); |
135 uint64_t greenDither __attribute__((aligned(8))); | |
136 uint64_t blueDither __attribute__((aligned(8))); | |
137 | |
138 uint64_t yCoeff __attribute__((aligned(8))); | |
139 uint64_t vrCoeff __attribute__((aligned(8))); | |
140 uint64_t ubCoeff __attribute__((aligned(8))); | |
141 uint64_t vgCoeff __attribute__((aligned(8))); | |
142 uint64_t ugCoeff __attribute__((aligned(8))); | |
143 uint64_t yOffset __attribute__((aligned(8))); | |
144 uint64_t uOffset __attribute__((aligned(8))); | |
145 uint64_t vOffset __attribute__((aligned(8))); | |
146 int32_t lumMmxFilter[4*MAX_FILTER_SIZE]; | |
147 int32_t chrMmxFilter[4*MAX_FILTER_SIZE]; | |
148 int dstW; | |
149 uint64_t esp __attribute__((aligned(8))); | |
150 uint64_t vRounder __attribute__((aligned(8))); | |
19172
bae6c99a99cc
vertical scaler with accurate rounding, some people on doom9 can see +-1 errors
michael
parents:
19143
diff
changeset
|
151 uint64_t u_temp __attribute__((aligned(8))); |
bae6c99a99cc
vertical scaler with accurate rounding, some people on doom9 can see +-1 errors
michael
parents:
19143
diff
changeset
|
152 uint64_t v_temp __attribute__((aligned(8))); |
18861 | 153 |
154 #ifdef HAVE_ALTIVEC | |
155 | |
156 vector signed short CY; | |
157 vector signed short CRV; | |
158 vector signed short CBU; | |
159 vector signed short CGU; | |
160 vector signed short CGV; | |
161 vector signed short OY; | |
162 vector unsigned short CSHIFT; | |
163 vector signed short *vYCoeffsBank, *vCCoeffsBank; | |
164 | |
165 #endif | |
166 | |
167 } SwsContext; | |
168 //FIXME check init (where 0) | |
169 | |
170 SwsFunc yuv2rgb_get_func_ptr (SwsContext *c); | |
171 int yuv2rgb_c_init_tables (SwsContext *c, const int inv_table[4], int fullRange, int brightness, int contrast, int saturation); | |
172 | |
19143
c4dac777b44c
Use libavutil in libswscale, and allow it to be built out of the mplayer tree
lucabe
parents:
18861
diff
changeset
|
173 char *sws_format_name(int format); |
c4dac777b44c
Use libavutil in libswscale, and allow it to be built out of the mplayer tree
lucabe
parents:
18861
diff
changeset
|
174 |
19872
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
175 //FIXME replace this with something faster |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
176 #define isPlanarYUV(x) ((x)==PIX_FMT_YUV410P || (x)==PIX_FMT_YUV420P \ |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
177 || (x)==PIX_FMT_YUV411P || (x)==PIX_FMT_YUV422P \ |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
178 || (x)==PIX_FMT_YUV444P || (x)==PIX_FMT_NV12 \ |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
179 || (x)==PIX_FMT_NV21) |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
180 #define isYUV(x) ((x)==PIX_FMT_UYVY422 || (x)==PIX_FMT_YUYV422 || isPlanarYUV(x)) |
20411 | 181 #define isGray(x) ((x)==PIX_FMT_GRAY8 || (x)==PIX_FMT_GRAY16BE || (x)==PIX_FMT_GRAY16LE) |
182 #define isGray16(x) ((x)==PIX_FMT_GRAY16BE || (x)==PIX_FMT_GRAY16LE) | |
19872
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
183 #define isRGB(x) ((x)==PIX_FMT_BGR32 || (x)==PIX_FMT_RGB24 \ |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
184 || (x)==PIX_FMT_RGB565 || (x)==PIX_FMT_RGB555 \ |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
185 || (x)==PIX_FMT_RGB8 || (x)==PIX_FMT_RGB4 \ |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
186 || (x)==PIX_FMT_MONOBLACK) |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
187 #define isBGR(x) ((x)==PIX_FMT_RGB32 || (x)==PIX_FMT_BGR24 \ |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
188 || (x)==PIX_FMT_BGR565 || (x)==PIX_FMT_BGR555 \ |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
189 || (x)==PIX_FMT_BGR8 || (x)==PIX_FMT_BGR4 \ |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
190 || (x)==PIX_FMT_MONOBLACK) |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
191 |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
192 static inline int fmt_depth(int fmt) |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
193 { |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
194 switch(fmt) { |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
195 case PIX_FMT_BGRA: |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
196 case PIX_FMT_ABGR: |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
197 case PIX_FMT_RGBA: |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
198 case PIX_FMT_ARGB: |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
199 return 32; |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
200 case PIX_FMT_BGR24: |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
201 case PIX_FMT_RGB24: |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
202 return 24; |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
203 case PIX_FMT_BGR565: |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
204 case PIX_FMT_RGB565: |
20411 | 205 case PIX_FMT_GRAY16BE: |
206 case PIX_FMT_GRAY16LE: | |
19872
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
207 return 16; |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
208 case PIX_FMT_BGR555: |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
209 case PIX_FMT_RGB555: |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
210 return 15; |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
211 case PIX_FMT_BGR8: |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
212 case PIX_FMT_RGB8: |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
213 return 8; |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
214 case PIX_FMT_BGR4: |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
215 case PIX_FMT_RGB4: |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
216 case PIX_FMT_BGR4_BYTE: |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
217 case PIX_FMT_RGB4_BYTE: |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
218 return 4; |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
219 case PIX_FMT_MONOBLACK: |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
220 return 1; |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
221 default: |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
222 return 0; |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
223 } |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
224 } |
8e50cba9fe03
Remove the dependency of libswscale on img_format.h
lucabe
parents:
19594
diff
changeset
|
225 |
18861 | 226 #endif |