Merge pull request #7524 from TryTwo/master

Fix Gecko codehandler lag
This commit is contained in:
Pierre Bourdon 2018-10-31 00:33:27 +01:00 committed by GitHub
commit 5508082345
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 72 additions and 60 deletions

Binary file not shown.

View File

@ -43,6 +43,8 @@ cheatdata:
.long frozenvalue .long frozenvalue
.space 39*4 .space 39*4
# Warning, _strip_and_align expects cheat codes to start on 0x0 or 0x8.
# Properly compiling it will add a nop if needed.
_start: _start:
stwu r1,-172(r1) # stores sp stwu r1,-172(r1) # stores sp
stw r0,8(r1) # stores r0 stw r0,8(r1) # stores r0
@ -150,7 +152,7 @@ _readcodes:
andis. r11,r3,0x1000 #test pointer andis. r11,r3,0x1000 #test pointer
rlwinm r3,r3,0,7,31 #r3 = extract address in r3 (code type 0/1/2) #0x01FFFFFF rlwinm r3,r3,0,7,31 #r3 = extract address in r3 (code type 0/1/2) #0x01FFFFFF
bne +12 #jump lf the pointer is used bne +12 #jump lf the pointer is used
rlwinm r12,r6,0,0,6 #lf pointer is not used, address = base address rlwinm r12,r6,0,0,6 #lf pointer is not used, address = base address
@ -178,6 +180,33 @@ _readcodes:
b _terminator_onoff_ #code type 7 : End of code list b _terminator_onoff_ #code type 7 : End of code list
_Write_32:
lwz r18, 0(r12) #Load data from registry that will be written to
cmpw r18, r5 #Is data to be written equal to the data in memory
beq+ +72 #Skip if yes
stw r5, 0(r12) #store opcode
li r9, 0 #safe, check r9 if more write_32's are linked.
b +48
_Write_08x:
lbzx r18, r9, r12
rlwinm r0, r4, 0, 24,31 #Clears any other data with r4's byte, for compare
cmpw r0, r18
beq+ +44
stbx r4,r9,r12
b +24
_Write_16x:
lhzx r18, r9, r12
rlwinm r0, r4, 0, 16,31 #Makes sure r4 is just a halfword for compare
cmpw r0, r18
beq+ +20
sthx r4,r9,r12
icbi r9, r12 #branch target. Clears cache. Need dcbf?
sync
isync
blr
#CT0============================================================================= #CT0=============================================================================
#write 8bits (0): 00XXXXXX YYYY00ZZ #write 8bits (0): 00XXXXXX YYYY00ZZ
#write 16bits (1): 02XXXXXX YYYYZZZZ #write 16bits (1): 02XXXXXX YYYYZZZZ
@ -201,45 +230,34 @@ _write:
rlwinm r10,r4,16,16,31 #r10 = extract number of times to write (16bits value) rlwinm r10,r4,16,16,31 #r10 = extract number of times to write (16bits value)
_write816: _write816:
beq cr4,+32 #lf r5 = 1 then 16 bits write beq cr4,+16 #lf r5 = 1 then 16 bits write
stbx r4,r9,r12 #write byte bl _Write_08x
add r21, r9, r12
icbi r0, r21
sync
isync
addi r9,r9,1 addi r9,r9,1
b +28 b +12
sthx r4,r9,r12 #write halfword bl _Write_16x
add r21, r9, r12 #Get Real Memory Offset addi r9, r9, 2
icbi r0, r21 #Invalidate Icache around real memory offset
sync
isync
addi r9,r9,2
subic. r10,r10,1 #number of times to write -1 subic. r10,r10,1 #number of times to write -1
bge- _write816 bge- _write816
b _readcodes b _readcodes
_write32: _write32:
rlwinm r12,r12,0,0,29 #32bits align adress rlwinm r12,r12,0,0,29 #32bits align adress
stw r4,0(r12) #write word to address mr r5, r4
icbi r0, r12 #Invalidate icache around address bl _Write_32
sync
isync
b _readcodes b _readcodes
_write_string: #endianess ? _write_string: #endianess ?
mr r9,r4 mr r9,r4
mr r22, r4
bne- cr7,_skip_and_align #lf code execution is false, skip string code data bne- cr7,_skip_and_align #lf code execution is false, skip string code data
_stb: _stb:
subic. r9,r9,1 #r9 -= 1 (and compares r9 with 0) subic. r9,r9,1 #r9 -= 1 (and compares r9 with 0)
blt- _skip_and_align #lf r9 < 0 then exit blt- _skip_and_align #lf r9 < 0 then exit
lbzx r5,r9,r15 lbzx r5,r9,r15
stbx r5,r9,r12 #loop until all the data has been written mr r4, r5
add r21, r9, r12 #Get Real Memory Offset bl _Write_08x #loop until all the data has been written
icbi r0, r21 #Invalidate Icache around real memory offset mr r4, r22
sync
isync
b _stb b _stb
_write_serial: _write_serial:
@ -259,15 +277,17 @@ _loop_serial:
beq- cr5,+16 #lf 16bits beq- cr5,+16 #lf 16bits
bgt+ cr5,+20 #lf 32bits bgt+ cr5,+20 #lf 32bits
stbx r4,r9,r12 #write serial byte (CT04,T=0) bl _Write_08x
b +16 b +40
sthx r4,r9,r12 #write serial halfword (CT04,T=1)
b +8
bl _Write_16x #write serial halfword (CT04,T=1)
b +32
lwzx r18, r9, r12
cmpw r4, r18
beq+ +20
stwx r4,r9,r12 #write serial word (CT04,T>=2) stwx r4,r9,r12 #write serial word (CT04,T>=2)
add r21, r9, r12 #Get Real Memory Offset icbi r9, r12 #Invalidate Icache around real memory offset
icbi r0, r21 #Invalidate Icache around real memory offset
sync sync
isync isync
add r4,r4,r11 #value +=VVVVVVVV add r4,r4,r11 #value +=VVVVVVVV
@ -560,35 +580,36 @@ _load:
bgt+ cr6,+24 bgt+ cr6,+24
beq- cr6,+12 beq- cr6,+12
lbz r4,0(r4) #load byte at address lbz r4,0(r12) #load byte at address
b _store_reg b _store_reg
lhz r4,0(r4) #load halfword at address lhz r4,0(r12) #load halfword at address
b _store_reg b _store_reg
lwz r4,0(r4) #load word at address lwz r4,0(r12) #load word at address
b _store_reg b _store_reg
_store: _store:
rlwinm r19,r3,28,20,31 #r9=r3 ror 12 (N84UYZZZ) rlwinm r19,r3,28,20,31 #r9=r3 ror 12 (N84UYZZZ)
mr r12, r4
mr r4, r9
mr r5, r9
li r9, 0
_storeloop: _storeloop:
bgt+ cr6,+32 bgt+ cr6,+32
beq- cr6,+16 beq- cr6,+16
stb r9,0(r4) #store byte at address bl _Write_08x #store byte at address
addi r4,r4,1 addi r12,r12,1
b _storeloopend b _storeloopend
sth r9,0(r4) #store byte at address bl _Write_16x #store byte at address
addi r4,r4,2 addi r12,r12,2
b _storeloopend b _storeloopend
stw r9,0(r4) #store byte at address bl _Write_32
icbi r0, r4 #Invalidate at offset given by storing gecko register addi r12,r12,4
sync
isync
addi r4,r4,4
_storeloopend: _storeloopend:
subic. r19,r19,1 subic. r19,r19,1
bge _storeloop bge _storeloop
@ -793,14 +814,14 @@ _compare16_counter:
b _conditional b _conditional
#=============================================================================== #===============================================================================
#execute (0) : C0000000 NNNNNNNN = execute #execute (0) : C0000000 NNNNNNNN = execute. End with 4E800020 00000000.
#hook1 (2) : C4XXXXXX NNNNNNNN = insert instructions at XXXXXX #hook1 (2) : C4XXXXXX NNNNNNNN = insert instructions at XXXXXX. Same as C2.
#hook2 (3) : C6XXXXXX YYYYYYYY = branch from XXXXXX to YYYYYY #hook2 (3) : C6XXXXXX YYYYYYYY = branch from XXXXXX to YYYYYY
#on/off (6) : CC000000 00000000 = on/off switch #on/off (6) : CC000000 00000000 = on/off switch
#range check (7) : CE000000 XXXXYYYY = is ba/po in XXXX0000-YYYY0000 #range check (7) : CE000000 XXXXYYYY = is ba/po in XXXX0000-YYYY0000
_hook_execute: _hook_execute:
mr r26,r4 #r18 = 0YYYYYYY mr r26,r4 #r26 = 0YYYYYYY
rlwinm r4,r4,3,0,28 #r4 = NNNNNNNN*8 = number of lines (and not number of bytes) rlwinm r4,r4,3,0,28 #r4 = NNNNNNNN*8 = number of lines (and not number of bytes)
bne- cr4,_hook_addresscheck #lf sub code type != 0 bne- cr4,_hook_addresscheck #lf sub code type != 0
bne- cr7,_skip_and_align bne- cr7,_skip_and_align
@ -815,7 +836,6 @@ _skip_and_align:
rlwinm r15,r15,0,0,28 #align 64-bit rlwinm r15,r15,0,0,28 #align 64-bit
b _readcodes b _readcodes
_hook_addresscheck: _hook_addresscheck:
cmpwi cr4,r5,3 cmpwi cr4,r5,3
@ -834,10 +854,7 @@ _hook2:
sub r4,r4,r12 #r4 = to-from sub r4,r4,r12 #r4 = to-from
rlwimi r5,r4,0,6,29 #r5 = (r4 AND 0x03FFFFFC) OR 0x48000000 rlwimi r5,r4,0,6,29 #r5 = (r4 AND 0x03FFFFFC) OR 0x48000000
rlwimi r5,r3,0,31,31 #restore lr bit rlwimi r5,r3,0,31,31 #restore lr bit
stw r5,0(r12) #store opcode bl _Write_32
icbi r0, r12 #Invalidate at branch
sync
isync
b _readcodes b _readcodes
_hook1: _hook1:
@ -845,19 +862,14 @@ _hook1:
sub r9,r15,r12 #r9 = to-from sub r9,r15,r12 #r9 = to-from
rlwimi r5,r9,0,6,29 #r5 = (r9 AND 0x03FFFFFC) OR 0x48000000 rlwimi r5,r9,0,6,29 #r5 = (r9 AND 0x03FFFFFC) OR 0x48000000
stw r5,0(r12) #stores b at the hook place (over original instruction) bl _Write_32
icbi r0, r12 #Invalidate at hook location
sync
isync
addi r12,r12,4 addi r12,r12,4
add r11,r15,r4 add r11,r15,r4
subi r11,r11,4 #r11 = address of the last word of the hook1 code subi r11,r11,4 #r11 = address of the last word of the hook1 code
sub r9,r12,r11 sub r9,r12,r11
rlwimi r5,r9,0,6,29 #r5 = (r9 AND 0x03FFFFFC) OR 0x48000000 rlwimi r5,r9,0,6,29 #r5 = (r9 AND 0x03FFFFFC) OR 0x48000000
stw r5,0(r11) #stores b at the last word of the hook1 code mr r12, r11
icbi r0, r12 #Invalidate at last instruction of hook bl _Write_32
sync
isync
b _skip_and_align b _skip_and_align
_addresscheck1: _addresscheck1:
@ -1045,4 +1057,4 @@ regbuffer:
codelist: codelist:
.space 2*4 .space 2*4
.end .end