diff options
| author | Jens Arnold <amiconn@rockbox.org> | 2010-06-04 21:12:06 +0000 |
|---|---|---|
| committer | Jens Arnold <amiconn@rockbox.org> | 2010-06-04 21:12:06 +0000 |
| commit | 081bda8ab258c763e654067740f365be68269340 (patch) | |
| tree | 6c259a698a78d16c967952c3c9fe5504e9b21bc4 | |
| parent | b91fa0425090536a254e25807e75ff624c07d503 (diff) | |
| download | rockbox-081bda8ab258c763e654067740f365be68269340.zip rockbox-081bda8ab258c763e654067740f365be68269340.tar.gz rockbox-081bda8ab258c763e654067740f365be68269340.tar.bz2 rockbox-081bda8ab258c763e654067740f365be68269340.tar.xz | |
Port greylib blitting optimisation to clipv1.
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@26557 a1c6a512-1295-4272-9138-f99709370657
| -rw-r--r-- | firmware/target/arm/as3525/sansa-clip/lcd-as-clip.S | 46 |
1 files changed, 17 insertions, 29 deletions
diff --git a/firmware/target/arm/as3525/sansa-clip/lcd-as-clip.S b/firmware/target/arm/as3525/sansa-clip/lcd-as-clip.S index 5a52eb0..942ddf7 100644 --- a/firmware/target/arm/as3525/sansa-clip/lcd-as-clip.S +++ b/firmware/target/arm/as3525/sansa-clip/lcd-as-clip.S @@ -56,42 +56,30 @@ lcd_grey_data: ldr lr, =DBOP_BASE .greyloop: - ldmia r1, {r3-r4} /* Fetch 8 pixel phases */ - ldmia r0!, {r5-r6} /* Fetch 8 pixel values */ - mov r7, #0 - - /* set bits 15..12 */ - tst r3, #0x80 - orrne r7, r7, #0x8000 - tst r3, #0x8000 - orrne r7, r7, #0x4000 - tst r3, #0x800000 - orrne r7, r7, #0x2000 - tst r3, #0x80000000 - orrne r7, r7, #0x1000 + ldmia r1, {r3-r4} + + and r5, r12, r3 @ r5 = 3.......2.......1.......0....... + and r6, r12, r4 @ r6 = 7.......6.......5.......4....... + orr r5, r5, r6, lsr #4 @ r5 = 3...7...2...6...1...5...0...4... + orr r5, r5, r5, lsr #9 @ r5 = 3...7...23..67..12..56..01..45.. + orr r5, r5, r5, lsr #9 @ r5 = 3...7...23..67..123.567.012.456. + orr r5, r5, r5, lsr #9 @ r5 = 3...7...23..67..123.567.01234567 + and r5, r5, #0xff + orr r5, r5, r5, lsl #8 @ post processing for clipv1 LCD */ + + ldmia r0!, {r6-r7} bic r3, r3, r12 - add r3, r3, r5 - - /* set bits 3..0 */ - tst r4, #0x80 - orrne r7, r7, #0x08 - tst r4, #0x8000 - orrne r7, r7, #0x04 - tst r4, #0x800000 - orrne r7, r7, #0x02 - tst r4, #0x80000000 - orrne r7, r7, #0x01 + add r3, r3, r6 bic r4, r4, r12 - add r4, r4, r6 - + add r4, r4, r7 stmia r1!, {r3-r4} - strh r7, [lr, #0x10] @ DBOP_DOUT + strh r5, [lr, #0x10] @ DBOP_DOUT 1: - ldr r5, [lr, #0xC] @ DBOP_STAT - ands r5, r5, #(1<<6) @ wait until push fifo is full + ldr r6, [lr, #0xC] @ DBOP_STAT + ands r6, r6, #(1<<6) @ wait until push fifo is full bne 1b subs r2, r2, #1 |