root/platform/g5x/sub/101a/filewrite.c

/* [<][>][^][v][top][bottom][index][help] */

DEFINITIONS

This source file includes following definitions.
  1. filewritetask
  2. sub_fc4e81c4_my
  3. sub_fc4e874a_my
  4. sub_fc4e82f6_my

   1 #include "lolevel.h"
   2 #include "platform.h"
   3 
   4 typedef struct {
   5     unsigned int address;
   6     unsigned int length;
   7 } cam_ptp_data_chunk; //camera specific structure
   8 
   9 #define MAX_CHUNKS_FOR_FWT 7 // filewritetask is prepared for this many chunks
  10                               // corresponds to filewritetask() jump table entries 0-6
  11 
  12 /*
  13  * fwt_data_struct: defined here as it's camera dependent
  14  * unneeded members are designated with unkn
  15  * file_offset, full_size, seek_flag only needs to be defined for cameras with CAM_FILEWRITETASK_SEEK/CAM_FILEWRITETASK_MULTIPASS
  16  * pdc is always required
  17  * name is not currently used
  18  */
  19 // Copied from G7X port - appears to be the same
  20 typedef struct
  21 {
  22     int unkn1;
  23     int file_offset;
  24     int maybe_full_size;
  25     int unkn2, unkn3;
  26     int unkn4;
  27     cam_ptp_data_chunk pdc[MAX_CHUNKS_FOR_FWT];
  28     int maybe_seek_flag;
  29     int unkn5, unkn6;
  30     char name[32];
  31 } fwt_data_struct;
  32 
  33 #include "../../../generic/filewrite.c"
  34 
  35 /*************************************************************/
  36 
  37 void __attribute__((naked,noinline))
  38 filewritetask()
  39 {
  40     asm volatile (
  41             //capdis -f=chdk -s=0xfc4e8441 -c=43 -stubs PRIMARY.BIN 0xfc000000
  42             "    push    {r3, r4, r5, r6, r7, lr}\n"
  43             "    ldr     r6, =0x09200001\n"
  44             "    movw    r7, #0x476\n"
  45             "    ldr     r5, =0x000264c0\n"
  46             "    adds    r6, #0x12\n"
  47             "loc_fc4e844c:\n"
  48             "    mov     r1, sp\n"
  49             "    movs    r2, #0\n"
  50             "    ldr     r0, [r5, #0x14]\n"
  51             "    blx     sub_fc34d054\n"
  52             "    cbz     r0, loc_fc4e8462\n"
  53             "    movs    r0, #0\n"
  54             "    mov     r2, r7\n"
  55             "    ldr     r1, =0xfc4e850c\n" //  *"dwFWrite.c"
  56             "    blx     sub_fc34d264\n"
  57             "loc_fc4e8462:\n"
  58             "    ldr     r0, [sp]\n"
  59             "    ldr     r1, [r0]\n"
  60             "    cmp     r1, #0xd\n"
  61             "    bhs     loc_fc4e844c\n"
  62             "    tbb     [pc, r1]\n" // (jumptable r1 13 elements)
  63             "branchtable_fc4e846e:\n"
  64             "    .byte((loc_fc4e84b0 - branchtable_fc4e846e) / 2)\n" // (case 0)
  65             "    .byte((loc_fc4e84b0 - branchtable_fc4e846e) / 2)\n" // (case 1)
  66             "    .byte((loc_fc4e84b0 - branchtable_fc4e846e) / 2)\n" // (case 2)
  67             "    .byte((loc_fc4e84b0 - branchtable_fc4e846e) / 2)\n" // (case 3)
  68             "    .byte((loc_fc4e84b0 - branchtable_fc4e846e) / 2)\n" // (case 4)
  69             "    .byte((loc_fc4e84b0 - branchtable_fc4e846e) / 2)\n" // (case 5)
  70             "    .byte((loc_fc4e84b0 - branchtable_fc4e846e) / 2)\n" // (case 6)
  71             "    .byte((loc_fc4e84b6 - branchtable_fc4e846e) / 2)\n" // (case 7)
  72             "    .byte((loc_fc4e847c - branchtable_fc4e846e) / 2)\n" // (case 8)
  73             "    .byte((loc_fc4e848e - branchtable_fc4e846e) / 2)\n" // (case 9)
  74             "    .byte((loc_fc4e84aa - branchtable_fc4e846e) / 2)\n" // (case 10)
  75             "    .byte((loc_fc4e8482 - branchtable_fc4e846e) / 2)\n" // (case 11)
  76             "    .byte((loc_fc4e8488 - branchtable_fc4e846e) / 2)\n" // (case 12)
  77             ".align 1\n"
  78             "loc_fc4e847c:\n"
  79             "    bl      sub_fc4e862e\n"
  80             "    b       loc_fc4e844c\n"
  81             "loc_fc4e8482:\n"
  82             "    bl      sub_fc4e867a\n"
  83             "    b       loc_fc4e844c\n"
  84             "loc_fc4e8488:\n"
  85             "    bl      sub_fc4e81c4_my\n"     // Patched
  86             "    b       loc_fc4e844c\n"
  87             "loc_fc4e848e:\n"
  88             "    ldr     r1, [r0, #4]\n"
  89             "    movs    r2, #0\n"
  90             "    mov     r4, r0\n"
  91             "    ldr     r0, [r5, #8]\n"
  92             "    bl      sub_fc3b5df2\n"
  93             "    adds    r0, r0, #1\n"
  94             "    bne     loc_fc4e844c\n"
  95             "    movs    r0, #7\n"
  96             "    mov     r1, r4\n"
  97             "    str     r6, [r4, #0x14]\n"
  98             "    bl      sub_fc4e814a\n"
  99             "    b       loc_fc4e844c\n"
 100             "loc_fc4e84aa:\n"
 101             "    bl      sub_fc4e86d8\n"
 102             "    b       loc_fc4e844c\n"
 103             "loc_fc4e84b0:\n"
 104             "    bl      sub_fc4e874a_my\n"     // Patched
 105             "    b       loc_fc4e844c\n"
 106             "loc_fc4e84b6:\n"
 107             "    bl      sub_fc4e82f6_my\n"     // Patched
 108             "    b       loc_fc4e844c\n"
 109     );
 110 }
 111 
 112 void __attribute__((naked,noinline))
 113 sub_fc4e81c4_my() {
 114     asm volatile (
 115             //capdis -f=chdk -s=0xfc4e81c5 -c=126 -stubs PRIMARY.BIN 0xfc000000
 116             "    push.w  {r4, r5, r6, r7, r8, sb, lr}\n"
 117             "    mov     r4, r0\n"
 118 
 119             //hook placed here to avoid conditional branch a few instructions below (watch out for registers!)
 120             //"  mov   r0, r4\n"      //data block start, commented out as R0 is already holding what we need
 121             "    bl filewrite_main_hook\n"
 122             "    mov     r0, r4\n"      //restore register(s)
 123 
 124             "    ldr     r0, [r0, #0x50]\n"
 125             "    sub     sp, #0x3c\n"
 126             "    lsls    r1, r0, #0x1f\n"
 127             "    bne     loc_fc4e81d6\n"
 128             "    lsls    r0, r0, #0x1d\n"
 129             "    bpl     loc_fc4e82d2\n"
 130             "loc_fc4e81d6:\n"
 131             "    ldr     r7, =0x000264c0\n"
 132             "    ldr     r0, [r7, #0x1c]\n"
 133             "    cbz     r0, loc_fc4e81de\n"
 134             "    blx     r0\n"
 135             "loc_fc4e81de:\n"
 136             "    add.w   r0, r4, #0x5c\n"
 137             "    mov     r8, r0\n"
 138             "    bl      sub_fc3b7620\n"
 139             "    movs    r1, #0\n"
 140             "    bl      sub_fc07dd36\n"
 141             "    movs    r1, #0\n"
 142             "    movs    r0, #0x47\n"
 143             "    bl      sub_fc3b5a60\n"
 144             "    ldr     r0, [r4, #0x50]\n"
 145             "    lsls    r0, r0, #0x1f\n"
 146             "    beq     loc_fc4e82d2\n"
 147             "    ldr     r0, [r4, #0x10]\n"
 148             "    bl      sub_fc1c8962\n"
 149             "    ldr     r0, [r4, #0x50]\n"
 150             "    movw    r5, #0x301\n"
 151             "    lsls    r1, r0, #0x1b\n"
 152             "    bpl     loc_fc4e8210\n"
 153             "    movs    r5, #9\n"
 154             "    b       loc_fc4e8216\n"
 155             "loc_fc4e8210:\n"
 156             "    lsls    r1, r0, #0x19\n"
 157             "    bpl     loc_fc4e8216\n"
 158             "    movs    r5, #1\n"
 159             "loc_fc4e8216:\n"
 160             "    lsls    r0, r0, #0x1a\n"
 161             "    bmi     loc_fc4e8220\n"
 162             "    ldr     r0, [r4, #0x58]\n"
 163             "    cmp     r0, #1\n"
 164             "    bne     loc_fc4e8224\n"
 165             "loc_fc4e8220:\n"
 166             "    orr     r5, r5, #0x8000\n"
 167             "loc_fc4e8224:\n"
 168             "    movw    sb, #0x1b6\n"
 169             "    ldr     r6, [r4, #0x10]\n"
 170             "    mov     r2, sb\n"
 171             "    mov     r1, r5\n"
 172             "    mov     r0, r8\n"
 173 
 174 //            "    bl      sub_fc3b5bda\n"    // Open
 175             "    bl      fwt_open\n"    // +
 176 
 177             "    adds    r1, r0, #1\n"
 178             "    bne     loc_fc4e8272\n"
 179             "    mov     r0, r8\n"
 180             "    bl      sub_fc3b60be\n"
 181             "    movs    r2, #0xf\n"
 182             "    mov     r1, r8\n"
 183             "    add     r0, sp, #4\n"
 184             "    blx     sub_fc34d21c\n"
 185             "    movs    r0, #0\n"
 186             "    strb.w  r0, [sp, #0x13]\n"
 187             "    movw    r1, #0x41ff\n"
 188             "    str     r1, [sp, #0x24]\n"
 189             "    strd    r0, r6, [sp, #0x2c]\n"
 190             "    movs    r1, #0x10\n"
 191             "    str     r6, [sp, #0x34]\n"
 192             "    add     r0, sp, #4\n"
 193             "    str     r6, [sp, #0x38]\n"
 194             "    str     r1, [sp, #0x28]\n"
 195             "    add     r1, sp, #0x24\n"
 196             "    bl      sub_fc1c8eb6\n"
 197             "    mov     r2, sb\n"
 198             "    mov     r1, r5\n"
 199             "    mov     r0, r8\n"
 200             "    bl      sub_fc3b5bda\n"
 201             "loc_fc4e8272:\n"
 202             "    mov     r5, r0\n"
 203             "    str     r0, [r7, #8]\n"
 204             "    adds    r0, r0, #1\n"
 205             "    bne     loc_fc4e82aa\n"
 206             "    movs    r1, #0\n"
 207             "    movs    r0, #0x48\n"
 208             "    bl      sub_fc3b5a60\n"
 209             "    mov     r0, r8\n"
 210             "    bl      sub_fc3b7620\n"
 211             "    ldr     r1, [r7, #0x20]\n"
 212             "    bl      sub_fc07dd94\n"
 213             "    ldr     r0, [r7, #0x18]\n"
 214             "    cmp     r0, #0\n"
 215             "    beq     loc_fc4e82f0\n"
 216             "    ldr     r5, =0x09200001\n"
 217             "    mov     r0, r4\n"
 218             "    mov     r1, r5\n"
 219             "    bl      sub_fc4e8110\n"
 220             "    ldr     r1, [r7, #0x18]\n"
 221             "    add     sp, #0x3c\n"
 222             "    mov     r0, r5\n"
 223             "    pop.w   {r4, r5, r6, r7, r8, sb, lr}\n"
 224             "    bx      r1\n"
 225             "loc_fc4e82aa:\n"
 226             "    ldr     r0, =0x001d2ae4\n"
 227             "    movs    r2, #0x20\n"
 228             "    mov     r1, r8\n"
 229             "    blx     sub_fc34d26c\n"
 230 
 231             // TODO looks equivalent to G7X, not verified that it's required
 232             //mod start
 233             "    LDR     r3, =current_write_ignored\n"
 234             "    LDR     r3, [r3]\n"
 235             "    cbnz    r3,loc_C\n" // jump over the next block
 236             //mod end
 237 
 238             "    ldr     r0, [r4, #0x50]\n"
 239             "    lsls    r0, r0, #0x18\n"
 240             "    bpl     loc_fc4e82d2\n"
 241             "    ldr     r1, [r4, #0xc]\n"
 242             "    mov     r0, r5\n"
 243             "    bl      sub_fc3b5ec6\n"
 244             "    cbnz    r0, loc_fc4e82d0\n"
 245             "    ldr     r0, =0x09200001\n"
 246             "    mov     r1, r4\n"
 247             "    adds    r0, #0x16\n"
 248             "    str     r0, [r4, #0x14]\n"
 249             "    movs    r0, #7\n"
 250             "    b       loc_fc4e82e8\n"
 251             "loc_fc4e82d0:\n"
 252             "    b       loc_fc4e82d2\n"
 253             "loc_fc4e82d2:\n"
 254             "loc_C:\n"
 255             "    ldr     r0, [r4, #0x50]\n"
 256             "    lsls    r0, r0, #0x19\n"
 257             "    bmi     loc_fc4e82dc\n"
 258             "    ldr     r0, [r4, #4]\n"
 259             "    cbz     r0, loc_fc4e82e4\n"
 260             "loc_fc4e82dc:\n"
 261             "    movs    r0, #9\n"
 262             "    mov     r1, r4\n"
 263             "    bl      sub_fc4e814a\n"
 264             "loc_fc4e82e4:\n"
 265             "    movs    r0, #0\n"
 266             "    mov     r1, r4\n"
 267             "loc_fc4e82e8:\n"
 268             "    add     sp, #0x3c\n"
 269             "    pop.w   {r4, r5, r6, r7, r8, sb, lr}\n"
 270             "    b       sub_fc4e814a\n"
 271             "loc_fc4e82f0:\n"
 272             "    add     sp, #0x3c\n"
 273             "    pop.w   {r4, r5, r6, r7, r8, sb, pc}\n"
 274     );
 275 }
 276 
 277 void __attribute__((naked,noinline))
 278 sub_fc4e874a_my() {
 279     asm volatile (
 280             //capdis -f=chdk -s=0xfc4e874b -c=65 -stubs PRIMARY.BIN 0xfc000000
 281             "    push.w  {r4, r5, r6, r7, r8, sb, sl, lr}\n"
 282             "    mov     r5, r0\n"
 283             "    ldr     r0, [r0]\n"
 284             "    cmp     r0, #6\n"
 285             "    bhi     loc_fc4e8762\n"
 286             "    add.w   r0, r5, r0, lsl #3\n"
 287             "    ldrd    r7, r6, [r0, #0x18]\n"
 288             "    cbnz    r6, loc_fc4e8776\n"
 289             "    b       loc_fc4e8770\n"
 290             "loc_fc4e8762:\n"
 291             "    movw    r2, #0x3b5\n"
 292             "    ldr     r1, =0xfc4e850c\n" //  *"dwFWrite.c"
 293             "    movs    r0, #0\n"
 294             "    blx     sub_fc34d264\n"
 295             "loc_fc4e8770:\n"
 296             "    movs    r0, #7\n"
 297             "    mov     r1, r5\n"
 298             "    b       loc_fc4e87e6\n"
 299             "loc_fc4e8776:\n"
 300             "    ldr.w   sl, =0x000264c0\n"
 301             "    mov.w   sb, #0x1000000\n"
 302             "    mov     r4, r6\n"
 303             "loc_fc4e8780:\n"
 304             "    ldr     r0, [r5, #4]\n"
 305             "    cmp     r4, sb\n"
 306             "    mov     r1, sb\n"
 307             "    bhi     loc_fc4e878a\n"
 308             "    mov     r1, r4\n"
 309             "loc_fc4e878a:\n"
 310             "    lsls    r2, r0, #8\n"
 311             "    beq     loc_fc4e879c\n"
 312             "    bic     r0, r0, #0xff000000\n"
 313             "    rsb.w   r0, r0, #0x1000000\n"
 314             "    cmp     r1, r0\n"
 315             "    bls     loc_fc4e879c\n"
 316             "    mov     r1, r0\n"
 317             "loc_fc4e879c:\n"
 318             "    ldr.w   r0, [sl, #8]\n"
 319             "    mov     r8, r1\n"
 320             "    mov     r2, r1\n"
 321             "    mov     r1, r7\n"
 322 
 323 //            "    bl      sub_fc3b5db4\n"    //j_Write_FW
 324             "    bl      fwt_write\n"   // +
 325 
 326             "    ldr     r1, [r5, #4]\n"
 327             "    cmp     r8, r0\n"
 328             "    add     r1, r0\n"
 329             "    str     r1, [r5, #4]\n"
 330             "    beq     loc_fc4e87c6\n"
 331             "    adds    r0, r0, #1\n"
 332             "    bne     loc_fc4e87be\n"
 333             "    ldr     r0, =0x09200006\n"
 334             "    subs    r0, r0, #1\n"
 335             "    b       loc_fc4e87c2\n"
 336             "loc_fc4e87be:\n"
 337             "    ldr     r0, =0x09200006\n"
 338             "    adds    r0, #0xf\n"
 339             "loc_fc4e87c2:\n"
 340             "    str     r0, [r5, #0x14]\n"
 341             "    b       loc_fc4e8770\n"
 342             "loc_fc4e87c6:\n"
 343             "    subs    r4, r4, r0\n"
 344             "    cmp     r4, r6\n"
 345             "    add     r7, r0\n"
 346             "    blo     loc_fc4e87dc\n"
 347             "    movw    r2, #0x3df\n"
 348             "    ldr     r1, =0xfc4e850c\n" //  *"dwFWrite.c"
 349             "    movs    r0, #0\n"
 350             "    blx     sub_fc34d264\n"
 351             "loc_fc4e87dc:\n"
 352             "    cmp     r4, #0\n"
 353             "    bne     loc_fc4e8780\n"
 354             "    ldr     r0, [r5]\n"
 355             "    mov     r1, r5\n"
 356             "    adds    r0, r0, #1\n"
 357             "loc_fc4e87e6:\n"
 358             "    pop.w   {r4, r5, r6, r7, r8, sb, sl, lr}\n"
 359             "    b       sub_fc4e814a\n"
 360     );
 361 }
 362 
 363 void __attribute__((naked,noinline))
 364 sub_fc4e82f6_my() {
 365     asm volatile (
 366             //capdis -f=chdk -s=0xfc4e82df -c=141 -stubs PRIMARY.BIN 0xfc000000
 367             "    push    {r4, r5, r6, r7, lr}\n"
 368             "    mov     r4, r0\n"
 369             "    ldr     r0, [r0, #0x50]\n"
 370             "    ldr     r5, =0x000264c0\n"
 371             "    sub     sp, #0x3c\n"
 372             "    add.w   r7, r4, #0x5c\n"
 373             "    lsls    r1, r0, #0x1e\n"
 374             "    bmi     loc_fc4e830e\n"
 375             "    lsls    r0, r0, #0x1c\n"
 376             "    bpl     loc_fc4e8408\n"
 377             "    b       loc_fc4e8362\n"
 378             "loc_fc4e830e:\n"
 379             "    lsls    r0, r0, #0x18\n"
 380             "    bpl     loc_fc4e833e\n"
 381             "    ldrd    r1, r0, [r4, #8]\n"
 382             "    cmp     r1, r0\n"
 383             "    beq     loc_fc4e833e\n"
 384             "    ldr     r0, [r5, #8]\n"
 385             "    bl      sub_fc3b5ec6\n"
 386             "    cbnz    r0, loc_fc4e832a\n"
 387             "    ldr     r0, =0x09200001\n"
 388             "    adds    r0, #0x16\n"
 389             "    str     r0, [r4, #0x14]\n"
 390             "    b       loc_fc4e833e\n"
 391             "loc_fc4e832a:\n"
 392             "    ldr     r0, [r4, #8]\n"
 393             "    add     r1, sp, #0x24\n"
 394             "    str     r0, [r4, #4]\n"
 395             "    mov     r0, r7\n"
 396             "    bl      sub_fc1c8e40\n"
 397             "    cmp     r0, #1\n"
 398             "    bne     loc_fc4e833e\n"
 399             "    ldr     r0, [r4, #4]\n"
 400             "    str     r0, [sp, #0x2c]\n"
 401             "loc_fc4e833e:\n"
 402             "    ldr     r0, [r5, #8]\n"
 403             "    adds    r1, r0, #1\n"
 404             "    beq     loc_fc4e8362\n"
 405             "    ldr     r6, =0x09200001\n"
 406             "    ldr     r1, [r4, #0x58]\n"
 407             "    adds    r6, r6, #2\n"
 408             "    cmp     r1, #1\n"
 409             "    bne     loc_fc4e8354\n"
 410 
 411             //mod start
 412             "    LDR R3, =current_write_ignored\n"
 413             "    LDR R3, [R3]\n"
 414             "    cbnz R3,loc_D\n" // jump over the next block
 415             //mod end
 416 
 417             "    bl      sub_fc3b5c48\n"
 418             "    b       loc_fc4e8358\n"
 419             "loc_fc4e8354:\n"
 420 
 421             "loc_D:\n"
 422 //            "    bl      sub_fc3b5c16\n"    // Close
 423             "    bl      fwt_close\n" // +
 424 
 425             "loc_fc4e8358:\n"
 426             "    cbz     r0, loc_fc4e835c\n"
 427             "    str     r6, [r4, #0x14]\n"
 428             "loc_fc4e835c:\n"
 429             "    mov.w   r0, #-1\n"
 430             "    str     r0, [r5, #8]\n"
 431             "loc_fc4e8362:\n"
 432             "    ldr     r0, [r4, #0x14]\n"
 433             "    lsls    r0, r0, #0x1f\n"
 434             "    bne     loc_fc4e840e\n"
 435             "    ldr     r0, [r4, #0x50]\n"
 436             "    lsls    r1, r0, #0x1f\n"
 437             "    beq     loc_fc4e838a\n"
 438             "    movw    r0, #0x81ff\n"
 439             "    str     r0, [sp, #0x24]\n"
 440             "    movs    r0, #0x20\n"
 441             "    str     r0, [sp, #0x28]\n"
 442             "    ldr     r0, [r4, #4]\n"
 443             "    str     r0, [sp, #0x2c]\n"
 444             "    ldr     r0, [r4, #0x10]\n"
 445             "    str     r0, [sp, #0x30]\n"
 446             "    ldr     r0, [r4, #0x10]\n"
 447             "    str     r0, [sp, #0x34]\n"
 448             "    ldr     r0, [r4, #0x10]\n"
 449             "    str     r0, [sp, #0x38]\n"
 450             "    b       loc_fc4e83ac\n"
 451             "loc_fc4e838a:\n"
 452             "    lsls    r0, r0, #0x1b\n"
 453             "    bpl     loc_fc4e83ac\n"
 454             "    add     r1, sp, #0x24\n"
 455             "    mov     r0, r7\n"
 456             "    bl      sub_fc1c8e40\n"
 457             "    cbnz    r0, loc_fc4e83a4\n"
 458             "    movs    r0, #0\n"
 459             "    movw    r2, #0x43b\n"
 460             "    ldr     r1, =0xfc4e850c\n" //  *"dwFWrite.c"
 461             "    blx     sub_fc34d264\n"
 462             "loc_fc4e83a4:\n"
 463             "    ldr     r0, [sp, #0x2c]\n"
 464             "    ldr     r1, [r4, #4]\n"
 465             "    add     r0, r1\n"
 466             "    str     r0, [sp, #0x2c]\n"
 467             "loc_fc4e83ac:\n"
 468             "    ldr     r0, [r4, #0x50]\n"
 469             "    mvns    r0, r0\n"
 470             "    lsls    r0, r0, #0x19\n"
 471             "    bpl     loc_fc4e83bc\n"
 472             "    add     r1, sp, #0x24\n"
 473             "    mov     r0, r7\n"
 474             "    bl      sub_fc1c8eb6\n"
 475             "loc_fc4e83bc:\n"
 476             "    ldr     r0, [r4, #0x50]\n"
 477             "    lsls    r1, r0, #0x1e\n"
 478             "    bpl     loc_fc4e840e\n"
 479             "    lsls    r0, r0, #0x1a\n"
 480             "    bpl     loc_fc4e840e\n"
 481             "    movs    r2, #0x20\n"
 482             "    mov     r1, r7\n"
 483             "    add     r0, sp, #4\n"
 484             "    blx     sub_fc34d26c\n"
 485             "    add     r0, sp, #4\n"
 486             "    bl      sub_fc3bf478\n"
 487             "    add     r2, sp, #4\n"
 488             "    add     r0, r2\n"
 489             "    movs    r1, #0x54\n"
 490             "    strb    r1, [r0, #-0x3]!\n"
 491             "    movs    r1, #0x4d\n"
 492             "    strb    r1, [r0, #1]\n"
 493             "    movs    r1, #0x50\n"
 494             "    strb    r1, [r0, #2]\n"
 495             "    add     r1, sp, #4\n"
 496             "    mov     r0, r7\n"
 497             "    bl      sub_fc1c8b3a\n"
 498             "    cbnz    r0, loc_fc4e83fe\n"
 499             "    movs    r0, #0\n"
 500             "    movw    r2, #0x1be\n"
 501             "    ldr     r1, =0xfc4e850c\n" //  *"dwFWrite.c"
 502             "    blx     sub_fc34d264\n"
 503             "loc_fc4e83fe:\n"
 504             "    add     r0, sp, #4\n"
 505             "    bl      sub_fc1c91a8\n"
 506             "    mov     r0, r7\n"
 507             "    b       loc_fc4e840a\n"
 508             "loc_fc4e8408:\n"
 509             "    b       loc_fc4e8424\n"
 510             "loc_fc4e840a:\n"
 511             "    bl      sub_fc1c91a8\n"
 512             "loc_fc4e840e:\n"
 513             "    movs    r1, #0\n"
 514             "    movs    r0, #0x48\n"
 515             "    bl      sub_fc3b5a60\n"
 516             "    mov     r0, r7\n"
 517             "    bl      sub_fc3b7620\n"
 518             "    ldr     r1, [r5, #0x20]\n"
 519             "    bl      sub_fc07dd94\n"
 520             "    b       loc_fc4e8428\n"
 521             "loc_fc4e8424:\n"
 522             "    ldr     r0, [r5, #0x20]\n"
 523             "    blx     r0\n"
 524             "loc_fc4e8428:\n"
 525             "    ldr     r0, [r5, #0x18]\n"
 526             "    cmp     r0, #0\n"
 527             "    beq     loc_fc4e843c\n"
 528             "    ldr     r1, [r4, #0x14]\n"
 529             "    mov     r0, r4\n"
 530             "    bl      sub_fc4e8110\n"
 531             "    ldr     r1, [r5, #0x18]\n"
 532             "    ldr     r0, [r4, #0x14]\n"
 533             "    blx     r1\n"
 534             "loc_fc4e843c:\n"
 535             "    add     sp, #0x3c\n"
 536             "    pop     {r4, r5, r6, r7, pc}\n"
 537     );
 538 }

/* [<][>][^][v][top][bottom][index][help] */