.include "asm/macros.inc" .include "constants/constants.inc" .syntax unified .text thumb_func_start object_new_hidden_with_callback object_new_hidden_with_callback: @ 806F640 push {r4-r6,lr} adds r6, r0, 0 ldr r0, =gUnknown_0832A3A8 movs r1, 0xF8 movs r2, 0xA8 movs r3, 0xE bl AddObjectToFront lsls r0, 24 lsrs r0, 24 ldr r5, =0x02020630 lsls r2, r0, 4 adds r2, r0 lsls r2, 2 adds r3, r2, r5 adds r3, 0x3E ldrb r1, [r3] movs r4, 0x4 orrs r1, r4 strb r1, [r3] adds r5, 0x1C adds r2, r5 str r6, [r2] pop {r4-r6} pop {r1} bx r1 .pool thumb_func_end object_new_hidden_with_callback thumb_func_start sub_806F67C sub_806F67C: @ 806F67C strh r1, [r0] lsrs r1, 16 strh r1, [r0, 0x2] bx lr thumb_func_end sub_806F67C thumb_func_start sub_806F684 sub_806F684: @ 806F684 ldrh r2, [r0] movs r3, 0x2 ldrsh r0, [r0, r3] lsls r0, 16 orrs r2, r0 str r2, [r1] bx lr thumb_func_end sub_806F684 thumb_func_start sub_806F694 sub_806F694: @ 806F694 push {r4-r7,lr} mov r7, r8 push {r7} ldr r4, [sp, 0x18] ldr r5, [sp, 0x1C] ldr r6, [sp, 0x20] ldr r7, [sp, 0x24] mov r8, r7 str r1, [r0] str r2, [r0, 0x4] strh r3, [r0, 0x8] strh r4, [r0, 0xA] strh r5, [r0, 0xC] strh r6, [r0, 0xE] mov r1, r8 strh r1, [r0, 0x10] pop {r3} mov r8, r3 pop {r4-r7} pop {r0} bx r0 thumb_func_end sub_806F694 thumb_func_start sub_806F6C0 sub_806F6C0: @ 806F6C0 push {r4-r6,lr} mov r6, r8 push {r6} sub sp, 0x24 mov r8, r0 ldr r0, [sp, 0x38] ldr r4, [sp, 0x3C] ldr r5, [sp, 0x40] ldr r6, [sp, 0x44] lsls r6, 16 lsrs r6, 16 lsls r3, 16 asrs r3, 16 lsls r0, 16 asrs r0, 16 str r0, [sp] lsls r4, 16 asrs r4, 16 str r4, [sp, 0x4] lsls r5, 16 asrs r5, 16 str r5, [sp, 0x8] str r6, [sp, 0xC] add r0, sp, 0x10 bl sub_806F694 add r0, sp, 0x10 mov r1, r8 movs r2, 0x1 bl BgAffineSet add sp, 0x24 pop {r3} mov r8, r3 pop {r4-r6} pop {r0} bx r0 thumb_func_end sub_806F6C0 thumb_func_start rfu_MBOOT_CHILD_inheritanceLinkStatus rfu_MBOOT_CHILD_inheritanceLinkStatus: @ 806F70C push {r4-r7,lr} mov r7, r10 mov r6, r9 mov r5, r8 push {r5-r7} sub sp, 0x38 str r2, [sp, 0x20] adds r4, r3, 0 ldr r7, [sp, 0x58] lsls r0, 24 lsls r1, 24 ldr r2, =gUnknown_0832A3C0 lsrs r1, 23 lsrs r0, 21 adds r1, r0 adds r0, r2, 0x1 adds r0, r1, r0 ldrb r0, [r0] str r0, [sp, 0x24] adds r1, r2 ldrb r1, [r1] str r1, [sp, 0x28] movs r0, 0 b _0806F88C .pool _0806F740: movs r5, 0 adds r0, 0x1 str r0, [sp, 0x30] b _0806F874 _0806F748: ldrh r0, [r4] ldr r2, =0x000003ff adds r1, r2, 0 ands r1, r0 lsls r1, 5 mov r8, r1 movs r2, 0xC0 lsls r2, 4 adds r1, r2, 0 ands r1, r0 mov r2, sp strh r0, [r2, 0x34] cmp r1, 0 bne _0806F788 ldr r0, [sp, 0x20] add r0, r8 adds r1, r7, 0 ldr r2, =0x04000008 bl CpuSet adds r4, 0x2 str r4, [sp, 0x2C] adds r7, 0x20 mov r10, r7 adds r5, 0x1 mov r9, r5 b _0806F86A .pool _0806F788: movs r0, 0x80 lsls r0, 4 cmp r1, r0 bne _0806F7CC movs r1, 0 adds r4, 0x2 str r4, [sp, 0x2C] movs r2, 0x20 adds r2, r7 mov r10, r2 adds r5, 0x1 mov r9, r5 _0806F7A0: lsls r4, r1, 24 asrs r4, 24 movs r0, 0x7 subs r0, r4 lsls r0, 2 add r0, r8 ldr r1, [sp, 0x20] adds r0, r1, r0 lsls r1, r4, 2 adds r1, r7, r1 ldr r2, =0x04000001 bl CpuSet adds r4, 0x1 lsls r4, 24 lsrs r1, r4, 24 asrs r4, 24 cmp r4, 0x7 ble _0806F7A0 b _0806F86A .pool _0806F7CC: movs r1, 0 adds r4, 0x2 str r4, [sp, 0x2C] movs r2, 0x20 adds r2, r7 mov r10, r2 adds r5, 0x1 mov r9, r5 movs r0, 0xF mov r12, r0 _0806F7E0: movs r2, 0 lsls r4, r1, 24 lsls r0, r4, 2 lsrs r0, 24 adds r6, r0, 0x3 mov r1, r8 adds r5, r1, r0 _0806F7EE: lsls r1, r2, 24 asrs r1, 24 subs r0, r6, r1 mov r2, sp adds r3, r2, r0 adds r0, r5, r1 ldr r2, [sp, 0x20] adds r0, r2, r0 ldrb r2, [r0] mov r0, r12 ands r0, r2 lsls r0, 4 lsrs r2, 4 orrs r0, r2 strb r0, [r3] adds r1, 0x1 lsls r1, 24 lsrs r2, r1, 24 asrs r1, 24 cmp r1, 0x3 ble _0806F7EE movs r1, 0x80 lsls r1, 17 adds r0, r4, r1 lsrs r1, r0, 24 asrs r0, 24 cmp r0, 0x7 ble _0806F7E0 mov r2, sp ldrh r0, [r2, 0x34] movs r2, 0x80 lsls r2, 4 ands r0, r2 cmp r0, 0 beq _0806F860 movs r1, 0 _0806F836: lsls r4, r1, 24 asrs r4, 24 movs r0, 0x7 subs r0, r4 lsls r0, 2 add r0, sp lsls r1, r4, 2 adds r1, r7, r1 ldr r2, =0x04000001 bl CpuSet adds r4, 0x1 lsls r4, 24 lsrs r1, r4, 24 asrs r4, 24 cmp r4, 0x7 ble _0806F836 b _0806F86A .pool _0806F860: mov r0, sp adds r1, r7, 0 ldr r2, =0x04000008 bl CpuSet _0806F86A: ldr r4, [sp, 0x2C] mov r7, r10 mov r1, r9 lsls r0, r1, 24 lsrs r5, r0, 24 _0806F874: ldr r2, [sp, 0x28] cmp r5, r2 bcs _0806F87C b _0806F748 _0806F87C: movs r0, 0x20 ldr r1, [sp, 0x28] subs r0, r1 lsls r0, 1 adds r4, r0 ldr r2, [sp, 0x30] lsls r0, r2, 24 lsrs r0, 24 _0806F88C: ldr r1, [sp, 0x24] cmp r0, r1 bcs _0806F894 b _0806F740 _0806F894: add sp, 0x38 pop {r3-r5} mov r8, r3 mov r9, r4 mov r10, r5 pop {r4-r7} pop {r0} bx r0 .pool thumb_func_end rfu_MBOOT_CHILD_inheritanceLinkStatus thumb_func_start sub_806F8A8 sub_806F8A8: @ 806F8A8 push {lr} adds r2, r0, 0 movs r1, 0 movs r3, 0x1 _0806F8B0: adds r0, r2, 0 ands r0, r3 cmp r0, 0 beq _0806F8BC adds r0, r1, 0 b _0806F8CA _0806F8BC: lsrs r2, 1 adds r0, r1, 0x1 lsls r0, 24 lsrs r1, r0, 24 cmp r1, 0x1F bls _0806F8B0 movs r0, 0 _0806F8CA: pop {r1} bx r1 thumb_func_end sub_806F8A8 thumb_func_start sub_806F8D0 sub_806F8D0: @ 806F8D0 push {r4-r7,lr} adds r7, r0, 0 adds r4, r1, 0 ldr r2, =0x00001121 movs r3, 0 cmp r3, r4 bge _0806F91C movs r6, 0x1 ldr r0, =0x00008408 adds r5, r0, 0 _0806F8E4: adds r0, r7, r3 ldrb r0, [r0] eors r2, r0 movs r1, 0 adds r3, 0x1 _0806F8EE: adds r0, r2, 0 ands r0, r6 cmp r0, 0 beq _0806F908 lsrs r0, r2, 1 eors r0, r5 lsls r0, 16 lsrs r2, r0, 16 b _0806F90A .pool _0806F908: lsrs r2, 1 _0806F90A: adds r0, r1, 0x1 lsls r0, 16 lsrs r1, r0, 16 cmp r1, 0x7 bls _0806F8EE lsls r0, r3, 16 lsrs r3, r0, 16 cmp r3, r4 blt _0806F8E4 _0806F91C: mvns r0, r2 lsls r0, 16 lsrs r0, 16 pop {r4-r7} pop {r1} bx r1 thumb_func_end sub_806F8D0 thumb_func_start sub_806F928 sub_806F928: @ 806F928 push {r4-r6,lr} adds r5, r0, 0 adds r4, r1, 0 ldr r2, =0x00001121 movs r3, 0 cmp r3, r4 bcs _0806F956 ldr r6, =gUnknown_0832A3D8 _0806F938: lsrs r1, r2, 8 adds r0, r5, r3 ldrb r0, [r0] eors r2, r0 lsls r0, r2, 24 lsrs r0, 23 adds r0, r6 ldrh r0, [r0] adds r2, r0, 0 eors r2, r1 adds r0, r3, 0x1 lsls r0, 16 lsrs r3, r0, 16 cmp r3, r4 bcc _0806F938 _0806F956: mvns r0, r2 lsls r0, 16 lsrs r0, 16 pop {r4-r6} pop {r1} bx r1 .pool thumb_func_end sub_806F928 thumb_func_start sub_806F96C sub_806F96C: @ 806F96C push {r4,lr} adds r4, r0, 0 movs r3, 0 movs r2, 0 cmp r3, r1 bcs _0806F984 _0806F978: adds r0, r4, r2 ldrb r0, [r0] adds r3, r0 adds r2, 0x1 cmp r2, r1 bcc _0806F978 _0806F984: adds r0, r3, 0 pop {r4} pop {r1} bx r1 thumb_func_end sub_806F96C .align 2, 0 @ Don't pad with nop.