Slope Calculations

From Final Fantasy Hacktics Wiki
Jump to navigation Jump to search

Instructions and notes

Parameters : r5 = Tile elevation
             r4 = previous routine stack pointer
                    - 0x00 = X mod (X coord * 28 + preset value)
                    - 0x02 = Elevation					 
                    - 0x04 = Y mod (Y coord * 28 + preset value)

Returns : r2 holding Height data as negative value depending of slope type
                  - (Height*12) if halves = 0 or unsupported slope type
                  - (Height*12) + (preset/28)*12*halves   (depending of slope see notes)
                  - (Height*12) + (1- preset/28)*12*halves  (depending of slope see notes)   
                  NB : is preset is 14 , same result for all slope
-----------------------------------------------------------------------------------------

0007c80c: 27bdffd8 addiu r29,r29,-0x0028    |(routine has a extremly bad setup - could be MUCH better)
0007c810: afb00018 sw r16,0x0018(r29)       |
0007c814: 00808021 addu r16,r4,r0           |r16 = Stack Pointer
0007c818: afb1001c sw r17,0x001c(r29)       |
0007c81c: 3c119249 lui r17,0x9249           |
0007c820: afbf0020 sw r31,0x0020(r29)       |
0007c824: 96020000 lhu r2,0x0000(r16)       |r2 = Unit X*28 +14 (X mod) - halfword
0007c828: 36312493 ori r17,r17,0x2493       |r17 = 0x92492493 ( =-3/7 * 2^32)
0007c82c: 00021400 sll r2,r2,0x10           |r2 = unit X mod * 1024 (move the lower part of the register in upper part)
0007c830: 00021c03 sra r3,r2,0x10           |r3 = unit  X Mod (Uper part of register is cleaned)
0007c834: 00710018 mult r3,r17              |X mod * -3/7 * 2^32
0007c838: 000217c3 sra r2,r2,0x1f           |r2 = r2/2^31 (mostly 0x00, unlikely 0x01)
0007c83c: 00002010 mfhi r4                  |r4 = unit X mod * -3/7
0007c840: 00832021 addu r4,r4,r3            |r4 = unit X Mod * 4 / 7 
0007c844: 00042103 sra r4,r4,0x04           |r4 = Unit XMod / 28 (= unit X coord)
0007c848: 00822023 subu r4,r4,r2            |rounding stuff
0007c84c: a7a40010 sh r4,0x0010(r29)        |Store Unit's X coord on stack 0x10 (Unused in the routine)
0007c850: 96030004 lhu r3,0x0004(r16)       |r3 = Unit Y*28 +14 (Y mod) - halfword
0007c854: 00000000 nop                      |
0007c858: 00031c00 sll r3,r3,0x10           |r3 = unit Y mod * 1024 
0007c85c: 00033403 sra r6,r3,0x10           |r6 = unit  Y Mod (register cleanup)
0007c860: 00d10018 mult r6,r17              |Y mod * -3/7 * 2^32
0007c864: 00042400 sll r4,r4,0x10           |r4 = unit X coord * 1024 
0007c868: 00042403 sra r4,r4,0x10           |r4 = Unit X coord (register cleanup)
0007c86c: 00031fc3 sra r3,r3,0x1f           |r3 = r3/2^31 = 0x00 (very unlikely 0x01)
0007c870: 00001010 mfhi r2                  |r2 = Unit Y mod * -3/7
0007c874: 00461021 addu r2,r2,r6            |r2 = Unit Y Mod * 4 / 7
0007c878: 00021103 sra r2,r2,0x04           |r2 = Unit's Y Coord (Y mod / 28)
0007c87c: 00431023 subu r2,r2,r3            |rounding stuff
0007c880: a7a20012 sh r2,0x0012(r29)        |Store Unit's Y coord on stack 0x12 (Unused in the routine)
0007c884: 00021400 sll r2,r2,0x10           |r2 = unit Y coord * 1024 (move the lower part of the register in upper part)
0007c888: 30a600ff andi r6,r5,0x00ff        |r6 = Unit's Elevation
0007c88c: 0c060fed jal 0x00183fb4           |-->Get_Tile_Data_Pointer Return r2 = Unit tile data pointer
0007c890: 00022c03 sra r5,r2,0x10           |r5 = Unit's Y (upper part of register cleared)
0007c894: 00402821 addu r5,r2,r0            |r5 = Tile Data Pointer
0007c898: 90a30002 lbu r3,0x0002(r5)        |r3 = Tile's Height
0007c89c: 00000000 nop                      |
0007c8a0: 00031040 sll r2,r3,0x01           |r2 = tile Height * 2
0007c8a4: 00431021 addu r2,r2,r3            |r2 = Height * 3
0007c8a8: 00021080 sll r2,r2,0x02           |r2 = Height * 12
0007c8ac: 00025023 subu r10,r0,r2           |r10 = -(Height * 12)
0007c8b0: 90a20003 lbu r2,0x0003(r5)        |r2 =  Tiles Halves + Depth
0007c8b4: 00000000 nop                      |
0007c8b8: 3049001f andi r9,r2,0x001f        |r9 = Tile  Halves
0007c8bc: 112001c6 beq r9,r0,0x0007cfd8     #If Halves <> 0x00 #Branch if Halves = 0 (skips ALL of the slope checks)
0007c8c0: 01402021 addu r4,r10,r0           |r4 = Z Mod
0007c8c4: 90a30004 lbu r3,0x0004(r5)             |r3 = Tile Slope Type
0007c8c8: 34020052 ori r2,r0,0x0052              |r2 = 0x52
0007c8cc: 1062002f beq r3,r2,0x0007c98c          #If Tile slope <> 0x52 #Else branch to Slope Type = 0x52 section
0007c8d0: 28620053 slti r2,r3,0x0053                 |r2 = 0x01 if slope < 0x53
0007c8d4: 10400013 beq r2,r0,0x0007c924              #If slope < 0x52 #Branch if Slope Type >= 0x53
0007c8d8: 34020025 ori r2,r0,0x0025                      |r2 = 0x25
0007c8dc: 1062004f beq r3,r2,0x0007ca1c                  #If slope <> 0x25 #Branch if Slope Type = 0x25
0007c8e0: 00000000 nop                                       |   
0007c8e4: 28620026 slti r2,r3,0x0026                         |r2 = 0x01 if slope < 0x26
0007c8e8: 10400007 beq r2,r0,0x0007c908                      #If slope < 0x26 #Branch if Slope Type >= 0x26
0007c8ec: 34020011 ori r2,r0,0x0011                              |r2 = 0x11
0007c8f0: 10620084 beq r3,r2,0x0007cb04                          #If slope <> 0x11 #Branch if Slope Type = 0x11
0007c8f4: 34020014 ori r2,r0,0x0014                                  |r2 = 0x14
0007c8f8: 106200ac beq r3,r2,0x0007cbac                              #If slop <> 0x14 #Branch if Slope Type = 0x14
0007c8fc: 00041400 sll r2,r4,0x10                                        |r2 = r10 * 1024 (1st move for register clean up)
0007c900: 0801f3f7 j 0x0007cfdc                                          >>jump to end (slope type not supported/invalid)
0007c904: 00000000 nop                                                   |
0007c908: 34020041 ori r2,r0,0x0041                          # Else (slope >= 0x26) r2 = 0x41
0007c90c: 10620059 beq r3,r2,0x0007ca74                      #If slope <> 0x41 #Branch if Slope Type = 0x41
0007c910: 34020044 ori r2,r0,0x0044                              |r2 = 0x44
0007c914: 106200cd beq r3,r2,0x0007cc4c                          #If slope <> 0x44 #Branch if Slope Type = 0x44
0007c918: 00041400 sll r2,r4,0x10                                    |r2 = r10 * 1024 (1st move for register clean up)
0007c91c: 0801f3f7 j 0x0007cfdc                                      >>jump to end (slope type not supported/invalid)
0007c920: 00000000 nop                                               |
0007c924: 34020069 ori r2,r0,0x0069                  #Else (Slope >= 0x53) r2 = 0x69
0007c928: 1062013d beq r3,r2,0x0007ce20              #If slope <> 0x69 #Branch if Slope Type = 0x69
0007c92c: 2862006a slti r2,r3,0x006a                     |r2 = 1 if slope < 0x6a
0007c930: 10400008 beq r2,r0,0x0007c954                  #If slope < 0x6a #Branch if Slope Type >= 0x6a
0007c934: 34020058 ori r2,r0,0x0058                          |r2 = 0x58
0007c938: 10620025 beq r3,r2,0x0007c9d0                      #If slope <> 0x58 #Branch if Slope Type = 0x58
0007c93c: 00000000 nop                                           | 
0007c940: 34020066 ori r2,r0,0x0066                              |r2 = 0x66
0007c944: 1062010c beq r3,r2,0x0007cd78                          #If slope <> 0x66 #Branch if Slope Type = 0x66
0007c948: 00041400 sll r2,r4,0x10                                    |r2 = r10 * 1024 (1st move for register clean up)
0007c94c: 0801f3f7 j 0x0007cfdc                                      >>jump to end (slope type not supported/invalid)
0007c950: 00000000 nop                                               |
0007c954: 34020096 ori r2,r0,0x0096                      #Else (slope >= 0x6a) r2 = 0x96
0007c958: 106200e3 beq r3,r2,0x0007cce8                  #If slope <> 0x96 #Branch if Slope Type = 0x96
0007c95c: 28620097 slti r2,r3,0x0097                         |r2 = 0x01 if slope < 0x97
0007c960: 10400005 beq r2,r0,0x0007c978                      #If slope < 0x97 #Branch if Slope Type >= 0x97
0007c964: 34020085 ori r2,r0,0x0085                              |r2 = 0x85
0007c968: 1062003f beq r3,r2,0x0007ca68                          #If slope <> 0x85 #Branch if Slope Type = 0x85
0007c96c: 00041400 sll r2,r4,0x10                                    |r2 = r10 * 1024 (1st move for register clean up)
0007c970: 0801f3f7 j 0x0007cfdc                                      >>jump to end (slope type not supported/invalid)
0007c974: 00000000 nop                                               |
0007c978: 34020099 ori r2,r0,0x0099                          #Else (slope > 0x97) r2 = 0x99
0007c97c: 10620150 beq r3,r2,0x0007cec0                      #if slope <> 0x99 #Branch if Slope Type = 0x99
0007c980: 00041400 sll r2,r4,0x10                                |r2 = r10 * 1024 (1st move for register clean up)
0007c984: 0801f3f7 j 0x0007cfdc                                  >>jump to end (slope type not supported/invalid)
0007c988: 00000000 nop                                           |

                                            --- Slope Type = 0x52  Section---
0007c98c: 96030000 lhu r3,0x0000(r16)            |r3 =  X Mod (X coord*28 +14)
0007c990: 00000000 nop                           |
0007c994: 00031c00 sll r3,r3,0x10                |r3 = X mod * 1024 (move halfword in upper register part)
0007c998: 00032403 sra r4,r3,0x10                |r4 = X mod *1024/1024 (move halfword in lower register part - upper part is 0x0000)
0007c99c: 00910018 mult r4,r17                   |X Mod * (-3 / 7)*2^32
0007c9a0: 00031fc3 sra r3,r3,0x1f                |r3 = 0x00 (or 0x01 if r3 is > 2^31 or r3 is a negative word - not possible X should be > 1169...)
0007c9a4: 00001010 mfhi r2                       |r2 = X mod * -3/7
0007c9a8: 00441021 addu r2,r2,r4                 |r2 = X Mod * 4 / 7
0007c9ac: 00021103 sra r2,r2,0x04                |r2 = X Coord (= X Mod / 28)
0007c9b0: 00431023 subu r2,r2,r3                 |(r2 = r2 - 0x00)
0007c9b4: 000218c0 sll r3,r2,0x03                |r3 = X coord * 8
0007c9b8: 00621823 subu r3,r3,r2                 |r3 = X coord * 7
0007c9bc: 00031880 sll r3,r3,0x02                |r3 = X coord * 28
0007c9c0: 00832023 subu r4,r4,r3                 |r4 = preset value   (X Coord*28 + 14 - X Coord*28 (=14)  depending of calling routine ?)
0007c9c4: 00042400 sll r4,r4,0x10                |r4 = preset value *1024
0007c9c8: 0801f3e8 j 0x0007cfa0                  >>Jump to  [(Preset/28) * (12 * Halves)] section with X preset >> 
0007c9cc: 00042403 sra r4,r4,0x10                |r4 = preset value with clean register

                                            --- Slope Type = 0x58  Section---
0007c9d0: 96030000 lhu r3,0x0000(r16)            |Load X Mod (X coord*28 + 14)
0007c9d4: 00000000 nop                           |
0007c9d8: 00031c00 sll r3,r3,0x10                |r3 = X Mod * 1024
0007c9dc: 00032403 sra r4,r3,0x10                |r4 = X Mod  (clear upper part of registery)
0007c9e0: 00910018 mult r4,r17                   |X Mod *( -3 / 7)*2^32
0007c9e4: 00031fc3 sra r3,r3,0x1f                |r3 = 0x00
0007c9e8: 00001010 mfhi r2                       |r2 = X mod * (-3/7)
0007c9ec: 00441021 addu r2,r2,r4                 |r2 = X Mod * 4 / 7
0007c9f0: 00021103 sra r2,r2,0x04                |r2 = X Mod / 28 (= X coord )
0007c9f4: 00431023 subu r2,r2,r3                 |r2 =  X coord -0x00
0007c9f8: 000218c0 sll r3,r2,0x03                |r3 = X Coord * 8
0007c9fc: 00621823 subu r3,r3,r2                 |r3 = X Coord * 7
0007ca00: 00031880 sll r3,r3,0x02                |r3 = X Coord * 28
0007ca04: 00832023 subu r4,r4,r3                 |r4 = 14 (X Coord * 28 + 14) - X coord*28   (depeding of calling routine ?)
0007ca08: 00042400 sll r4,r4,0x10                |
0007ca0c: 00042403 sra r4,r4,0x10                |r4 =14 (upper part of registery cleared)
0007ca10: 00041040 sll r2,r4,0x01                |r2 = 28 (preset*2)
0007ca14: 0801f3d7 j 0x0007cf5c                  >>Jump to [(1-preset/28) * (12*Halves)] section with X preset
0007ca18: 00441021 addu r2,r2,r4                 |r2 = 42 (preset *3)

                                            --- Slope Type = 0x25  Section---
0007ca1c: 96030004 lhu r3,0x0004(r16)            |r3 = Y Mod (Y coord*28 + 14)
0007ca20: 00000000 nop                           |
0007ca24: 00031c00 sll r3,r3,0x10                |r3 = r3*1024
0007ca28: 00032403 sra r4,r3,0x10                |r3 = Y Mod (register cleared)
0007ca2c: 00910018 mult r4,r17                   |r4 = Y Mod * -3 / 7 * 2^32
0007ca30: 00031fc3 sra r3,r3,0x1f                |r3 = 0x00
0007ca34: 00001010 mfhi r2                       |r2 = Y Mod * -3/7
0007ca38: 00441021 addu r2,r2,r4                 |r2 = Y Mod * 4/7
0007ca3c: 00021103 sra r2,r2,0x04                |r2 = Y Coord
0007ca40: 00431023 subu r2,r2,r3                 |r2 = Y Coord
0007ca44: 000218c0 sll r3,r2,0x03                |r2 = Y Coord * 8
0007ca48: 00621823 subu r3,r3,r2                 |r2 = Y Coord * 7
0007ca4c: 00031880 sll r3,r3,0x02                |r2 = Y Coord * 28
0007ca50: 00832023 subu r4,r4,r3                 |r4 = Y preset value
0007ca54: 00042400 sll r4,r4,0x10                |r4 = r4 * 1024
0007ca58: 00042403 sra r4,r4,0x10                |r4 = Y preset value (register cleared)
0007ca5c: 00041040 sll r2,r4,0x01                |r2 = Y preset value * 2
0007ca60: 0801f3d7 j 0x0007cf5c                  >>Jump to [(1-preset/28) * (12*Halves)] section with Y preset
0007ca64: 00441021 addu r2,r2,r4                 |r2 = Y preset value * 3

                                            --- Slope Type = 0x85  Section---
0007ca68: 96030004 lhu r3,0x0004(r16)            |r3 = Y Mod (Y coord*28 + 14)
0007ca6c: 0801f266 j 0x0007c998                  >>Jump to 0x52 section with Y Mod  will go to [(Preset/28) * (12 * Halves)] section with Y preset
0007ca70: 00031c00 sll r3,r3,0x10                |r3 = r3 * 1024 (1st move of register cleanup)

                                            --- Slope Type = 0x41   Section---
0007ca74: 96020000 lhu r2,0x0000(r16)            |r2 = X Mod (X Coord*28 + X Preset)
0007ca78: 00000000 nop                           |
0007ca7c: 00021400 sll r2,r2,0x10                |r2 = r2 * 1024
0007ca80: 00022403 sra r4,r2,0x10                |r4 = X mod (upper register cleanup)
0007ca84: 00910018 mult r4,r17                   |X mod * -3/7 * 2^32
0007ca88: 96060004 lhu r6,0x0004(r16)            |r6 =  Y Mod (Y Coord * 28 + Y preset)
0007ca8c: 00001810 mfhi r3                       |r3 = X mod * -3/7
0007ca90: 00063400 sll r6,r6,0x10                |r6 = r6 *1024
0007ca94: 00062c03 sra r5,r6,0x10                |r5 = Y mod (upper register cleanup)
0007ca98: 00b10018 mult r5,r17                   |Y Mod * -3 / 7 * 2^32
0007ca9c: 000217c3 sra r2,r2,0x1f                |r2 = 0x00
0007caa0: 000637c3 sra r6,r6,0x1f                |r6 = 0x00
0007caa4: 00641821 addu r3,r3,r4                 |r3 = X Mod * 4 / 7
0007caa8: 00031903 sra r3,r3,0x04                |r3 = X Mod / 28 = X coord
0007caac: 00621823 subu r3,r3,r2                 |r3 = X coord - 0x00
0007cab0: 000310c0 sll r2,r3,0x03                |r2 = X Coord * 8
0007cab4: 00431023 subu r2,r2,r3                 |r2 = X Coord * 7
0007cab8: 00021080 sll r2,r2,0x02                |r2 = X Coord * 28
0007cabc: 00822023 subu r4,r4,r2                 |r4 = X preset value
0007cac0: 00042400 sll r4,r4,0x10                |r4 = r4 * 1024
0007cac4: 00043c03 sra r7,r4,0x10                |r7 = X preset value (upper register cleanup)
0007cac8: 00001010 mfhi r2                       |r2 = Y Mod * -3/7
0007cacc: 00451021 addu r2,r2,r5                 |r2 = Y Mod *4/7
0007cad0: 00021103 sra r2,r2,0x04                |r2 = Y Mod / 28 = Y Coord
0007cad4: 00461023 subu r2,r2,r6                 |r2 = Y Coord  - 0x00
0007cad8: 000218c0 sll r3,r2,0x03                |r3 = Y Coord * 8
0007cadc: 00621823 subu r3,r3,r2                 |r3 = Y Coord * 7
0007cae0: 00031880 sll r3,r3,0x02                |r3 = Y Coord * 28
0007cae4: 00a32823 subu r5,r5,r3                 |r5 = Y preset
0007cae8: 00052c00 sll r5,r5,0x10                |r5 = Y preset * 1024
0007caec: 00052403 sra r4,r5,0x10                |r4 = Y preset (upper register cleanup)
0007caf0: 00e4102a slt r2,r7,r4                  |r2 = 0x01 if X preset < Y preset / Else 0x00
0007caf4: 1040012a beq r2,r0,0x0007cfa0          #If X preset < Y preset / if X Preset >= Y Preset  branch to  [(Preset/28) * (12 * Halves)] section with Y preset
0007caf8: 00071040 sll r2,r7,0x01                    |r2 = X preset * 2
0007cafc: 0801f3ea j 0x0007cfa8                      >>Jump to  [(Preset/28) * (12 * Halves)] section with X preset
0007cb00: 00471021 addu r2,r2,r7                     |r2 = X preset * 3

                                            --- Slope Type = 0x11   Section---
0007cb04: 96020000 lhu r2,0x0000(r16)            |r2 = X Mod (X Coord*28 + X Preset)
0007cb08: 00000000 nop                           |
0007cb0c: 00021400 sll r2,r2,0x10                |r2 = r2 * 1024
0007cb10: 00022403 sra r4,r2,0x10                |r4 = X mod (upper register cleanup)
0007cb14: 00910018 mult r4,r17                   |X mod * -3/7 * 2^32 X Mod * -3 / 7
0007cb18: 96060004 lhu r6,0x0004(r16)            |r6 =  Y Mod (Y Coord * 28 + Y preset)
0007cb1c: 00001810 mfhi r3                       |r3 = X mod * -3/7
0007cb20: 00063400 sll r6,r6,0x10                |r6 = r6 *1024
0007cb24: 00062c03 sra r5,r6,0x10                |r5 = Y mod (upper register cleanup)
0007cb28: 00b10018 mult r5,r17                   |Y Mod * -3 / 7 * 2^32
0007cb2c: 000217c3 sra r2,r2,0x1f                |r2 = 0x00
0007cb30: 000637c3 sra r6,r6,0x1f                |r6 = 0x00
0007cb34: 00641821 addu r3,r3,r4                 |r3 = X Mod * 4 / 7
0007cb38: 00031903 sra r3,r3,0x04                |r3 = X Mod / 28 = X coord
0007cb3c: 00621823 subu r3,r3,r2                 |r3 = X coord - 0x00
0007cb40: 000310c0 sll r2,r3,0x03                |r2 = X Coord * 8
0007cb44: 00431023 subu r2,r2,r3                 |r2 = X Coord * 7
0007cb48: 00021080 sll r2,r2,0x02                |r2 = X Coord * 28
0007cb4c: 00822023 subu r4,r4,r2                 |r4 = X preset value
0007cb50: 00042400 sll r4,r4,0x10                |r4 = r4 * 1024
0007cb54: 00043c03 sra r7,r4,0x10                |r7 = X preset value (upper register cleanup)
0007cb58: 00001010 mfhi r2                       |r2 = Y Mod * -3/7
0007cb5c: 00451021 addu r2,r2,r5                 |r2 = Y Mod *4/7
0007cb60: 00021103 sra r2,r2,0x04                |r2 = Y Mod / 28 = Y Coord
0007cb64: 00461023 subu r2,r2,r6                 |r2 = Y Coord  - 0x00
0007cb68: 000218c0 sll r3,r2,0x03                |r3 = Y Coord * 8
0007cb6c: 00621823 subu r3,r3,r2                 |r3 = Y Coord * 7
0007cb70: 00031880 sll r3,r3,0x02                |r3 = Y Coord * 28
0007cb74: 00a32823 subu r5,r5,r3                 |r5 = Y preset
0007cb78: 00052c00 sll r5,r5,0x10                |r5 = Y preset * 1024
0007cb7c: 00052c03 sra r5,r5,0x10                |r5 = Y preset (upper registery clean up)
0007cb80: 3402001c ori r2,r0,0x001c              |r2 = 28
0007cb84: 00452023 subu r4,r2,r5                 |28 - Y preset
0007cb88: 00e4102a slt r2,r7,r4                  |r2 = 0x01 if X preset < 28-Y preset
0007cb8c: 14400004 bne r2,r0,0x0007cba0          #If X preset > (28 - Y preset)
0007cb90: 00000000 nop                               | 
0007cb94: 00051040 sll r2,r5,0x01                    |r2 = Y preset * 2
0007cb98: 0801f3d7 j 0x0007cf5c                      >>Jump to [(1-preset/28) * (12*Halves)] section with Y preset
0007cb9c: 00451021 addu r2,r2,r5                     |r2 = Y preset * 3
0007cba0: 00071040 sll r2,r7,0x01                |r2 = X preset *2
0007cba4: 0801f3ea j 0x0007cfa8                  >>Jump to  [(Preset/28) * (12 * Halves)] section with X preset
0007cba8: 00471021 addu r2,r2,r7                 |r2 = X preset *3

                                            --- Slope Type = 0x14   Section---
0007cbac: 96020000 lhu r2,0x0000(r16)            |r2 = X Mod (X Coord*28 + X Preset)
0007cbb0: 00000000 nop                           |
0007cbb4: 00021400 sll r2,r2,0x10                |r2 = r2 * 1024
0007cbb8: 00022403 sra r4,r2,0x10                |r4 = X mod (upper register cleanup)
0007cbbc: 00910018 mult r4,r17                   |X mod * -3/7 * 2^32 X Mod * -3 / 7
0007cbc0: 96060004 lhu r6,0x0004(r16)            |r6 =  Y Mod (Y Coord * 28 + Y preset)
0007cbc4: 00000000 nop                           |
0007cbc8: 00063400 sll r6,r6,0x10                |r6 = r6 *1024
0007cbcc: 00062c03 sra r5,r6,0x10                |r5 = Y mod (upper register cleanup)
0007cbd0: 00001810 mfhi r3                       |r3 = X mod * -3/7
0007cbd4: 000217c3 sra r2,r2,0x1f                |r2 = 0x00
0007cbd8: 000637c3 sra r6,r6,0x1f                |r6 = 0x00
0007cbdc: 00b10018 mult r5,r17                   |Y Mod * -3 / 7 * 2^32
0007cbe0: 00641821 addu r3,r3,r4                 |r3 = X Mod * 4 / 7
0007cbe4: 00031903 sra r3,r3,0x04                |r3 = X Mod / 28 = X coord
0007cbe8: 00621823 subu r3,r3,r2                 |r3 = X coord - 0x00
0007cbec: 000310c0 sll r2,r3,0x03                |r2 = X Coord * 8
0007cbf0: 00431023 subu r2,r2,r3                 |r2 = X Coord * 7
0007cbf4: 00021080 sll r2,r2,0x02                |r2 = X Coord * 28
0007cbf8: 00822023 subu r4,r4,r2                 |r4 = X preset value
0007cbfc: 00042400 sll r4,r4,0x10                |r4 = r4 * 1024
0007cc00: 00044403 sra r8,r4,0x10                |r8 = X preset value (upper register cleanup)
0007cc04: 3404001c ori r4,r0,0x001c              |r4 = 28
0007cc08: 00883823 subu r7,r4,r8                 |r7 = 28-X preset
0007cc0c: 00001010 mfhi r2                       |r2 = Y Mod * -3/7
0007cc10: 00451021 addu r2,r2,r5                 |r2 = Y Mod *4/7
0007cc14: 00021103 sra r2,r2,0x04                |r2 = Y Mod / 28 = Y Coord
0007cc18: 00461023 subu r2,r2,r6                 |r2 = Y Coord  - 0x00
0007cc1c: 000218c0 sll r3,r2,0x03                |r3 = Y Coord * 8
0007cc20: 00621823 subu r3,r3,r2                 |r3 = Y Coord * 7
0007cc24: 00031880 sll r3,r3,0x02                |r3 = Y Coord * 28
0007cc28: 00a32823 subu r5,r5,r3                 |r5 = Y preset
0007cc2c: 00052c00 sll r5,r5,0x10                |r5 = Y preset * 1024
0007cc30: 00052c03 sra r5,r5,0x10                |r5 = Y preset (upper registery clean up)
0007cc34: 00852023 subu r4,r4,r5                 |r4 = 28 - Y Preset
0007cc38: 00e4102a slt r2,r7,r4                  |r2 = 0x01 if (28-X preset)<(28-Y preset)
0007cc3c: 144000c5 bne r2,r0,0x0007cf54          #If (28-Y preset)<=(28-X preset) /Else Branch to [(1-preset/28) * (12*Halves)] section with X preset
0007cc40: 00051040 sll r2,r5,0x01                    |r2 = Y preset*2
0007cc44: 0801f3d7 j 0x0007cf5c                      >>Jump to [(1-preset/28) * (12*Halves)] section with Y preset
0007cc48: 00451021 addu r2,r2,r5                     |r2 = Y preset*3

                                            --- Slope Type = 0x44   Section---
0007cc4c: 96020000 lhu r2,0x0000(r16)            |r2 = X Mod (X Coord*28 + X Preset)
0007cc50: 00000000 nop                           |
0007cc54: 00021400 sll r2,r2,0x10                |r2 = r2 * 1024
0007cc58: 00022403 sra r4,r2,0x10                |r4 = X mod (upper register cleanup)
0007cc5c: 00910018 mult r4,r17                   |X mod * -3/7 * 2^32
0007cc60: 96060004 lhu r6,0x0004(r16)            |r6 =  Y Mod (Y Coord * 28 + Y preset)
0007cc64: 00000000 nop                           |
0007cc68: 00063400 sll r6,r6,0x10                |r6 = r6 *1024
0007cc6c: 00062c03 sra r5,r6,0x10                |r5 = Y mod (upper register cleanup)
0007cc70: 00001810 mfhi r3                       |r3 = X mod * -3/7
0007cc74: 000217c3 sra r2,r2,0x1f                |r2 = 0x00
0007cc78: 000637c3 sra r6,r6,0x1f                |r6 = 0x00
0007cc7c: 00b10018 mult r5,r17                   |Y Mod * -3 / 7 * 2^32
0007cc80: 00641821 addu r3,r3,r4                 |r3 = X Mod * 4 / 7
0007cc84: 00031903 sra r3,r3,0x04                |r3 = X Mod / 28 = X coord
0007cc88: 00621823 subu r3,r3,r2                 |r3 = X coord - 0x00
0007cc8c: 000310c0 sll r2,r3,0x03                |r2 = X Coord * 8
0007cc90: 00431023 subu r2,r2,r3                 |r2 = X Coord * 7
0007cc94: 00021080 sll r2,r2,0x02                |r2 = X Coord * 28
0007cc98: 00822023 subu r4,r4,r2                 |r4 = X preset value
0007cc9c: 00042400 sll r4,r4,0x10                |r4 = r4 * 1024
0007cca0: 00044403 sra r8,r4,0x10                |r8 = X preset value (upper register cleanup)
0007cca4: 3402001c ori r2,r0,0x001c              |r2 = 28
0007cca8: 00483823 subu r7,r2,r8                 |r7 = 28-X preset
0007ccac: 00001010 mfhi r2                       |r2 = Y Mod * -3/7
0007ccb0: 00451021 addu r2,r2,r5                 |r2 = Y Mod *4/7
0007ccb4: 00021103 sra r2,r2,0x04                |r2 = Y Mod / 28 = Y Coord
0007ccb8: 00461023 subu r2,r2,r6                 |r2 = Y Coord  - 0x00
0007ccbc: 000218c0 sll r3,r2,0x03                |r3 = Y Coord * 8
0007ccc0: 00621823 subu r3,r3,r2                 |r3 = Y Coord * 7
0007ccc4: 00031880 sll r3,r3,0x02                |r3 = Y Coord * 28
0007ccc8: 00a32823 subu r5,r5,r3                 |r5 = Y preset
0007cccc: 00052c00 sll r5,r5,0x10                |r5 = Y preset * 1024
0007ccd0: 00052403 sra r4,r5,0x10                |r4 = Y preset (upper registery clean up)
0007ccd4: 00e4102a slt r2,r7,r4                  |r2 = 0x01 if (28-X preset) < Y preset
0007ccd8: 104000b2 beq r2,r0,0x0007cfa4          #If  28-X preset < Y preset / Else branch to  [(Preset/28) * (12 * Halves)] section with Y preset
0007ccdc: 00041040 sll r2,r4,0x01                |r2 = Y preset*2
0007cce0: 0801f3d6 j 0x0007cf58                      >>Jump to [(1-preset/28) * (12*Halves)] section with X preset
0007cce4: 00081040 sll r2,r8,0x01                    |r2 = X preset*2

                                            --- Slope Type = 0x96   Section---
0007cce8: 96020000 lhu r2,0x0000(r16)            |r2 = X Mod (X Coord*28 + X Preset)
0007ccec: 00000000 nop                           |
0007ccf0: 00021400 sll r2,r2,0x10                |r2 = r2 * 1024
0007ccf4: 00022403 sra r4,r2,0x10                |r4 = X mod (upper register cleanup)
0007ccf8: 00910018 mult r4,r17                   |X mod * -3/7 * 2^32
0007ccfc: 96060004 lhu r6,0x0004(r16)            |r6 =  Y Mod (Y Coord * 28 + Y preset)
0007cd00: 00001810 mfhi r3                       |r3 = X mod * -3/7
0007cd04: 00063400 sll r6,r6,0x10                |r6 = r6 *1024
0007cd08: 00062c03 sra r5,r6,0x10                |r5 = Y mod (upper register cleanup)
0007cd0c: 00b10018 mult r5,r17                   |Y Mod * -3 / 7 * 2^32
0007cd10: 000217c3 sra r2,r2,0x1f                |r2 = 0x00
0007cd14: 000637c3 sra r6,r6,0x1f                |r6 = 0x00
0007cd18: 00641821 addu r3,r3,r4                 |r3 = X Mod * 4 / 7
0007cd1c: 00031903 sra r3,r3,0x04                |r3 = X Mod / 28 = X coord
0007cd20: 00621823 subu r3,r3,r2                 |r3 = X coord - 0x00
0007cd24: 000310c0 sll r2,r3,0x03                |r2 = X Coord * 8
0007cd28: 00431023 subu r2,r2,r3                 |r2 = X Coord * 7
0007cd2c: 00021080 sll r2,r2,0x02                |r2 = X Coord * 28
0007cd30: 00822023 subu r4,r4,r2                 |r4 = X preset value
0007cd34: 00042400 sll r4,r4,0x10                |r4 = r4 * 1024
0007cd38: 00043c03 sra r7,r4,0x10                |r7 = X preset value (upper register cleanup)
0007cd3c: 00001010 mfhi r2                       |r2 = Y Mod * -3/7
0007cd40: 00451021 addu r2,r2,r5                 |r2 = Y Mod *4/7
0007cd44: 00021103 sra r2,r2,0x04                |r2 = Y Mod / 28 = Y Coord
0007cd48: 00461023 subu r2,r2,r6                 |r2 = Y Coord  - 0x00
0007cd4c: 000218c0 sll r3,r2,0x03                |r3 = Y Coord * 8
0007cd50: 00621823 subu r3,r3,r2                 |r3 = Y Coord * 7
0007cd54: 00031880 sll r3,r3,0x02                |r3 = Y Coord * 28
0007cd58: 00a32823 subu r5,r5,r3                 |r5 = Y preset
0007cd5c: 00052c00 sll r5,r5,0x10                |r5 = Y preset * 1024
0007cd60: 00052403 sra r4,r5,0x10                |r4 = Y preset (upper registery clean up)
0007cd64: 00e4102a slt r2,r7,r4                  |r2 = 0x01 if X preset < Y preset
0007cd68: 1440008d bne r2,r0,0x0007cfa0          #If X preset > Y preset / Else branch to  [(Preset/28) * (12 * Halves)] section with Y preset
0007cd6c: 00071040 sll r2,r7,0x01                    |r2 = X preset * 2
0007cd70: 0801f3ea j 0x0007cfa8                      >>Jump to  [(Preset/28) * (12 * Halves)] section with X preset
0007cd74: 00471021 addu r2,r2,r7                     |r2 = X preset * 3

                                            --- Slope Type = 0x66   Section---
0007cd78: 96020000 lhu r2,0x0000(r16)            |r2 = X Mod (X Coord*28 + X Preset)
0007cd7c: 00000000 nop                           |
0007cd80: 00021400 sll r2,r2,0x10                |r2 = r2 * 1024
0007cd84: 00022403 sra r4,r2,0x10                |r4 = X mod (upper register cleanup)
0007cd88: 00910018 mult r4,r17                   |X mod * -3/7 * 2^32
0007cd8c: 96060004 lhu r6,0x0004(r16)            |r6 =  Y Mod (Y Coord * 28 + Y preset)
0007cd90: 00001810 mfhi r3                       |r3 = X mod * -3/7
0007cd94: 00063400 sll r6,r6,0x10                |r6 = r6 *1024
0007cd98: 00062c03 sra r5,r6,0x10                |r5 = Y mod (upper register cleanup)
0007cd9c: 00b10018 mult r5,r17                   |Y Mod * -3 / 7 * 2^32
0007cda0: 000217c3 sra r2,r2,0x1f                |r2 = 0x00
0007cda4: 000637c3 sra r6,r6,0x1f                |r6 = 0x00
0007cda8: 00641821 addu r3,r3,r4                 |r3 = X Mod * 4 / 7
0007cdac: 00031903 sra r3,r3,0x04                |r3 = X Mod / 28 = X coord
0007cdb0: 00621823 subu r3,r3,r2                 |r3 = X coord - 0x00
0007cdb4: 000310c0 sll r2,r3,0x03                |r2 = X Coord * 8
0007cdb8: 00431023 subu r2,r2,r3                 |r2 = X Coord * 7
0007cdbc: 00021080 sll r2,r2,0x02                |r2 = X Coord * 28
0007cdc0: 00822023 subu r4,r4,r2                 |r4 = X preset value
0007cdc4: 00042400 sll r4,r4,0x10                |r4 = r4 * 1024
0007cdc8: 00043c03 sra r7,r4,0x10                |r7 = X preset value (upper register cleanup)
0007cdcc: 00001010 mfhi r2                       |r2 = Y Mod * -3/7
0007cdd0: 00451021 addu r2,r2,r5                 |r2 = Y Mod *4/7
0007cdd4: 00021103 sra r2,r2,0x04                |r2 = Y Mod / 28 = Y Coord
0007cdd8: 00461023 subu r2,r2,r6                 |r2 = Y Coord  - 0x00
0007cddc: 000218c0 sll r3,r2,0x03                |r3 = Y Coord * 8
0007cde0: 00621823 subu r3,r3,r2                 |r3 = Y Coord * 7
0007cde4: 00031880 sll r3,r3,0x02                |r3 = Y Coord * 28
0007cde8: 00a32823 subu r5,r5,r3                 |r5 = Y preset
0007cdec: 00052c00 sll r5,r5,0x10                |r5 = Y preset * 1024
0007cdf0: 00052c03 sra r5,r5,0x10                |r5 = Y preset (upper registery clean up)
0007cdf4: 3402001c ori r2,r0,0x001c              |r2 = 28
0007cdf8: 00452023 subu r4,r2,r5                 |r4 = 28 - Y preset
0007cdfc: 00e4102a slt r2,r7,r4                  |r2 = 0x01 if X preset < (28-Y preset)
0007ce00: 14400004 bne r2,r0,0x0007ce14          #If  X preset >= (28-Y preset)
0007ce04: 00000000 nop                               | 
0007ce08: 00071040 sll r2,r7,0x01                    |r2 = X preset * 2
0007ce0c: 0801f3ea j 0x0007cfa8                      >>Jump to  [(Preset/28) * (12 * Halves)] section with X preset
0007ce10: 00471021 addu r2,r2,r7                     |r2 = X preset * 3
0007ce14: 00051040 sll r2,r5,0x01                |r2 = Y preset*2
0007ce18: 0801f3d7 j 0x0007cf5c                  >>Jump to [(1-preset/28) * (12*Halves)] section with  Y preset
0007ce1c: 00451021 addu r2,r2,r5                 |r2 = Y preset*3

                                            --- Slope Type = 0x69   Section---
0007ce20: 96020000 lhu r2,0x0000(r16)            |r2 = X Mod (X Coord*28 + X Preset)
0007ce24: 00000000 nop                           |
0007ce28: 00021400 sll r2,r2,0x10                |r2 = r2 * 1024
0007ce2c: 00022403 sra r4,r2,0x10                |r4 = X mod (upper register cleanup)
0007ce30: 00910018 mult r4,r17                   |X mod * -3/7 * 2^32
0007ce34: 96060004 lhu r6,0x0004(r16)            |r6 =  Y Mod (Y Coord * 28 + Y preset)
0007ce38: 00000000 nop                           |
0007ce3c: 00063400 sll r6,r6,0x10                |r6 = r6 *1024
0007ce40: 00062c03 sra r5,r6,0x10                |r5 = Y mod (upper register cleanup)
0007ce44: 00001810 mfhi r3                       |r3 = X mod * -3/7
0007ce48: 000217c3 sra r2,r2,0x1f                |r2 = 0x00
0007ce4c: 000637c3 sra r6,r6,0x1f                |r6 = 0x00
0007ce50: 00b10018 mult r5,r17                   |Y Mod * -3 / 7 * 2^32
0007ce54: 00641821 addu r3,r3,r4                 |r3 = X Mod * 4 / 7
0007ce58: 00031903 sra r3,r3,0x04                |r3 = X Mod / 28 = X coord
0007ce5c: 00621823 subu r3,r3,r2                 |r3 = X coord - 0x00
0007ce60: 000310c0 sll r2,r3,0x03                |r2 = X Coord * 8
0007ce64: 00431023 subu r2,r2,r3                 |r2 = X Coord * 7
0007ce68: 00021080 sll r2,r2,0x02                |r2 = X Coord * 28
0007ce6c: 00822023 subu r4,r4,r2                 |r4 = X preset value
0007ce70: 00042400 sll r4,r4,0x10                |r4 = r4 * 1024
0007ce74: 00044403 sra r8,r4,0x10                |r8 = X preset value (upper register cleanup)
0007ce78: 3404001c ori r4,r0,0x001c              |r4 = 28
0007ce7c: 00883823 subu r7,r4,r8                 |r7 = 28 - X preset
0007ce80: 00001010 mfhi r2                       |r2 = Y Mod * -3/7
0007ce84: 00451021 addu r2,r2,r5                 |r2 = Y Mod *4/7
0007ce88: 00021103 sra r2,r2,0x04                |r2 = Y Mod / 28 = Y Coord
0007ce8c: 00461023 subu r2,r2,r6                 |r2 = Y Coord  - 0x00
0007ce90: 000218c0 sll r3,r2,0x03                |r3 = Y Coord * 8
0007ce94: 00621823 subu r3,r3,r2                 |r3 = Y Coord * 7
0007ce98: 00031880 sll r3,r3,0x02                |r3 = Y Coord * 28
0007ce9c: 00a32823 subu r5,r5,r3                 |r5 = Y preset
0007cea0: 00052c00 sll r5,r5,0x10                |r5 = Y preset * 1024 r2 = 28
0007cea4: 00052c03 sra r5,r5,0x10                |r5 = Y preset (upper registery clean up)
0007cea8: 00852023 subu r4,r4,r5                 |r4 = 28 - Y preset r2 = 0x01 if X preset < (28-Y preset)
0007ceac: 00e4102a slt r2,r7,r4                  |r2 = 0x01 if (28-X preset) <  (28-Y preset)
0007ceb0: 10400028 beq r2,r0,0x0007cf54          #If (28-Y preset) > (28-X preset) /Else branch to [(1-preset/28) * (12*Halves)] section with  X preset
0007ceb4: 00051040 sll r2,r5,0x01                    |r2 = Y preset * 2
0007ceb8: 0801f3d7 j 0x0007cf5c                      >>Jump to [(1-preset/28) * (12*Halves)] section with  Y preset
0007cebc: 00451021 addu r2,r2,r5                     |r2 = Y preset * 3

                                            --- Slope Type = 0x99   Section---
0007cec0: 96020000 lhu r2,0x0000(r16)            |r2 = X Mod (X Coord*28 + X Preset)
0007cec4: 00000000 nop                           |
0007cec8: 00021400 sll r2,r2,0x10                |r2 = r2 * 1024
0007cecc: 00022403 sra r4,r2,0x10                |r4 = X mod (upper register cleanup)
0007ced0: 00910018 mult r4,r17                   |X mod * -3/7 * 2^32
0007ced4: 96060004 lhu r6,0x0004(r16)            |r6 =  Y Mod (Y Coord * 28 + Y preset)
0007ced8: 00000000 nop                           |
0007cedc: 00063400 sll r6,r6,0x10                |r6 = r6 *1024
0007cee0: 00062c03 sra r5,r6,0x10                |r5 = Y mod (upper register cleanup)
0007cee4: 00001810 mfhi r3                       |r3 = X mod * -3/7
0007cee8: 000217c3 sra r2,r2,0x1f                |r2 = 0x00
0007ceec: 000637c3 sra r6,r6,0x1f                |r6 = 0x00
0007cef0: 00b10018 mult r5,r17                   |Y Mod * -3 / 7 * 2^32
0007cef4: 00641821 addu r3,r3,r4                 |r3 = X Mod * 4 / 7
0007cef8: 00031903 sra r3,r3,0x04                |r3 = X Mod / 28 = X coord
0007cefc: 00621823 subu r3,r3,r2                 |r3 = X coord - 0x00
0007cf00: 000310c0 sll r2,r3,0x03                |r2 = X Coord * 8
0007cf04: 00431023 subu r2,r2,r3                 |r2 = X Coord * 7
0007cf08: 00021080 sll r2,r2,0x02                |r2 = X Coord * 28
0007cf0c: 00822023 subu r4,r4,r2                 |r4 = X preset value
0007cf10: 00042400 sll r4,r4,0x10                |r4 = r4 * 1024
0007cf14: 00044403 sra r8,r4,0x10                |r8 = X preset value (upper register cleanup)
0007cf18: 3402001c ori r2,r0,0x001c              |r2 = 28
0007cf1c: 00483823 subu r7,r2,r8                 |r7 = 28 - X preset
0007cf20: 00001010 mfhi r2                       |r2 = Y Mod * -3/7
0007cf24: 00451021 addu r2,r2,r5                 |r2 = Y Mod *4/7
0007cf28: 00021103 sra r2,r2,0x04                |r2 = Y Mod / 28 = Y Coord
0007cf2c: 00461023 subu r2,r2,r6                 |r2 = Y Coord  - 0x00
0007cf30: 000218c0 sll r3,r2,0x03                |r3 = Y Coord * 8
0007cf34: 00621823 subu r3,r3,r2                 |r3 = Y Coord * 7
0007cf38: 00031880 sll r3,r3,0x02                |r3 = Y Coord * 28
0007cf3c: 00a32823 subu r5,r5,r3                 |r5 = Y preset
0007cf40: 00052c00 sll r5,r5,0x10                |r5 = Y preset * 1024
0007cf44: 00052403 sra r4,r5,0x10                |r4 = Y preset (upper registery clean up)
0007cf48: 00e4102a slt r2,r7,r4                  |r2 = 0x01 if  (28-X preset)<Y preset
0007cf4c: 14400015 bne r2,r0,0x0007cfa4          #If (28-X preset) >= Y preset
0007cf50: 00041040 sll r2,r4,0x01                |r2 = Y preset * 2

                                            ---- [(1-preset/28) * (12*Halves)] section ----
0007cf54: 00081040 sll r2,r8,0x01                    |r2 = Preset * 2 (could be X or Y - depending of jumping location)
0007cf58: 00481021 addu r2,r2,r8                     |r2 = Preset * 3
0007cf5c: 00021080 sll r2,r2,0x02                    |r2 = Preset * 12
0007cf60: 00490018 mult r2,r9                        |Preset * 12 * Halves
0007cf64: 00002012 mflo r4                           |r4 = Preset*12*Halves
0007cf68: 00000000 nop                               |
0007cf6c: 00000000 nop                               |
0007cf70: 00910018 mult r4,r17                       |r4 = Preset*12*Halves * -3/7 * 2^32
0007cf74: 00091840 sll r3,r9,0x01                    |r3 = Halves * 2
0007cf78: 00691821 addu r3,r3,r9                     |r3 = Halves * 3
0007cf7c: 00031880 sll r3,r3,0x02                    |r3 = Halves * 12
0007cf80: 00001010 mfhi r2                           |r2 = Preset * 12 * Halves * -3/7
0007cf84: 00441021 addu r2,r2,r4                     |r2 = Preset * 12 * Halves * 4/7
0007cf88: 00021103 sra r2,r2,0x04                    |r2 = Preset * 12 * Halves /28
0007cf8c: 000427c3 sra r4,r4,0x1f                    |r4 = 0x00
0007cf90: 00441023 subu r2,r2,r4                     |r2 = Preset * 12 * Halves /28 = halve*6
0007cf94: 00621823 subu r3,r3,r2                     |r3 = (Halves * 12)- (Halve*12*preset)/28 = (1-preset/28)*12*Halves
0007cf98: 0801f3f6 j 0x0007cfd8                      >>Jump to almost end (clear return register)
0007cf9c: 01432023 subu r4,r10,r3                    |r4 = Final Height = -(height*12 + (1-preset/28)*12*Halves)

                                            ---- [(preset/28) * (12*Halves)] section ----
0007cfa0: 00041040 sll r2,r4,0x01                |r2 = preset * 2
0007cfa4: 00441021 addu r2,r2,r4                 |r2 = preset * 3
0007cfa8: 00021080 sll r2,r2,0x02                |r2 = preset * 12
0007cfac: 00490018 mult r2,r9                    |preset * 12 * Halves
0007cfb0: 00001812 mflo r3                       |r3 = preset * 12 * Halves
0007cfb4: 00000000 nop                           |
0007cfb8: 00000000 nop                           |
0007cfbc: 00710018 mult r3,r17                   |(Slope mod* 12 * Halves) * (-3 / 7)*2^32
0007cfc0: 00001010 mfhi r2                       |r2 = (preset* 12 * Halves) * -3/7
0007cfc4: 00431021 addu r2,r2,r3                 |r2 = (Preset* 12 * Halves) * -3/7
0007cfc8: 00021103 sra r2,r2,0x04                |r2 = (Preset* 12 * Halves) /28
0007cfcc: 00031fc3 sra r3,r3,0x1f                |r3 = 0x00
0007cfd0: 00431023 subu r2,r2,r3                 |r2 = Halves * 12 * Preset/28 = Halves*6 when preset = 14
0007cfd4: 01422023 subu r4,r10,r2                |r4 = final height = -(height*12 + halves*12*preset/28) 
0007cfd8: 00041400 sll r2,r4,0x10                |
0007cfdc: 00021403 sra r2,r2,0x10                |r2 = final height with clean register
0007cfe0: 8fbf0020 lw r31,0x0020(r29)            |
0007cfe4: 8fb1001c lw r17,0x001c(r29)            |
0007cfe8: 8fb00018 lw r16,0x0018(r29)            |
0007cfec: 27bd0028 addiu r29,r29,0x0028          |
0007cff0: 03e00008 jr r31                   END
0007cff4: 00000000 nop

Notes


For notes below, (preset X)/28 will be refered as X and (preset Y/28) as Y. (1-preset/28) will be refered as anti-preset
So X, Y, Anti-X, Anti-Y (...)

Here is the details per slope type
 0x11 : X or Anti-Y (smallest value)
 0x14 : Anti-X or Anti-Y (smallest value)
 0x25 : Anti-Y (always)
 0x41 : X or Y (smallest value)
 0x44 : Anti-X or Y (smallest value)
 0x52 : X (always)
 0x58 : Anti-X (always)
 0x66 : X or Anti-Y (greatest value)
 0x69 : Anti-X or Anti-Y (greatest value)
 0x85 : Y (always)
 0x96 : X or Y (greatest value)
 0x99 : Anti-X or Y (greatest value)

Return locations

Battle.bin
0007d150: Complex_Height_Data_from_unit_misc_data_and_coordinates - When call by 0007d51c_-_0007d5cc X preset = Y preset = 14
0007d988: 0007d5d0_-_0007db18
00089144: 000890b8_-_00089248
00089a90: 000898a0_-_00089b9c
00089c9c: 00089ba0_-_00089d9c
0008a03c: 00089f24_-_0008a114
0008cb40: 0008ca7c_-_0008cbb0