32x: final renderer tweaks; PWM disable kills PWM irqs

git-svn-id: file:///home/notaz/opt/svn/PicoDrive@857 be3aeb3a-fb24-0410-a615-afba39da0efa
This commit is contained in:
notaz 2010-01-12 13:35:52 +00:00
parent e51e5983fe
commit 07e5dbab71
6 changed files with 135 additions and 39 deletions

View file

@ -52,7 +52,7 @@ static void convert_pal555(int invert_prio)
int i; \ int i; \
for (i = 320; i > 0; i--, pd++, p32x++, pmd++) { \ for (i = 320; i > 0; i--, pd++, p32x++, pmd++) { \
t = pal[*(unsigned char *)((long)p32x ^ 1)]; \ t = pal[*(unsigned char *)((long)p32x ^ 1)]; \
if (*pmd == mdbg || (t & 0x20)) \ if ((t & 0x20) || *pmd == mdbg) \
*pd = t; \ *pd = t; \
else \ else \
pmd_draw_code; \ pmd_draw_code; \

View file

@ -122,28 +122,8 @@ Pico32xNativePal:
@ packed pixel @ packed pixel
.macro do_pixel_pp do_md @ note: this may read a few bytes over the end of PicoDraw2FB and dram,
ldrb r7, [r11], #1 @ MD pixel @ so those should have a bit more alloc'ed than really needed.
eor r12,r5, #1
ldrb r8, [r12] @ palette index
cmp r7, r3 @ MD has bg pixel?
mov r12,r8,lsl #1
ldrh r8, [r10,r12] @ t = 32x pixel
mov r7, r7, lsl #1
add r5, r5, #1
eorne r12,r8, #0x20
tstne r12, #0x20
.if \do_md
ldrneh r8, [r9, r7] @ t = palmd[*pmd]
subs r6, r6, #1
strh r8, [r0], #2 @ *dst++ = t
.else
streqh r8, [r0], #2
addne r0, r0, #2
subs r6, r6, #1
.endif
.endm
@ unsigned short *dst, unsigned short *dram, int lines_sft_offs, int mdbg @ unsigned short *dst, unsigned short *dram, int lines_sft_offs, int mdbg
.macro make_do_loop_pp name call_scan do_md .macro make_do_loop_pp name call_scan do_md
.global \name .global \name
@ -173,16 +153,128 @@ Pico32xNativePal:
mov r12,r4, lsl #1 mov r12,r4, lsl #1
ldrh r12,[r1, r12] ldrh r12,[r1, r12]
add r11,r11,#8 add r11,r11,#8
mov r6, #320 mov r6, #320/2
add r5, r1, r12, lsl #1 @ p32x = dram + dram[l] add r5, r1, r12, lsl #1 @ p32x = dram + dram[l]
and r12,r2, #0x100 @ shift and r12,r2, #0x100 @ shift
add r5, r5, r12,lsr #8 add r5, r5, r12,lsr #8
2: @ loop_inner: 2: @ loop_inner:
do_pixel_pp \do_md @ r4,r6 - counters; r5 - 32x data; r9,r10 - md,32x pal; r11 - md data
do_pixel_pp \do_md @ r7,r8,r12,lr - temp
bgt 2b @ loop_inner tst r5, #1
b 0b @ loop_outer ldreqb r8, [r5], #2
ldrb r7, [r5, #-1]
ldrneb r8, [r5, #2]! @ r7,r8 - pixel 0,1 index
subs r6, r6, #1
blt 0b @ loop_outer
cmp r7, r8
beq 5f @ check_fill @ +8
3: @ no_fill:
mov r12,r7, lsl #1
mov lr, r8, lsl #1
ldrh r7, [r10,r12]
ldrh r8, [r10,lr]
add r11,r11,#2
eor r12,r7, #0x20
tst r12,#0x20
ldrneb r12,[r11,#-2] @ MD pixel 0
eor lr, r8, #0x20
cmpne r12,r3 @ MD has bg pixel?
.if \do_md
mov r12,r12,lsl #1
ldrneh r7, [r9, r12] @ t = palmd[pmd[0]]
tst lr, #0x20
ldrneb lr, [r11,#-1] @ MD pixel 1
strh r7, [r0], #2
cmpne lr, r3 @ MD has bg pixel?
mov lr, lr, lsl #1
ldrneh r8, [r9, lr] @ t = palmd[pmd[1]]
strh r8, [r0], #2
.else
streqh r7, [r0]
tst lr, #0x20
ldrneb lr, [r11,#-1] @ MD pixel 1
add r0, r0, #4
cmpne lr, r3 @ MD has bg pixel?
streqh r8, [r0, #-2]
.endif
b 2b @ loop_inner
5: @ check_fill
@ count pixels, align if needed
bic r12,r5, #1
ldrh r12,[r12]
orr lr, r7, r7, lsl #8
cmp r12,lr
bne 3b @ no_fill
tst r5, #1
sub lr, r5, #2 @ starting r5 (32x render data start)
addeq r5, r5, #2
addne r5, r5, #1 @ add for the check above
add r6, r6, #1 @ restore from dec
orr r7, r7, r7, lsl #8
6:
sub r12,r5, lr
ldrh r8, [r5], #2
cmp r12,r6, lsl #1
ldrh r12,[r5], #2
bge 7f @ count_done
cmp r8, r7
cmpeq r12,r7
beq 6b
7: @ count_done
sub r5, r5, #4 @ undo readahead
@ fix alignment and check type
sub r8, r5, lr
tst r8, #1
subne r5, r5, #1
subne r8, r8, #1
and r7, r7, #0xff
cmp r8, r6, lsl #1
mov r7, r7, lsl #1
movgt r8, r6, lsl #1 @ r8=count
ldrh r7, [r10,r7]
sub r6, r6, r8, lsr #1 @ adjust counter
tst r7, #0x20
beq 9f @ bg_mode
add r11,r11,r8
8:
subs r8, r8, #2
strgeh r7, [r0], #2
strgeh r7, [r0], #2
bgt 8b
b 2b @ loop_inner
9: @ bg_mode:
ldrb r12,[r11],#1 @ MD pixel
ldrb lr, [r11],#1
cmp r12,r3 @ MD has bg pixel?
.if \do_md
mov r12,r12,lsl #1
ldrneh r12,[r9, r12] @ t = palmd[*pmd]
moveq r12,r7
cmp lr, r3
mov lr, lr, lsl #1
ldrneh lr, [r9, lr]
moveq lr, r7
strh r12,[r0], #2
strh lr, [r0], #2
.else
streqh r7, [r0]
cmp lr, r3
streqh r7, [r0, #2]
add r0, r0, #4
.endif
subs r8, r8, #2
bgt 9b @ bg_mode
b 2b @ loop_inner
.endm .endm

View file

@ -50,6 +50,9 @@ void p32x_timers_recalc(void)
void p32x_timers_do(int new_line) void p32x_timers_do(int new_line)
{ {
int tm, cnt, i; int tm, cnt, i;
if (PicoOpt & POPT_EN_PWM)
{
tm = (Pico32x.regs[0x30 / 2] & 0x0f00) >> 8; tm = (Pico32x.regs[0x30 / 2] & 0x0f00) >> 8;
if (tm != 0) { if (tm != 0) {
if (new_line) if (new_line)
@ -60,6 +63,7 @@ void p32x_timers_do(int new_line)
p32x_update_irls(); p32x_update_irls();
} }
} }
}
if (!new_line) if (!new_line)
return; return;

View file

@ -1476,6 +1476,7 @@ void emu_loop(void)
} }
bench_fps += frames_shown; bench_fps += frames_shown;
sprintf(fpsbuff, "%02i/%02i/%02i", frames_shown, bench_fps_s, (bf[0]+bf[1]+bf[2]+bf[3])>>2); sprintf(fpsbuff, "%02i/%02i/%02i", frames_shown, bench_fps_s, (bf[0]+bf[1]+bf[2]+bf[3])>>2);
printf("%s\n", fpsbuff);
#else #else
if (currentConfig.EmuOpt & EOPT_SHOW_FPS) { if (currentConfig.EmuOpt & EOPT_SHOW_FPS) {
sprintf(fpsbuff, "%02i/%02i", frames_shown, frames_done); sprintf(fpsbuff, "%02i/%02i", frames_shown, frames_done);

View file

@ -30,8 +30,6 @@
#include <pico/sound/mix.h> #include <pico/sound/mix.h>
#include <zlib/zlib.h> #include <zlib/zlib.h>
//#define PFRAMES
#ifdef BENCHMARK #ifdef BENCHMARK
#define OSD_FPS_X 220 #define OSD_FPS_X 220
#else #else

View file

@ -20,7 +20,8 @@
#define CAN_HANDLE_240_LINES 1 #define CAN_HANDLE_240_LINES 1
// logging emu events // logging emu events
#define EL_LOGMASK (EL_STATUS|EL_IDLE) // (EL_STATUS|EL_ANOMALY|EL_UIO|EL_SRAMIO|EL_INTS|EL_CDPOLL) // xffff #define EL_LOGMASK (EL_STATUS)
// (EL_STATUS|EL_ANOMALY|EL_UIO|EL_SRAMIO|EL_INTS|EL_CDPOLL|EL_IDLE)
//#define dprintf(f,...) printf("%05i:%03i: " f "\n",Pico.m.frame_count,Pico.m.scanline,##__VA_ARGS__) //#define dprintf(f,...) printf("%05i:%03i: " f "\n",Pico.m.frame_count,Pico.m.scanline,##__VA_ARGS__)
#define dprintf(x...) #define dprintf(x...)