Difference between revisions of "00012d40 - 00012e78"

From Final Fantasy Hacktics Wiki
Jump to navigation Jump to search
(Created page with "<font face='Courier New'> 00012d40: 3c038003 lui r3,0x8003 00012d44: 8c632a60 lw r3,0x2a60(r3) 00012d48: 00004821 addu r9,r0,r0 00012d4c: 00005021 addu r10,r0,r0 00012d...")
 
m (not done yet, no leads :/)
Line 2: Line 2:
 
   
 
   
 
  00012d40: 3c038003 lui r3,0x8003
 
  00012d40: 3c038003 lui r3,0x8003
  00012d44: 8c632a60 lw r3,0x2a60(r3)
+
  00012d44: 8c632a60 lw r3,0x2a60(r3) #load ? (pointer?)
 
  00012d48: 00004821 addu r9,r0,r0
 
  00012d48: 00004821 addu r9,r0,r0
 
  00012d4c: 00005021 addu r10,r0,r0
 
  00012d4c: 00005021 addu r10,r0,r0
 
  00012d50: 34070001 ori r7,r0,0x0001
 
  00012d50: 34070001 ori r7,r0,0x0001
 
  00012d54: 34080008 ori r8,r0,0x0008
 
  00012d54: 34080008 ori r8,r0,0x0008
  00012d58: 246600b8 addiu r6,r3,0x00b8
+
  00012d58: 246600b8 addiu r6,r3,0x00b8 #pointer + 0xb8
  00012d5c: 246300ec addiu r3,r3,0x00ec
+
  00012d5c: 246300ec addiu r3,r3,0x00ec #P + 0xec
  00012d60: 94c20000 lhu r2,0x0000(r6)
+
  00012d60: 94c20000 lhu r2,0x0000(r6)
 
  00012d64: 00000000 nop
 
  00012d64: 00000000 nop
 
  00012d68: 30420001 andi r2,r2,0x0001
 
  00012d68: 30420001 andi r2,r2,0x0001
  00012d6c: 10400009 beq r2,r0,0x00012d94
+
  00012d6c: 10400009 beq r2,r0,0x00012d94 #branch if flag 1 not enabled?
  00012d70: 2508ffff addiu r8,r8,0xffff
+
  00012d70: 2508ffff addiu r8,r8,0xffff #-1
 
  00012d74: 8c62ffd4 lw r2,-0x002c(r3)
 
  00012d74: 8c62ffd4 lw r2,-0x002c(r3)
 
  00012d78: 00000000 nop
 
  00012d78: 00000000 nop
  00012d7c: 14440005 bne r2,r4,0x00012d94
+
  00012d7c: 14440005 bne r2,r4,0x00012d94 #branch if item from r3 pointer? does not equal input from animation instruction?
 
  00012d80: 00000000 nop
 
  00012d80: 00000000 nop
 
  00012d84: 8c620000 lw r2,0x0000(r3)
 
  00012d84: 8c620000 lw r2,0x0000(r3)
  00012d88: 01475025 or r10,r10,r7
+
  00012d88: 01475025 or r10,r10,r7 #r10 = flags for all input != r2?
  00012d8c: a4c00000 sh r0,0x0000(r6)
+
  00012d8c: a4c00000 sh r0,0x0000(r6) #store 0 here
  00012d90: 01224825 or r9,r9,r2
+
  00012d90: 01224825 or r9,r9,r2 #bitflag combine r9 and r2
  00012d94: 00073840 sll r7,r7,0x01
+
  00012d94: 00073840 sll r7,r7,0x01 #next flag to append to r10?
  00012d98: 24630160 addiu r3,r3,0x0160
+
  00012d98: 24630160 addiu r3,r3,0x0160 #next?
  00012d9c: 1500fff0 bne r8,r0,0x00012d60
+
  00012d9c: 1500fff0 bne r8,r0,0x00012d60 #loop 8 times
  00012da0: 24c60160 addiu r6,r6,0x0160
+
  00012da0: 24c60160 addiu r6,r6,0x0160 #next? (table is 0x0160 per entry? what's it of? it's 0xB00 bytes long whatever it is!)
 
  00012da4: 34020006 ori r2,r0,0x0006
 
  00012da4: 34020006 ori r2,r0,0x0006
  00012da8: 00452023 subu r4,r2,r5
+
  00012da8: 00452023 subu r4,r2,r5 #r4 = 6 - r5
 
  00012dac: 34020020 ori r2,r0,0x0020
 
  00012dac: 34020020 ori r2,r0,0x0020
  00012db0: 00451023 subu r2,r2,r5
+
  00012db0: 00451023 subu r2,r2,r5 #r2 = 0x20 - r5
  00012db4: 2403ffff addiu r3,r0,0xffff
+
  00012db4: 2403ffff addiu r3,r0,0xffff #0xffffffff (here, 4,294,967,295)
  00012db8: 00436006 srlv r12,r3,r2
+
  00012db8: 00436006 srlv r12,r3,r2 #r12 = above divided by 2^(32 - r5)
  00012dbc: 008c3804 sllv r7,r12,r4
+
  00012dbc: 008c3804 sllv r7,r12,r4 #r7 = above divided by 2^(26) rounded to 6 - r5 bits? gets bitmask range to test for flags within a range?
  00012dc0: 00041040 sll r2,r4,0x01
+
  00012dc0: 00041040 sll r2,r4,0x01 #2 * r4
  00012dc4: 00441021 addu r2,r2,r4
+
  00012dc4: 00441021 addu r2,r2,r4 #3 *
  00012dc8: 00021080 sll r2,r2,0x02
+
  00012dc8: 00021080 sll r2,r2,0x02 #0xc * r4
  00012dcc: 00441023 subu r2,r2,r4
+
  00012dcc: 00441023 subu r2,r2,r4 #0xb * r4
  00012dd0: 00021140 sll r2,r2,0x05
+
  00012dd0: 00021140 sll r2,r2,0x05 #0x160 * (6 - r5)
 
  00012dd4: 3c038003 lui r3,0x8003
 
  00012dd4: 3c038003 lui r3,0x8003
  00012dd8: 8c632a60 lw r3,0x2a60(r3)
+
  00012dd8: 8c632a60 lw r3,0x2a60(r3) #pointer to that table again
 
  00012ddc: 244200b8 addiu r2,r2,0x00b8
 
  00012ddc: 244200b8 addiu r2,r2,0x00b8
 
  00012de0: 3c018003 lui r1,0x8003
 
  00012de0: 3c018003 lui r1,0x8003
  00012de4: ac2a2a10 sw r10,0x2a10(r1)
+
  00012de4: ac2a2a10 sw r10,0x2a10(r1) #store flags marking all r4 that matched table entry + 0xc0
 
  00012de8: 3c018003 lui r1,0x8003
 
  00012de8: 3c018003 lui r1,0x8003
  00012dec: ac292a14 sw r9,0x2a14(r1)
+
  00012dec: ac292a14 sw r9,0x2a14(r1) #store bitflag combined all table entry + 0xEC for all r4 that matched table entry + 0xc0
  00012df0: 00623021 addu r6,r3,r2
+
  00012df0: 00623021 addu r6,r3,r2 #relevant table entry between 0 and 6
 
  00012df4: 8c630058 lw r3,0x0058(r3)
 
  00012df4: 8c630058 lw r3,0x0058(r3)
  00012df8: 000a1027 nor r2,r0,r10
+
  00012df8: 000a1027 nor r2,r0,r10 #Nor r10
  00012dfc: 00434024 and r8,r2,r3
+
  00012dfc: 00434024 and r8,r2,r3 #check for all table entries that did not match for?
  00012e00: 01071024 and r2,r8,r7
+
  00012e00: 01071024 and r2,r8,r7 #check for all table entries that did not match for, between current table entry (r5?) and 6?
  00012e04: 1040001b beq r2,r0,0x00012e74
+
  00012e04: 1040001b beq r2,r0,0x00012e74 #branch if no valid matching table entries (end, return r2 = 6 - r5)
 
  00012e08: 240bffff addiu r11,r0,0xffff
 
  00012e08: 240bffff addiu r11,r0,0xffff
 
  00012e0c: 00051040 sll r2,r5,0x01
 
  00012e0c: 00051040 sll r2,r5,0x01
Line 56: Line 56:
 
  00012e14: 00021080 sll r2,r2,0x02
 
  00012e14: 00021080 sll r2,r2,0x02
 
  00012e18: 00451023 subu r2,r2,r5
 
  00012e18: 00451023 subu r2,r2,r5
  00012e1c: 00024940 sll r9,r2,0x05
+
  00012e1c: 00024940 sll r9,r2,0x05 #r5 * 0x160 (for table entry valid to r5?)
 
  00012e20: 8cc30010 lw r3,0x0010(r6)
 
  00012e20: 8cc30010 lw r3,0x0010(r6)
 
  00012e24: 00000000 nop
 
  00012e24: 00000000 nop
 
  00012e28: 006b102b sltu r2,r3,r11
 
  00012e28: 006b102b sltu r2,r3,r11
  00012e2c: 10400008 beq r2,r0,0x00012e50
+
  00012e2c: 10400008 beq r2,r0,0x00012e50 #branch ahead if 0x10 + table entry? is less than -1
  00012e30: 00a73806 srlv r7,r7,r5
+
  00012e30: 00a73806 srlv r7,r7,r5 #flush bits with lower bound (integer limit / 2^(26+r5))
 
  00012e34: 90c2000d lbu r2,0x000d(r6)
 
  00012e34: 90c2000d lbu r2,0x000d(r6)
 
  00012e38: 00000000 nop
 
  00012e38: 00000000 nop
  00012e3c: 2c420021 sltiu r2,r2,0x0021
+
  00012e3c: 2c420021 sltiu r2,r2,0x0021 #less than 33?
  00012e40: 10400004 beq r2,r0,0x00012e54
+
  00012e40: 10400004 beq r2,r0,0x00012e54 #branch if not
 
  00012e44: 00ec102b sltu r2,r7,r12
 
  00012e44: 00ec102b sltu r2,r7,r12
 
  00012e48: 00605821 addu r11,r3,r0
 
  00012e48: 00605821 addu r11,r3,r0

Revision as of 07:59, 23 August 2022

00012d40: 3c038003 lui r3,0x8003
00012d44: 8c632a60 lw r3,0x2a60(r3)			#load ? (pointer?)
00012d48: 00004821 addu r9,r0,r0
00012d4c: 00005021 addu r10,r0,r0
00012d50: 34070001 ori r7,r0,0x0001
00012d54: 34080008 ori r8,r0,0x0008
00012d58: 246600b8 addiu r6,r3,0x00b8			#pointer + 0xb8
00012d5c: 246300ec addiu r3,r3,0x00ec			#P + 0xec
00012d60: 94c20000 lhu r2,0x0000(r6)			
00012d64: 00000000 nop
00012d68: 30420001 andi r2,r2,0x0001
00012d6c: 10400009 beq r2,r0,0x00012d94		#branch if flag 1 not enabled?
00012d70: 2508ffff addiu r8,r8,0xffff			#-1
00012d74: 8c62ffd4 lw r2,-0x002c(r3)
00012d78: 00000000 nop
00012d7c: 14440005 bne r2,r4,0x00012d94		#branch if item from r3 pointer? does not equal input from animation instruction?
00012d80: 00000000 nop
00012d84: 8c620000 lw r2,0x0000(r3)
00012d88: 01475025 or r10,r10,r7			#r10 = flags for all input != r2?
00012d8c: a4c00000 sh r0,0x0000(r6)			#store 0 here
00012d90: 01224825 or r9,r9,r2				#bitflag combine r9 and r2
00012d94: 00073840 sll r7,r7,0x01			#next flag to append to r10?
00012d98: 24630160 addiu r3,r3,0x0160			#next?
00012d9c: 1500fff0 bne r8,r0,0x00012d60		#loop 8 times
00012da0: 24c60160 addiu r6,r6,0x0160			#next? (table is 0x0160 per entry? what's it of? it's 0xB00 bytes long whatever it is!)
00012da4: 34020006 ori r2,r0,0x0006
00012da8: 00452023 subu r4,r2,r5			#r4 = 6 - r5
00012dac: 34020020 ori r2,r0,0x0020
00012db0: 00451023 subu r2,r2,r5			#r2 = 0x20 - r5
00012db4: 2403ffff addiu r3,r0,0xffff			#0xffffffff (here, 4,294,967,295)
00012db8: 00436006 srlv r12,r3,r2			#r12 = above divided by 2^(32 - r5)
00012dbc: 008c3804 sllv r7,r12,r4			#r7 = above divided by 2^(26) rounded to 6 - r5 bits? gets bitmask range to test for flags within a range?
00012dc0: 00041040 sll r2,r4,0x01			#2 * r4
00012dc4: 00441021 addu r2,r2,r4			#3 *
00012dc8: 00021080 sll r2,r2,0x02			#0xc * r4
00012dcc: 00441023 subu r2,r2,r4			#0xb * r4
00012dd0: 00021140 sll r2,r2,0x05			#0x160 * (6 - r5)
00012dd4: 3c038003 lui r3,0x8003
00012dd8: 8c632a60 lw r3,0x2a60(r3)			#pointer to that table again
00012ddc: 244200b8 addiu r2,r2,0x00b8
00012de0: 3c018003 lui r1,0x8003
00012de4: ac2a2a10 sw r10,0x2a10(r1)			#store flags marking all r4 that matched table entry + 0xc0
00012de8: 3c018003 lui r1,0x8003
00012dec: ac292a14 sw r9,0x2a14(r1)			#store bitflag combined all table entry + 0xEC for all r4 that matched table entry + 0xc0
00012df0: 00623021 addu r6,r3,r2			#relevant table entry between 0 and 6
00012df4: 8c630058 lw r3,0x0058(r3)
00012df8: 000a1027 nor r2,r0,r10			#Nor r10
00012dfc: 00434024 and r8,r2,r3			#check for all table entries that did not match for?
00012e00: 01071024 and r2,r8,r7			#check for all table entries that did not match for, between current table entry (r5?) and 6?
00012e04: 1040001b beq r2,r0,0x00012e74		#branch if no valid matching table entries (end, return r2 = 6 - r5)
00012e08: 240bffff addiu r11,r0,0xffff
00012e0c: 00051040 sll r2,r5,0x01
00012e10: 00451021 addu r2,r2,r5
00012e14: 00021080 sll r2,r2,0x02
00012e18: 00451023 subu r2,r2,r5
00012e1c: 00024940 sll r9,r2,0x05			#r5 * 0x160 (for table entry valid to r5?)
00012e20: 8cc30010 lw r3,0x0010(r6)
00012e24: 00000000 nop
00012e28: 006b102b sltu r2,r3,r11
00012e2c: 10400008 beq r2,r0,0x00012e50		#branch ahead if 0x10 + table entry? is less than -1
00012e30: 00a73806 srlv r7,r7,r5			#flush bits with lower bound (integer limit / 2^(26+r5))
00012e34: 90c2000d lbu r2,0x000d(r6)
00012e38: 00000000 nop
00012e3c: 2c420021 sltiu r2,r2,0x0021			#less than 33?
00012e40: 10400004 beq r2,r0,0x00012e54		#branch if not
00012e44: 00ec102b sltu r2,r7,r12
00012e48: 00605821 addu r11,r3,r0
00012e4c: 00806821 addu r13,r4,r0
00012e50: 00ec102b sltu r2,r7,r12
00012e54: 10400003 beq r2,r0,0x00012e64
00012e58: 00000000 nop
00012e5c: 08004b9d j 0x00012e74
00012e60: 01a02021 addu r4,r13,r0
00012e64: 00c93023 subu r6,r6,r9
00012e68: 01071024 and r2,r8,r7
00012e6c: 1440ffec bne r2,r0,0x00012e20
00012e70: 00852023 subu r4,r4,r5
00012e74: 03e00008 jr r31
00012e78: 00801021 addu r2,r4,r0