annotate imgconvert.c @ 17:b69fe46fd708 libavcodec

Adding fastmemcpy stuff to speedup mplayer project
author nickols_k
date Thu, 02 Aug 2001 08:29:38 +0000
parents 986e461dc072
children 1d2077091e88
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
1 /*
986e461dc072 Initial revision
glantau
parents:
diff changeset
2 * Misc image convertion routines
986e461dc072 Initial revision
glantau
parents:
diff changeset
3 * Copyright (c) 2001 Gerard Lantau.
986e461dc072 Initial revision
glantau
parents:
diff changeset
4 *
986e461dc072 Initial revision
glantau
parents:
diff changeset
5 * This program is free software; you can redistribute it and/or modify
986e461dc072 Initial revision
glantau
parents:
diff changeset
6 * it under the terms of the GNU General Public License as published by
986e461dc072 Initial revision
glantau
parents:
diff changeset
7 * the Free Software Foundation; either version 2 of the License, or
986e461dc072 Initial revision
glantau
parents:
diff changeset
8 * (at your option) any later version.
986e461dc072 Initial revision
glantau
parents:
diff changeset
9 *
986e461dc072 Initial revision
glantau
parents:
diff changeset
10 * This program is distributed in the hope that it will be useful,
986e461dc072 Initial revision
glantau
parents:
diff changeset
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
986e461dc072 Initial revision
glantau
parents:
diff changeset
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
986e461dc072 Initial revision
glantau
parents:
diff changeset
13 * GNU General Public License for more details.
986e461dc072 Initial revision
glantau
parents:
diff changeset
14 *
986e461dc072 Initial revision
glantau
parents:
diff changeset
15 * You should have received a copy of the GNU General Public License
986e461dc072 Initial revision
glantau
parents:
diff changeset
16 * along with this program; if not, write to the Free Software
986e461dc072 Initial revision
glantau
parents:
diff changeset
17 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
986e461dc072 Initial revision
glantau
parents:
diff changeset
18 */
986e461dc072 Initial revision
glantau
parents:
diff changeset
19 #include <stdlib.h>
986e461dc072 Initial revision
glantau
parents:
diff changeset
20 #include <stdio.h>
986e461dc072 Initial revision
glantau
parents:
diff changeset
21 #include <string.h>
986e461dc072 Initial revision
glantau
parents:
diff changeset
22 #include "avcodec.h"
986e461dc072 Initial revision
glantau
parents:
diff changeset
23
17
b69fe46fd708 Adding fastmemcpy stuff to speedup mplayer project
nickols_k
parents: 0
diff changeset
24 /* Stuff below is useful only for mplayer project */
b69fe46fd708 Adding fastmemcpy stuff to speedup mplayer project
nickols_k
parents: 0
diff changeset
25 #ifdef HAVE_CONFIG_H
b69fe46fd708 Adding fastmemcpy stuff to speedup mplayer project
nickols_k
parents: 0
diff changeset
26 #include "../config.h"
b69fe46fd708 Adding fastmemcpy stuff to speedup mplayer project
nickols_k
parents: 0
diff changeset
27 #endif
b69fe46fd708 Adding fastmemcpy stuff to speedup mplayer project
nickols_k
parents: 0
diff changeset
28
b69fe46fd708 Adding fastmemcpy stuff to speedup mplayer project
nickols_k
parents: 0
diff changeset
29 #ifdef USE_FASTMEMCPY
b69fe46fd708 Adding fastmemcpy stuff to speedup mplayer project
nickols_k
parents: 0
diff changeset
30 #include "fastmemcpy.h"
b69fe46fd708 Adding fastmemcpy stuff to speedup mplayer project
nickols_k
parents: 0
diff changeset
31 #endif
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
32 /* XXX: totally non optimized */
986e461dc072 Initial revision
glantau
parents:
diff changeset
33
986e461dc072 Initial revision
glantau
parents:
diff changeset
34 static void yuv422_to_yuv420p(UINT8 *lum, UINT8 *cb, UINT8 *cr,
986e461dc072 Initial revision
glantau
parents:
diff changeset
35 UINT8 *src, int width, int height)
986e461dc072 Initial revision
glantau
parents:
diff changeset
36 {
986e461dc072 Initial revision
glantau
parents:
diff changeset
37 int x, y;
986e461dc072 Initial revision
glantau
parents:
diff changeset
38 UINT8 *p = src;
986e461dc072 Initial revision
glantau
parents:
diff changeset
39
986e461dc072 Initial revision
glantau
parents:
diff changeset
40 for(y=0;y<height;y+=2) {
986e461dc072 Initial revision
glantau
parents:
diff changeset
41 for(x=0;x<width;x+=2) {
986e461dc072 Initial revision
glantau
parents:
diff changeset
42 lum[0] = p[0];
986e461dc072 Initial revision
glantau
parents:
diff changeset
43 cb[0] = p[1];
986e461dc072 Initial revision
glantau
parents:
diff changeset
44 lum[1] = p[2];
986e461dc072 Initial revision
glantau
parents:
diff changeset
45 cr[0] = p[3];
986e461dc072 Initial revision
glantau
parents:
diff changeset
46 p += 4;
986e461dc072 Initial revision
glantau
parents:
diff changeset
47 lum += 2;
986e461dc072 Initial revision
glantau
parents:
diff changeset
48 cb++;
986e461dc072 Initial revision
glantau
parents:
diff changeset
49 cr++;
986e461dc072 Initial revision
glantau
parents:
diff changeset
50 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
51 for(x=0;x<width;x+=2) {
986e461dc072 Initial revision
glantau
parents:
diff changeset
52 lum[0] = p[0];
986e461dc072 Initial revision
glantau
parents:
diff changeset
53 lum[1] = p[2];
986e461dc072 Initial revision
glantau
parents:
diff changeset
54 p += 4;
986e461dc072 Initial revision
glantau
parents:
diff changeset
55 lum += 2;
986e461dc072 Initial revision
glantau
parents:
diff changeset
56 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
57 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
58 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
59
986e461dc072 Initial revision
glantau
parents:
diff changeset
60 #define SCALEBITS 8
986e461dc072 Initial revision
glantau
parents:
diff changeset
61 #define ONE_HALF (1 << (SCALEBITS - 1))
986e461dc072 Initial revision
glantau
parents:
diff changeset
62 #define FIX(x) ((int) ((x) * (1L<<SCALEBITS) + 0.5))
986e461dc072 Initial revision
glantau
parents:
diff changeset
63
986e461dc072 Initial revision
glantau
parents:
diff changeset
64 static void rgb24_to_yuv420p(UINT8 *lum, UINT8 *cb, UINT8 *cr,
986e461dc072 Initial revision
glantau
parents:
diff changeset
65 UINT8 *src, int width, int height)
986e461dc072 Initial revision
glantau
parents:
diff changeset
66 {
986e461dc072 Initial revision
glantau
parents:
diff changeset
67 int wrap, wrap3, x, y;
986e461dc072 Initial revision
glantau
parents:
diff changeset
68 int r, g, b, r1, g1, b1;
986e461dc072 Initial revision
glantau
parents:
diff changeset
69 UINT8 *p;
986e461dc072 Initial revision
glantau
parents:
diff changeset
70
986e461dc072 Initial revision
glantau
parents:
diff changeset
71 wrap = width;
986e461dc072 Initial revision
glantau
parents:
diff changeset
72 wrap3 = width * 3;
986e461dc072 Initial revision
glantau
parents:
diff changeset
73 p = src;
986e461dc072 Initial revision
glantau
parents:
diff changeset
74 for(y=0;y<height;y+=2) {
986e461dc072 Initial revision
glantau
parents:
diff changeset
75 for(x=0;x<width;x+=2) {
986e461dc072 Initial revision
glantau
parents:
diff changeset
76 r = p[0];
986e461dc072 Initial revision
glantau
parents:
diff changeset
77 g = p[1];
986e461dc072 Initial revision
glantau
parents:
diff changeset
78 b = p[2];
986e461dc072 Initial revision
glantau
parents:
diff changeset
79 r1 = r;
986e461dc072 Initial revision
glantau
parents:
diff changeset
80 g1 = g;
986e461dc072 Initial revision
glantau
parents:
diff changeset
81 b1 = b;
986e461dc072 Initial revision
glantau
parents:
diff changeset
82 lum[0] = (FIX(0.29900) * r + FIX(0.58700) * g +
986e461dc072 Initial revision
glantau
parents:
diff changeset
83 FIX(0.11400) * b + ONE_HALF) >> SCALEBITS;
986e461dc072 Initial revision
glantau
parents:
diff changeset
84 r = p[3];
986e461dc072 Initial revision
glantau
parents:
diff changeset
85 g = p[4];
986e461dc072 Initial revision
glantau
parents:
diff changeset
86 b = p[5];
986e461dc072 Initial revision
glantau
parents:
diff changeset
87 r1 += r;
986e461dc072 Initial revision
glantau
parents:
diff changeset
88 g1 += g;
986e461dc072 Initial revision
glantau
parents:
diff changeset
89 b1 += b;
986e461dc072 Initial revision
glantau
parents:
diff changeset
90 lum[1] = (FIX(0.29900) * r + FIX(0.58700) * g +
986e461dc072 Initial revision
glantau
parents:
diff changeset
91 FIX(0.11400) * b + ONE_HALF) >> SCALEBITS;
986e461dc072 Initial revision
glantau
parents:
diff changeset
92 p += wrap3;
986e461dc072 Initial revision
glantau
parents:
diff changeset
93 lum += wrap;
986e461dc072 Initial revision
glantau
parents:
diff changeset
94
986e461dc072 Initial revision
glantau
parents:
diff changeset
95 r = p[0];
986e461dc072 Initial revision
glantau
parents:
diff changeset
96 g = p[1];
986e461dc072 Initial revision
glantau
parents:
diff changeset
97 b = p[2];
986e461dc072 Initial revision
glantau
parents:
diff changeset
98 r1 += r;
986e461dc072 Initial revision
glantau
parents:
diff changeset
99 g1 += g;
986e461dc072 Initial revision
glantau
parents:
diff changeset
100 b1 += b;
986e461dc072 Initial revision
glantau
parents:
diff changeset
101 lum[0] = (FIX(0.29900) * r + FIX(0.58700) * g +
986e461dc072 Initial revision
glantau
parents:
diff changeset
102 FIX(0.11400) * b + ONE_HALF) >> SCALEBITS;
986e461dc072 Initial revision
glantau
parents:
diff changeset
103 r = p[3];
986e461dc072 Initial revision
glantau
parents:
diff changeset
104 g = p[4];
986e461dc072 Initial revision
glantau
parents:
diff changeset
105 b = p[5];
986e461dc072 Initial revision
glantau
parents:
diff changeset
106 r1 += r;
986e461dc072 Initial revision
glantau
parents:
diff changeset
107 g1 += g;
986e461dc072 Initial revision
glantau
parents:
diff changeset
108 b1 += b;
986e461dc072 Initial revision
glantau
parents:
diff changeset
109 lum[1] = (FIX(0.29900) * r + FIX(0.58700) * g +
986e461dc072 Initial revision
glantau
parents:
diff changeset
110 FIX(0.11400) * b + ONE_HALF) >> SCALEBITS;
986e461dc072 Initial revision
glantau
parents:
diff changeset
111
986e461dc072 Initial revision
glantau
parents:
diff changeset
112 cb[0] = ((- FIX(0.16874) * r1 - FIX(0.33126) * g1 +
986e461dc072 Initial revision
glantau
parents:
diff changeset
113 FIX(0.50000) * b1 + 4 * ONE_HALF - 1) >> (SCALEBITS + 2)) + 128;
986e461dc072 Initial revision
glantau
parents:
diff changeset
114 cr[0] = ((FIX(0.50000) * r1 - FIX(0.41869) * g1 -
986e461dc072 Initial revision
glantau
parents:
diff changeset
115 FIX(0.08131) * b1 + 4 * ONE_HALF - 1) >> (SCALEBITS + 2)) + 128;
986e461dc072 Initial revision
glantau
parents:
diff changeset
116
986e461dc072 Initial revision
glantau
parents:
diff changeset
117 cb++;
986e461dc072 Initial revision
glantau
parents:
diff changeset
118 cr++;
986e461dc072 Initial revision
glantau
parents:
diff changeset
119 p += -wrap3 + 2 * 3;
986e461dc072 Initial revision
glantau
parents:
diff changeset
120 lum += -wrap + 2;
986e461dc072 Initial revision
glantau
parents:
diff changeset
121 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
122 p += wrap3;
986e461dc072 Initial revision
glantau
parents:
diff changeset
123 lum += wrap;
986e461dc072 Initial revision
glantau
parents:
diff changeset
124 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
125 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
126
986e461dc072 Initial revision
glantau
parents:
diff changeset
127 static void bgr24_to_yuv420p(UINT8 *lum, UINT8 *cb, UINT8 *cr,
986e461dc072 Initial revision
glantau
parents:
diff changeset
128 UINT8 *src, int width, int height)
986e461dc072 Initial revision
glantau
parents:
diff changeset
129 {
986e461dc072 Initial revision
glantau
parents:
diff changeset
130 int wrap, wrap3, x, y;
986e461dc072 Initial revision
glantau
parents:
diff changeset
131 int r, g, b, r1, g1, b1;
986e461dc072 Initial revision
glantau
parents:
diff changeset
132 UINT8 *p;
986e461dc072 Initial revision
glantau
parents:
diff changeset
133
986e461dc072 Initial revision
glantau
parents:
diff changeset
134 wrap = width;
986e461dc072 Initial revision
glantau
parents:
diff changeset
135 wrap3 = width * 3;
986e461dc072 Initial revision
glantau
parents:
diff changeset
136 p = src;
986e461dc072 Initial revision
glantau
parents:
diff changeset
137 for(y=0;y<height;y+=2) {
986e461dc072 Initial revision
glantau
parents:
diff changeset
138 for(x=0;x<width;x+=2) {
986e461dc072 Initial revision
glantau
parents:
diff changeset
139 b = p[0];
986e461dc072 Initial revision
glantau
parents:
diff changeset
140 g = p[1];
986e461dc072 Initial revision
glantau
parents:
diff changeset
141 r = p[2];
986e461dc072 Initial revision
glantau
parents:
diff changeset
142 r1 = r;
986e461dc072 Initial revision
glantau
parents:
diff changeset
143 g1 = g;
986e461dc072 Initial revision
glantau
parents:
diff changeset
144 b1 = b;
986e461dc072 Initial revision
glantau
parents:
diff changeset
145 lum[0] = (FIX(0.29900) * r + FIX(0.58700) * g +
986e461dc072 Initial revision
glantau
parents:
diff changeset
146 FIX(0.11400) * b + ONE_HALF) >> SCALEBITS;
986e461dc072 Initial revision
glantau
parents:
diff changeset
147 b = p[3];
986e461dc072 Initial revision
glantau
parents:
diff changeset
148 g = p[4];
986e461dc072 Initial revision
glantau
parents:
diff changeset
149 r = p[5];
986e461dc072 Initial revision
glantau
parents:
diff changeset
150 r1 += r;
986e461dc072 Initial revision
glantau
parents:
diff changeset
151 g1 += g;
986e461dc072 Initial revision
glantau
parents:
diff changeset
152 b1 += b;
986e461dc072 Initial revision
glantau
parents:
diff changeset
153 lum[1] = (FIX(0.29900) * r + FIX(0.58700) * g +
986e461dc072 Initial revision
glantau
parents:
diff changeset
154 FIX(0.11400) * b + ONE_HALF) >> SCALEBITS;
986e461dc072 Initial revision
glantau
parents:
diff changeset
155 p += wrap3;
986e461dc072 Initial revision
glantau
parents:
diff changeset
156 lum += wrap;
986e461dc072 Initial revision
glantau
parents:
diff changeset
157
986e461dc072 Initial revision
glantau
parents:
diff changeset
158 b = p[0];
986e461dc072 Initial revision
glantau
parents:
diff changeset
159 g = p[1];
986e461dc072 Initial revision
glantau
parents:
diff changeset
160 r = p[2];
986e461dc072 Initial revision
glantau
parents:
diff changeset
161 r1 += r;
986e461dc072 Initial revision
glantau
parents:
diff changeset
162 g1 += g;
986e461dc072 Initial revision
glantau
parents:
diff changeset
163 b1 += b;
986e461dc072 Initial revision
glantau
parents:
diff changeset
164 lum[0] = (FIX(0.29900) * r + FIX(0.58700) * g +
986e461dc072 Initial revision
glantau
parents:
diff changeset
165 FIX(0.11400) * b + ONE_HALF) >> SCALEBITS;
986e461dc072 Initial revision
glantau
parents:
diff changeset
166 b = p[3];
986e461dc072 Initial revision
glantau
parents:
diff changeset
167 g = p[4];
986e461dc072 Initial revision
glantau
parents:
diff changeset
168 r = p[5];
986e461dc072 Initial revision
glantau
parents:
diff changeset
169 r1 += r;
986e461dc072 Initial revision
glantau
parents:
diff changeset
170 g1 += g;
986e461dc072 Initial revision
glantau
parents:
diff changeset
171 b1 += b;
986e461dc072 Initial revision
glantau
parents:
diff changeset
172 lum[1] = (FIX(0.29900) * r + FIX(0.58700) * g +
986e461dc072 Initial revision
glantau
parents:
diff changeset
173 FIX(0.11400) * b + ONE_HALF) >> SCALEBITS;
986e461dc072 Initial revision
glantau
parents:
diff changeset
174
986e461dc072 Initial revision
glantau
parents:
diff changeset
175 cb[0] = ((- FIX(0.16874) * r1 - FIX(0.33126) * g1 +
986e461dc072 Initial revision
glantau
parents:
diff changeset
176 FIX(0.50000) * b1 + 4 * ONE_HALF - 1) >> (SCALEBITS + 2)) + 128;
986e461dc072 Initial revision
glantau
parents:
diff changeset
177 cr[0] = ((FIX(0.50000) * r1 - FIX(0.41869) * g1 -
986e461dc072 Initial revision
glantau
parents:
diff changeset
178 FIX(0.08131) * b1 + 4 * ONE_HALF - 1) >> (SCALEBITS + 2)) + 128;
986e461dc072 Initial revision
glantau
parents:
diff changeset
179
986e461dc072 Initial revision
glantau
parents:
diff changeset
180 cb++;
986e461dc072 Initial revision
glantau
parents:
diff changeset
181 cr++;
986e461dc072 Initial revision
glantau
parents:
diff changeset
182 p += -wrap3 + 2 * 3;
986e461dc072 Initial revision
glantau
parents:
diff changeset
183 lum += -wrap + 2;
986e461dc072 Initial revision
glantau
parents:
diff changeset
184 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
185 p += wrap3;
986e461dc072 Initial revision
glantau
parents:
diff changeset
186 lum += wrap;
986e461dc072 Initial revision
glantau
parents:
diff changeset
187 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
188 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
189
986e461dc072 Initial revision
glantau
parents:
diff changeset
190 int img_convert_to_yuv420(UINT8 *img_out, UINT8 *img,
986e461dc072 Initial revision
glantau
parents:
diff changeset
191 int pix_fmt, int width, int height)
986e461dc072 Initial revision
glantau
parents:
diff changeset
192 {
986e461dc072 Initial revision
glantau
parents:
diff changeset
193 UINT8 *pict;
986e461dc072 Initial revision
glantau
parents:
diff changeset
194 int size, size_out;
986e461dc072 Initial revision
glantau
parents:
diff changeset
195 UINT8 *picture[3];
986e461dc072 Initial revision
glantau
parents:
diff changeset
196
986e461dc072 Initial revision
glantau
parents:
diff changeset
197 pict = img_out;
986e461dc072 Initial revision
glantau
parents:
diff changeset
198 size = width * height;
986e461dc072 Initial revision
glantau
parents:
diff changeset
199 size_out = (size * 3) / 2;
986e461dc072 Initial revision
glantau
parents:
diff changeset
200 picture[0] = pict;
986e461dc072 Initial revision
glantau
parents:
diff changeset
201 picture[1] = pict + size;
986e461dc072 Initial revision
glantau
parents:
diff changeset
202 picture[2] = picture[1] + (size / 4);
986e461dc072 Initial revision
glantau
parents:
diff changeset
203
986e461dc072 Initial revision
glantau
parents:
diff changeset
204 switch(pix_fmt) {
986e461dc072 Initial revision
glantau
parents:
diff changeset
205 case PIX_FMT_YUV420P:
986e461dc072 Initial revision
glantau
parents:
diff changeset
206 memcpy(pict, img, size_out);
986e461dc072 Initial revision
glantau
parents:
diff changeset
207 break;
986e461dc072 Initial revision
glantau
parents:
diff changeset
208 case PIX_FMT_YUV422:
986e461dc072 Initial revision
glantau
parents:
diff changeset
209 yuv422_to_yuv420p(picture[0], picture[1], picture[2],
986e461dc072 Initial revision
glantau
parents:
diff changeset
210 img, width, height);
986e461dc072 Initial revision
glantau
parents:
diff changeset
211 break;
986e461dc072 Initial revision
glantau
parents:
diff changeset
212 case PIX_FMT_RGB24:
986e461dc072 Initial revision
glantau
parents:
diff changeset
213 rgb24_to_yuv420p(picture[0], picture[1], picture[2],
986e461dc072 Initial revision
glantau
parents:
diff changeset
214 img, width, height);
986e461dc072 Initial revision
glantau
parents:
diff changeset
215 break;
986e461dc072 Initial revision
glantau
parents:
diff changeset
216 case PIX_FMT_BGR24:
986e461dc072 Initial revision
glantau
parents:
diff changeset
217 bgr24_to_yuv420p(picture[0], picture[1], picture[2],
986e461dc072 Initial revision
glantau
parents:
diff changeset
218 img, width, height);
986e461dc072 Initial revision
glantau
parents:
diff changeset
219 break;
986e461dc072 Initial revision
glantau
parents:
diff changeset
220 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
221 return size_out;
986e461dc072 Initial revision
glantau
parents:
diff changeset
222 }