cemu_graphic_packs/Mods/BreathOfTheWild_FPS++/patches.txt
2018-12-29 10:27:11 +01:00

271 lines
13 KiB
Plaintext

[BotwFPSV208]
moduleMatches = 0x6267BFD0
#rodata constants
_float.5 = 0x100005E0
_float1 = 0x10000670
_float30 = 0x101E7964
_convSub = 0x10000BB0
_float32 = 0x1021FCEC
_arrowsDiv = 0x1001CCAC
_arrowsDer = 0x1001CB18
#TestCave
codeCaveSize = 0x12C
_fpsCalc = 0x00000010
0x00000000 = .float 2 ; Don't edit me!
_lowlimit = 0x00000000
0x00000004 = .float 62156250
_busSpeed = 0x00000004
_averageFPS = 0x00000008
_speedDiv = 0x0000000C
# HOW TO CHANGE AMOUNT OF FRAMES TO AVERAGE
0x00000128 = .float 32 #This float can be anything. To change the amount of frames averaged change this float...
_bufferSize = 0x00000128 #...and change the "0x84" on line 74 to this number times 4 plus 4 converted to hex.
#Example using 8 frames. 8 x 4 = 34. 34 + 4 = 38. In hex 0x26
#So line 74 would change from "cmpwi r12, 0x0C" to "cmpwi r12, 0x26"
0x00000010 = stw r0, 0x78(r30) #orig instruction we are replacing ;ticks between frame are currently in r12.
0x00000014 = xoris r12, r12, 0x8000 #flip the sign bit of int ticks for floating point conversion
0x00000018 = stw r12, 0xD4(r30) #store sign flipped ticks in memory as lower half of double
0x0000001C = lis r12, 0x4330 #create upper half of ticks double
0x00000020 = stw r12, 0xD0(r30) #store it in upper half of memory
0x00000024 = lfd f10, 0xD0(r30) #Load full double ticks into f10
0x00000028 = lis r12, _convSub@ha #load number to subtract from tick double...
0x0000002C = lfd f12, _convSub@l(r12) #...to create tick float into f12
0x00000030 = fsub f10, f10, f12 #Do the subtraction
0x00000034 = frsp f10, f10 #round to single precision and tick float is in f10
0x00000038 = lis r12, _float1@ha #Load float of 1...
0x0000003C = lfs f12, _float1@l(r12) #...into f12
0x00000040 = fdivs f10, f12, f10 #divide 1 by ticks
0x00000044 = lis r12, _busSpeed@ha #load wii u bus speed...
0x00000048 = lfs f12, _busSpeed@l(r12) #...into f12
0x0000004C = fmuls f10, f12, f10 #multiply bus speed to have current fps in f10. (1/ticks)*bus speed
0x00000050 = mr r3, r30 #Make a copy of r30 so we can screw around with it
0x00000054 = addi r3, r3, 0xE0 #Add offset to available memory space
0x00000058 = stw r3, 0xD8(r30) #Save our virgin memory address so we can retrieve it later
0x0000005C = lwz r12, 0xDC(r30) #load counter into r12
0x00000060 = add r3, r3, r12 #add our counter to the offset for our memory location
0x00000064 = stfsu f10, 0x04(r3) #store current fps to memory location +4 and update efective address into r3
0x00000068 = lfs f7, 0xE0(r30) #Load fpsSum into f7
0x0000006C = fadds f10, f10, f7 #Add currentFPS to fpsSum
0x00000070 = addi r12, r12, 0x04 #Incriment counter by 4
0x00000074 = cmpwi r12, 0x84 #Compare counter with 0x80(32 address from base memory location)
0x00000078 = bne .+0x0C #If we write our last current fps then
0x0000007C = lis r12, 0 #Zero our counter
0x00000080 = lwz r3, 0xD8(r30) #and reload our virgin memory offset
0x00000084 = stw r12, 0xDC(r30) #Store counter r12 to memory location
0x00000088 = lfs f7, 0x04(r3) #load oldest fps into f7
0x0000008C = fsubs f10, f10, f7 #Subtract oldest fps from fpsSum
0x00000090 = stfs f10, 0xE0(r30) #store fpsSum back into it's memory address.
0x00000094 = lis r12, _bufferSize@ha #load 32 as a float ...
0x00000098 = lfs f7, _bufferSize@l(r12) #...into f7
0x0000009C = fdivs f10, f10, f7 #divide fps sum by 32, the number of saved fps values, to get average fps over 32 frames
0x000000A0 = lis r12, _averageFPS@ha #Store averaged fps...
0x000000A4 = stfs f10, _averageFPS@l(r12) #... into _averageFPS variable.
0x000000A8 = lis r12, _float30@ha #Setting up speed diviser. 30/current fps = game speed. ex 30/60 = .5 game speed
0x000000AC = lfs f12, _float30@l(r12) #load float 30 into f12
0x000000B0 = fdivs f7, f12, f10 #do the division f10 is our current fps(now averaged)
0x000000B4 = lis r12, _lowlimit@ha #set up a low limit to not set game speed below. here: 10/30 = 3
0x000000B8 = lfs f12, _lowlimit@l(r12) #Set 3 as the low limit into f12
0x000000BC = lis r12, _speedDiv@ha #prepare to store game speed into _speedDiv but wait.
0x000000C0 = fcmpu cr0, f7, f12 #compare Compare lowlimit with current working game speed
0x000000C4 = bge .+0x08 #If game speed is not being set below 10 fps...
0x000000C8 = b .+0x08 #then skip the next line
0x000000CC = fmr f7, f12 #else overrite working current speed with low limit as new working current speed
0x000000D0 = stfs f7, _speedDiv@l(r12) #store working current speed into _speedDiv
0x000000D4 = lis r12, _float30@ha #An attempt to port arrow fix to fps++
0x000000D8 = lfs f12, _float30@l(r12) #load float30 into f12
0x000000DC = fmuls f10, f7, f12 #arrowsDiv = 30 * speedDiv
0x000000E0 = lis r12, _arrowsDiv@ha
0x000000E4 = stfs f10, _arrowsDiv@l(r12) #store the results
0x000000E8 = lis r12, _float.5@ha #load float of .5 into f12
0x000000EC = lfs f12, _float.5@l(r12)
0x000000F0 = fdivs f10, f12, f7 #arrowsDer = .5 / speedDiv
0x000000F4 = lis r12, _arrowsDer@ha
0x000000F8 = stfs f10, _arrowsDer@l(r12) #store the results
0x000000FC = blr #return
_fenceNeg1 = 0x00000100
0x00000100 = add r6, r12, r0 #orig instruction we are replacing
0x00000104 = cmpwi r6, 500 #check if less than 500 (full sync on those first frames to prevent milk water)
0x00000108 = blt .+0x08 #skip subtract if less than
0x0000010C = subi r6, r6, 1 #do the subtract
0x00000110 = blr #return
_arrowTimeDrain = 0x00000114
0x00000114 = lfs f1, 0xFC(r11)
0x00000118 = lis r12, _speedDiv@ha
0x0000011C = lfs f0, _speedDiv@l(r12)
0x00000120 = fmuls f1, f1, f0
0x00000124 = blr
#codeChanges
0x031FA97C = bla _fpsCalc
0x03793328 = nop
0x03793334 = nop
0x03793378 = lis r29, _speedDiv@ha
0x03793380 = lfs f0, _speedDiv@L(r29)
0x0379338C = nop
0x03415C1C = lis r12, _speedDiv@ha
0x03415C24 = lfs f0, _speedDiv@l(r12)
0x03415C2C = nop
0x02D90D2C = lis r10, _averageFPS@ha
0x02D90D30 = lfs f11, _averageFPS@l(r10)
0x02D90D88 = lis r10, _averageFPS@ha
0x02D90D8C = lfs f11, _averageFPS@l(r10)
0x02D5F760 = bla _arrowTimeDrain
0x037DC35C = lis r12, _speedDiv@ha #Audio fix
0x037DC360 = lfs f13, _speedDiv@l(r12)
0x037DBDF8 = lis r11, _speedDiv@ha
0x037DBDFC = lfs f31, _speedDiv@l(r11)
#break all forms of frame limiting
0x031FAAFC = bla _fenceNeg1 ;Best fence (make sure GPU is never more than 1 frame ahead)
;0x031FAAE8 = li r0, 1 ;Better fence (make sure GPU is never more than 1 second? ahead)
;0x031FAB00 = nop ; skip fence (no waiting on GPU)
0x031FACD0 = nop ; disable vsync
0x031FACF4 = nop ; disable vsync loop
[BotwFPSv176V192]
moduleMatches = 0xFD091F9F, 0xD472D8A5
# rodata constants
_float.5 = 0x100005E0
_float1 = 0x10000670
_float30 = 0x101E78F4
_float32 = 0x1025D1A8
_convSub = 0x10000BB0
_arrowsDiv = 0x1001CCAC
_arrowsDer = 0x1001CB18
#TestCave
codeCaveSize = 0x12C
_fpsCalc = 0x00000010
0x00000000 = .float 2 ; Don't edit me!
_lowlimit = 0x00000000
0x00000004 = .float 62156250
_busSpeed = 0x00000004
_averageFPS = 0x00000008
_speedDiv = 0x0000000C
# HOW TO CHANGE AMOUNT OF FRAMES TO AVERAGE
0x00000128 = .float 32 #This float can be anything. To change the amount of frames averaged change this float...
_bufferSize = 0x00000128 #...and change the "0x84" on line 74 to this number times 4 plus 4 converted to hex.
#Example using 8 frames. 8 x 4 = 34. 34 + 4 = 38. In hex 0x26
#So line 74 would change from "cmpwi r12, 0x0C" to "cmpwi r12, 0x26"
0x00000010 = stw r0, 0x78(r30) #orig instruction we are replacing ;ticks between frame are currently in r12.
0x00000014 = xoris r12, r12, 0x8000 #flip the sign bit of int ticks for floating point conversion
0x00000018 = stw r12, 0xD4(r30) #store sign flipped ticks in memory as lower half of double
0x0000001C = lis r12, 0x4330 #create upper half of ticks double
0x00000020 = stw r12, 0xD0(r30) #store it in upper half of memory
0x00000024 = lfd f10, 0xD0(r30) #Load full double ticks into f10
0x00000028 = lis r12, _convSub@ha #load number to subtract from tick double...
0x0000002C = lfd f12, _convSub@l(r12) #...to create tick float into f12
0x00000030 = fsub f10, f10, f12 #Do the subtraction
0x00000034 = frsp f10, f10 #round to single precision and tick float is in f10
0x00000038 = lis r12, _float1@ha #Load float of 1...
0x0000003C = lfs f12, _float1@l(r12) #...into f12
0x00000040 = fdivs f10, f12, f10 #divide 1 by ticks
0x00000044 = lis r12, _busSpeed@ha #load wii u bus speed...
0x00000048 = lfs f12, _busSpeed@l(r12) #...into f12
0x0000004C = fmuls f10, f12, f10 #multiply bus speed to have current fps in f10. (1/ticks)*bus speed
0x00000050 = mr r3, r30 #Make a copy of r30 so we can screw around with it
0x00000054 = addi r3, r3, 0xE0 #Add offset to available memory space
0x00000058 = stw r3, 0xD8(r30) #Save our virgin memory address so we can retrieve it later
0x0000005C = lwz r12, 0xDC(r30) #load counter into r12
0x00000060 = add r3, r3, r12 #add our counter to the offset for our memory location
0x00000064 = stfsu f10, 0x04(r3) #store current fps to memory location +4 and update efective address into r3
0x00000068 = lfs f7, 0xE0(r30) #Load fpsSum into f7
0x0000006C = fadds f10, f10, f7 #Add currentFPS to fpsSum
0x00000070 = addi r12, r12, 0x04 #Incriment counter by 4
0x00000074 = cmpwi r12, 0x84 #Compare counter with 0x84(32 address from base memory location)
0x00000078 = bne .+0x0C #If we write our last current fps then
0x0000007C = lis r12, 0 #Zero our counter
0x00000080 = lwz r3, 0xD8(r30) #and reload our virgin memory offset
0x00000084 = stw r12, 0xDC(r30) #Store counter r12 to memory location
0x00000088 = lfs f7, 0x04(r3) #load oldest fps into f7
0x0000008C = fsubs f10, f10, f7 #Subtract oldest fps from fpsSum
0x00000090 = stfs f10, 0xE0(r30) #store fpsSum back into it's memory address.
0x00000094 = lis r12, _float32@ha #load 32 as a float ...
0x00000098 = lfs f7, _float32@l(r12) #...into f7
0x0000009C = fdivs f10, f10, f7 #divide fps sum by 32, the number of saved fps values, to get average fps over 32 frames
0x000000A0 = lis r12, _averageFPS@ha #Store averaged fps...
0x000000A4 = stfs f10, _averageFPS@l(r12) #... into _averageFPS variable.
0x000000A8 = lis r12, _float30@ha #Setting up speed diviser. 30/current fps = game speed. ex 30/60 = .5 game speed
0x000000AC = lfs f12, _float30@l(r12) #load float 30 into f12
0x000000B0 = fdivs f7, f12, f10 #do the division f10 is our current fps(now averaged)
0x000000B4 = lis r12, _lowlimit@ha #set up a low limit to not set game speed below. here: 10/30 = 3
0x000000B8 = lfs f12, _lowlimit@l(r12) #Set 3 as the low limit into f12
0x000000BC = lis r12, _speedDiv@ha #prepare to store game speed into _speedDiv but wait.
0x000000C0 = fcmpu cr0, f7, f12 #compare Compare lowlimit with current working game speed
0x000000C4 = bge .+0x08 #If game speed is not being set below 10 fps...
0x000000C8 = b .+0x08 #then skip the next line
0x000000CC = fmr f7, f12 #else overrite working current speed with low limit as new working current speed
0x000000D0 = stfs f7, _speedDiv@l(r12) #store working current speed into _speedDiv
0x000000D4 = lis r12, _float30@ha #An attempt to port arrow fix to fps++
0x000000D8 = lfs f12, _float30@l(r12) #load float30 into f12
0x000000DC = fmuls f10, f7, f12 #arrowsDiv = 30 * speedDiv
0x000000E0 = lis r12, _arrowsDiv@ha
0x000000E4 = stfs f10, _arrowsDiv@l(r12) #store the results
0x000000E8 = lis r12, _float.5@ha #load float of .5 into f12
0x000000EC = lfs f12, _float.5@l(r12)
0x000000F0 = fdivs f10, f12, f7 #arrowsDer = .5 / speedDiv
0x000000F4 = lis r12, _arrowsDer@ha
0x000000F8 = stfs f10, _arrowsDer@l(r12) #store the results
0x000000FC = blr #return
_fenceNeg1 = 0x00000100
0x00000100 = add r6, r12, r0 #orig instruction we are replacing
0x00000104 = cmpwi r6, 500 #check if less than 500 (full sync on those first frames to prevent milk water)
0x00000108 = blt .+0x08 #skip subtract if less than
0x0000010C = subi r6, r6, 1 #do the subtract
0x00000110 = blr #return
_arrowTimeDrain = 0x00000114
0x00000114 = lfs f1, 0xFC(r11)
0x00000118 = lis r12, _speedDiv@ha
0x0000011C = lfs f0, _speedDiv@l(r12)
0x00000120 = fmuls f1, f1, f0
0x00000124 = blr
#codeChanges
0x031F9E80 = bla _fpsCalc
0x03792620 = nop
0x0379262C = nop
0x03792670 = lis r29, _speedDiv@ha
0x03792678 = lfs f0, _speedDiv@l(r29)
0x03792684 = nop
0x03414EF8 = lis r12, _speedDiv@ha
0x03414F00 = lfs f0, _speedDiv@l(r12)
0x03414F08 = nop
0x02D90790 = lis r10, _averageFPS@ha
0x02D90794 = lfs f11, _averageFPS@l(r10)
0x02D907EC = lis r10, _averageFPS@ha
0x02D907F0 = lfs f11, _averageFPS@l(r10)
0x02D5F200 = bla _arrowTimeDrain
# Break all forms of frame limiting
0x031FA000 = bla _fenceNeg1
;0x031F9FEC = li r0, 1
;0x031FA004 = nop
0x031FA1D4 = nop
0x031FA1F8 = nop