diff options
Diffstat (limited to 'firmware/target/arm')
-rw-r--r-- | firmware/target/arm/lcd-as-memframe.S | 554 | ||||
-rw-r--r-- | firmware/target/arm/s3c2440/gigabeat-fx/lcd-as-meg-fx.S | 279 | ||||
-rw-r--r-- | firmware/target/arm/s3c2440/gigabeat-fx/lcd-meg-fx.c | 45 | ||||
-rw-r--r-- | firmware/target/arm/sandisk/sansa-e200/lcd-as-e200.S | 279 | ||||
-rw-r--r-- | firmware/target/arm/sandisk/sansa-e200/lcd-e200.c | 45 |
5 files changed, 628 insertions, 574 deletions
diff --git a/firmware/target/arm/lcd-as-memframe.S b/firmware/target/arm/lcd-as-memframe.S new file mode 100644 index 0000000000..7071bec7ac --- /dev/null +++ b/firmware/target/arm/lcd-as-memframe.S | |||
@@ -0,0 +1,554 @@ | |||
1 | /*************************************************************************** | ||
2 | * __________ __ ___. | ||
3 | * Open \______ \ ____ ____ | | _\_ |__ _______ ___ | ||
4 | * Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ / | ||
5 | * Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < < | ||
6 | * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \ | ||
7 | * \/ \/ \/ \/ \/ | ||
8 | * $Id$ | ||
9 | * | ||
10 | * Copyright (C) 2007 by Michael Sevakis | ||
11 | * | ||
12 | * ARM code for memory framebuffer LCDs | ||
13 | * | ||
14 | * All files in this archive are subject to the GNU General Public License. | ||
15 | * See the file COPYING in the source tree root for full license agreement. | ||
16 | * | ||
17 | * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY | ||
18 | * KIND, either express or implied. | ||
19 | * | ||
20 | ****************************************************************************/ | ||
21 | |||
22 | #include "config.h" | ||
23 | #include "cpu.h" | ||
24 | |||
25 | /**************************************************************************** | ||
26 | * void lcd_copy_buffer_rect(fb_data *dst, fb_data *src, int width, | ||
27 | * int height); | ||
28 | */ | ||
29 | .section .icode, "ax", %progbits | ||
30 | .align 2 | ||
31 | .global lcd_copy_buffer_rect | ||
32 | .type lcd_copy_buffer_rect, %function | ||
33 | @ r0 = dst | ||
34 | @ r1 = src | ||
35 | @ r2 = width | ||
36 | @ r3 = height | ||
37 | lcd_copy_buffer_rect: @ | ||
38 | stmfd sp!, { r4-r12, lr } @ save non-scratch regs | ||
39 | mov r5, r2 @ r5 = cached width | ||
40 | rsb r4, r2, #LCD_WIDTH @ r4 = LCD_WIDTH - width | ||
41 | 10: @ copy line @ | ||
42 | subs r2, r5, #1 @ r2 = width - 1 | ||
43 | beq 40f @ finish line @ one halfword? skip to trailing copy | ||
44 | tst r0, #2 @ word aligned? | ||
45 | beq 20f @ rem copy @ yes? skip to word copy | ||
46 | ldrh r6, [r1], #2 @ copy leading halfword | ||
47 | subs r2, r2, #1 @ | ||
48 | strh r6, [r0], #2 @ | ||
49 | ble 40f @ finish line @ next line if lt or finish | ||
50 | @ trailing halfword if eq | ||
51 | 20: @ rem copy @ | ||
52 | add r14, r2, #1 @ get remaining width mod 16 after word | ||
53 | @ align (rw) | ||
54 | and r14, r14, #0xe @ r14 = 0 (16), 2, 4, 6, 8, 10, 12, 14 | ||
55 | add pc, pc, r14, lsl #3 @ branch to 32-byte align | ||
56 | nop @ | ||
57 | b 30f @ rw % 16 = 0 or 1? use octword loop | ||
58 | nop @ | ||
59 | nop @ | ||
60 | nop @ | ||
61 | ldr r6, [r1], #4 @ rw % 16 = 2 or 3 | ||
62 | subs r2, r2, #2 @ | ||
63 | str r6, [r0], #4 @ | ||
64 | b 25f @ copy up done @ | ||
65 | ldmia r1!, { r6-r7 } @ rw % 16 = 4 or 5 | ||
66 | subs r2, r2, #4 @ | ||
67 | stmia r0!, { r6-r7 } @ | ||
68 | b 25f @ copy up done @ | ||
69 | ldmia r1!, { r6-r8 } @ rw % 16 = 6 or 7 | ||
70 | subs r2, r2, #6 @ | ||
71 | stmia r0!, { r6-r8 } @ | ||
72 | b 25f @ copy up done @ | ||
73 | ldmia r1!, { r6-r9 } @ rw % 16 = 8 or 9 | ||
74 | subs r2, r2, #8 @ | ||
75 | stmia r0!, { r6-r9 } @ | ||
76 | b 25f @ copy up done @ | ||
77 | ldmia r1!, { r6-r10 } @ rw % 16 = 10 or 11 | ||
78 | subs r2, r2, #10 @ | ||
79 | stmia r0!, { r6-r10 } @ | ||
80 | b 25f @ copy up done @ | ||
81 | ldmia r1!, { r6-r11 } @ rw % 16 = 12 or 13 | ||
82 | subs r2, r2, #12 @ | ||
83 | stmia r0!, { r6-r11 } @ | ||
84 | b 25f @ copy up done @ | ||
85 | ldmia r1!, { r6-r12 } @ rw % 16 = 14 or 15 | ||
86 | subs r2, r2, #14 @ | ||
87 | stmia r0!, { r6-r12 } @ | ||
88 | 25: @ copy up done @ | ||
89 | ble 40f @ finish line @ no 32-byte segments remaining? | ||
90 | 30: @ octword loop @ copy 16 pixels per loop | ||
91 | ldmia r1!, { r6-r12, r14 } @ | ||
92 | subs r2, r2, #16 @ | ||
93 | stmia r0!, { r6-r12, r14 } @ | ||
94 | bgt 30b @ octword loop @ | ||
95 | 40: @ finish line @ | ||
96 | ldreqh r6, [r1], #2 @ finish last halfword if eq ... | ||
97 | add r1, r1, r4, lsl #1 @ | ||
98 | streqh r6, [r0], #2 @ ... | ||
99 | add r0, r0, r4, lsl #1 @ | ||
100 | subs r3, r3, #1 @ next line | ||
101 | bgt 10b @ copy line @ | ||
102 | ldmfd sp!, { r4-r12, pc } @ restore regs and return | ||
103 | .ltorg @ dump constant pool | ||
104 | .size lcd_copy_buffer_rect, .-lcd_copy_buffer_rect | ||
105 | |||
106 | |||
107 | /**************************************************************************** | ||
108 | * void lcd_write_yuv_420_lines(fb_data *dst, | ||
109 | * unsigned char const * const src[3], | ||
110 | * int width, | ||
111 | * int stride); | ||
112 | * | ||
113 | * |R| |1.000000 -0.000001 1.402000| |Y'| | ||
114 | * |G| = |1.000000 -0.334136 -0.714136| |Pb| | ||
115 | * |B| |1.000000 1.772000 0.000000| |Pr| | ||
116 | * Scaled, normalized, rounded and tweaked to yield RGB 565: | ||
117 | * |R| |74 0 101| |Y' - 16| >> 9 | ||
118 | * |G| = |74 -24 -51| |Cb - 128| >> 8 | ||
119 | * |B| |74 128 0| |Cr - 128| >> 9 | ||
120 | * | ||
121 | * Write four RGB565 pixels in the following order on each loop: | ||
122 | * 1 3 + > down | ||
123 | * 2 4 \/ left | ||
124 | */ | ||
125 | .section .icode, "ax", %progbits | ||
126 | .align 2 | ||
127 | .global lcd_write_yuv420_lines | ||
128 | .type lcd_write_yuv420_lines, %function | ||
129 | lcd_write_yuv420_lines: | ||
130 | @ r0 = dst | ||
131 | @ r1 = yuv_src | ||
132 | @ r2 = width | ||
133 | @ r3 = stride | ||
134 | stmfd sp!, { r4-r12 } @ save non-scratch | ||
135 | ldmia r1, { r4, r5, r6 } @ r4 = yuv_src[0] = Y'_p | ||
136 | @ r5 = yuv_src[1] = Cb_p | ||
137 | @ r6 = yuv_src[2] = Cr_p | ||
138 | @ r1 = scratch | ||
139 | sub r3, r3, #1 @ | ||
140 | 10: @ loop line @ | ||
141 | ldrb r7, [r4], #1 @ r7 = *Y'_p++; | ||
142 | ldrb r8, [r5], #1 @ r8 = *Cb_p++; | ||
143 | ldrb r9, [r6], #1 @ r9 = *Cr_p++; | ||
144 | @ | ||
145 | sub r7, r7, #16 @ r7 = Y = (Y' - 16)*74 | ||
146 | add r12, r7, r7, asl #2 @ actually (Y' - 16)*37 and shift right | ||
147 | add r7, r12, r7, asl #5 @ by one less when adding - same for all | ||
148 | @ | ||
149 | sub r8, r8, #128 @ Cb -= 128 | ||
150 | sub r9, r9, #128 @ Cr -= 128 | ||
151 | @ | ||
152 | add r10, r9, r9, asl #1 @ r10 = Cr*51 + Cb*24 | ||
153 | add r10, r10, r10, asl #4 @ | ||
154 | add r10, r10, r8, asl #3 @ | ||
155 | add r10, r10, r8, asl #4 @ | ||
156 | @ | ||
157 | add r11, r9, r9, asl #2 @ r9 = Cr*101 | ||
158 | add r11, r11, r9, asl #5 @ | ||
159 | add r9, r11, r9, asl #6 @ | ||
160 | @ | ||
161 | add r8, r8, #2 @ r8 = bu = (Cb*128 + 128) >> 8 | ||
162 | mov r8, r8, asr #2 @ | ||
163 | add r9, r9, #256 @ r9 = rv = (r9 + 256) >> 9 | ||
164 | mov r9, r9, asr #9 @ | ||
165 | rsb r10, r10, #128 @ r10 = guv = (-r10 + 128) >> 8 | ||
166 | mov r10, r10, asr #8 @ | ||
167 | @ compute R, G, and B | ||
168 | add r1, r8, r7, asr #8 @ r1 = b = (Y >> 9) + bu | ||
169 | add r11, r9, r7, asr #8 @ r11 = r = (Y >> 9) + rv | ||
170 | add r7, r10, r7, asr #7 @ r7 = g = (Y >> 8) + guv | ||
171 | @ | ||
172 | orr r12, r1, r11 @ check if clamping is needed... | ||
173 | orr r12, r12, r7, asr #1 @ ...at all | ||
174 | cmp r12, #31 @ | ||
175 | bls 15f @ no clamp @ | ||
176 | cmp r1, #31 @ clamp b | ||
177 | mvnhi r1, r1, asr #31 @ | ||
178 | andhi r1, r1, #31 @ | ||
179 | cmp r11, #31 @ clamp r | ||
180 | mvnhi r11, r11, asr #31 @ | ||
181 | andhi r11, r11, #31 @ | ||
182 | cmp r7, #63 @ clamp g | ||
183 | mvnhi r7, r7, asr #31 @ | ||
184 | andhi r7, r7, #63 @ | ||
185 | 15: @ no clamp @ | ||
186 | @ | ||
187 | ldrb r12, [r4, r3] @ r12 = Y' = *(Y'_p + stride) | ||
188 | @ | ||
189 | orr r1, r1, r7, lsl #5 @ r4 |= (g << 5) | ||
190 | orr r1, r1, r11, lsl #11 @ r4 = b | (r << 11) | ||
191 | strh r1, [r0], #LCD_WIDTH @ store pixel | ||
192 | @ | ||
193 | sub r7, r12, #16 @ r7 = Y = (Y' - 16)*74 | ||
194 | add r12, r7, r7, asl #2 @ | ||
195 | add r7, r12, r7, asl #5 @ | ||
196 | @ compute R, G, and B | ||
197 | add r1, r8, r7, asr #8 @ r1 = b = (Y >> 9) + bu | ||
198 | add r11, r9, r7, asr #8 @ r11 = r = (Y >> 9) + rv | ||
199 | add r7, r10, r7, asr #7 @ r7 = g = (Y >> 8) + guv | ||
200 | @ | ||
201 | orr r12, r1, r11 @ check if clamping is needed... | ||
202 | orr r12, r12, r7, asr #1 @ ...at all | ||
203 | cmp r12, #31 @ | ||
204 | bls 15f @ no clamp @ | ||
205 | cmp r1, #31 @ clamp b | ||
206 | mvnhi r1, r1, asr #31 @ | ||
207 | andhi r1, r1, #31 @ | ||
208 | cmp r11, #31 @ clamp r | ||
209 | mvnhi r11, r11, asr #31 @ | ||
210 | andhi r11, r11, #31 @ | ||
211 | cmp r7, #63 @ clamp g | ||
212 | mvnhi r7, r7, asr #31 @ | ||
213 | andhi r7, r7, #63 @ | ||
214 | 15: @ no clamp @ | ||
215 | @ | ||
216 | ldrb r12, [r4], #1 @ r12 = Y' = *(Y'_p++) | ||
217 | @ | ||
218 | orr r1, r1, r11, lsl #11 @ r1 = b | (r << 11) | ||
219 | orr r1, r1, r7, lsl #5 @ r1 |= (g << 5) | ||
220 | strh r1, [r0, #-LCD_WIDTH-2] @ store pixel | ||
221 | @ | ||
222 | sub r7, r12, #16 @ r7 = Y = (Y' - 16)*74 | ||
223 | add r12, r7, r7, asl #2 @ | ||
224 | add r7, r12, r7, asl #5 @ | ||
225 | @ compute R, G, and B | ||
226 | add r1, r8, r7, asr #8 @ r1 = b = (Y >> 9) + bu | ||
227 | add r11, r9, r7, asr #8 @ r11 = r = (Y >> 9) + rv | ||
228 | add r7, r10, r7, asr #7 @ r7 = g = (Y >> 8) + guv | ||
229 | @ | ||
230 | orr r12, r1, r11 @ check if clamping is needed... | ||
231 | orr r12, r12, r7, asr #1 @ ...at all | ||
232 | cmp r12, #31 @ | ||
233 | bls 15f @ no clamp @ | ||
234 | cmp r1, #31 @ clamp b | ||
235 | mvnhi r1, r1, asr #31 @ | ||
236 | andhi r1, r1, #31 @ | ||
237 | cmp r11, #31 @ clamp r | ||
238 | mvnhi r11, r11, asr #31 @ | ||
239 | andhi r11, r11, #31 @ | ||
240 | cmp r7, #63 @ clamp g | ||
241 | mvnhi r7, r7, asr #31 @ | ||
242 | andhi r7, r7, #63 @ | ||
243 | 15: @ no clamp @ | ||
244 | @ | ||
245 | ldrb r12, [r4, r3] @ r12 = Y' = *(Y'_p + stride) | ||
246 | @ | ||
247 | orr r1, r1, r7, lsl #5 @ r1 = b | (g << 5) | ||
248 | orr r1, r1, r11, lsl #11 @ r1 |= (r << 11) | ||
249 | strh r1, [r0, #LCD_WIDTH]! @ store pixel | ||
250 | @ | ||
251 | sub r7, r12, #16 @ r7 = Y = (Y' - 16)*74 | ||
252 | add r12, r7, r7, asl #2 @ | ||
253 | add r7, r12, r7, asl #5 @ | ||
254 | @ compute R, G, and B | ||
255 | add r1, r8, r7, asr #8 @ r1 = b = (Y >> 9) + bu | ||
256 | add r11, r9, r7, asr #8 @ r11 = r = (Y >> 9) + rv | ||
257 | add r7, r10, r7, asr #7 @ r7 = g = (Y >> 8) + guv | ||
258 | @ | ||
259 | orr r12, r1, r11 @ check if clamping is needed... | ||
260 | orr r12, r12, r7, asr #1 @ ...at all | ||
261 | cmp r12, #31 @ | ||
262 | bls 15f @ no clamp @ | ||
263 | cmp r1, #31 @ clamp b | ||
264 | mvnhi r1, r1, asr #31 @ | ||
265 | andhi r1, r1, #31 @ | ||
266 | cmp r11, #31 @ clamp r | ||
267 | mvnhi r11, r11, asr #31 @ | ||
268 | andhi r11, r11, #31 @ | ||
269 | cmp r7, #63 @ clamp g | ||
270 | mvnhi r7, r7, asr #31 @ | ||
271 | andhi r7, r7, #63 @ | ||
272 | 15: @ no clamp @ | ||
273 | @ | ||
274 | orr r12, r1, r11, lsl #11 @ r12 = b | (r << 11) | ||
275 | orr r12, r12, r7, lsl #5 @ r12 |= (g << 5) | ||
276 | strh r12, [r0, #-2] @ store pixel | ||
277 | add r0, r0, #2*LCD_WIDTH @ | ||
278 | @ | ||
279 | subs r2, r2, #2 @ subtract block from width | ||
280 | bgt 10b @ loop line @ | ||
281 | @ | ||
282 | ldmfd sp!, { r4-r12 } @ restore registers and return | ||
283 | bx lr @ | ||
284 | .ltorg @ dump constant pool | ||
285 | .size lcd_write_yuv420_lines, .-lcd_write_yuv420_lines | ||
286 | |||
287 | |||
288 | /**************************************************************************** | ||
289 | * void lcd_write_yuv_420_lines_odither(fb_data *dst, | ||
290 | * unsigned char const * const src[3], | ||
291 | * int width, | ||
292 | * int stride, | ||
293 | * int x_screen, | ||
294 | * int y_screen); | ||
295 | * | ||
296 | * |R| |1.000000 -0.000001 1.402000| |Y'| | ||
297 | * |G| = |1.000000 -0.334136 -0.714136| |Pb| | ||
298 | * |B| |1.000000 1.772000 0.000000| |Pr| | ||
299 | * Red scaled at twice g & b but at same precision to place it in correct | ||
300 | * bit position after multiply and leave instruction count lower. | ||
301 | * |R| |258 0 408| |Y' - 16| | ||
302 | * |G| = |149 -49 -104| |Cb - 128| | ||
303 | * |B| |149 258 0| |Cr - 128| | ||
304 | * | ||
305 | * Write four RGB565 pixels in the following order on each loop: | ||
306 | * 1 3 + > down | ||
307 | * 2 4 \/ left | ||
308 | * | ||
309 | * Kernel pattern (raw|rotated|use order): | ||
310 | * 5 3 4 2 2 6 3 7 row0 row2 > down | ||
311 | * 1 7 0 6 | 4 0 5 1 | 2 4 6 0 3 5 7 1 col0 left | ||
312 | * 4 2 5 3 | 3 7 2 6 | 3 5 7 1 2 4 6 0 col2 \/ | ||
313 | * 0 6 1 7 5 1 4 0 | ||
314 | */ | ||
315 | .section .icode, "ax", %progbits | ||
316 | .align 2 | ||
317 | .global lcd_write_yuv420_lines_odither | ||
318 | .type lcd_write_yuv420_lines_odither, %function | ||
319 | lcd_write_yuv420_lines_odither: | ||
320 | @ r0 = dst | ||
321 | @ r1 = yuv_src | ||
322 | @ r2 = width | ||
323 | @ r3 = stride | ||
324 | @ [sp] = x_screen | ||
325 | @ [sp+4] = y_screen | ||
326 | stmfd sp!, { r4-r12, lr } @ save non-scratch | ||
327 | ldmia r1, { r4, r5, r6 } @ r4 = yuv_src[0] = Y'_p | ||
328 | @ r5 = yuv_src[1] = Cb_p | ||
329 | @ r6 = yuv_src[2] = Cr_p | ||
330 | @ | ||
331 | sub r3, r3, #1 @ | ||
332 | add r1, sp, #40 @ Line up pattern and kernel quadrant | ||
333 | ldmia r1, { r12, r14 } @ | ||
334 | eor r14, r14, r12 @ | ||
335 | and r14, r14, #0x2 @ | ||
336 | mov r14, r14, lsl #6 @ 0x00 or 0x80 | ||
337 | 10: @ loop line @ | ||
338 | @ | ||
339 | ldrb r7, [r4], #1 @ r7 = *Y'_p++; | ||
340 | ldrb r8, [r5], #1 @ r8 = *Cb_p++; | ||
341 | ldrb r9, [r6], #1 @ r9 = *Cr_p++; | ||
342 | @ | ||
343 | eor r14, r14, #0x80 @ flip pattern quadrant | ||
344 | @ | ||
345 | sub r7, r7, #16 @ r7 = Y = (Y' - 16)*149 | ||
346 | add r12, r7, r7, asl #2 @ | ||
347 | add r12, r12, r12, asl #4 @ | ||
348 | add r7, r12, r7, asl #6 @ | ||
349 | @ | ||
350 | sub r8, r8, #128 @ Cb -= 128 | ||
351 | sub r9, r9, #128 @ Cr -= 128 | ||
352 | @ | ||
353 | add r10, r8, r8, asl #4 @ r10 = guv = Cr*104 + Cb*49 | ||
354 | add r10, r10, r8, asl #5 @ | ||
355 | add r10, r10, r9, asl #3 @ | ||
356 | add r10, r10, r9, asl #5 @ | ||
357 | add r10, r10, r9, asl #6 @ | ||
358 | @ | ||
359 | mov r8, r8, asl #1 @ r8 = bu = Cb*258 | ||
360 | add r8, r8, r8, asl #7 @ | ||
361 | @ | ||
362 | add r9, r9, r9, asl #1 @ r9 = rv = Cr*408 | ||
363 | add r9, r9, r9, asl #4 @ | ||
364 | mov r9, r9, asl #3 @ | ||
365 | @ | ||
366 | @ compute R, G, and B | ||
367 | add r1, r8, r7 @ r1 = b' = Y + bu | ||
368 | add r11, r9, r7, asl #1 @ r11 = r' = Y*2 + rv | ||
369 | rsb r7, r10, r7 @ r7 = g' = Y + guv | ||
370 | @ | ||
371 | @ r8 = bu, r9 = rv, r10 = guv | ||
372 | @ | ||
373 | sub r12, r1, r1, lsr #5 @ r1 = 31/32*b + b/256 | ||
374 | add r1, r12, r1, lsr #8 @ | ||
375 | @ | ||
376 | sub r12, r11, r11, lsr #5 @ r11 = 31/32*r + r/256 | ||
377 | add r11, r12, r11, lsr #8 @ | ||
378 | @ | ||
379 | sub r12, r7, r7, lsr #6 @ r7 = 63/64*g + g/256 | ||
380 | add r7, r12, r7, lsr #8 @ | ||
381 | @ | ||
382 | add r12, r14, #0x100 @ | ||
383 | @ | ||
384 | add r1, r1, r12 @ b = r1 + delta | ||
385 | add r11, r11, r12, lsl #1 @ r = r11 + delta*2 | ||
386 | add r7, r7, r12, lsr #1 @ g = r7 + delta/2 | ||
387 | @ | ||
388 | orr r12, r1, r11, asr #1 @ check if clamping is needed... | ||
389 | orr r12, r12, r7 @ ...at all | ||
390 | movs r12, r12, asr #15 @ | ||
391 | beq 15f @ no clamp @ | ||
392 | movs r12, r1, asr #15 @ clamp b | ||
393 | mvnne r1, r12, lsr #15 @ | ||
394 | andne r1, r1, #0x7c00 @ mask b only if clamped | ||
395 | movs r12, r11, asr #16 @ clamp r | ||
396 | mvnne r11, r12, lsr #16 @ | ||
397 | movs r12, r7, asr #15 @ clamp g | ||
398 | mvnne r7, r12, lsr #15 @ | ||
399 | 15: @ no clamp @ | ||
400 | @ | ||
401 | ldrb r12, [r4, r3] @ r12 = Y' = *(Y'_p + stride) | ||
402 | @ | ||
403 | and r11, r11, #0xf800 @ pack pixel | ||
404 | and r7, r7, #0x7e00 @ r1 = pixel = (r & 0xf800) | | ||
405 | orr r11, r11, r7, lsr #4 @ ((g & 0x7e00) >> 4) | | ||
406 | orr r1, r11, r1, lsr #10 @ (b >> 10) | ||
407 | @ | ||
408 | strh r1, [r0], #LCD_WIDTH @ store pixel | ||
409 | @ | ||
410 | sub r7, r12, #16 @ r7 = Y = (Y' - 16)*149 | ||
411 | add r12, r7, r7, asl #2 @ | ||
412 | add r12, r12, r12, asl #4 @ | ||
413 | add r7, r12, r7, asl #6 @ | ||
414 | @ compute R, G, and B | ||
415 | add r1, r8, r7 @ r1 = b' = Y + bu | ||
416 | add r11, r9, r7, asl #1 @ r11 = r' = Y*2 + rv | ||
417 | rsb r7, r10, r7 @ r7 = g' = Y + guv | ||
418 | @ | ||
419 | sub r12, r1, r1, lsr #5 @ r1 = 31/32*b' + b'/256 | ||
420 | add r1, r12, r1, lsr #8 @ | ||
421 | @ | ||
422 | sub r12, r11, r11, lsr #5 @ r11 = 31/32*r' + r'/256 | ||
423 | add r11, r12, r11, lsr #8 @ | ||
424 | @ | ||
425 | sub r12, r7, r7, lsr #6 @ r7 = 63/64*g' + g'/256 | ||
426 | add r7, r12, r7, lsr #8 @ | ||
427 | @ | ||
428 | add r12, r14, #0x200 @ | ||
429 | @ | ||
430 | add r1, r1, r12 @ b = r1 + delta | ||
431 | add r11, r11, r12, lsl #1 @ r = r11 + delta*2 | ||
432 | add r7, r7, r12, lsr #1 @ g = r7 + delta/2 | ||
433 | @ | ||
434 | orr r12, r1, r11, asr #1 @ check if clamping is needed... | ||
435 | orr r12, r12, r7 @ ...at all | ||
436 | movs r12, r12, asr #15 @ | ||
437 | beq 15f @ no clamp @ | ||
438 | movs r12, r1, asr #15 @ clamp b | ||
439 | mvnne r1, r12, lsr #15 @ | ||
440 | andne r1, r1, #0x7c00 @ mask b only if clamped | ||
441 | movs r12, r11, asr #16 @ clamp r | ||
442 | mvnne r11, r12, lsr #16 @ | ||
443 | movs r12, r7, asr #15 @ clamp g | ||
444 | mvnne r7, r12, lsr #15 @ | ||
445 | 15: @ no clamp @ | ||
446 | @ | ||
447 | ldrb r12, [r4], #1 @ r12 = Y' = *(Y'_p++) | ||
448 | @ | ||
449 | and r11, r11, #0xf800 @ pack pixel | ||
450 | and r7, r7, #0x7e00 @ r1 = pixel = (r & 0xf800) | | ||
451 | orr r11, r11, r7, lsr #4 @ ((g & 0x7e00) >> 4) | | ||
452 | orr r1, r11, r1, lsr #10 @ (b >> 10) | ||
453 | @ | ||
454 | strh r1, [r0, #-LCD_WIDTH-2] @ store pixel | ||
455 | @ | ||
456 | sub r7, r12, #16 @ r7 = Y = (Y' - 16)*149 | ||
457 | add r12, r7, r7, asl #2 @ | ||
458 | add r12, r12, r12, asl #4 @ | ||
459 | add r7, r12, r7, asl #6 @ | ||
460 | @ compute R, G, and B | ||
461 | add r1, r8, r7 @ r1 = b' = Y + bu | ||
462 | add r11, r9, r7, asl #1 @ r11 = r' = Y*2 + rv | ||
463 | rsb r7, r10, r7 @ r7 = g' = Y + guv | ||
464 | @ | ||
465 | @ r8 = bu, r9 = rv, r10 = guv | ||
466 | @ | ||
467 | sub r12, r1, r1, lsr #5 @ r1 = 31/32*b' + b'/256 | ||
468 | add r1, r12, r1, lsr #8 @ | ||
469 | @ | ||
470 | sub r12, r11, r11, lsr #5 @ r11 = 31/32*r' + r'/256 | ||
471 | add r11, r12, r11, lsr #8 @ | ||
472 | @ | ||
473 | sub r12, r7, r7, lsr #6 @ r7 = 63/64*g' + g'/256 | ||
474 | add r7, r12, r7, lsr #8 @ | ||
475 | @ | ||
476 | add r12, r14, #0x300 @ | ||
477 | @ | ||
478 | add r1, r1, r12 @ b = r1 + delta | ||
479 | add r11, r11, r12, lsl #1 @ r = r11 + delta*2 | ||
480 | add r7, r7, r12, lsr #1 @ g = r7 + delta/2 | ||
481 | @ | ||
482 | orr r12, r1, r11, asr #1 @ check if clamping is needed... | ||
483 | orr r12, r12, r7 @ ...at all | ||
484 | movs r12, r12, asr #15 @ | ||
485 | beq 15f @ no clamp @ | ||
486 | movs r12, r1, asr #15 @ clamp b | ||
487 | mvnne r1, r12, lsr #15 @ | ||
488 | andne r1, r1, #0x7c00 @ mask b only if clamped | ||
489 | movs r12, r11, asr #16 @ clamp r | ||
490 | mvnne r11, r12, lsr #16 @ | ||
491 | movs r12, r7, asr #15 @ clamp g | ||
492 | mvnne r7, r12, lsr #15 @ | ||
493 | 15: @ no clamp @ | ||
494 | @ | ||
495 | ldrb r12, [r4, r3] @ r12 = Y' = *(Y'_p + stride) | ||
496 | @ | ||
497 | and r11, r11, #0xf800 @ pack pixel | ||
498 | and r7, r7, #0x7e00 @ r1 = pixel = (r & 0xf800) | | ||
499 | orr r11, r11, r7, lsr #4 @ ((g & 0x7e00) >> 4) | | ||
500 | orr r1, r11, r1, lsr #10 @ (b >> 10) | ||
501 | @ | ||
502 | strh r1, [r0, #LCD_WIDTH]! @ store pixel | ||
503 | @ | ||
504 | sub r7, r12, #16 @ r7 = Y = (Y' - 16)*149 | ||
505 | add r12, r7, r7, asl #2 @ | ||
506 | add r12, r12, r12, asl #4 @ | ||
507 | add r7, r12, r7, asl #6 @ | ||
508 | @ compute R, G, and B | ||
509 | add r1, r8, r7 @ r1 = b' = Y + bu | ||
510 | add r11, r9, r7, asl #1 @ r11 = r' = Y*2 + rv | ||
511 | rsb r7, r10, r7 @ r7 = g' = Y + guv | ||
512 | @ | ||
513 | sub r12, r1, r1, lsr #5 @ r1 = 31/32*b + b/256 | ||
514 | add r1, r12, r1, lsr #8 @ | ||
515 | @ | ||
516 | sub r12, r11, r11, lsr #5 @ r11 = 31/32*r + r/256 | ||
517 | add r11, r12, r11, lsr #8 @ | ||
518 | @ | ||
519 | sub r12, r7, r7, lsr #6 @ r7 = 63/64*g + g/256 | ||
520 | add r7, r12, r7, lsr #8 @ | ||
521 | @ | ||
522 | @ This element is zero - use r14 @ | ||
523 | @ | ||
524 | add r1, r1, r14 @ b = r1 + delta | ||
525 | add r11, r11, r14, lsl #1 @ r = r11 + delta*2 | ||
526 | add r7, r7, r14, lsr #1 @ g = r7 + delta/2 | ||
527 | @ | ||
528 | orr r12, r1, r11, asr #1 @ check if clamping is needed... | ||
529 | orr r12, r12, r7 @ ...at all | ||
530 | movs r12, r12, asr #15 @ | ||
531 | beq 15f @ no clamp @ | ||
532 | movs r12, r1, asr #15 @ clamp b | ||
533 | mvnne r1, r12, lsr #15 @ | ||
534 | andne r1, r1, #0x7c00 @ mask b only if clamped | ||
535 | movs r12, r11, asr #16 @ clamp r | ||
536 | mvnne r11, r12, lsr #16 @ | ||
537 | movs r12, r7, asr #15 @ clamp g | ||
538 | mvnne r7, r12, lsr #15 @ | ||
539 | 15: @ no clamp @ | ||
540 | @ | ||
541 | and r11, r11, #0xf800 @ pack pixel | ||
542 | and r7, r7, #0x7e00 @ r1 = pixel = (r & 0xf800) | | ||
543 | orr r11, r11, r7, lsr #4 @ ((g & 0x7e00) >> 4) | | ||
544 | orr r1, r11, r1, lsr #10 @ (b >> 10) | ||
545 | @ | ||
546 | strh r1, [r0, #-2] @ store pixel | ||
547 | add r0, r0, #2*LCD_WIDTH @ | ||
548 | @ | ||
549 | subs r2, r2, #2 @ subtract block from width | ||
550 | bgt 10b @ loop line @ | ||
551 | @ | ||
552 | ldmfd sp!, { r4-r12, pc } @ restore registers and return | ||
553 | .ltorg @ dump constant pool | ||
554 | .size lcd_write_yuv420_lines_odither, .-lcd_write_yuv420_lines_odither | ||
diff --git a/firmware/target/arm/s3c2440/gigabeat-fx/lcd-as-meg-fx.S b/firmware/target/arm/s3c2440/gigabeat-fx/lcd-as-meg-fx.S deleted file mode 100644 index 4926c7fa79..0000000000 --- a/firmware/target/arm/s3c2440/gigabeat-fx/lcd-as-meg-fx.S +++ /dev/null | |||
@@ -1,279 +0,0 @@ | |||
1 | /*************************************************************************** | ||
2 | * __________ __ ___. | ||
3 | * Open \______ \ ____ ____ | | _\_ |__ _______ ___ | ||
4 | * Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ / | ||
5 | * Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < < | ||
6 | * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \ | ||
7 | * \/ \/ \/ \/ \/ | ||
8 | * $Id$ | ||
9 | * | ||
10 | * Copyright (C) 2007 by Michael Sevakis | ||
11 | * | ||
12 | * All files in this archive are subject to the GNU General Public License. | ||
13 | * See the file COPYING in the source tree root for full license agreement. | ||
14 | * | ||
15 | * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY | ||
16 | * KIND, either express or implied. | ||
17 | * | ||
18 | ****************************************************************************/ | ||
19 | |||
20 | #include "config.h" | ||
21 | #include "cpu.h" | ||
22 | |||
23 | /**************************************************************************** | ||
24 | * void lcd_copy_buffer_rect(fb_data *dst, fb_data *src, int width, | ||
25 | * int height); | ||
26 | */ | ||
27 | .section .icode, "ax", %progbits | ||
28 | .align 2 | ||
29 | .global lcd_copy_buffer_rect | ||
30 | .type lcd_copy_buffer_rect, %function | ||
31 | @ r0 = dst | ||
32 | @ r1 = src | ||
33 | @ r2 = width | ||
34 | @ r3 = height | ||
35 | lcd_copy_buffer_rect: @ | ||
36 | stmfd sp!, { r4-r12, lr } @ save non-scratch regs | ||
37 | mov r5, r2 @ r5 = cached width | ||
38 | rsb r4, r2, #LCD_WIDTH @ r4 = LCD_WIDTH - width | ||
39 | 10: @ copy line @ | ||
40 | subs r2, r5, #1 @ r2 = width - 1 | ||
41 | beq 40f @ finish line @ one halfword? skip to trailing copy | ||
42 | tst r0, #2 @ word aligned? | ||
43 | beq 20f @ rem copy @ yes? skip to word copy | ||
44 | ldrh r6, [r1], #2 @ copy leading halfword | ||
45 | subs r2, r2, #1 @ | ||
46 | strh r6, [r0], #2 @ | ||
47 | ble 40f @ finish line @ next line if lt or finish | ||
48 | @ trailing halfword if eq | ||
49 | 20: @ rem copy @ | ||
50 | add r14, r2, #1 @ get remaining width mod 16 after word | ||
51 | @ align (rw) | ||
52 | and r14, r14, #0xe @ r14 = 0 (16), 2, 4, 6, 8, 10, 12, 14 | ||
53 | add pc, pc, r14, lsl #3 @ branch to 32-byte align | ||
54 | nop @ | ||
55 | b 30f @ rw % 16 = 0 or 1? use octword loop | ||
56 | nop @ | ||
57 | nop @ | ||
58 | nop @ | ||
59 | ldr r6, [r1], #4 @ rw % 16 = 2 or 3 | ||
60 | subs r2, r2, #2 @ | ||
61 | str r6, [r0], #4 @ | ||
62 | b 25f @ copy up done @ | ||
63 | ldmia r1!, { r6-r7 } @ rw % 16 = 4 or 5 | ||
64 | subs r2, r2, #4 @ | ||
65 | stmia r0!, { r6-r7 } @ | ||
66 | b 25f @ copy up done @ | ||
67 | ldmia r1!, { r6-r8 } @ rw % 16 = 6 or 7 | ||
68 | subs r2, r2, #6 @ | ||
69 | stmia r0!, { r6-r8 } @ | ||
70 | b 25f @ copy up done @ | ||
71 | ldmia r1!, { r6-r9 } @ rw % 16 = 8 or 9 | ||
72 | subs r2, r2, #8 @ | ||
73 | stmia r0!, { r6-r9 } @ | ||
74 | b 25f @ copy up done @ | ||
75 | ldmia r1!, { r6-r10 } @ rw % 16 = 10 or 11 | ||
76 | subs r2, r2, #10 @ | ||
77 | stmia r0!, { r6-r10 } @ | ||
78 | b 25f @ copy up done @ | ||
79 | ldmia r1!, { r6-r11 } @ rw % 16 = 12 or 13 | ||
80 | subs r2, r2, #12 @ | ||
81 | stmia r0!, { r6-r11 } @ | ||
82 | b 25f @ copy up done @ | ||
83 | ldmia r1!, { r6-r12 } @ rw % 16 = 14 or 15 | ||
84 | subs r2, r2, #14 @ | ||
85 | stmia r0!, { r6-r12 } @ | ||
86 | 25: @ copy up done @ | ||
87 | ble 40f @ finish line @ no 32-byte segments remaining? | ||
88 | 30: @ octword loop @ copy 16 pixels per loop | ||
89 | ldmia r1!, { r6-r12, r14 } @ | ||
90 | subs r2, r2, #16 @ | ||
91 | stmia r0!, { r6-r12, r14 } @ | ||
92 | bgt 30b @ octword loop @ | ||
93 | 40: @ finish line @ | ||
94 | ldreqh r6, [r1], #2 @ finish last halfword if eq ... | ||
95 | add r1, r1, r4, lsl #1 @ | ||
96 | streqh r6, [r0], #2 @ ... | ||
97 | add r0, r0, r4, lsl #1 @ | ||
98 | subs r3, r3, #1 @ next line | ||
99 | bgt 10b @ copy line @ | ||
100 | ldmfd sp!, { r4-r12, pc } @ restore regs and return | ||
101 | .size lcd_copy_buffer_rect, .-lcd_copy_buffer_rect | ||
102 | |||
103 | |||
104 | /**************************************************************************** | ||
105 | * void lcd_write_yuv_420_lines(fb_data *dst, | ||
106 | * unsigned char const * const src[3], | ||
107 | * int width, | ||
108 | * int stride); | ||
109 | * | ||
110 | * |R| |1.000000 -0.000001 1.402000| |Y'| | ||
111 | * |G| = |1.000000 -0.334136 -0.714136| |Pb| | ||
112 | * |B| |1.000000 1.772000 0.000000| |Pr| | ||
113 | * Scaled, normalized, rounded and tweaked to yield RGB 565: | ||
114 | * |R| |74 0 101| |Y' - 16| >> 9 | ||
115 | * |G| = |74 -24 -51| |Cb - 128| >> 8 | ||
116 | * |B| |74 128 0| |Cr - 128| >> 9 | ||
117 | * | ||
118 | * Write four RGB565 pixels in the following order on each loop: | ||
119 | * 1 3 + > down | ||
120 | * 2 4 \/ left | ||
121 | */ | ||
122 | .section .icode, "ax", %progbits | ||
123 | .align 2 | ||
124 | .global lcd_write_yuv420_lines | ||
125 | .type lcd_write_yuv420_lines, %function | ||
126 | lcd_write_yuv420_lines: | ||
127 | @ r0 = dst | ||
128 | @ r1 = yuv_src | ||
129 | @ r2 = width | ||
130 | @ r3 = stride | ||
131 | stmfd sp!, { r4-r12 } @ save non-scratch | ||
132 | ldmia r1, { r4, r5, r6 } @ r4 = yuv_src[0] = Y'_p | ||
133 | @ r5 = yuv_src[1] = Cb_p | ||
134 | @ r6 = yuv_src[2] = Cr_p | ||
135 | @ r1 = scratch | ||
136 | 10: @ loop line @ | ||
137 | ldrb r7, [r4] @ r7 = *Y'_p; | ||
138 | ldrb r8, [r5], #1 @ r8 = *Cb_p++; | ||
139 | ldrb r9, [r6], #1 @ r9 = *Cr_p++; | ||
140 | @ | ||
141 | sub r7, r7, #16 @ r7 = Y = (Y' - 16)*74 | ||
142 | add r12, r7, r7, asl #2 @ actually (Y' - 16)*37 and shift right | ||
143 | add r7, r12, r7, asl #5 @ by one less when adding - same for all | ||
144 | @ | ||
145 | sub r8, r8, #128 @ Cb -= 128 | ||
146 | sub r9, r9, #128 @ Cr -= 128 | ||
147 | @ | ||
148 | add r10, r9, r9, asl #1 @ r10 = Cr*51 + Cb*24 | ||
149 | add r10, r10, r10, asl #4 @ | ||
150 | add r10, r10, r8, asl #3 @ | ||
151 | add r10, r10, r8, asl #4 @ | ||
152 | @ | ||
153 | add r11, r9, r9, asl #2 @ r9 = Cr*101 | ||
154 | add r11, r11, r9, asl #5 @ | ||
155 | add r9, r11, r9, asl #6 @ | ||
156 | @ | ||
157 | add r8, r8, #2 @ r8 = bu = (Cb*128 + 128) >> 8 | ||
158 | mov r8, r8, asr #2 @ | ||
159 | add r9, r9, #256 @ r9 = rv = (r9 + 256) >> 9 | ||
160 | mov r9, r9, asr #9 @ | ||
161 | rsb r10, r10, #128 @ r10 = guv = (-r10 + 128) >> 8 | ||
162 | mov r10, r10, asr #8 @ | ||
163 | @ compute R, G, and B | ||
164 | add r1, r8, r7, asr #8 @ r1 = b = (Y >> 9) + bu | ||
165 | add r11, r9, r7, asr #8 @ r11 = r = (Y >> 9) + rv | ||
166 | add r7, r10, r7, asr #7 @ r7 = g = (Y >> 8) + guv | ||
167 | @ | ||
168 | orr r12, r1, r11 @ check if clamping is needed... | ||
169 | orr r12, r12, r7, asr #1 @ ...at all | ||
170 | cmp r12, #31 @ | ||
171 | bls 15f @ no clamp @ | ||
172 | cmp r1, #31 @ clamp b | ||
173 | mvnhi r1, r1, asr #31 @ | ||
174 | andhi r1, r1, #31 @ | ||
175 | cmp r11, #31 @ clamp r | ||
176 | mvnhi r11, r11, asr #31 @ | ||
177 | andhi r11, r11, #31 @ | ||
178 | cmp r7, #63 @ clamp g | ||
179 | mvnhi r7, r7, asr #31 @ | ||
180 | andhi r7, r7, #63 @ | ||
181 | 15: @ no clamp @ | ||
182 | @ | ||
183 | orr r12, r1, r7, lsl #5 @ r4 |= (g << 5) | ||
184 | ldrb r7, [r4, r3] @ r7 = Y' = *(Y'_p + stride) | ||
185 | orr r12, r12, r11, lsl #11 @ r4 = b | (r << 11) | ||
186 | strh r12, [r0] @ store pixel | ||
187 | @ | ||
188 | sub r7, r7, #16 @ r7 = Y = (Y' - 16)*74 | ||
189 | add r12, r7, r7, asl #2 @ | ||
190 | add r7, r12, r7, asl #5 @ | ||
191 | @ compute R, G, and B | ||
192 | add r1, r8, r7, asr #8 @ r1 = b = (Y >> 9) + bu | ||
193 | add r11, r9, r7, asr #8 @ r11 = r = (Y >> 9) + rv | ||
194 | add r7, r10, r7, asr #7 @ r7 = g = (Y >> 8) + guv | ||
195 | @ | ||
196 | orr r12, r1, r11 @ check if clamping is needed... | ||
197 | orr r12, r12, r7, asr #1 @ ...at all | ||
198 | cmp r12, #31 @ | ||
199 | bls 15f @ no clamp @ | ||
200 | cmp r1, #31 @ clamp b | ||
201 | mvnhi r1, r1, asr #31 @ | ||
202 | andhi r1, r1, #31 @ | ||
203 | cmp r11, #31 @ clamp r | ||
204 | mvnhi r11, r11, asr #31 @ | ||
205 | andhi r11, r11, #31 @ | ||
206 | cmp r7, #63 @ clamp g | ||
207 | mvnhi r7, r7, asr #31 @ | ||
208 | andhi r7, r7, #63 @ | ||
209 | 15: @ no clamp @ | ||
210 | @ | ||
211 | orr r12, r1, r11, lsl #11 @ r12 = b | (r << 11) | ||
212 | orr r12, r12, r7, lsl #5 @ r12 |= (g << 5) | ||
213 | ldrb r7, [r4, #1]! @ r7 = Y' = *(++Y'_p) | ||
214 | strh r12, [r0, #-2] @ store pixel | ||
215 | add r0, r0, #2*LCD_WIDTH @ | ||
216 | @ | ||
217 | sub r7, r7, #16 @ r7 = Y = (Y' - 16)*74 | ||
218 | add r12, r7, r7, asl #2 @ | ||
219 | add r7, r12, r7, asl #5 @ | ||
220 | @ compute R, G, and B | ||
221 | add r1, r8, r7, asr #8 @ r1 = b = (Y >> 9) + bu | ||
222 | add r11, r9, r7, asr #8 @ r11 = r = (Y >> 9) + rv | ||
223 | add r7, r10, r7, asr #7 @ r7 = g = (Y >> 8) + guv | ||
224 | @ | ||
225 | orr r12, r1, r11 @ check if clamping is needed... | ||
226 | orr r12, r12, r7, asr #1 @ ...at all | ||
227 | cmp r12, #31 @ | ||
228 | bls 15f @ no clamp @ | ||
229 | cmp r1, #31 @ clamp b | ||
230 | mvnhi r1, r1, asr #31 @ | ||
231 | andhi r1, r1, #31 @ | ||
232 | cmp r11, #31 @ clamp r | ||
233 | mvnhi r11, r11, asr #31 @ | ||
234 | andhi r11, r11, #31 @ | ||
235 | cmp r7, #63 @ clamp g | ||
236 | mvnhi r7, r7, asr #31 @ | ||
237 | andhi r7, r7, #63 @ | ||
238 | 15: @ no clamp @ | ||
239 | @ | ||
240 | orr r12, r1, r7, lsl #5 @ r12 = b | (g << 5) | ||
241 | ldrb r7, [r4, r3] @ r7 = Y' = *(Y'_p + stride) | ||
242 | orr r12, r12, r11, lsl #11 @ r12 |= (r << 11) | ||
243 | strh r12, [r0] @ store pixel | ||
244 | @ | ||
245 | sub r7, r7, #16 @ r7 = Y = (Y' - 16)*74 | ||
246 | add r12, r7, r7, asl #2 @ | ||
247 | add r7, r12, r7, asl #5 @ | ||
248 | @ compute R, G, and B | ||
249 | add r1, r8, r7, asr #8 @ r1 = b = (Y >> 9) + bu | ||
250 | add r11, r9, r7, asr #8 @ r11 = r = (Y >> 9) + rv | ||
251 | add r7, r10, r7, asr #7 @ r7 = g = (Y >> 8) + guv | ||
252 | @ | ||
253 | orr r12, r1, r11 @ check if clamping is needed... | ||
254 | orr r12, r12, r7, asr #1 @ ...at all | ||
255 | cmp r12, #31 @ | ||
256 | bls 15f @ no clamp @ | ||
257 | cmp r1, #31 @ clamp b | ||
258 | mvnhi r1, r1, asr #31 @ | ||
259 | andhi r1, r1, #31 @ | ||
260 | cmp r11, #31 @ clamp r | ||
261 | mvnhi r11, r11, asr #31 @ | ||
262 | andhi r11, r11, #31 @ | ||
263 | cmp r7, #63 @ clamp g | ||
264 | mvnhi r7, r7, asr #31 @ | ||
265 | andhi r7, r7, #63 @ | ||
266 | 15: @ no clamp @ | ||
267 | @ | ||
268 | orr r12, r1, r11, lsl #11 @ r12 = b | (r << 11) | ||
269 | orr r12, r12, r7, lsl #5 @ r12 |= (g << 5) | ||
270 | strh r12, [r0, #-2] @ store pixel | ||
271 | add r0, r0, #2*LCD_WIDTH @ | ||
272 | add r4, r4, #1 @ | ||
273 | @ | ||
274 | subs r2, r2, #2 @ subtract block from width | ||
275 | bgt 10b @ loop line @ | ||
276 | @ | ||
277 | ldmfd sp!, { r4-r12 } @ restore registers and return | ||
278 | bx lr @ | ||
279 | .size lcd_write_yuv420_lines, .-lcd_write_yuv420_lines | ||
diff --git a/firmware/target/arm/s3c2440/gigabeat-fx/lcd-meg-fx.c b/firmware/target/arm/s3c2440/gigabeat-fx/lcd-meg-fx.c index ab7c91437c..91b2eae986 100644 --- a/firmware/target/arm/s3c2440/gigabeat-fx/lcd-meg-fx.c +++ b/firmware/target/arm/s3c2440/gigabeat-fx/lcd-meg-fx.c | |||
@@ -9,6 +9,7 @@ | |||
9 | 9 | ||
10 | static volatile bool lcd_on = true; | 10 | static volatile bool lcd_on = true; |
11 | volatile bool lcd_poweroff = false; | 11 | volatile bool lcd_poweroff = false; |
12 | static unsigned lcd_yuv_options = 0; | ||
12 | /* | 13 | /* |
13 | ** These are imported from lcd-16bit.c | 14 | ** These are imported from lcd-16bit.c |
14 | */ | 15 | */ |
@@ -248,11 +249,22 @@ void lcd_bitmap_transparent_part(const fb_data *src, int src_x, int src_y, | |||
248 | ); | 249 | ); |
249 | } | 250 | } |
250 | 251 | ||
252 | void lcd_yuv_set_options(unsigned options) | ||
253 | { | ||
254 | lcd_yuv_options = options; | ||
255 | } | ||
256 | |||
251 | /* Line write helper function for lcd_yuv_blit. Write two lines of yuv420. */ | 257 | /* Line write helper function for lcd_yuv_blit. Write two lines of yuv420. */ |
252 | extern void lcd_write_yuv420_lines(fb_data *dst, | 258 | extern void lcd_write_yuv420_lines(fb_data *dst, |
253 | unsigned char const * const src[3], | 259 | unsigned char const * const src[3], |
254 | int width, | 260 | int width, |
255 | int stride); | 261 | int stride); |
262 | extern void lcd_write_yuv420_lines_odither(fb_data *dst, | ||
263 | unsigned char const * const src[3], | ||
264 | int width, | ||
265 | int stride, | ||
266 | int x_screen, /* To align dither pattern */ | ||
267 | int y_screen); | ||
256 | /* Performance function to blit a YUV bitmap directly to the LCD */ | 268 | /* Performance function to blit a YUV bitmap directly to the LCD */ |
257 | /* For the Gigabeat - show it rotated */ | 269 | /* For the Gigabeat - show it rotated */ |
258 | /* So the LCD_WIDTH is now the height */ | 270 | /* So the LCD_WIDTH is now the height */ |
@@ -272,22 +284,39 @@ void lcd_yuv_blit(unsigned char * const src[3], | |||
272 | width &= ~1; | 284 | width &= ~1; |
273 | height >>= 1; | 285 | height >>= 1; |
274 | 286 | ||
275 | fb_data *dst = (fb_data*)FRAME + x * LCD_WIDTH + (LCD_WIDTH - y) - 1; | 287 | y = LCD_WIDTH - 1 - y; |
288 | fb_data *dst = (fb_data*)FRAME + x * LCD_WIDTH + y; | ||
276 | 289 | ||
277 | z = stride*src_y; | 290 | z = stride*src_y; |
278 | yuv_src[0] = src[0] + z + src_x; | 291 | yuv_src[0] = src[0] + z + src_x; |
279 | yuv_src[1] = src[1] + (z >> 2) + (src_x >> 1); | 292 | yuv_src[1] = src[1] + (z >> 2) + (src_x >> 1); |
280 | yuv_src[2] = src[2] + (yuv_src[1] - src[1]); | 293 | yuv_src[2] = src[2] + (yuv_src[1] - src[1]); |
281 | 294 | ||
282 | do | 295 | if (lcd_yuv_options & LCD_YUV_DITHER) |
296 | { | ||
297 | do | ||
298 | { | ||
299 | lcd_write_yuv420_lines_odither(dst, yuv_src, width, stride, y, x); | ||
300 | yuv_src[0] += stride << 1; /* Skip down two luma lines */ | ||
301 | yuv_src[1] += stride >> 1; /* Skip down one chroma line */ | ||
302 | yuv_src[2] += stride >> 1; | ||
303 | dst -= 2; | ||
304 | y -= 2; | ||
305 | } | ||
306 | while (--height > 0); | ||
307 | } | ||
308 | else | ||
283 | { | 309 | { |
284 | lcd_write_yuv420_lines(dst, yuv_src, width, stride); | 310 | do |
285 | yuv_src[0] += stride << 1; /* Skip down two luma lines */ | 311 | { |
286 | yuv_src[1] += stride >> 1; /* Skip down one chroma line */ | 312 | lcd_write_yuv420_lines(dst, yuv_src, width, stride); |
287 | yuv_src[2] += stride >> 1; | 313 | yuv_src[0] += stride << 1; /* Skip down two luma lines */ |
288 | dst -= 2; | 314 | yuv_src[1] += stride >> 1; /* Skip down one chroma line */ |
315 | yuv_src[2] += stride >> 1; | ||
316 | dst -= 2; | ||
317 | } | ||
318 | while (--height > 0); | ||
289 | } | 319 | } |
290 | while (--height > 0); | ||
291 | } | 320 | } |
292 | 321 | ||
293 | void lcd_set_contrast(int val) { | 322 | void lcd_set_contrast(int val) { |
diff --git a/firmware/target/arm/sandisk/sansa-e200/lcd-as-e200.S b/firmware/target/arm/sandisk/sansa-e200/lcd-as-e200.S deleted file mode 100644 index 4926c7fa79..0000000000 --- a/firmware/target/arm/sandisk/sansa-e200/lcd-as-e200.S +++ /dev/null | |||
@@ -1,279 +0,0 @@ | |||
1 | /*************************************************************************** | ||
2 | * __________ __ ___. | ||
3 | * Open \______ \ ____ ____ | | _\_ |__ _______ ___ | ||
4 | * Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ / | ||
5 | * Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < < | ||
6 | * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \ | ||
7 | * \/ \/ \/ \/ \/ | ||
8 | * $Id$ | ||
9 | * | ||
10 | * Copyright (C) 2007 by Michael Sevakis | ||
11 | * | ||
12 | * All files in this archive are subject to the GNU General Public License. | ||
13 | * See the file COPYING in the source tree root for full license agreement. | ||
14 | * | ||
15 | * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY | ||
16 | * KIND, either express or implied. | ||
17 | * | ||
18 | ****************************************************************************/ | ||
19 | |||
20 | #include "config.h" | ||
21 | #include "cpu.h" | ||
22 | |||
23 | /**************************************************************************** | ||
24 | * void lcd_copy_buffer_rect(fb_data *dst, fb_data *src, int width, | ||
25 | * int height); | ||
26 | */ | ||
27 | .section .icode, "ax", %progbits | ||
28 | .align 2 | ||
29 | .global lcd_copy_buffer_rect | ||
30 | .type lcd_copy_buffer_rect, %function | ||
31 | @ r0 = dst | ||
32 | @ r1 = src | ||
33 | @ r2 = width | ||
34 | @ r3 = height | ||
35 | lcd_copy_buffer_rect: @ | ||
36 | stmfd sp!, { r4-r12, lr } @ save non-scratch regs | ||
37 | mov r5, r2 @ r5 = cached width | ||
38 | rsb r4, r2, #LCD_WIDTH @ r4 = LCD_WIDTH - width | ||
39 | 10: @ copy line @ | ||
40 | subs r2, r5, #1 @ r2 = width - 1 | ||
41 | beq 40f @ finish line @ one halfword? skip to trailing copy | ||
42 | tst r0, #2 @ word aligned? | ||
43 | beq 20f @ rem copy @ yes? skip to word copy | ||
44 | ldrh r6, [r1], #2 @ copy leading halfword | ||
45 | subs r2, r2, #1 @ | ||
46 | strh r6, [r0], #2 @ | ||
47 | ble 40f @ finish line @ next line if lt or finish | ||
48 | @ trailing halfword if eq | ||
49 | 20: @ rem copy @ | ||
50 | add r14, r2, #1 @ get remaining width mod 16 after word | ||
51 | @ align (rw) | ||
52 | and r14, r14, #0xe @ r14 = 0 (16), 2, 4, 6, 8, 10, 12, 14 | ||
53 | add pc, pc, r14, lsl #3 @ branch to 32-byte align | ||
54 | nop @ | ||
55 | b 30f @ rw % 16 = 0 or 1? use octword loop | ||
56 | nop @ | ||
57 | nop @ | ||
58 | nop @ | ||
59 | ldr r6, [r1], #4 @ rw % 16 = 2 or 3 | ||
60 | subs r2, r2, #2 @ | ||
61 | str r6, [r0], #4 @ | ||
62 | b 25f @ copy up done @ | ||
63 | ldmia r1!, { r6-r7 } @ rw % 16 = 4 or 5 | ||
64 | subs r2, r2, #4 @ | ||
65 | stmia r0!, { r6-r7 } @ | ||
66 | b 25f @ copy up done @ | ||
67 | ldmia r1!, { r6-r8 } @ rw % 16 = 6 or 7 | ||
68 | subs r2, r2, #6 @ | ||
69 | stmia r0!, { r6-r8 } @ | ||
70 | b 25f @ copy up done @ | ||
71 | ldmia r1!, { r6-r9 } @ rw % 16 = 8 or 9 | ||
72 | subs r2, r2, #8 @ | ||
73 | stmia r0!, { r6-r9 } @ | ||
74 | b 25f @ copy up done @ | ||
75 | ldmia r1!, { r6-r10 } @ rw % 16 = 10 or 11 | ||
76 | subs r2, r2, #10 @ | ||
77 | stmia r0!, { r6-r10 } @ | ||
78 | b 25f @ copy up done @ | ||
79 | ldmia r1!, { r6-r11 } @ rw % 16 = 12 or 13 | ||
80 | subs r2, r2, #12 @ | ||
81 | stmia r0!, { r6-r11 } @ | ||
82 | b 25f @ copy up done @ | ||
83 | ldmia r1!, { r6-r12 } @ rw % 16 = 14 or 15 | ||
84 | subs r2, r2, #14 @ | ||
85 | stmia r0!, { r6-r12 } @ | ||
86 | 25: @ copy up done @ | ||
87 | ble 40f @ finish line @ no 32-byte segments remaining? | ||
88 | 30: @ octword loop @ copy 16 pixels per loop | ||
89 | ldmia r1!, { r6-r12, r14 } @ | ||
90 | subs r2, r2, #16 @ | ||
91 | stmia r0!, { r6-r12, r14 } @ | ||
92 | bgt 30b @ octword loop @ | ||
93 | 40: @ finish line @ | ||
94 | ldreqh r6, [r1], #2 @ finish last halfword if eq ... | ||
95 | add r1, r1, r4, lsl #1 @ | ||
96 | streqh r6, [r0], #2 @ ... | ||
97 | add r0, r0, r4, lsl #1 @ | ||
98 | subs r3, r3, #1 @ next line | ||
99 | bgt 10b @ copy line @ | ||
100 | ldmfd sp!, { r4-r12, pc } @ restore regs and return | ||
101 | .size lcd_copy_buffer_rect, .-lcd_copy_buffer_rect | ||
102 | |||
103 | |||
104 | /**************************************************************************** | ||
105 | * void lcd_write_yuv_420_lines(fb_data *dst, | ||
106 | * unsigned char const * const src[3], | ||
107 | * int width, | ||
108 | * int stride); | ||
109 | * | ||
110 | * |R| |1.000000 -0.000001 1.402000| |Y'| | ||
111 | * |G| = |1.000000 -0.334136 -0.714136| |Pb| | ||
112 | * |B| |1.000000 1.772000 0.000000| |Pr| | ||
113 | * Scaled, normalized, rounded and tweaked to yield RGB 565: | ||
114 | * |R| |74 0 101| |Y' - 16| >> 9 | ||
115 | * |G| = |74 -24 -51| |Cb - 128| >> 8 | ||
116 | * |B| |74 128 0| |Cr - 128| >> 9 | ||
117 | * | ||
118 | * Write four RGB565 pixels in the following order on each loop: | ||
119 | * 1 3 + > down | ||
120 | * 2 4 \/ left | ||
121 | */ | ||
122 | .section .icode, "ax", %progbits | ||
123 | .align 2 | ||
124 | .global lcd_write_yuv420_lines | ||
125 | .type lcd_write_yuv420_lines, %function | ||
126 | lcd_write_yuv420_lines: | ||
127 | @ r0 = dst | ||
128 | @ r1 = yuv_src | ||
129 | @ r2 = width | ||
130 | @ r3 = stride | ||
131 | stmfd sp!, { r4-r12 } @ save non-scratch | ||
132 | ldmia r1, { r4, r5, r6 } @ r4 = yuv_src[0] = Y'_p | ||
133 | @ r5 = yuv_src[1] = Cb_p | ||
134 | @ r6 = yuv_src[2] = Cr_p | ||
135 | @ r1 = scratch | ||
136 | 10: @ loop line @ | ||
137 | ldrb r7, [r4] @ r7 = *Y'_p; | ||
138 | ldrb r8, [r5], #1 @ r8 = *Cb_p++; | ||
139 | ldrb r9, [r6], #1 @ r9 = *Cr_p++; | ||
140 | @ | ||
141 | sub r7, r7, #16 @ r7 = Y = (Y' - 16)*74 | ||
142 | add r12, r7, r7, asl #2 @ actually (Y' - 16)*37 and shift right | ||
143 | add r7, r12, r7, asl #5 @ by one less when adding - same for all | ||
144 | @ | ||
145 | sub r8, r8, #128 @ Cb -= 128 | ||
146 | sub r9, r9, #128 @ Cr -= 128 | ||
147 | @ | ||
148 | add r10, r9, r9, asl #1 @ r10 = Cr*51 + Cb*24 | ||
149 | add r10, r10, r10, asl #4 @ | ||
150 | add r10, r10, r8, asl #3 @ | ||
151 | add r10, r10, r8, asl #4 @ | ||
152 | @ | ||
153 | add r11, r9, r9, asl #2 @ r9 = Cr*101 | ||
154 | add r11, r11, r9, asl #5 @ | ||
155 | add r9, r11, r9, asl #6 @ | ||
156 | @ | ||
157 | add r8, r8, #2 @ r8 = bu = (Cb*128 + 128) >> 8 | ||
158 | mov r8, r8, asr #2 @ | ||
159 | add r9, r9, #256 @ r9 = rv = (r9 + 256) >> 9 | ||
160 | mov r9, r9, asr #9 @ | ||
161 | rsb r10, r10, #128 @ r10 = guv = (-r10 + 128) >> 8 | ||
162 | mov r10, r10, asr #8 @ | ||
163 | @ compute R, G, and B | ||
164 | add r1, r8, r7, asr #8 @ r1 = b = (Y >> 9) + bu | ||
165 | add r11, r9, r7, asr #8 @ r11 = r = (Y >> 9) + rv | ||
166 | add r7, r10, r7, asr #7 @ r7 = g = (Y >> 8) + guv | ||
167 | @ | ||
168 | orr r12, r1, r11 @ check if clamping is needed... | ||
169 | orr r12, r12, r7, asr #1 @ ...at all | ||
170 | cmp r12, #31 @ | ||
171 | bls 15f @ no clamp @ | ||
172 | cmp r1, #31 @ clamp b | ||
173 | mvnhi r1, r1, asr #31 @ | ||
174 | andhi r1, r1, #31 @ | ||
175 | cmp r11, #31 @ clamp r | ||
176 | mvnhi r11, r11, asr #31 @ | ||
177 | andhi r11, r11, #31 @ | ||
178 | cmp r7, #63 @ clamp g | ||
179 | mvnhi r7, r7, asr #31 @ | ||
180 | andhi r7, r7, #63 @ | ||
181 | 15: @ no clamp @ | ||
182 | @ | ||
183 | orr r12, r1, r7, lsl #5 @ r4 |= (g << 5) | ||
184 | ldrb r7, [r4, r3] @ r7 = Y' = *(Y'_p + stride) | ||
185 | orr r12, r12, r11, lsl #11 @ r4 = b | (r << 11) | ||
186 | strh r12, [r0] @ store pixel | ||
187 | @ | ||
188 | sub r7, r7, #16 @ r7 = Y = (Y' - 16)*74 | ||
189 | add r12, r7, r7, asl #2 @ | ||
190 | add r7, r12, r7, asl #5 @ | ||
191 | @ compute R, G, and B | ||
192 | add r1, r8, r7, asr #8 @ r1 = b = (Y >> 9) + bu | ||
193 | add r11, r9, r7, asr #8 @ r11 = r = (Y >> 9) + rv | ||
194 | add r7, r10, r7, asr #7 @ r7 = g = (Y >> 8) + guv | ||
195 | @ | ||
196 | orr r12, r1, r11 @ check if clamping is needed... | ||
197 | orr r12, r12, r7, asr #1 @ ...at all | ||
198 | cmp r12, #31 @ | ||
199 | bls 15f @ no clamp @ | ||
200 | cmp r1, #31 @ clamp b | ||
201 | mvnhi r1, r1, asr #31 @ | ||
202 | andhi r1, r1, #31 @ | ||
203 | cmp r11, #31 @ clamp r | ||
204 | mvnhi r11, r11, asr #31 @ | ||
205 | andhi r11, r11, #31 @ | ||
206 | cmp r7, #63 @ clamp g | ||
207 | mvnhi r7, r7, asr #31 @ | ||
208 | andhi r7, r7, #63 @ | ||
209 | 15: @ no clamp @ | ||
210 | @ | ||
211 | orr r12, r1, r11, lsl #11 @ r12 = b | (r << 11) | ||
212 | orr r12, r12, r7, lsl #5 @ r12 |= (g << 5) | ||
213 | ldrb r7, [r4, #1]! @ r7 = Y' = *(++Y'_p) | ||
214 | strh r12, [r0, #-2] @ store pixel | ||
215 | add r0, r0, #2*LCD_WIDTH @ | ||
216 | @ | ||
217 | sub r7, r7, #16 @ r7 = Y = (Y' - 16)*74 | ||
218 | add r12, r7, r7, asl #2 @ | ||
219 | add r7, r12, r7, asl #5 @ | ||
220 | @ compute R, G, and B | ||
221 | add r1, r8, r7, asr #8 @ r1 = b = (Y >> 9) + bu | ||
222 | add r11, r9, r7, asr #8 @ r11 = r = (Y >> 9) + rv | ||
223 | add r7, r10, r7, asr #7 @ r7 = g = (Y >> 8) + guv | ||
224 | @ | ||
225 | orr r12, r1, r11 @ check if clamping is needed... | ||
226 | orr r12, r12, r7, asr #1 @ ...at all | ||
227 | cmp r12, #31 @ | ||
228 | bls 15f @ no clamp @ | ||
229 | cmp r1, #31 @ clamp b | ||
230 | mvnhi r1, r1, asr #31 @ | ||
231 | andhi r1, r1, #31 @ | ||
232 | cmp r11, #31 @ clamp r | ||
233 | mvnhi r11, r11, asr #31 @ | ||
234 | andhi r11, r11, #31 @ | ||
235 | cmp r7, #63 @ clamp g | ||
236 | mvnhi r7, r7, asr #31 @ | ||
237 | andhi r7, r7, #63 @ | ||
238 | 15: @ no clamp @ | ||
239 | @ | ||
240 | orr r12, r1, r7, lsl #5 @ r12 = b | (g << 5) | ||
241 | ldrb r7, [r4, r3] @ r7 = Y' = *(Y'_p + stride) | ||
242 | orr r12, r12, r11, lsl #11 @ r12 |= (r << 11) | ||
243 | strh r12, [r0] @ store pixel | ||
244 | @ | ||
245 | sub r7, r7, #16 @ r7 = Y = (Y' - 16)*74 | ||
246 | add r12, r7, r7, asl #2 @ | ||
247 | add r7, r12, r7, asl #5 @ | ||
248 | @ compute R, G, and B | ||
249 | add r1, r8, r7, asr #8 @ r1 = b = (Y >> 9) + bu | ||
250 | add r11, r9, r7, asr #8 @ r11 = r = (Y >> 9) + rv | ||
251 | add r7, r10, r7, asr #7 @ r7 = g = (Y >> 8) + guv | ||
252 | @ | ||
253 | orr r12, r1, r11 @ check if clamping is needed... | ||
254 | orr r12, r12, r7, asr #1 @ ...at all | ||
255 | cmp r12, #31 @ | ||
256 | bls 15f @ no clamp @ | ||
257 | cmp r1, #31 @ clamp b | ||
258 | mvnhi r1, r1, asr #31 @ | ||
259 | andhi r1, r1, #31 @ | ||
260 | cmp r11, #31 @ clamp r | ||
261 | mvnhi r11, r11, asr #31 @ | ||
262 | andhi r11, r11, #31 @ | ||
263 | cmp r7, #63 @ clamp g | ||
264 | mvnhi r7, r7, asr #31 @ | ||
265 | andhi r7, r7, #63 @ | ||
266 | 15: @ no clamp @ | ||
267 | @ | ||
268 | orr r12, r1, r11, lsl #11 @ r12 = b | (r << 11) | ||
269 | orr r12, r12, r7, lsl #5 @ r12 |= (g << 5) | ||
270 | strh r12, [r0, #-2] @ store pixel | ||
271 | add r0, r0, #2*LCD_WIDTH @ | ||
272 | add r4, r4, #1 @ | ||
273 | @ | ||
274 | subs r2, r2, #2 @ subtract block from width | ||
275 | bgt 10b @ loop line @ | ||
276 | @ | ||
277 | ldmfd sp!, { r4-r12 } @ restore registers and return | ||
278 | bx lr @ | ||
279 | .size lcd_write_yuv420_lines, .-lcd_write_yuv420_lines | ||
diff --git a/firmware/target/arm/sandisk/sansa-e200/lcd-e200.c b/firmware/target/arm/sandisk/sansa-e200/lcd-e200.c index 3e1f74d7a1..0d3a1a3049 100644 --- a/firmware/target/arm/sandisk/sansa-e200/lcd-e200.c +++ b/firmware/target/arm/sandisk/sansa-e200/lcd-e200.c | |||
@@ -29,6 +29,7 @@ | |||
29 | /* Power and display status */ | 29 | /* Power and display status */ |
30 | static bool power_on = false; /* Is the power turned on? */ | 30 | static bool power_on = false; /* Is the power turned on? */ |
31 | static bool display_on NOCACHEBSS_ATTR = false; /* Is the display turned on? */ | 31 | static bool display_on NOCACHEBSS_ATTR = false; /* Is the display turned on? */ |
32 | static unsigned lcd_yuv_options NOCACHEBSS_ATTR = 0; | ||
32 | 33 | ||
33 | /* Reverse Flag */ | 34 | /* Reverse Flag */ |
34 | #define R_DISP_CONTROL_NORMAL 0x0004 | 35 | #define R_DISP_CONTROL_NORMAL 0x0004 |
@@ -625,11 +626,22 @@ void lcd_blit(const fb_data* data, int x, int by, int width, | |||
625 | (void)stride; | 626 | (void)stride; |
626 | } | 627 | } |
627 | 628 | ||
629 | void lcd_yuv_set_options(unsigned options) | ||
630 | { | ||
631 | lcd_yuv_options = options; | ||
632 | } | ||
633 | |||
628 | /* Line write helper function for lcd_yuv_blit. Write two lines of yuv420. */ | 634 | /* Line write helper function for lcd_yuv_blit. Write two lines of yuv420. */ |
629 | extern void lcd_write_yuv420_lines(fb_data *dst, | 635 | extern void lcd_write_yuv420_lines(fb_data *dst, |
630 | unsigned char const * const src[3], | 636 | unsigned char const * const src[3], |
631 | int width, | 637 | int width, |
632 | int stride); | 638 | int stride); |
639 | extern void lcd_write_yuv420_lines_odither(fb_data *dst, | ||
640 | unsigned char const * const src[3], | ||
641 | int width, | ||
642 | int stride, | ||
643 | int x_screen, /* To align dither pattern */ | ||
644 | int y_screen); | ||
633 | /* Performance function to blit a YUV bitmap directly to the LCD */ | 645 | /* Performance function to blit a YUV bitmap directly to the LCD */ |
634 | /* For the e200 - show it rotated */ | 646 | /* For the e200 - show it rotated */ |
635 | /* So the LCD_WIDTH is now the height */ | 647 | /* So the LCD_WIDTH is now the height */ |
@@ -647,21 +659,38 @@ void lcd_yuv_blit(unsigned char * const src[3], | |||
647 | width &= ~1; | 659 | width &= ~1; |
648 | height >>= 1; | 660 | height >>= 1; |
649 | 661 | ||
662 | y = LCD_WIDTH - 1 - y; | ||
650 | fb_data *dst = (fb_data*)lcd_driver_framebuffer + | 663 | fb_data *dst = (fb_data*)lcd_driver_framebuffer + |
651 | x * LCD_WIDTH + (LCD_WIDTH - y) - 1; | 664 | x * LCD_WIDTH + y; |
652 | 665 | ||
653 | z = stride*src_y; | 666 | z = stride*src_y; |
654 | yuv_src[0] = src[0] + z + src_x; | 667 | yuv_src[0] = src[0] + z + src_x; |
655 | yuv_src[1] = src[1] + (z >> 2) + (src_x >> 1); | 668 | yuv_src[1] = src[1] + (z >> 2) + (src_x >> 1); |
656 | yuv_src[2] = src[2] + (yuv_src[1] - src[1]); | 669 | yuv_src[2] = src[2] + (yuv_src[1] - src[1]); |
657 | 670 | ||
658 | do | 671 | if (lcd_yuv_options & LCD_YUV_DITHER) |
672 | { | ||
673 | do | ||
674 | { | ||
675 | lcd_write_yuv420_lines_odither(dst, yuv_src, width, stride, y, x); | ||
676 | yuv_src[0] += stride << 1; /* Skip down two luma lines */ | ||
677 | yuv_src[1] += stride >> 1; /* Skip down one chroma line */ | ||
678 | yuv_src[2] += stride >> 1; | ||
679 | dst -= 2; | ||
680 | y -= 2; | ||
681 | } | ||
682 | while (--height > 0); | ||
683 | } | ||
684 | else | ||
659 | { | 685 | { |
660 | lcd_write_yuv420_lines(dst, yuv_src, width, stride); | 686 | do |
661 | yuv_src[0] += stride << 1; /* Skip down two luma lines */ | 687 | { |
662 | yuv_src[1] += stride >> 1; /* Skip down one chroma line */ | 688 | lcd_write_yuv420_lines(dst, yuv_src, width, stride); |
663 | yuv_src[2] += stride >> 1; | 689 | yuv_src[0] += stride << 1; /* Skip down two luma lines */ |
664 | dst -= 2; | 690 | yuv_src[1] += stride >> 1; /* Skip down one chroma line */ |
691 | yuv_src[2] += stride >> 1; | ||
692 | dst -= 2; | ||
693 | } | ||
694 | while (--height > 0); | ||
665 | } | 695 | } |
666 | while (--height > 0); | ||
667 | } | 696 | } |