| 1 | #include "lolevel.h" |
|---|
| 2 | #include "platform.h" |
|---|
| 3 | #include "core.h" |
|---|
| 4 | |
|---|
| 5 | // TODO ???? |
|---|
| 6 | static long *nrflag = (long*)0xE15C; // in sub_FFAEC6E8 (comp D10) |
|---|
| 7 | |
|---|
| 8 | #include "../../../generic/capt_seq.c" |
|---|
| 9 | |
|---|
| 10 | //void __attribute__((naked,noinline)) hangdebug() { |
|---|
| 11 | // debug_led(1); |
|---|
| 12 | // while(1); |
|---|
| 13 | //} |
|---|
| 14 | |
|---|
| 15 | // @ FF8868C0 in firmware |
|---|
| 16 | void __attribute__((naked,noinline)) capt_seq_task() { |
|---|
| 17 | |
|---|
| 18 | asm volatile ( |
|---|
| 19 | |
|---|
| 20 | "STMFD SP!, {R3-R7,LR}\n" |
|---|
| 21 | "LDR R7, =0x3648\n" |
|---|
| 22 | "LDR R4, =0x3BC24\n" |
|---|
| 23 | "MOV R6, #0\n" |
|---|
| 24 | |
|---|
| 25 | "loc_FF8868D0:\n" |
|---|
| 26 | "LDR R0, [R7,#4]\n" |
|---|
| 27 | "MOV R2, #0\n" |
|---|
| 28 | "MOV R1, SP\n" |
|---|
| 29 | "BL sub_FF83A4C8\n" |
|---|
| 30 | "TST R0, #1\n" |
|---|
| 31 | "BEQ loc_FF8868FC\n" |
|---|
| 32 | "LDR R1, =0x43F\n" |
|---|
| 33 | "LDR R0, =0xFF8863B0\n" //aSsshoottask_c |
|---|
| 34 | "BL _DebugAssert\n" |
|---|
| 35 | "BL _eventproc_export_ExitTask\n" |
|---|
| 36 | "LDMFD SP!, {R3-R7,PC}\n" |
|---|
| 37 | |
|---|
| 38 | "loc_FF8868FC:\n" |
|---|
| 39 | "LDR R0, [SP]\n" |
|---|
| 40 | "LDR R1, [R0]\n" |
|---|
| 41 | "CMP R1, #0x22\n" |
|---|
| 42 | "ADDLS PC, PC, R1,LSL#2\n" |
|---|
| 43 | |
|---|
| 44 | "B loc_FF886B50\n" |
|---|
| 45 | "loc_FF886910: B loc_FF88699C\n" |
|---|
| 46 | "loc_FF886914: B loc_FF8869B4\n" |
|---|
| 47 | "loc_FF886918: B loc_FF8869CC\n" |
|---|
| 48 | "loc_FF88691C: B loc_FF8869EC\n" |
|---|
| 49 | "loc_FF886920: B loc_FF8869E4\n" |
|---|
| 50 | "loc_FF886924: B loc_FF8869F8\n" |
|---|
| 51 | "loc_FF886928: B loc_FF886A00\n" |
|---|
| 52 | "loc_FF88692C: B loc_FF886A08\n" |
|---|
| 53 | "loc_FF886930: B loc_FF886A14\n" |
|---|
| 54 | "loc_FF886934: B loc_FF886A3C\n" |
|---|
| 55 | "loc_FF886938: B loc_FF886A20\n" |
|---|
| 56 | "loc_FF88693C: B loc_FF886A2C\n" |
|---|
| 57 | "loc_FF886940: B loc_FF886A34\n" |
|---|
| 58 | "loc_FF886944: B loc_FF886A44\n" |
|---|
| 59 | "loc_FF886948: B loc_FF886A4C\n" |
|---|
| 60 | "loc_FF88694C: B loc_FF886A54\n" |
|---|
| 61 | "loc_FF886950: B loc_FF886A5C\n" |
|---|
| 62 | "loc_FF886954: B loc_FF886A64\n" |
|---|
| 63 | "loc_FF886958: B loc_FF886A6C\n" |
|---|
| 64 | "loc_FF88695C: B loc_FF886A74\n" |
|---|
| 65 | "loc_FF886960: B loc_FF886A7C\n" |
|---|
| 66 | "loc_FF886964: B loc_FF886A84\n" |
|---|
| 67 | "loc_FF886968: B loc_FF886A8C\n" |
|---|
| 68 | "loc_FF88696C: B loc_FF886A98\n" |
|---|
| 69 | "loc_FF886970: B loc_FF886AA0\n" |
|---|
| 70 | "loc_FF886974: B loc_FF886AAC\n" |
|---|
| 71 | "loc_FF886978: B loc_FF886AB4\n" |
|---|
| 72 | "loc_FF88697C: B loc_FF886AE4\n" |
|---|
| 73 | "loc_FF886980: B loc_FF886AEC\n" |
|---|
| 74 | "loc_FF886984: B loc_FF886AF4\n" |
|---|
| 75 | "loc_FF886988: B loc_FF886AFC\n" |
|---|
| 76 | "loc_FF88698C: B loc_FF886B04\n" |
|---|
| 77 | "loc_FF886990: B loc_FF886B0C\n" |
|---|
| 78 | "loc_FF886994: B loc_FF886B18\n" |
|---|
| 79 | "loc_FF886998: B loc_FF886B5C\n" |
|---|
| 80 | |
|---|
| 81 | // jump table entry 0 |
|---|
| 82 | "loc_FF88699C:\n" |
|---|
| 83 | " BL sub_FF887084 \n" |
|---|
| 84 | |
|---|
| 85 | " BL shooting_expo_param_override\n" // added |
|---|
| 86 | |
|---|
| 87 | " BL sub_FF8840BC \n" |
|---|
| 88 | " LDR R0, [R4,#0x24] \n" |
|---|
| 89 | " CMP R0, #0 \n" |
|---|
| 90 | |
|---|
| 91 | //" BLNE sub_FF992DAC \n" |
|---|
| 92 | " BLNE sub_FF992DAC_my \n" // patched |
|---|
| 93 | |
|---|
| 94 | " B loc_FF886B5C \n" |
|---|
| 95 | |
|---|
| 96 | // jump table entry 1 |
|---|
| 97 | "loc_FF8869B4: \n" |
|---|
| 98 | " LDRH R1, [R4] \n" |
|---|
| 99 | " SUB R12, R1, #0x8200 \n" |
|---|
| 100 | " SUBS R12, R12, #0x2E \n" |
|---|
| 101 | " LDRNE R0, [R0,#0xC] \n" |
|---|
| 102 | |
|---|
| 103 | //" BLNE sub_FF992BD8 \n" |
|---|
| 104 | " BLNE sub_FF992BD8_my \n" |
|---|
| 105 | |
|---|
| 106 | " B loc_FF886B5C \n" |
|---|
| 107 | |
|---|
| 108 | // jump table entry 2 |
|---|
| 109 | "loc_FF8869CC: \n" |
|---|
| 110 | " MOV R0, #1 \n" |
|---|
| 111 | " BL sub_FF88739C \n" |
|---|
| 112 | " LDR R0, [R4,#0xC]\n" |
|---|
| 113 | " CMP R0, #0\n" |
|---|
| 114 | " BLNE sub_FF888024 \n" |
|---|
| 115 | " B loc_FF886B5C \n" |
|---|
| 116 | |
|---|
| 117 | "loc_FF8869E4: \n" |
|---|
| 118 | " BL sub_FF886D20 \n" |
|---|
| 119 | " B loc_FF8869F0 \n" |
|---|
| 120 | |
|---|
| 121 | "loc_FF8869EC: \n" |
|---|
| 122 | " BL sub_FF887064 \n" |
|---|
| 123 | "loc_FF8869F0: \n" |
|---|
| 124 | " STR R6, [R4,#0x24] \n" |
|---|
| 125 | " B loc_FF886B5C \n" |
|---|
| 126 | |
|---|
| 127 | "loc_FF8869F8: \n" |
|---|
| 128 | " BL sub_FF88706C \n" |
|---|
| 129 | " B loc_FF886B5C \n" |
|---|
| 130 | |
|---|
| 131 | "loc_FF886A00: \n" |
|---|
| 132 | " BL sub_FF887270 \n" |
|---|
| 133 | " B loc_FF886A18 \n" |
|---|
| 134 | |
|---|
| 135 | "loc_FF886A08: \n" |
|---|
| 136 | " LDR R0, [R0,#0xC] \n" |
|---|
| 137 | " BL sub_FF992E14 \n" |
|---|
| 138 | " B loc_FF886B5C \n" |
|---|
| 139 | |
|---|
| 140 | "loc_FF886A14: \n" |
|---|
| 141 | " BL sub_FF88730C \n" |
|---|
| 142 | "loc_FF886A18: \n" |
|---|
| 143 | " BL sub_FF8840BC \n" |
|---|
| 144 | " B loc_FF886B5C \n" |
|---|
| 145 | |
|---|
| 146 | "loc_FF886A20: \n" |
|---|
| 147 | " LDR R0, [R4,#0x54] \n" |
|---|
| 148 | " BL sub_FF887A5C \n" |
|---|
| 149 | " B loc_FF886B5C \n" |
|---|
| 150 | |
|---|
| 151 | "loc_FF886A2C: \n" |
|---|
| 152 | " BL sub_FF887DDC \n" |
|---|
| 153 | " B loc_FF886B5C \n" |
|---|
| 154 | |
|---|
| 155 | "loc_FF886A34: \n" |
|---|
| 156 | " BL sub_FF887E40 \n" |
|---|
| 157 | " B loc_FF886B5C \n" |
|---|
| 158 | |
|---|
| 159 | "loc_FF886A3C: \n" |
|---|
| 160 | " BL sub_FF887064 \n" |
|---|
| 161 | " B loc_FF886B5C \n" |
|---|
| 162 | |
|---|
| 163 | "loc_FF886A44: \n" |
|---|
| 164 | " BL sub_FF991BB4 \n" |
|---|
| 165 | " B loc_FF886B5C \n" |
|---|
| 166 | |
|---|
| 167 | "loc_FF886A4C: \n" |
|---|
| 168 | " BL sub_FF991E04 \n" |
|---|
| 169 | " B loc_FF886B5C \n" |
|---|
| 170 | |
|---|
| 171 | "loc_FF886A54: \n" |
|---|
| 172 | " BL sub_FF991ED0 \n" |
|---|
| 173 | " B loc_FF886B5C \n" |
|---|
| 174 | |
|---|
| 175 | "loc_FF886A5C: \n" |
|---|
| 176 | " BL sub_FF991FE4 \n" |
|---|
| 177 | " B loc_FF886B5C \n" |
|---|
| 178 | |
|---|
| 179 | "loc_FF886A64: \n" |
|---|
| 180 | " BL sub_FF9920B4 \n" |
|---|
| 181 | " B loc_FF886B5C \n" |
|---|
| 182 | |
|---|
| 183 | "loc_FF886A6C: \n" |
|---|
| 184 | " MOV R0, #0 \n" |
|---|
| 185 | " B loc_FF886A90 \n" |
|---|
| 186 | |
|---|
| 187 | "loc_FF886A74: \n" |
|---|
| 188 | " BL sub_FF9926C8 \n" |
|---|
| 189 | " B loc_FF886B5C \n" |
|---|
| 190 | |
|---|
| 191 | "loc_FF886A7C: \n" |
|---|
| 192 | " BL sub_FF992760 \n" |
|---|
| 193 | " B loc_FF886B5C \n" |
|---|
| 194 | |
|---|
| 195 | "loc_FF886A84: \n" |
|---|
| 196 | " BL sub_FF992840 \n" |
|---|
| 197 | " B loc_FF886B5C \n" |
|---|
| 198 | |
|---|
| 199 | "loc_FF886A8C: \n" |
|---|
| 200 | " MOV R0, #1 \n" |
|---|
| 201 | "loc_FF886A90: \n" |
|---|
| 202 | " BL sub_FF99256C \n" |
|---|
| 203 | " B loc_FF886B5C \n" |
|---|
| 204 | |
|---|
| 205 | "loc_FF886A98: \n" |
|---|
| 206 | " BL sub_FF8875D8 \n" |
|---|
| 207 | " B loc_FF886B5C \n" |
|---|
| 208 | |
|---|
| 209 | "loc_FF886AA0: \n" |
|---|
| 210 | " BL sub_FF887680 \n" |
|---|
| 211 | " BL sub_FF993A74 \n" |
|---|
| 212 | " B loc_FF886B5C \n" |
|---|
| 213 | |
|---|
| 214 | "loc_FF886AAC: \n" |
|---|
| 215 | " BL sub_FF992394 \n" |
|---|
| 216 | " B loc_FF886B5C \n" |
|---|
| 217 | |
|---|
| 218 | "loc_FF886AB4: \n" |
|---|
| 219 | " MOV R2, #2 \n" |
|---|
| 220 | " ADD R1, R4, #0x68 \n" |
|---|
| 221 | " MOV R0, #0x6F \n" |
|---|
| 222 | " BL _PT_GetPropertyCaseString \n" |
|---|
| 223 | " TST R0, #1 \n" |
|---|
| 224 | " LDRNE R1, =0x531 \n" |
|---|
| 225 | " LDRNE R0, =0xFF8863B0 \n" //=aSsshoottask_c |
|---|
| 226 | " BLNE _DebugAssert \n" |
|---|
| 227 | " LDRH R0, [R4,#0x68] \n" |
|---|
| 228 | " CMP R0, #1 \n" |
|---|
| 229 | " BLEQ sub_FF992388 \n" |
|---|
| 230 | " B loc_FF886B5C \n" |
|---|
| 231 | |
|---|
| 232 | "loc_FF886AE4: \n" |
|---|
| 233 | " BL sub_FF9924C0 \n" |
|---|
| 234 | " B loc_FF886B5C \n" |
|---|
| 235 | |
|---|
| 236 | "loc_FF886AEC: \n" |
|---|
| 237 | " BL sub_FF993B44 \n" |
|---|
| 238 | " B loc_FF886B5C \n" |
|---|
| 239 | |
|---|
| 240 | "loc_FF886AF4: \n" |
|---|
| 241 | " BL sub_FF837D44 \n" |
|---|
| 242 | " B loc_FF886B5C \n" |
|---|
| 243 | |
|---|
| 244 | "loc_FF886AFC: \n" |
|---|
| 245 | " BL sub_FF88A2D8 \n" |
|---|
| 246 | " B loc_FF886B5C \n" |
|---|
| 247 | |
|---|
| 248 | "loc_FF886B04: \n" |
|---|
| 249 | " BL sub_FF88A360 \n" |
|---|
| 250 | " B loc_FF886B5C \n" |
|---|
| 251 | |
|---|
| 252 | "loc_FF886B0C: \n" |
|---|
| 253 | " BL sub_FF88A3BC \n" |
|---|
| 254 | " BL sub_FF88A37C \n" |
|---|
| 255 | " B loc_FF886B5C \n" |
|---|
| 256 | |
|---|
| 257 | "loc_FF886B18: \n" |
|---|
| 258 | " MOV R0, #1 \n" |
|---|
| 259 | " BL sub_FF9935B0 \n" |
|---|
| 260 | " MOV R0, #1 \n" |
|---|
| 261 | " BL sub_FF9936E0 \n" |
|---|
| 262 | " LDRH R0, [R4,#0xA4] \n" |
|---|
| 263 | " CMP R0, #4 \n" |
|---|
| 264 | " LDRNEH R0, [R4] \n" |
|---|
| 265 | " SUBNE R12, R0, #0x4200 \n" |
|---|
| 266 | " SUBNES R12, R12, #0x2A \n" |
|---|
| 267 | " BNE loc_FF886B5C \n" |
|---|
| 268 | " BL sub_FF88A360 \n" |
|---|
| 269 | " BL sub_FF88A8D4 \n" |
|---|
| 270 | " BL sub_FF88A7DC \n" |
|---|
| 271 | " B loc_FF886B5C \n" |
|---|
| 272 | |
|---|
| 273 | "loc_FF886B50: \n" |
|---|
| 274 | " LDR R1, =0x591 \n" |
|---|
| 275 | " LDR R0, =0xFF8863B0 \n" // "SsShootTask.c" |
|---|
| 276 | " BL _DebugAssert \n" |
|---|
| 277 | |
|---|
| 278 | "loc_FF886B5C: \n" |
|---|
| 279 | " LDR R0, [SP] \n" |
|---|
| 280 | " LDR R1, [R0,#4] \n" |
|---|
| 281 | " LDR R0, [R7] \n" |
|---|
| 282 | " BL sub_FF891798 \n" |
|---|
| 283 | " LDR R5, [SP] \n" |
|---|
| 284 | " LDR R0, [R5,#8] \n" |
|---|
| 285 | " CMP R0, #0 \n" |
|---|
| 286 | " LDREQ R1, =0x115 \n" |
|---|
| 287 | " LDREQ R0, =0xFF8863B0 \n" // "SsShootTask.c" |
|---|
| 288 | " BLEQ _DebugAssert \n" |
|---|
| 289 | " STR R6, [R5,#8] \n" |
|---|
| 290 | " B loc_FF8868D0 \n" |
|---|
| 291 | ); |
|---|
| 292 | } |
|---|
| 293 | |
|---|
| 294 | void __attribute__((naked,noinline)) sub_FF992BD8_my(){ |
|---|
| 295 | asm volatile( |
|---|
| 296 | " STMFD SP!, {R3-R7,LR} \n" |
|---|
| 297 | " LDR R5, =0x3BC24 \n" |
|---|
| 298 | " MOV R4, R0 \n" |
|---|
| 299 | " LDR R0, [R5,#0x24] \n" |
|---|
| 300 | " MOV R6, #0 \n" |
|---|
| 301 | " CMP R0, #0 \n" |
|---|
| 302 | " BNE loc_FF992C14 \n" |
|---|
| 303 | " MOV R0, #0xC \n" |
|---|
| 304 | " BL sub_FF88C648 \n" |
|---|
| 305 | " TST R0, #1 \n" |
|---|
| 306 | " MOVNE R2, R4 \n" |
|---|
| 307 | " LDMNEFD SP!, {R3-R7,LR} \n" |
|---|
| 308 | " MOVNE R1, #1 \n" |
|---|
| 309 | " MOVNE R0, #1 \n" |
|---|
| 310 | " BNE sub_FF884798 \n" |
|---|
| 311 | |
|---|
| 312 | "loc_FF992C14: \n" |
|---|
| 313 | " LDR R0, [R4,#8] \n" |
|---|
| 314 | " LDR R7, =0x420C \n" |
|---|
| 315 | " ORR R0, R0, #1 \n" |
|---|
| 316 | " STR R0, [R4,#8] \n" |
|---|
| 317 | " LDRH R0, [R5] \n" |
|---|
| 318 | " CMP R0, R7 \n" |
|---|
| 319 | " BEQ loc_FF992CA4 \n" |
|---|
| 320 | " LDRH R0, [R5,#0xA2] \n" |
|---|
| 321 | " CMP R0, #3 \n" |
|---|
| 322 | " BEQ loc_FF992CEC \n" |
|---|
| 323 | " LDR R0, [R4,#0xC] \n" |
|---|
| 324 | " CMP R0, #1 \n" |
|---|
| 325 | " BLS loc_FF992CB0 \n" |
|---|
| 326 | " LDRH R0, [R5,#0xA0] \n" |
|---|
| 327 | " CMP R0, #0 \n" |
|---|
| 328 | " BNE loc_FF992CEC \n" |
|---|
| 329 | " LDRH R0, [R5,#0x9C] \n" |
|---|
| 330 | " CMP R0, #2 \n" |
|---|
| 331 | " BNE loc_FF992CBC \n" |
|---|
| 332 | " BL sub_FF887740 \n" |
|---|
| 333 | " LDRH R0, [R5] \n" |
|---|
| 334 | " CMP R0, R7 \n" |
|---|
| 335 | " BEQ loc_FF992CA4 \n" |
|---|
| 336 | " LDRH R0, [R5,#0xA2] \n" |
|---|
| 337 | " CMP R0, #3 \n" |
|---|
| 338 | " BEQ loc_FF992CEC \n" |
|---|
| 339 | " LDR R0, [R4,#0xC] \n" |
|---|
| 340 | " CMP R0, #1 \n" |
|---|
| 341 | " BLS loc_FF992CB0 \n" |
|---|
| 342 | " LDRH R0, [R5,#0xA0] \n" |
|---|
| 343 | " CMP R0, #0 \n" |
|---|
| 344 | " BNE loc_FF992CEC \n" |
|---|
| 345 | " LDRH R0, [R5,#0x9C] \n" |
|---|
| 346 | " CMP R0, #2 \n" |
|---|
| 347 | " BEQ loc_FF992CE8 \n" |
|---|
| 348 | " B loc_FF992CBC \n" |
|---|
| 349 | |
|---|
| 350 | "loc_FF992CA4: \n" |
|---|
| 351 | " LDRH R0, [R5,#0xA2] \n" |
|---|
| 352 | " CMP R0, #3 \n" |
|---|
| 353 | " BEQ loc_FF992CEC \n" |
|---|
| 354 | |
|---|
| 355 | "loc_FF992CB0: \n" |
|---|
| 356 | " LDRH R0, [R5,#0xA0] \n" |
|---|
| 357 | " CMP R0, #0 \n" |
|---|
| 358 | " BNE loc_FF992CEC \n" |
|---|
| 359 | |
|---|
| 360 | "loc_FF992CBC: \n" |
|---|
| 361 | " LDRH R0, [R5,#0x9C] \n" |
|---|
| 362 | " CMP R0, #1 \n" |
|---|
| 363 | " BNE loc_FF992CEC \n" |
|---|
| 364 | " LDRH R0, [R5] \n" |
|---|
| 365 | " CMP R0, R7 \n" |
|---|
| 366 | " LDRNE R0, [R4,#0xC] \n" |
|---|
| 367 | " CMPNE R0, #1 \n" |
|---|
| 368 | " BLS loc_FF992CEC \n" |
|---|
| 369 | " LDR R0, [R4,#0x10] \n" |
|---|
| 370 | " CMP R0, #1 \n" |
|---|
| 371 | " BNE loc_FF992CEC \n" |
|---|
| 372 | |
|---|
| 373 | "loc_FF992CE8: \n" |
|---|
| 374 | " BL sub_FF993B7C \n" |
|---|
| 375 | |
|---|
| 376 | "loc_FF992CEC: \n" |
|---|
| 377 | " BL sub_FF993B44 \n" |
|---|
| 378 | " BL sub_FF887074 \n" |
|---|
| 379 | " LDR R0, [R5,#0x24] \n" // before shot XXX |
|---|
| 380 | " CMP R0, #0 \n" |
|---|
| 381 | " BNE loc_FF992D84 \n" |
|---|
| 382 | " MOV R0, R4 \n" |
|---|
| 383 | " BL sub_FFAEC1EC \n" |
|---|
| 384 | " TST R0, #1 \n" |
|---|
| 385 | " BNE locret_FF992DA8 \n" |
|---|
| 386 | " MOV R0, R4 \n" |
|---|
| 387 | " BL sub_FFAEC600 \n" |
|---|
| 388 | " BL sub_FF993384 \n" |
|---|
| 389 | " MOV R6, #1 \n" |
|---|
| 390 | " MOV R0, #2 \n" |
|---|
| 391 | " BL sub_FF87FD8C \n" // after pre-flash, before shot XXX |
|---|
| 392 | |
|---|
| 393 | "BL wait_until_remote_button_is_released\n" |
|---|
| 394 | "BL capt_seq_hook_set_nr\n" // + |
|---|
| 395 | |
|---|
| 396 | " LDRH R0, [R5] \n" |
|---|
| 397 | " SUB R12, R0, #0x8200 \n" |
|---|
| 398 | " SUBS R12, R12, #0x2D \n" |
|---|
| 399 | " BNE loc_FF992D74 \n" |
|---|
| 400 | " MOV R2, #2 \n" |
|---|
| 401 | " ADD R0, R2, #0x15C \n" |
|---|
| 402 | " MOV R1, SP \n" |
|---|
| 403 | " STR R6, [SP] \n" |
|---|
| 404 | " BL _PT_GetPropertyCaseString \n" |
|---|
| 405 | " TST R0, #1 \n" |
|---|
| 406 | " MOVNE R1, #0xC3 \n" |
|---|
| 407 | //" ADRNE R0, aSscaptureseq_c \n" |
|---|
| 408 | " LDRNE R0, =0xFF992E88 \n" |
|---|
| 409 | " BLNE _DebugAssert \n" |
|---|
| 410 | " LDRH R0, [SP] \n" |
|---|
| 411 | " CMP R0, #1 \n" |
|---|
| 412 | " STRHI R6, [R4,#0xD4] \n" |
|---|
| 413 | " BHI loc_FF992D94 \n" |
|---|
| 414 | " MOV R0, #0 \n" |
|---|
| 415 | " STR R0, [R4,#0xD4] \n" |
|---|
| 416 | |
|---|
| 417 | "loc_FF992D74: \n" |
|---|
| 418 | " MOV R0, R4 \n" |
|---|
| 419 | //" BL sub_FFAECAF8 \n" // main flash / shot XXX |
|---|
| 420 | " BL sub_FFAECAF8_my \n" // main flash / shot XXX |
|---|
| 421 | " MOV R6, R0 \n" |
|---|
| 422 | " B loc_FF992D98 \n" |
|---|
| 423 | |
|---|
| 424 | "loc_FF992D84: \n" |
|---|
| 425 | " LDR R0, =0x85AC \n" |
|---|
| 426 | " LDR R0, [R0] \n" |
|---|
| 427 | " CMP R0, #0 \n" |
|---|
| 428 | " BEQ loc_FF992D98 \n" |
|---|
| 429 | |
|---|
| 430 | "loc_FF992D94: \n" |
|---|
| 431 | " MOV R6, #0x1D \n" |
|---|
| 432 | |
|---|
| 433 | "loc_FF992D98: \n" |
|---|
| 434 | " MOV R1, R6 \n" |
|---|
| 435 | " MOV R0, R4 \n" |
|---|
| 436 | " LDMFD SP!, {R3-R7,LR} \n" |
|---|
| 437 | " B sub_FFAEC310 \n" |
|---|
| 438 | |
|---|
| 439 | "locret_FF992DA8: \n" |
|---|
| 440 | " LDMFD SP!, {R3-R7,PC} \n" |
|---|
| 441 | ); |
|---|
| 442 | } |
|---|
| 443 | |
|---|
| 444 | void __attribute__((naked,noinline)) sub_FF992DAC_my(){ |
|---|
| 445 | asm volatile( |
|---|
| 446 | " STMFD SP!, {R4-R6,LR} \n" |
|---|
| 447 | " BL sub_FF886080 \n" |
|---|
| 448 | " MOV R4, R0 \n" |
|---|
| 449 | " LDR R0, =0x3BC24 \n" |
|---|
| 450 | " LDR R5, =0x85AC \n" |
|---|
| 451 | " LDR R0, [R0,#0x24] \n" |
|---|
| 452 | " MOV R6, #1 \n" |
|---|
| 453 | " CMP R0, #0 \n" |
|---|
| 454 | " BEQ loc_FF992DF0 \n" |
|---|
| 455 | " MOV R0, #0xC \n" |
|---|
| 456 | " BL sub_FF88C648 \n" |
|---|
| 457 | " TST R0, #1 \n" |
|---|
| 458 | " STRNE R6, [R5] \n" |
|---|
| 459 | " LDRNE R0, [R4,#8] \n" |
|---|
| 460 | " ORRNE R0, R0, #0x40000000 \n" |
|---|
| 461 | " STRNE R0, [R4,#8] \n" |
|---|
| 462 | " LDMNEFD SP!, {R4-R6,PC} \n" |
|---|
| 463 | "loc_FF992DF0: \n" |
|---|
| 464 | " MOV R0, R4 \n" |
|---|
| 465 | " BL sub_FF9929B0 \n" |
|---|
| 466 | " MOV R0, R4 \n" |
|---|
| 467 | " BL sub_FFAEC170 \n" |
|---|
| 468 | " MOV R0, R4 \n" |
|---|
| 469 | |
|---|
| 470 | //" BL sub_FFAECAF8 \n" |
|---|
| 471 | " BL sub_FFAECAF8_my \n" // patched |
|---|
| 472 | |
|---|
| 473 | " TST R0, #1 \n" |
|---|
| 474 | " STRNE R6, [R5] \n" |
|---|
| 475 | " LDMFD SP!, {R4-R6,PC} \n" |
|---|
| 476 | ); |
|---|
| 477 | } |
|---|
| 478 | |
|---|
| 479 | void __attribute__((naked,noinline)) sub_FFAECAF8_my(){ |
|---|
| 480 | asm volatile( |
|---|
| 481 | " STMFD SP!, {R2-R6,LR} \n" |
|---|
| 482 | " MOV R5, R0 \n" |
|---|
| 483 | " BL sub_FF9938A4 \n" |
|---|
| 484 | //" MOVL R1, 0xFFFFFFFF \n" |
|---|
| 485 | " MVN R1, #0 \n" |
|---|
| 486 | " BL sub_FF8917CC \n" |
|---|
| 487 | " LDR R0, =0xFFAEC38C \n" //sub_FFAEC38C |
|---|
| 488 | " MOV R1, R5 \n" |
|---|
| 489 | " BL sub_FF8C6444 \n" |
|---|
| 490 | " MOV R0, R5 \n" |
|---|
| 491 | " BL sub_FFAEC298 \n" |
|---|
| 492 | " MOV R0, R5 \n" |
|---|
| 493 | " BL sub_FFAEC6E8 \n" |
|---|
| 494 | " MOV R4, R0 \n" |
|---|
| 495 | " LDR R1, =0xE164 \n" |
|---|
| 496 | " MOV R0, #0x8A \n" |
|---|
| 497 | " MOV R2, #4 \n" |
|---|
| 498 | " BL _PT_GetPropertyCaseString \n" |
|---|
| 499 | " TST R0, #1 \n" |
|---|
| 500 | " LDRNE R1, =0x1F6 \n" |
|---|
| 501 | //" ADRNE R0, aSsstandardcapt ; "SsStandardCaptureSeq.c" \n" |
|---|
| 502 | " LDRNE R0, =0xFFAECC80 \n" |
|---|
| 503 | " BLNE _DebugAssert \n" |
|---|
| 504 | " BL sub_FF889A00 \n" |
|---|
| 505 | " MOV R0, R4 \n" |
|---|
| 506 | " CMP R0, #1 \n" |
|---|
| 507 | " MOV R4, #0 \n" |
|---|
| 508 | " BEQ loc_FFAECB98 \n" |
|---|
| 509 | " CMP R0, #2 \n" |
|---|
| 510 | " BEQ loc_FFAECBA8 \n" |
|---|
| 511 | " CMP R0, #3 \n" |
|---|
| 512 | " BEQ loc_FFAECBCC \n" |
|---|
| 513 | " CMP R0, #7 \n" |
|---|
| 514 | " BNE loc_FFAECBE8 \n" |
|---|
| 515 | " MOV R0, #0 \n" |
|---|
| 516 | " BL sub_FF8C6474 \n" |
|---|
| 517 | " MOV R0, #4 \n" |
|---|
| 518 | " STR R0, [SP,#0x4] \n" |
|---|
| 519 | |
|---|
| 520 | "loc_FFAECB88: \n" |
|---|
| 521 | " ADD R1, SP, #0x4 \n" |
|---|
| 522 | " MOV R0, R5 \n" |
|---|
| 523 | " BL sub_FFAEC95C \n" |
|---|
| 524 | " B loc_FFAECBC4 \n" |
|---|
| 525 | |
|---|
| 526 | "loc_FFAECB98: \n" |
|---|
| 527 | " MOV R0, #1 \n" |
|---|
| 528 | " BL sub_FF8C6474 \n" |
|---|
| 529 | " STR R4, [SP,#0x4] \n" |
|---|
| 530 | " B loc_FFAECB88 \n" |
|---|
| 531 | |
|---|
| 532 | "loc_FFAECBA8: \n" |
|---|
| 533 | " MOV R0, #1 \n" |
|---|
| 534 | " BL sub_FF8C6474 \n" |
|---|
| 535 | " MOV R0, #1 \n" |
|---|
| 536 | " STR R0, [SP,#0x4] \n" |
|---|
| 537 | " MOV R0, R5 \n" |
|---|
| 538 | " ADD R1, SP, #0x4 \n" |
|---|
| 539 | " BL sub_FFAECD54 \n" |
|---|
| 540 | |
|---|
| 541 | "loc_FFAECBC4: \n" |
|---|
| 542 | |
|---|
| 543 | " BL capt_seq_hook_raw_here\n" // added (16/2/2011, moved here so that long exposures work) |
|---|
| 544 | |
|---|
| 545 | " MOV R6, R0 \n" |
|---|
| 546 | " B loc_FFAECBF4 \n" |
|---|
| 547 | |
|---|
| 548 | "loc_FFAECBCC: \n" |
|---|
| 549 | " MOV R0, #1 \n" |
|---|
| 550 | " BL sub_FF8C6474 \n" |
|---|
| 551 | " ADD R1, SP, #0x4 \n" |
|---|
| 552 | " MOV R0, R5 \n" |
|---|
| 553 | " STR R4, [SP,#0x4] \n" |
|---|
| 554 | " BL sub_FFAEC9D8 \n" |
|---|
| 555 | " B loc_FFAECBC4 \n" |
|---|
| 556 | |
|---|
| 557 | "loc_FFAECBE8: \n" |
|---|
| 558 | " MOV R1, #0x22C \n" |
|---|
| 559 | //" ADR R0, aSsstandardcapt ; "SsStandardCaptureSeq.c" \n" |
|---|
| 560 | " LDR R0, =0xFFAECC80 \n" |
|---|
| 561 | " BL _DebugAssert \n" |
|---|
| 562 | |
|---|
| 563 | "loc_FFAECBF4: \n" |
|---|
| 564 | " TST R6, #1 \n" |
|---|
| 565 | " MOVNE R0, R6 \n" |
|---|
| 566 | " BNE locret_FFAECC60 \n" |
|---|
| 567 | " MOV R1, #0 \n" |
|---|
| 568 | //" ADR R0, nullsub_371 \n" |
|---|
| 569 | " LDR R0, =0xFFAEC8CC \n" |
|---|
| 570 | " BL sub_FF8C6444 \n" |
|---|
| 571 | " LDR R0, =0x3BC24 \n" |
|---|
| 572 | " LDRH R0, [R0] \n" |
|---|
| 573 | " SUB R12, R0, #0x4000 \n" |
|---|
| 574 | " SUBS R12, R12, #0x20C \n" |
|---|
| 575 | " BLEQ sub_FF8AF950 \n" |
|---|
| 576 | " MOV R0, R5 \n" |
|---|
| 577 | " BL sub_FFAEC790 \n" |
|---|
| 578 | " BL sub_FF9938A4 \n" |
|---|
| 579 | " MOV R3, #0x244 \n" |
|---|
| 580 | " STR R3, [SP] \n" |
|---|
| 581 | " LDR R2, =0x3A98 \n" |
|---|
| 582 | //" ADR R3, aSsstandardcapt ; "SsStandardCaptureSeq.c" \n" |
|---|
| 583 | " LDR R3, =0xFFAECC80 \n" |
|---|
| 584 | " MOV R1, #4 \n" |
|---|
| 585 | " BL sub_FF88C9C4 \n" |
|---|
| 586 | " CMP R0, #0 \n" |
|---|
| 587 | " MOVNE R1, #0x244 \n" |
|---|
| 588 | //" ADRNE R0, aSsstandardcapt ; "SsStandardCaptureSeq.c" \n" |
|---|
| 589 | " LDRNE R0, =0xFFAECC80 \n" |
|---|
| 590 | " BLNE _DebugAssert \n" |
|---|
| 591 | " LDRH R0, [SP,#0x4] \n" |
|---|
| 592 | " STRH R0, [R5,#0x14] \n" |
|---|
| 593 | " MOV R0, #0 \n" |
|---|
| 594 | |
|---|
| 595 | "locret_FFAECC60: \n" |
|---|
| 596 | " LDMFD SP!, {R2-R6,PC} \n" |
|---|
| 597 | ); |
|---|
| 598 | } |
|---|
| 599 | |
|---|
| 600 | /*************************************************************/ |
|---|
| 601 | // @ FF8D0818 |
|---|
| 602 | void __attribute__((naked,noinline)) exp_drv_task(){ |
|---|
| 603 | |
|---|
| 604 | asm volatile( |
|---|
| 605 | " STMFD SP!, {R4-R8,LR} \n" |
|---|
| 606 | " SUB SP, SP, #0x20 \n" |
|---|
| 607 | " LDR R8, =0xBB8 \n" |
|---|
| 608 | " LDR R7, =0x5094 \n" |
|---|
| 609 | " LDR R5, =0x57870 \n" |
|---|
| 610 | " MOV R0, #0 \n" |
|---|
| 611 | " ADD R6, SP, #0x10 \n" |
|---|
| 612 | " STR R0, [SP,#0x0C] \n" |
|---|
| 613 | |
|---|
| 614 | "loc_FF8D0838: \n" |
|---|
| 615 | " LDR R0, [R7,#0x20] \n" |
|---|
| 616 | " MOV R2, #0 \n" |
|---|
| 617 | " ADD R1, SP, #0x1C \n" |
|---|
| 618 | " BL sub_FF83A4C8 \n" |
|---|
| 619 | " LDR R0, [SP,#0x0C] \n" |
|---|
| 620 | " CMP R0, #1 \n" |
|---|
| 621 | " BNE loc_FF8D0884 \n" |
|---|
| 622 | " LDR R0, [SP,#0x1C] \n" |
|---|
| 623 | " LDR R0, [R0] \n" |
|---|
| 624 | " CMP R0, #0x14 \n" |
|---|
| 625 | " CMPNE R0, #0x15 \n" |
|---|
| 626 | " CMPNE R0, #0x16 \n" |
|---|
| 627 | " CMPNE R0, #0x17 \n" |
|---|
| 628 | " BEQ loc_FF8D09E8 \n" |
|---|
| 629 | " CMP R0, #0x29 \n" |
|---|
| 630 | " BEQ loc_FF8D0970 \n" |
|---|
| 631 | " ADD R1, SP, #0x0C \n" |
|---|
| 632 | " MOV R0, #0 \n" |
|---|
| 633 | " BL sub_FF8D07C8 \n" |
|---|
| 634 | |
|---|
| 635 | "loc_FF8D0884: \n" |
|---|
| 636 | " LDR R0, [SP,#0x1C] \n" |
|---|
| 637 | " LDR R1, [R0] \n" |
|---|
| 638 | " CMP R1, #0x2F \n" |
|---|
| 639 | " BNE loc_FF8D08B4 \n" |
|---|
| 640 | " LDR R0, [SP,#0x1C] \n" |
|---|
| 641 | " BL sub_FF8D1BBC \n" |
|---|
| 642 | " LDR R0, [R7,#0x1C] \n" |
|---|
| 643 | " MOV R1, #1 \n" |
|---|
| 644 | " BL sub_FF891798 \n" |
|---|
| 645 | " BL _eventproc_export_ExitTask \n" |
|---|
| 646 | " ADD SP, SP, #0x20 \n" |
|---|
| 647 | " LDMFD SP!, {R4-R8,PC} \n" |
|---|
| 648 | |
|---|
| 649 | "loc_FF8D08B4: \n" |
|---|
| 650 | " CMP R1, #0x2E \n" |
|---|
| 651 | " BNE loc_FF8D08D0 \n" |
|---|
| 652 | " LDR R2, [R0,#0x8C]! \n" |
|---|
| 653 | " LDR R1, [R0,#4] \n" |
|---|
| 654 | " MOV R0, R1 \n" |
|---|
| 655 | " BLX R2 \n" |
|---|
| 656 | " B loc_FF8D0EA4 \n" |
|---|
| 657 | |
|---|
| 658 | "loc_FF8D08D0: \n" |
|---|
| 659 | " CMP R1, #0x27 \n" |
|---|
| 660 | " BNE loc_FF8D0920 \n" |
|---|
| 661 | " LDR R0, [R7,#0x1C] \n" |
|---|
| 662 | " MOV R1, #0x80 \n" |
|---|
| 663 | " BL sub_FF8917CC \n" |
|---|
| 664 | " LDR R0, =0xFF8CC678 \n" |
|---|
| 665 | " MOV R1, #0x80 \n" |
|---|
| 666 | " BL sub_FF97F6E4 \n" |
|---|
| 667 | " LDR R0, [R7,#0x1C] \n" |
|---|
| 668 | " MOV R2, R8 \n" |
|---|
| 669 | " MOV R1, #0x80 \n" |
|---|
| 670 | " BL sub_FF8916D8 \n" |
|---|
| 671 | " TST R0, #1 \n" |
|---|
| 672 | " LDRNE R1, =0x1089 \n" |
|---|
| 673 | " BNE loc_FF8D09DC \n" |
|---|
| 674 | |
|---|
| 675 | "loc_FF8D090C: \n" |
|---|
| 676 | " LDR R1, [SP,#0x1C] \n" |
|---|
| 677 | " LDR R0, [R1,#0x90] \n" |
|---|
| 678 | " LDR R1, [R1,#0x8C] \n" |
|---|
| 679 | " BLX R1 \n" |
|---|
| 680 | " B loc_FF8D0EA4 \n" |
|---|
| 681 | |
|---|
| 682 | "loc_FF8D0920: \n" |
|---|
| 683 | " CMP R1, #0x28 \n" |
|---|
| 684 | " BNE loc_FF8D0968 \n" |
|---|
| 685 | " ADD R1, SP, #0x0C \n" |
|---|
| 686 | " BL sub_FF8D07C8 \n" |
|---|
| 687 | " LDR R0, [R7,#0x1C] \n" |
|---|
| 688 | " MOV R1, #0x100 \n" |
|---|
| 689 | " BL sub_FF8917CC \n" |
|---|
| 690 | " LDR R0, =0xFF8CC688 \n" |
|---|
| 691 | " MOV R1, #0x100 \n" |
|---|
| 692 | " BL sub_FF980114 \n" |
|---|
| 693 | " LDR R0, [R7,#0x1C] \n" |
|---|
| 694 | " MOV R2, R8 \n" |
|---|
| 695 | " MOV R1, #0x100 \n" |
|---|
| 696 | " BL sub_FF8916D8 \n" |
|---|
| 697 | " TST R0, #1 \n" |
|---|
| 698 | " BEQ loc_FF8D090C \n" |
|---|
| 699 | " LDR R1, =0x1093 \n" |
|---|
| 700 | " B loc_FF8D09DC \n" |
|---|
| 701 | |
|---|
| 702 | "loc_FF8D0968: \n" |
|---|
| 703 | " CMP R1, #0x29 \n" |
|---|
| 704 | " BNE loc_FF8D0980 \n" |
|---|
| 705 | |
|---|
| 706 | "loc_FF8D0970: \n" |
|---|
| 707 | " LDR R0, [SP,#0x1C] \n" |
|---|
| 708 | " ADD R1, SP, #0x0C \n" |
|---|
| 709 | " BL sub_FF8D07C8 \n" |
|---|
| 710 | " B loc_FF8D090C \n" |
|---|
| 711 | |
|---|
| 712 | "loc_FF8D0980: \n" |
|---|
| 713 | " CMP R1, #0x2C \n" |
|---|
| 714 | " BNE loc_FF8D0998 \n" |
|---|
| 715 | " BL sub_FF8BEBCC \n" |
|---|
| 716 | " BL sub_FF8BF7D8 \n" |
|---|
| 717 | " BL sub_FF8BF344 \n" |
|---|
| 718 | " B loc_FF8D090C \n" |
|---|
| 719 | |
|---|
| 720 | "loc_FF8D0998: \n" |
|---|
| 721 | " CMP R1, #0x2D \n" |
|---|
| 722 | " BNE loc_FF8D09E8 \n" |
|---|
| 723 | " LDR R0, [R7,#0x1C] \n" |
|---|
| 724 | " MOV R1, #4 \n" |
|---|
| 725 | " BL sub_FF8917CC \n" |
|---|
| 726 | " LDR R1, =0xFF8CC6A8 \n" |
|---|
| 727 | " LDR R0, =0xFFFFF400 \n" |
|---|
| 728 | " MOV R2, #4 \n" |
|---|
| 729 | " BL sub_FF8BE648 \n" |
|---|
| 730 | " BL sub_FF8BE8D0 \n" |
|---|
| 731 | " LDR R0, [R7,#0x1C] \n" |
|---|
| 732 | " MOV R2, R8 \n" |
|---|
| 733 | " MOV R1, #4 \n" |
|---|
| 734 | " BL sub_FF8915F4 \n" |
|---|
| 735 | " TST R0, #1 \n" |
|---|
| 736 | " BEQ loc_FF8D090C \n" |
|---|
| 737 | " LDR R1, =0x10BB \n" |
|---|
| 738 | |
|---|
| 739 | "loc_FF8D09DC: \n" |
|---|
| 740 | " LDR R0, =0xFF8CCD30 \n" |
|---|
| 741 | " BL _DebugAssert \n" |
|---|
| 742 | " B loc_FF8D090C \n" |
|---|
| 743 | |
|---|
| 744 | "loc_FF8D09E8: \n" |
|---|
| 745 | " LDR R0, [SP,#0x1C] \n" |
|---|
| 746 | " MOV R4, #1 \n" |
|---|
| 747 | " LDR R1, [R0] \n" |
|---|
| 748 | " CMP R1, #0x12 \n" |
|---|
| 749 | " CMPNE R1, #0x13 \n" |
|---|
| 750 | " BNE loc_FF8D0A58 \n" |
|---|
| 751 | " LDR R1, [R0,#0x7C] \n" |
|---|
| 752 | " ADD R1, R1, R1,LSL#1 \n" |
|---|
| 753 | " ADD R1, R0, R1,LSL#2 \n" |
|---|
| 754 | " SUB R1, R1, #8 \n" |
|---|
| 755 | " LDMIA R1, {R2-R4} \n" |
|---|
| 756 | " STMIA R6, {R2-R4} \n" |
|---|
| 757 | " BL sub_FF8CEF50 \n" |
|---|
| 758 | " LDR R0, [SP,#0x1C] \n" |
|---|
| 759 | " LDR R1, [R0,#0x7C] \n" |
|---|
| 760 | " LDR R3, [R0,#0x8C] \n" |
|---|
| 761 | " LDR R2, [R0,#0x90] \n" |
|---|
| 762 | " ADD R0, R0, #4 \n" |
|---|
| 763 | " BLX R3 \n" |
|---|
| 764 | " LDR R0, [SP,#0x1C] \n" |
|---|
| 765 | " BL sub_FF8D1FC8 \n" |
|---|
| 766 | " LDR R0, [SP,#0x1C] \n" |
|---|
| 767 | " LDR R1, [R0,#0x7C] \n" |
|---|
| 768 | " LDR R3, [R0,#0x94] \n" |
|---|
| 769 | " LDR R2, [R0,#0x98] \n" |
|---|
| 770 | " ADD R0, R0, #4 \n" |
|---|
| 771 | " BLX R3 \n" |
|---|
| 772 | " B loc_FF8D0DE0 \n" |
|---|
| 773 | |
|---|
| 774 | "loc_FF8D0A58: \n" |
|---|
| 775 | " CMP R1, #0x14 \n" |
|---|
| 776 | " CMPNE R1, #0x15 \n" |
|---|
| 777 | " CMPNE R1, #0x16 \n" |
|---|
| 778 | " CMPNE R1, #0x17 \n" |
|---|
| 779 | " BNE loc_FF8D0B10 \n" |
|---|
| 780 | " ADD R3, SP, #0x0C \n" |
|---|
| 781 | " MOV R2, SP \n" |
|---|
| 782 | " ADD R1, SP, #0x10 \n" |
|---|
| 783 | " BL sub_FF8CF1BC \n" |
|---|
| 784 | " CMP R0, #1 \n" |
|---|
| 785 | " MOV R4, R0 \n" |
|---|
| 786 | " CMPNE R4, #5 \n" |
|---|
| 787 | " BNE loc_FF8D0AAC \n" |
|---|
| 788 | " LDR R0, [SP,#0x1C] \n" |
|---|
| 789 | " MOV R2, R4 \n" |
|---|
| 790 | " LDR R1, [R0,#0x7C]! \n" |
|---|
| 791 | " LDR R12, [R0,#0x10]! \n" |
|---|
| 792 | " LDR R3, [R0,#4] \n" |
|---|
| 793 | " MOV R0, SP \n" |
|---|
| 794 | " BLX R12 \n" |
|---|
| 795 | " B loc_FF8D0AE4 \n" |
|---|
| 796 | |
|---|
| 797 | "loc_FF8D0AAC: \n" |
|---|
| 798 | " LDR R0, [SP,#0x1C] \n" |
|---|
| 799 | " CMP R4, #2 \n" |
|---|
| 800 | " LDR R3, [R0,#0x90] \n" |
|---|
| 801 | " CMPNE R4, #6 \n" |
|---|
| 802 | " BNE loc_FF8D0AF8 \n" |
|---|
| 803 | " LDR R12, [R0,#0x8C] \n" |
|---|
| 804 | " MOV R0, SP \n" |
|---|
| 805 | " MOV R2, R4 \n" |
|---|
| 806 | " MOV R1, #1 \n" |
|---|
| 807 | " BLX R12 \n" |
|---|
| 808 | " LDR R0, [SP,#0x1C] \n" |
|---|
| 809 | " MOV R2, SP \n" |
|---|
| 810 | " ADD R1, SP, #0x10 \n" |
|---|
| 811 | " BL sub_FF8D0514 \n" |
|---|
| 812 | |
|---|
| 813 | "loc_FF8D0AE4: \n" |
|---|
| 814 | " LDR R0, [SP,#0x1C] \n" |
|---|
| 815 | " LDR R2, [SP,#0x0C] \n" |
|---|
| 816 | " MOV R1, R4 \n" |
|---|
| 817 | " BL sub_FF8D0768 \n" |
|---|
| 818 | " B loc_FF8D0DE0 \n" |
|---|
| 819 | |
|---|
| 820 | "loc_FF8D0AF8: \n" |
|---|
| 821 | " LDR R1, [R0,#0x7C] \n" |
|---|
| 822 | " LDR R12, [R0,#0x8C] \n" |
|---|
| 823 | " ADD R0, R0, #4 \n" |
|---|
| 824 | " MOV R2, R4 \n" |
|---|
| 825 | " BLX R12 \n" |
|---|
| 826 | " B loc_FF8D0DE0 \n" |
|---|
| 827 | |
|---|
| 828 | "loc_FF8D0B10: \n" |
|---|
| 829 | " CMP R1, #0x23 \n" |
|---|
| 830 | " CMPNE R1, #0x24 \n" |
|---|
| 831 | " BNE loc_FF8D0B5C \n" |
|---|
| 832 | " LDR R1, [R0,#0x7C] \n" |
|---|
| 833 | " ADD R1, R1, R1,LSL#1 \n" |
|---|
| 834 | " ADD R1, R0, R1,LSL#2 \n" |
|---|
| 835 | " SUB R1, R1, #8 \n" |
|---|
| 836 | " LDMIA R1, {R2-R4} \n" |
|---|
| 837 | " STMIA R6, {R2-R4} \n" |
|---|
| 838 | " BL sub_FF8CDFD4 \n" |
|---|
| 839 | " LDR R0, [SP,#0x1C] \n" |
|---|
| 840 | " LDR R1, [R0,#0x7C] \n" |
|---|
| 841 | " LDR R3, [R0,#0x8C] \n" |
|---|
| 842 | " LDR R2, [R0,#0x90] \n" |
|---|
| 843 | " ADD R0, R0, #4 \n" |
|---|
| 844 | " BLX R3 \n" |
|---|
| 845 | " LDR R0, [SP,#0x1C] \n" |
|---|
| 846 | " BL sub_FF8CE420 \n" |
|---|
| 847 | " B loc_FF8D0DE0 \n" |
|---|
| 848 | |
|---|
| 849 | "loc_FF8D0B5C: \n" |
|---|
| 850 | " ADD R1, R0, #4 \n" |
|---|
| 851 | " LDMIA R1, {R2,R3,R12} \n" |
|---|
| 852 | " STMIA R6, {R2,R3,R12} \n" |
|---|
| 853 | " LDR R1, [R0] \n" |
|---|
| 854 | " CMP R1, #0x26 \n" |
|---|
| 855 | " ADDLS PC, PC, R1,LSL#2 \n" |
|---|
| 856 | " B loc_FF8D0DC0 \n" |
|---|
| 857 | |
|---|
| 858 | "loc_FF8D0B78: \n" |
|---|
| 859 | " B loc_FF8D0C14 \n" |
|---|
| 860 | |
|---|
| 861 | "loc_FF8D0B7C: \n" |
|---|
| 862 | " B loc_FF8D0C14 \n" |
|---|
| 863 | |
|---|
| 864 | "loc_FF8D0B80: \n" |
|---|
| 865 | " B loc_FF8D0C1C \n" |
|---|
| 866 | |
|---|
| 867 | "loc_FF8D0B84: \n" |
|---|
| 868 | " B loc_FF8D0C24 \n" |
|---|
| 869 | |
|---|
| 870 | "loc_FF8D0B88: \n" |
|---|
| 871 | " B loc_FF8D0C24 \n" |
|---|
| 872 | |
|---|
| 873 | "loc_FF8D0B8C: \n" |
|---|
| 874 | " B loc_FF8D0C24 \n" |
|---|
| 875 | |
|---|
| 876 | "loc_FF8D0B90: \n" |
|---|
| 877 | " B loc_FF8D0C14 \n" |
|---|
| 878 | |
|---|
| 879 | "loc_FF8D0B94: \n" |
|---|
| 880 | " B loc_FF8D0C1C \n" |
|---|
| 881 | |
|---|
| 882 | "loc_FF8D0B98: \n" |
|---|
| 883 | " B loc_FF8D0C24 \n" |
|---|
| 884 | |
|---|
| 885 | "loc_FF8D0B9C: \n" |
|---|
| 886 | " B loc_FF8D0C24 \n" |
|---|
| 887 | |
|---|
| 888 | "loc_FF8D0BA0: \n" |
|---|
| 889 | " B loc_FF8D0C3C \n" |
|---|
| 890 | |
|---|
| 891 | "loc_FF8D0BA4: \n" |
|---|
| 892 | " B loc_FF8D0C3C \n" |
|---|
| 893 | |
|---|
| 894 | "loc_FF8D0BA8: \n" |
|---|
| 895 | " B loc_FF8D0DAC \n" |
|---|
| 896 | |
|---|
| 897 | "loc_FF8D0BAC: \n" |
|---|
| 898 | " B loc_FF8D0DB4 \n" |
|---|
| 899 | |
|---|
| 900 | "loc_FF8D0BB0: \n" |
|---|
| 901 | " B loc_FF8D0DB4 \n" |
|---|
| 902 | |
|---|
| 903 | "loc_FF8D0BB4: \n" |
|---|
| 904 | " B loc_FF8D0DB4 \n" |
|---|
| 905 | |
|---|
| 906 | "loc_FF8D0BB8: \n" |
|---|
| 907 | " B loc_FF8D0DB4 \n" |
|---|
| 908 | |
|---|
| 909 | "loc_FF8D0BBC: \n" |
|---|
| 910 | " B loc_FF8D0DBC \n" |
|---|
| 911 | |
|---|
| 912 | "loc_FF8D0BC0: \n" |
|---|
| 913 | " B loc_FF8D0DC0 \n" |
|---|
| 914 | |
|---|
| 915 | "loc_FF8D0BC4: \n" |
|---|
| 916 | " B loc_FF8D0DC0 \n" |
|---|
| 917 | |
|---|
| 918 | "loc_FF8D0BC8: \n" |
|---|
| 919 | " B loc_FF8D0DC0 \n" |
|---|
| 920 | |
|---|
| 921 | "loc_FF8D0BCC: \n" |
|---|
| 922 | " B loc_FF8D0DC0 \n" |
|---|
| 923 | |
|---|
| 924 | "loc_FF8D0BD0: \n" |
|---|
| 925 | " B loc_FF8D0DC0 \n" |
|---|
| 926 | |
|---|
| 927 | "loc_FF8D0BD4: \n" |
|---|
| 928 | " B loc_FF8D0DC0 \n" |
|---|
| 929 | |
|---|
| 930 | "loc_FF8D0BD8: \n" |
|---|
| 931 | " B loc_FF8D0C2C \n" |
|---|
| 932 | |
|---|
| 933 | "loc_FF8D0BDC: \n" |
|---|
| 934 | " B loc_FF8D0C34 \n" |
|---|
| 935 | |
|---|
| 936 | "loc_FF8D0BE0: \n" |
|---|
| 937 | " B loc_FF8D0C34 \n" |
|---|
| 938 | |
|---|
| 939 | "loc_FF8D0BE4: \n" |
|---|
| 940 | " B loc_FF8D0C48 \n" |
|---|
| 941 | |
|---|
| 942 | "loc_FF8D0BE8: \n" |
|---|
| 943 | " B loc_FF8D0C48 \n" |
|---|
| 944 | |
|---|
| 945 | "loc_FF8D0BEC: \n" |
|---|
| 946 | " B loc_FF8D0C50 \n" |
|---|
| 947 | |
|---|
| 948 | "loc_FF8D0BF0: \n" |
|---|
| 949 | " B loc_FF8D0C88 \n" |
|---|
| 950 | |
|---|
| 951 | "loc_FF8D0BF4: \n" |
|---|
| 952 | " B loc_FF8D0CC0 \n" |
|---|
| 953 | |
|---|
| 954 | "loc_FF8D0BF8: \n" |
|---|
| 955 | " B loc_FF8D0D5C \n" |
|---|
| 956 | |
|---|
| 957 | "loc_FF8D0BFC: \n" |
|---|
| 958 | " B loc_FF8D0D94 \n" |
|---|
| 959 | |
|---|
| 960 | "loc_FF8D0C00: \n" |
|---|
| 961 | " B loc_FF8D0D94 \n" |
|---|
| 962 | |
|---|
| 963 | "loc_FF8D0C04: \n" |
|---|
| 964 | " B loc_FF8D0DC0 \n" |
|---|
| 965 | |
|---|
| 966 | "loc_FF8D0C08: \n" |
|---|
| 967 | " B loc_FF8D0DC0 \n" |
|---|
| 968 | |
|---|
| 969 | "loc_FF8D0C0C: \n" |
|---|
| 970 | " B loc_FF8D0D9C \n" |
|---|
| 971 | |
|---|
| 972 | "loc_FF8D0C10: \n" |
|---|
| 973 | " B loc_FF8D0DA4 \n" |
|---|
| 974 | |
|---|
| 975 | "loc_FF8D0C14: \n" |
|---|
| 976 | //"; jumptable FF8D0B70 entries 0,1,6 ; LOCATION: ExpDrv.c:928 |
|---|
| 977 | " BL sub_FF8CCBB8 \n" |
|---|
| 978 | " B loc_FF8D0DC0 \n" |
|---|
| 979 | |
|---|
| 980 | "loc_FF8D0C1C: \n" |
|---|
| 981 | //"; jumptable FF8D0B70 entries 2,7 ; LOCATION: ExpDrv.c:0 |
|---|
| 982 | " BL sub_FF8CCE54 \n" |
|---|
| 983 | " B loc_FF8D0DC0 \n" |
|---|
| 984 | |
|---|
| 985 | "loc_FF8D0C24: \n" |
|---|
| 986 | //"; jumptable FF8D0B70 entries 3-5,8,9 ; LOCATION: ExpDrv.c:0 |
|---|
| 987 | " BL sub_FF8CD07C \n" |
|---|
| 988 | " B loc_FF8D0DC0 \n" |
|---|
| 989 | |
|---|
| 990 | "loc_FF8D0C2C: \n" |
|---|
| 991 | //"; jumptable FF8D0B70 entry 24 ; LOCATION: ExpDrv.c:2 |
|---|
| 992 | " BL sub_FF8CD354 \n" |
|---|
| 993 | " B loc_FF8D0DC0 \n" |
|---|
| 994 | |
|---|
| 995 | "loc_FF8D0C34: \n" |
|---|
| 996 | //"; jumptable FF8D0B70 entries 25,26 ; LOCATION: ExpDrv.c:0 |
|---|
| 997 | " BL sub_FF8CD56C \n" |
|---|
| 998 | " B loc_FF8D0DC0 \n" |
|---|
| 999 | |
|---|
| 1000 | "loc_FF8D0C3C: \n" |
|---|
| 1001 | //"; jumptable FF8D0B70 entries 10,11 ; LOCATION: ExpDrv.c:2 |
|---|
| 1002 | //" BL sub_FF8CD890 \n" |
|---|
| 1003 | " BL sub_FF8CD890_my \n" // patched |
|---|
| 1004 | " MOV R4, #0 \n" |
|---|
| 1005 | " B loc_FF8D0DC0 \n" |
|---|
| 1006 | |
|---|
| 1007 | "loc_FF8D0C48: \n" |
|---|
| 1008 | //"; jumptable FF8D0B70 entries 27,28 ; LOCATION: ExpDrv.c:0 |
|---|
| 1009 | " BL sub_FF8CD9D8 \n" |
|---|
| 1010 | " B loc_FF8D0DC0 \n" |
|---|
| 1011 | |
|---|
| 1012 | "loc_FF8D0C50: \n" |
|---|
| 1013 | //"; jumptable FF8D0B70 entry 29 |
|---|
| 1014 | " LDRH R1, [R0,#4] \n" |
|---|
| 1015 | " STRH R1, [SP,#0x10] \n" |
|---|
| 1016 | " LDRH R1, [R5,#2] \n" |
|---|
| 1017 | " STRH R1, [SP,#0x12] \n" |
|---|
| 1018 | " LDRH R1, [R5,#4] \n" |
|---|
| 1019 | " STRH R1, [SP,#0x14] \n" |
|---|
| 1020 | " LDRH R1, [R5,#6] \n" |
|---|
| 1021 | " STRH R1, [SP,#0x16] \n" |
|---|
| 1022 | " LDRH R1, [R0,#0xC] \n" |
|---|
| 1023 | " STRH R1, [SP,#0x18] \n" |
|---|
| 1024 | " LDRH R1, [R5,#0xA] \n" |
|---|
| 1025 | " STRH R1, [SP,#0x1A] \n" |
|---|
| 1026 | " BL sub_FF8D1CC0 \n" |
|---|
| 1027 | " B loc_FF8D0DC0 \n" |
|---|
| 1028 | |
|---|
| 1029 | "loc_FF8D0C88: \n" |
|---|
| 1030 | //"; jumptable FF8D0B70 entry 30 |
|---|
| 1031 | " LDRH R1, [R0,#4] \n" |
|---|
| 1032 | " STRH R1, [SP,#0x10] \n" |
|---|
| 1033 | " LDRH R1, [R5,#2] \n" |
|---|
| 1034 | " STRH R1, [SP,#0x12] \n" |
|---|
| 1035 | " LDRH R1, [R5,#4] \n" |
|---|
| 1036 | " STRH R1, [SP,#0x14] \n" |
|---|
| 1037 | " LDRH R1, [R5,#6] \n" |
|---|
| 1038 | " STRH R1, [SP,#0x16] \n" |
|---|
| 1039 | " LDRH R1, [R5,#8] \n" |
|---|
| 1040 | " STRH R1, [SP,#0x18] \n" |
|---|
| 1041 | " LDRH R1, [R5,#0xA] \n" |
|---|
| 1042 | " STRH R1, [SP,#0x1A] \n" |
|---|
| 1043 | " BL sub_FF8D1DC8 \n" |
|---|
| 1044 | " B loc_FF8D0DC0 \n" |
|---|
| 1045 | |
|---|
| 1046 | "loc_FF8D0CC0: \n" |
|---|
| 1047 | //"; jumptable FF8D0B70 entry 31 |
|---|
| 1048 | " LDRH R1, [R5] \n" |
|---|
| 1049 | " STRH R1, [SP,#0x10] \n" |
|---|
| 1050 | " LDRH R1, [R0,#6] \n" |
|---|
| 1051 | " STRH R1, [SP,#0x12] \n" |
|---|
| 1052 | " LDRH R1, [R5,#4] \n" |
|---|
| 1053 | " STRH R1, [SP,#0x14] \n" |
|---|
| 1054 | " LDRH R1, [R5,#6] \n" |
|---|
| 1055 | " STRH R1, [SP,#0x16] \n" |
|---|
| 1056 | " LDRH R1, [R5,#8] \n" |
|---|
| 1057 | " STRH R1, [SP,#0x18] \n" |
|---|
| 1058 | " LDRH R1, [R5,#0xA] \n" |
|---|
| 1059 | " STRH R1, [SP,#0x1A] \n" |
|---|
| 1060 | " BL sub_FF8D1E7C \n" |
|---|
| 1061 | " B loc_FF8D0DC0 \n" |
|---|
| 1062 | |
|---|
| 1063 | "loc_FF8D0D5C: \n" |
|---|
| 1064 | //"; jumptable FF8D0B70 entry 32 |
|---|
| 1065 | " LDRH R1, [R5] \n" |
|---|
| 1066 | " STRH R1, [SP,#0x10] \n" |
|---|
| 1067 | " LDRH R1, [R5,#2] \n" |
|---|
| 1068 | " STRH R1, [SP,#0x12] \n" |
|---|
| 1069 | " LDRH R1, [R5,#4] \n" |
|---|
| 1070 | " STRH R1, [SP,#0x14] \n" |
|---|
| 1071 | " LDRH R1, [R5,#6] \n" |
|---|
| 1072 | " STRH R1, [SP,#0x16] \n" |
|---|
| 1073 | " LDRH R1, [R0,#0xC] \n" |
|---|
| 1074 | " STRH R1, [SP,#0x18] \n" |
|---|
| 1075 | " LDRH R1, [R5,#0xA] \n" |
|---|
| 1076 | " STRH R1, [SP,#0x1A] \n" |
|---|
| 1077 | " BL sub_FF8D1F24 \n" |
|---|
| 1078 | " B loc_FF8D0DC0 \n" |
|---|
| 1079 | |
|---|
| 1080 | "loc_FF8D0D94: \n" |
|---|
| 1081 | //"; jumptable FF8D0B70 entries 33,34 ; LOCATION: ExpDrv.c:6 |
|---|
| 1082 | " BL sub_FF8CDDAC \n" |
|---|
| 1083 | " B loc_FF8D0DC0 \n" |
|---|
| 1084 | |
|---|
| 1085 | "loc_FF8D0D9C: \n" |
|---|
| 1086 | //"; jumptable FF8D0B70 entry 37 ; LOCATION: ExpDrv.c:10 |
|---|
| 1087 | " BL sub_FF8CE524 \n" |
|---|
| 1088 | " B loc_FF8D0DC0 \n" |
|---|
| 1089 | |
|---|
| 1090 | "loc_FF8D0DA4: \n" |
|---|
| 1091 | //"; jumptable FF8D0B70 entry 38 ; LOCATION: ExpDrv.c:6 |
|---|
| 1092 | " BL sub_FF8CE7C0 \n" |
|---|
| 1093 | " B loc_FF8D0DC0 \n" |
|---|
| 1094 | |
|---|
| 1095 | "loc_FF8D0DAC: \n" |
|---|
| 1096 | //"; jumptable FF8D0B70 entry 12 ; LOCATION: ExpDrv.c:2 |
|---|
| 1097 | " BL sub_FF8CE9A0 \n" |
|---|
| 1098 | " B loc_FF8D0DC0 \n" |
|---|
| 1099 | |
|---|
| 1100 | "loc_FF8D0DB4: \n" |
|---|
| 1101 | //"; jumptable FF8D0B70 entries 13-16 ; LOCATION: ExpDrv.c:128 |
|---|
| 1102 | " BL sub_FF8CEB5C \n" |
|---|
| 1103 | " B loc_FF8D0DC0 \n" |
|---|
| 1104 | |
|---|
| 1105 | "loc_FF8D0DBC: \n" |
|---|
| 1106 | //"; jumptable FF8D0B70 entry 17 ; LOCATION: ExpDrv.c:2 |
|---|
| 1107 | " BL sub_FF8CED48 \n" |
|---|
| 1108 | |
|---|
| 1109 | "loc_FF8D0DC0: \n" |
|---|
| 1110 | //"; jumptable FF8D0B70 default entry |
|---|
| 1111 | //"; jumptable FF8D0B70 entries 18-23,35,36 |
|---|
| 1112 | " LDR R0, [SP,#0x1C] \n" |
|---|
| 1113 | " LDR R1, [R0,#0x7C] \n" |
|---|
| 1114 | " LDR R3, [R0,#0x8C] \n" |
|---|
| 1115 | " LDR R2, [R0,#0x90] \n" |
|---|
| 1116 | " ADD R0, R0, #4 \n" |
|---|
| 1117 | " BLX R3 \n" |
|---|
| 1118 | " CMP R4, #1 \n" |
|---|
| 1119 | " BNE loc_FF8D0E28 \n" |
|---|
| 1120 | |
|---|
| 1121 | "loc_FF8D0DE0: \n" |
|---|
| 1122 | " LDR R0, [SP,#0x1C] \n" |
|---|
| 1123 | " MOV R2, #0xC \n" |
|---|
| 1124 | " LDR R1, [R0,#0x7C] \n" |
|---|
| 1125 | " ADD R1, R1, R1,LSL#1 \n" |
|---|
| 1126 | " ADD R0, R0, R1,LSL#2 \n" |
|---|
| 1127 | " SUB R4, R0, #8 \n" |
|---|
| 1128 | " LDR R0, =0x57870 \n" |
|---|
| 1129 | " ADD R1, SP, #0x10 \n" |
|---|
| 1130 | " BL sub_FFB92348 \n" |
|---|
| 1131 | " LDR R0, =0x5787C \n" |
|---|
| 1132 | " MOV R2, #0xC \n" |
|---|
| 1133 | " ADD R1, SP, #0x10 \n" |
|---|
| 1134 | " BL sub_FFB92348 \n" |
|---|
| 1135 | " LDR R0, =0x57888 \n" |
|---|
| 1136 | " MOV R2, #0xC \n" |
|---|
| 1137 | " MOV R1, R4 \n" |
|---|
| 1138 | " BL sub_FFB92348 \n" |
|---|
| 1139 | " B loc_FF8D0EA4 \n" |
|---|
| 1140 | |
|---|
| 1141 | "loc_FF8D0E28: \n" |
|---|
| 1142 | " LDR R0, [SP,#0x1C] \n" |
|---|
| 1143 | " MOV R3, #1 \n" |
|---|
| 1144 | " LDR R0, [R0] \n" |
|---|
| 1145 | " CMP R0, #0xB \n" |
|---|
| 1146 | " BNE loc_FF8D0E70 \n" |
|---|
| 1147 | " MOV R2, #0 \n" |
|---|
| 1148 | " STRD R2, [SP] \n" |
|---|
| 1149 | " MOV R2, #1 \n" |
|---|
| 1150 | " MOV R1, #1 \n" |
|---|
| 1151 | " MOV R0, #0 \n" |
|---|
| 1152 | " BL sub_FF8CC998 \n" |
|---|
| 1153 | " MOV R3, #1 \n" |
|---|
| 1154 | " MOV R2, #0 \n" |
|---|
| 1155 | " STRD R2, [SP] \n" |
|---|
| 1156 | " MOV R2, #1 \n" |
|---|
| 1157 | " MOV R1, #1 \n" |
|---|
| 1158 | " MOV R0, #0 \n" |
|---|
| 1159 | " B loc_FF8D0EA0 \n" |
|---|
| 1160 | |
|---|
| 1161 | "loc_FF8D0E70: \n" |
|---|
| 1162 | " MOV R2, #1 \n" |
|---|
| 1163 | " STRD R2, [SP] \n" |
|---|
| 1164 | " MOV R3, #1 \n" |
|---|
| 1165 | " MOV R1, #1 \n" |
|---|
| 1166 | " MOV R0, #1 \n" |
|---|
| 1167 | " BL sub_FF8CC998 \n" |
|---|
| 1168 | " MOV R3, #1 \n" |
|---|
| 1169 | " MOV R2, #1 \n" |
|---|
| 1170 | " MOV R1, #1 \n" |
|---|
| 1171 | " MOV R0, #1 \n" |
|---|
| 1172 | " STR R3, [SP] \n" |
|---|
| 1173 | " STR R3, [SP,#0x04] \n" |
|---|
| 1174 | |
|---|
| 1175 | "loc_FF8D0EA0: \n" |
|---|
| 1176 | " BL sub_FF8CCB00 \n" |
|---|
| 1177 | |
|---|
| 1178 | "loc_FF8D0EA4: \n" |
|---|
| 1179 | " LDR R0, [SP,#0x1C] \n" |
|---|
| 1180 | " BL sub_FF8D1BBC \n" |
|---|
| 1181 | " B loc_FF8D0838 \n" |
|---|
| 1182 | ); |
|---|
| 1183 | } |
|---|
| 1184 | |
|---|
| 1185 | void __attribute__((naked,noinline)) sub_FF8CD890_my() { |
|---|
| 1186 | asm volatile ( |
|---|
| 1187 | " STMFD SP!, {R4-R8,LR} \n" |
|---|
| 1188 | " LDR R7, =0x5094 \n" |
|---|
| 1189 | " MOV R4, R0 \n" |
|---|
| 1190 | " LDR R0, [R7,#0x1C] \n" |
|---|
| 1191 | " MOV R1, #0x3E \n" |
|---|
| 1192 | " BL sub_FF8917CC \n" |
|---|
| 1193 | " LDRSH R0, [R4,#4] \n" |
|---|
| 1194 | " MOV R2, #0 \n" |
|---|
| 1195 | " MOV R1, #0 \n" |
|---|
| 1196 | " BL sub_FF8CC6FC \n" |
|---|
| 1197 | " MOV R5, R0 \n" |
|---|
| 1198 | " LDRSH R0, [R4,#6] \n" |
|---|
| 1199 | " BL sub_FF8CC80C \n" |
|---|
| 1200 | " LDRSH R0, [R4,#8] \n" |
|---|
| 1201 | " BL sub_FF8CC864 \n" |
|---|
| 1202 | " LDRSH R0, [R4,#0xA] \n" |
|---|
| 1203 | " BL sub_FF8CC8BC \n" |
|---|
| 1204 | " LDRSH R0, [R4,#0xC] \n" |
|---|
| 1205 | " MOV R1, #0 \n" |
|---|
| 1206 | " BL sub_FF8CC914 \n" |
|---|
| 1207 | " MOV R6, R0 \n" |
|---|
| 1208 | " LDRSH R0, [R4,#0xE] \n" |
|---|
| 1209 | " BL sub_FF8D1C60 \n" |
|---|
| 1210 | " LDR R0, [R4] \n" |
|---|
| 1211 | " LDR R8, =0x57888 \n" |
|---|
| 1212 | " CMP R0, #0xB \n" |
|---|
| 1213 | " MOVEQ R5, #0 \n" |
|---|
| 1214 | " MOVEQ R6, #0 \n" |
|---|
| 1215 | " BEQ loc_FF8CD92C \n" |
|---|
| 1216 | " CMP R5, #1 \n" |
|---|
| 1217 | " BNE loc_FF8CD92C \n" |
|---|
| 1218 | " LDRSH R0, [R4,#4] \n" |
|---|
| 1219 | " LDR R1, =0xFF8CC668 \n" |
|---|
| 1220 | " MOV R2, #2 \n" |
|---|
| 1221 | " BL sub_FF97FA30 \n" |
|---|
| 1222 | " STRH R0, [R4,#4] \n" |
|---|
| 1223 | " MOV R0, #0 \n" |
|---|
| 1224 | " STR R0, [R7,#0x28] \n" |
|---|
| 1225 | " B loc_FF8CD934 \n" |
|---|
| 1226 | |
|---|
| 1227 | "loc_FF8CD92C: \n" |
|---|
| 1228 | " LDRH R0, [R8] \n" |
|---|
| 1229 | " STRH R0, [R4,#4] \n" |
|---|
| 1230 | |
|---|
| 1231 | "loc_FF8CD934: \n" |
|---|
| 1232 | " CMP R6, #1 \n" |
|---|
| 1233 | " LDRNEH R0, [R8,#8] \n" |
|---|
| 1234 | " BNE loc_FF8CD950 \n" |
|---|
| 1235 | " LDRSH R0, [R4,#0xC] \n" |
|---|
| 1236 | " LDR R1, =0xFF8CC6EC \n" |
|---|
| 1237 | " MOV R2, #0x20 \n" |
|---|
| 1238 | " BL sub_FF8D1C7C \n" |
|---|
| 1239 | |
|---|
| 1240 | "loc_FF8CD950: \n" |
|---|
| 1241 | " STRH R0, [R4,#0xC] \n" |
|---|
| 1242 | " LDRSH R0, [R4,#6] \n" |
|---|
| 1243 | //" BL sub_FF8BE93C \n" |
|---|
| 1244 | " BL sub_FF8BE93C_my \n" // patched |
|---|
| 1245 | " B sub_FF8CD95C \n" // continue in firmware |
|---|
| 1246 | ); |
|---|
| 1247 | } |
|---|
| 1248 | |
|---|
| 1249 | void __attribute__((naked,noinline)) sub_FF8BE93C_my() { |
|---|
| 1250 | asm volatile ( |
|---|
| 1251 | " STMFD SP!, {R4-R6,LR} \n" |
|---|
| 1252 | " LDR R5, =0x4D70 \n" |
|---|
| 1253 | " MOV R4, R0 \n" |
|---|
| 1254 | " LDR R0, [R5,#4] \n" |
|---|
| 1255 | " CMP R0, #1 \n" |
|---|
| 1256 | " LDRNE R1, =0x146 \n" |
|---|
| 1257 | " LDRNE R0, =0xFF8BE740 \n" |
|---|
| 1258 | " BLNE _DebugAssert \n" |
|---|
| 1259 | " CMN R4, #0xC00 \n" |
|---|
| 1260 | " LDREQSH R4, [R5,#2] \n" |
|---|
| 1261 | " CMN R4, #0xC00 \n" |
|---|
| 1262 | " MOVEQ R1, #0x14C \n" |
|---|
| 1263 | " LDRNE R0, =0xFF8BE740 \n" |
|---|
| 1264 | " STRH R4, [R5,#2] \n" |
|---|
| 1265 | " BLEQ _DebugAssert \n" |
|---|
| 1266 | " MOV R0, R4 \n" |
|---|
| 1267 | " BL apex2us \n" // patched |
|---|
| 1268 | " B sub_FF8BE980 \n" // continue in firmware |
|---|
| 1269 | ); |
|---|
| 1270 | } |
|---|