mirror of
https://github.com/RaySollium99/picodrive.git
synced 2025-09-05 07:17:45 -04:00
idle loop detection (Cyclone only, with debug stuff)
git-svn-id: file:///home/notaz/opt/svn/PicoDrive@502 be3aeb3a-fb24-0410-a615-afba39da0efa
This commit is contained in:
parent
d95259bdaa
commit
053fd9b42f
17 changed files with 372 additions and 37 deletions
180
cpu/Cyclone/tools/idle.s
Normal file
180
cpu/Cyclone/tools/idle.s
Normal file
|
@ -0,0 +1,180 @@
|
|||
@ vim:filetype=armasm
|
||||
|
||||
@ ranges/opcodes (idle, normal):
|
||||
@ 71xx, 73xx - bne.s (8bit offset)
|
||||
@ 75xx, 77xx - beq.s (8bit offset)
|
||||
@ 7dxx, 7fxx - bra.s (8bit offset)
|
||||
|
||||
.data
|
||||
.align 2
|
||||
|
||||
have_patches:
|
||||
.word 0
|
||||
|
||||
.equ patch_desc_table_size, 10
|
||||
|
||||
patch_desc_table:
|
||||
.word (0x71fa<<16) | 0x66fa, idle_detector_bcc8, idle_bne, Op6601 @ bne.s
|
||||
.word (0x71f8<<16) | 0x66f8, idle_detector_bcc8, idle_bne, Op6601 @ bne.s
|
||||
.word (0x71f6<<16) | 0x66f6, idle_detector_bcc8, idle_bne, Op6601 @ bne.s
|
||||
.word (0x71f2<<16) | 0x66f2, idle_detector_bcc8, idle_bne, Op6601 @ bne.s
|
||||
.word (0x75fa<<16) | 0x67fa, idle_detector_bcc8, idle_beq, Op6701 @ beq.s
|
||||
.word (0x75f8<<16) | 0x67f8, idle_detector_bcc8, idle_beq, Op6701 @ beq.s
|
||||
.word (0x75f6<<16) | 0x67f6, idle_detector_bcc8, idle_beq, Op6701 @ bne.s
|
||||
.word (0x75f2<<16) | 0x67f2, idle_detector_bcc8, idle_beq, Op6701 @ bne.s
|
||||
.word (0x7dfe<<16) | 0x60fe, idle_detector_dead, idle_bra, Op6001 @ bra.s
|
||||
.word (0x7dfc<<16) | 0x60fc, idle_detector_dead, idle_bra, Op6001 @ bra.s
|
||||
|
||||
|
||||
.text
|
||||
.align 2
|
||||
|
||||
|
||||
.global CycloneInitIdle
|
||||
|
||||
CycloneInitIdle:
|
||||
ldr r3, =CycloneJumpTab
|
||||
ldr r2, =patch_desc_table
|
||||
mov r12,#patch_desc_table_size
|
||||
|
||||
cii_loop:
|
||||
ldrh r0, [r2]
|
||||
ldr r1, [r2, #4] @ detector
|
||||
str r1, [r3, r0, lsl #2]
|
||||
ldrh r0, [r2, #2]
|
||||
ldr r1, [r2, #8] @ idle
|
||||
add r0, r3, r0, lsl #2
|
||||
str r1, [r0]
|
||||
ldr r1, [r2, #12] @ normal
|
||||
str r1, [r0, #0x800]
|
||||
add r2, r2, #16
|
||||
subs r12,r12,#1
|
||||
bgt cii_loop
|
||||
|
||||
ldr r0, =have_patches
|
||||
mov r1, #1
|
||||
str r1, [r0]
|
||||
bx lr
|
||||
|
||||
|
||||
.global CycloneFinishIdle
|
||||
|
||||
CycloneFinishIdle:
|
||||
ldr r0, =have_patches
|
||||
ldr r0, [r0]
|
||||
tst r0, r0
|
||||
bxeq lr
|
||||
|
||||
ldr r3, =CycloneJumpTab
|
||||
ldr r2, =patch_desc_table
|
||||
mov r12,#patch_desc_table_size
|
||||
|
||||
cfi_loop:
|
||||
ldrh r0, [r2]
|
||||
ldr r1, [r2, #12] @ normal
|
||||
str r1, [r3, r0, lsl #2]
|
||||
ldrh r0, [r2, #2]
|
||||
ldr r1, =Op____
|
||||
add r0, r3, r0, lsl #2
|
||||
str r1, [r0]
|
||||
str r1, [r0, #0x800]
|
||||
add r2, r2, #16
|
||||
subs r12,r12,#1
|
||||
bgt cfi_loop
|
||||
|
||||
ldr r0, =have_patches
|
||||
mov r1, #0
|
||||
str r1, [r0]
|
||||
bx lr
|
||||
|
||||
|
||||
|
||||
.macro inc_counter cond
|
||||
ldr r0, =idle_hit_counter
|
||||
ldr r1, [r0]
|
||||
add r1, r1, #1
|
||||
str\cond r1, [r0]
|
||||
.endm
|
||||
|
||||
idle_bra:
|
||||
mov r5, #4
|
||||
inc_counter
|
||||
b Op6001
|
||||
|
||||
idle_bne:
|
||||
msr cpsr_flg, r10 ;@ ARM flags = 68000 flags
|
||||
movne r5, #4
|
||||
inc_counter ne
|
||||
b Op6601
|
||||
|
||||
idle_beq:
|
||||
msr cpsr_flg, r10 ;@ ARM flags = 68000 flags
|
||||
moveq r5, #4
|
||||
inc_counter eq
|
||||
b Op6701
|
||||
|
||||
|
||||
@ @@@ @
|
||||
|
||||
idle_detector_bcc8:
|
||||
ldr r0, =(Pico+0x22208) @ Pico.m
|
||||
ldr r1, =idledet_start_frame
|
||||
ldr r0, [r0, #0x1c] @ ..frame_count
|
||||
ldr r1, [r1]
|
||||
cmp r0, r1
|
||||
blt exit_detector @ not yet
|
||||
|
||||
mov r0, r8, asl #24 @ Shift 8-bit signed offset up...
|
||||
add r0, r4, r0, asr #24 @ jump dest
|
||||
bic r0, r0, #1
|
||||
|
||||
mov r1, #0
|
||||
sub r1, r1, r8, lsl #24
|
||||
mov r1, r1, lsr #24
|
||||
sub r1, r1, #2
|
||||
|
||||
bl SekIsIdleCode
|
||||
tst r0, r0
|
||||
and r2, r8, #0x00ff
|
||||
orr r2, r2, #0x7100
|
||||
orreq r2, r2, #0x0200
|
||||
tst r8, #0x0100 @ 67xx (beq)?
|
||||
orrne r2, r2, #0x0400
|
||||
|
||||
@ r2 = patch_opcode
|
||||
sub r0, r4, #2
|
||||
ldrh r1, [r0]
|
||||
mov r11,r2
|
||||
bl SekRegisterIdlePatch
|
||||
cmp r0, #1 @ 0 - ok to patch, 1 - no patch, 2 - remove detector
|
||||
strlth r11,[r4, #-2]
|
||||
ble exit_detector
|
||||
|
||||
@ remove detector from Cyclone
|
||||
tst r8, #0x0100 @ 67xx (beq)?
|
||||
ldreq r1, =Op6601
|
||||
ldrne r1, =Op6701
|
||||
|
||||
ldr r3, =CycloneJumpTab
|
||||
str r1, [r3, r8, lsl #2]
|
||||
bx r1
|
||||
|
||||
exit_detector:
|
||||
tst r8, #0x0100 @ 67xx (beq)?
|
||||
beq Op6601
|
||||
b Op6701
|
||||
|
||||
|
||||
idle_detector_dead:
|
||||
@ patch without further questions
|
||||
and r2, r8, #0x00ff
|
||||
orr r2, r2, #0x7d00
|
||||
sub r0, r4, #2
|
||||
ldrh r1, [r0]
|
||||
mov r11,r2
|
||||
bl SekRegisterIdlePatch
|
||||
strh r11,[r4, #-2]
|
||||
b Op6001
|
||||
|
||||
.pool
|
||||
|
Loading…
Add table
Add a link
Reference in a new issue