thumb_func_start gpu_init_bgs ; void gpu_init_bgs() gpu_init_bgs: ; 80012F0 push {lr} bl gpu_reset_bg_configs ldr r1, =0x030008e0 movs r0, 0 strh r0, [r1, 0x10] bl gpu_sync_text_mode_and_hide_bgs pop {r0} bx r0 .align 2, 0 .pool thumb_func_end gpu_init_bgs thumb_func_start gpu_set_bg_mode ; void gpu_set_bg_mode(u8 bg_mode) gpu_set_bg_mode: ; 8001308 lsls r0, 24 lsrs r0, 24 ldr r3, =0x030008e0 ldrh r2, [r3, 0x10] ldr r1, =0x0000fff8 ands r1, r2 orrs r1, r0 strh r1, [r3, 0x10] bx lr .align 2, 0 .pool thumb_func_end gpu_set_bg_mode thumb_func_start gpu_get_bg_mode ; u8 gpu_get_bg_mode() gpu_get_bg_mode: ; 8001324 ldr r0, =0x030008e0 ldrb r1, [r0, 0x10] movs r0, 0x7 ands r0, r1 bx lr .align 2, 0 .pool thumb_func_end gpu_get_bg_mode thumb_func_start gpu_reset_bg_configs ; void gpu_reset_bg_configs() gpu_reset_bg_configs: ; 8001334 push {lr} ldr r2, =0x030008e0 ldr r0, =gBgConfigZeroValue ldr r0, [r0] adds r1, r2, 0 adds r1, 0xC @08001340: str r0, [r1] subs r1, 0x4 cmp r1, r2 bge @08001340 pop {r0} bx r0 .align 2, 0 .pool thumb_func_end gpu_reset_bg_configs thumb_func_start sub_8001354 sub_8001354: ; 8001354 push {r4,lr} lsls r0, 24 lsrs r4, r0, 24 adds r0, r4, 0 bl is_invalid_bg_id lsls r0, 24 cmp r0, 0 bne @08001372 ldr r1, =0x030008e0 lsls r0, r4, 2 adds r0, r1 ldr r1, =gBgConfigZeroValue ldr r1, [r1] str r1, [r0] @08001372: pop {r4} pop {r0} bx r0 .align 2, 0 .pool thumb_func_end sub_8001354 thumb_func_start gpu_bg_config_set_fields ; void gpu_bg_config_set_fields(u8 bg_id, u8 character_base_block, u8 screen_base_block, u8 screen_size, u8 palette_size_select, u8 priority, u8 mosaic, u8 wraparound) gpu_bg_config_set_fields: ; 8001380 push {r4-r7,lr} mov r7, r10 mov r6, r9 mov r5, r8 push {r5-r7} sub sp, 0x10 ldr r4, [sp, 0x30] ldr r5, [sp, 0x34] ldr r6, [sp, 0x38] mov r12, r6 ldr r6, [sp, 0x3C] mov r8, r6 lsls r0, 24 lsrs r7, r0, 24 str r7, [sp] lsls r1, 24 lsrs r1, 24 mov r10, r1 lsls r2, 24 lsrs r6, r2, 24 lsls r3, 24 lsrs r3, 24 mov r9, r3 lsls r4, 24 lsrs r4, 24 str r4, [sp, 0x4] lsls r5, 24 lsrs r5, 24 mov r0, r12 lsls r0, 24 lsrs r4, r0, 24 mov r1, r8 lsls r1, 24 lsrs r1, 24 str r1, [sp, 0xC] adds r0, r7, 0 bl is_invalid_bg_id lsls r0, 24 lsrs r0, 24 mov r12, r0 cmp r0, 0 bne @08001498 ldr r2, =0x030008e0 mov r8, r2 mov r0, r10 cmp r0, 0xFF beq @080013F4 lsls r2, r7, 2 add r2, r8 movs r1, 0x3 ands r1, r0 ldrb r3, [r2, 0x1] movs r0, 0x4 negs r0, r0 ands r0, r3 orrs r0, r1 strb r0, [r2, 0x1] @080013F4: cmp r6, 0xFF beq @0800140C lsls r1, r7, 2 add r1, r8 movs r0, 0x1F ands r6, r0 lsls r3, r6, 2 ldrb r2, [r1, 0x1] subs r0, 0x9C ands r0, r2 orrs r0, r3 strb r0, [r1, 0x1] @0800140C: mov r1, r9 cmp r1, 0xFF beq @08001428 lsls r1, r7, 2 add r1, r8 movs r0, 0x3 mov r2, r9 ands r2, r0 lsls r3, r2, 2 ldrb r2, [r1] subs r0, 0x10 ands r0, r2 orrs r0, r3 strb r0, [r1] @08001428: ldr r6, [sp, 0x4] cmp r6, 0xFF beq @0800143E lsls r1, r7, 2 add r1, r8 lsls r3, r6, 7 ldrb r2, [r1, 0x1] movs r0, 0x7F ands r0, r2 orrs r0, r3 strb r0, [r1, 0x1] @0800143E: cmp r5, 0xFF beq @08001456 lsls r1, r7, 2 add r1, r8 movs r0, 0x3 ands r5, r0 lsls r3, r5, 4 ldrb r2, [r1] subs r0, 0x34 ands r0, r2 orrs r0, r3 strb r0, [r1] @08001456: cmp r4, 0xFF beq @0800146E lsls r1, r7, 2 add r1, r8 movs r0, 0x1 ands r4, r0 lsls r3, r4, 6 ldrb r2, [r1] subs r0, 0x42 ands r0, r2 orrs r0, r3 strb r0, [r1] @0800146E: ldr r0, [sp, 0xC] cmp r0, 0xFF beq @08001484 lsls r1, r7, 2 add r1, r8 lsls r3, r0, 7 ldrb r2, [r1] movs r0, 0x7F ands r0, r2 orrs r0, r3 strb r0, [r1] @08001484: ldr r1, [sp] lsls r0, r1, 2 add r0, r8 mov r2, r12 strb r2, [r0, 0x2] strb r2, [r0, 0x3] ldrb r1, [r0] movs r2, 0x1 orrs r1, r2 strb r1, [r0] @08001498: add sp, 0x10 pop {r3-r5} mov r8, r3 mov r9, r4 mov r10, r5 pop {r4-r7} pop {r0} bx r0 .align 2, 0 .pool thumb_func_end gpu_bg_config_set_fields thumb_func_start gpu_bg_config_get_field ; int gpu_bg_config_get_field(u8 bg_id, u8 field_id) gpu_bg_config_get_field: ; 80014AC push {r4,r5,lr} lsls r0, 24 lsrs r4, r0, 24 lsls r1, 24 lsrs r5, r1, 24 adds r0, r4, 0 bl is_invalid_bg_id lsls r0, 24 cmp r0, 0 bne @08001558 ldr r1, =0x030008e0 lsls r2, r4, 2 adds r0, r2, r1 ldrb r0, [r0] lsls r0, 31 adds r3, r1, 0 cmp r0, 0 beq @08001558 subs r0, r5, 0x1 cmp r0, 0x7 bhi @08001558 lsls r0, 2 ldr r1, =@080014EC adds r0, r1 ldr r0, [r0] mov pc, r0 .align 2, 0 .pool .align 2, 0 @080014EC: .4byte @0800150C .4byte @08001516 .4byte @08001520 .4byte @0800152A .4byte @08001534 .4byte @0800153C .4byte @08001546 .4byte @08001550 @0800150C: adds r0, r2, r3 ldrb r0, [r0] lsls r0, 31 lsrs r0, 31 b @0800155A @08001516: adds r0, r2, r3 ldrb r0, [r0, 0x1] lsls r0, 30 lsrs r0, 30 b @0800155A @08001520: adds r0, r2, r3 ldrb r0, [r0, 0x1] lsls r0, 25 lsrs r0, 27 b @0800155A @0800152A: adds r0, r2, r3 ldrb r0, [r0] lsls r0, 28 lsrs r0, 30 b @0800155A @08001534: adds r0, r2, r3 ldrb r0, [r0, 0x1] lsrs r0, 7 b @0800155A @0800153C: adds r0, r2, r3 ldrb r0, [r0] lsls r0, 26 lsrs r0, 30 b @0800155A @08001546: adds r0, r2, r3 ldrb r0, [r0] lsls r0, 25 lsrs r0, 31 b @0800155A @08001550: adds r0, r2, r3 ldrb r0, [r0] lsrs r0, 7 b @0800155A @08001558: movs r0, 0xFF @0800155A: pop {r4,r5} pop {r1} bx r1 thumb_func_end gpu_bg_config_get_field thumb_func_start gpu_copy_to_vram_by_bg_id ; s8 gpu_copy_to_vram_by_bg_id(u8 bg_id, int src, u16 byte_count, u16 dest_offset, gpu_copy_to_vram_type type) gpu_copy_to_vram_by_bg_id: ; 8001560 push {r4-r7,lr} mov r7, r8 push {r7} mov r8, r1 ldr r1, [sp, 0x18] lsls r0, 24 lsrs r4, r0, 24 lsls r2, 16 lsrs r7, r2, 16 lsls r3, 16 lsrs r6, r3, 16 lsls r1, 24 lsrs r5, r1, 24 adds r0, r4, 0 bl is_invalid_bg_id lsls r0, 24 cmp r0, 0 bne @080015D8 ldr r1, =0x030008e0 lsls r0, r4, 2 adds r1, r0, r1 ldrb r0, [r1] lsls r0, 31 cmp r0, 0 beq @080015D8 cmp r5, 0x1 beq @080015A4 cmp r5, 0x2 beq @080015AC movs r2, 0xFF b @080015DC .align 2, 0 .pool @080015A4: ldrb r0, [r1, 0x1] lsls r0, 30 lsrs r0, 16 b @080015B4 @080015AC: ldrb r0, [r1, 0x1] lsls r0, 25 lsrs r0, 27 lsls r0, 11 @080015B4: adds r0, r6, r0 lsls r0, 16 lsrs r0, 16 movs r1, 0xC0 lsls r1, 19 adds r1, r0, r1 mov r0, r8 adds r2, r7, 0 movs r3, 0 bl RequestDma3Copy lsls r0, 24 lsrs r2, r0, 24 asrs r0, 24 movs r1, 0x1 negs r1, r1 cmp r0, r1 bne @080015DC @080015D8: movs r0, 0xFF b @080015DE @080015DC: adds r0, r2, 0 @080015DE: pop {r3} mov r8, r3 pop {r4-r7} pop {r1} bx r1 thumb_func_end gpu_copy_to_vram_by_bg_id thumb_func_start gpu_bg_show ; void gpu_bg_show(u8 bg_id) gpu_bg_show: ; 80015E8 push {r4,r5,lr} lsls r0, 24 lsrs r4, r0, 24 adds r0, r4, 0 bl is_invalid_bg_id lsls r0, 24 cmp r0, 0 bne @08001656 ldr r5, =0x030008e0 lsls r0, r4, 2 adds r2, r0, r5 ldrb r3, [r2] lsls r0, r3, 31 cmp r0, 0 beq @08001656 lsls r1, r3, 26 lsrs r1, 30 ldrb r2, [r2, 0x1] lsls r0, r2, 30 lsrs r0, 28 orrs r1, r0 movs r0, 0x40 ands r0, r3 orrs r1, r0 lsrs r0, r2, 7 lsls r0, 7 orrs r1, r0 lsls r2, 25 lsrs r2, 27 lsls r2, 8 orrs r1, r2 lsrs r0, r3, 7 lsls r0, 13 orrs r1, r0 lsls r0, r3, 28 lsrs r0, 30 lsls r0, 14 orrs r1, r0 lsls r0, r4, 25 movs r2, 0x80 lsls r2, 20 adds r0, r2 lsrs r0, 24 bl lcd_io_set adds r1, r4, 0 adds r1, 0x8 movs r0, 0x1 lsls r0, r1 ldrh r1, [r5, 0x10] orrs r0, r1 ldr r1, =0x00000f07 ands r0, r1 strh r0, [r5, 0x10] @08001656: pop {r4,r5} pop {r0} bx r0 .align 2, 0 .pool thumb_func_end gpu_bg_show thumb_func_start gpu_bg_hide ; void gpu_bg_hide(u8 bg_id) gpu_bg_hide: ; 8001664 push {r4,lr} lsls r0, 24 lsrs r4, r0, 24 adds r0, r4, 0 bl is_invalid_bg_id lsls r0, 24 cmp r0, 0 bne @0800168A ldr r2, =0x030008e0 adds r0, r4, 0 adds r0, 0x8 movs r1, 0x1 lsls r1, r0 ldrh r0, [r2, 0x10] bics r0, r1 ldr r1, =0x00000f07 ands r0, r1 strh r0, [r2, 0x10] @0800168A: pop {r4} pop {r0} bx r0 .align 2, 0 .pool thumb_func_end gpu_bg_hide thumb_func_start gpu_sync_bg_visibility_and_mode ; void gpu_sync_bg_visibility_and_mode() gpu_sync_bg_visibility_and_mode: ; 8001698 push {lr} movs r0, 0 bl lcd_io_get ldr r1, =0x0000f0f8 ands r1, r0 ldr r0, =0x030008e0 ldrh r0, [r0, 0x10] orrs r1, r0 movs r0, 0 bl lcd_io_set pop {r0} bx r0 .align 2, 0 .pool thumb_func_end gpu_sync_bg_visibility_and_mode thumb_func_start gpu_sync_text_mode_and_hide_bgs ; void gpu_sync_text_mode_and_hide_bgs() gpu_sync_text_mode_and_hide_bgs: ; 80016BC push {lr} movs r0, 0 bl lcd_io_get ldr r1, =0x0000f0f8 ands r1, r0 movs r0, 0 bl lcd_io_set pop {r0} bx r0 .align 2, 0 .pool thumb_func_end gpu_sync_text_mode_and_hide_bgs thumb_func_start gpu_bg_affine_set ; void gpu_bg_affine_set(u8 bg_id, int bg_center_x, int bg_center_y, u16 display_center_x, s16 display_center_y, s16 scale_x, s16 scale_y, s16 rotation_angle) gpu_bg_affine_set: ; 80016D8 push {r4-r7,lr} mov r7, r8 push {r7} sub sp, 0x24 mov r12, r1 mov r8, r2 ldr r1, [sp, 0x3C] ldr r2, [sp, 0x40] ldr r4, [sp, 0x44] ldr r5, [sp, 0x48] lsls r0, 24 lsrs r6, r0, 24 lsls r3, 16 lsrs r3, 16 lsls r1, 16 lsrs r7, r1, 16 lsls r2, 16 lsrs r2, 16 lsls r4, 16 lsrs r4, 16 lsls r5, 16 lsrs r5, 16 ldr r0, =0x030008e0 ldrh r0, [r0, 0x10] movs r1, 0x7 ands r1, r0 cmp r1, 0x1 beq @08001720 cmp r1, 0x1 ble @08001796 cmp r1, 0x2 beq @08001726 b @08001796 .align 2, 0 .pool @08001720: cmp r6, 0x2 bne @08001796 b @08001730 @08001726: subs r0, r6, 0x2 lsls r0, 24 lsrs r0, 24 cmp r0, 0x1 bhi @08001796 @08001730: mov r0, r12 str r0, [sp] mov r0, r8 str r0, [sp, 0x4] mov r0, sp strh r3, [r0, 0x8] strh r7, [r0, 0xA] strh r2, [r0, 0xC] strh r4, [r0, 0xE] strh r5, [r0, 0x10] add r4, sp, 0x14 adds r1, r4, 0 movs r2, 0x1 bl BgAffineSet ldrh r1, [r4] movs r0, 0x20 bl lcd_io_set ldrh r1, [r4, 0x2] movs r0, 0x22 bl lcd_io_set ldrh r1, [r4, 0x4] movs r0, 0x24 bl lcd_io_set ldrh r1, [r4, 0x6] movs r0, 0x26 bl lcd_io_set ldrh r1, [r4] movs r0, 0x20 bl lcd_io_set ldrh r1, [r4, 0x8] movs r0, 0x28 bl lcd_io_set ldrh r1, [r4, 0xA] movs r0, 0x2A bl lcd_io_set ldrh r1, [r4, 0xC] movs r0, 0x2C bl lcd_io_set ldrh r1, [r4, 0xE] movs r0, 0x2E bl lcd_io_set @08001796: add sp, 0x24 pop {r3} mov r8, r3 pop {r4-r7} pop {r0} bx r0 thumb_func_end gpu_bg_affine_set thumb_func_start is_invalid_bg_id ; _BOOL1 is_invalid_bg_id(u8 bg_id) is_invalid_bg_id: ; 80017A4 push {lr} lsls r0, 24 lsrs r0, 24 cmp r0, 0x3 bhi @080017B2 movs r0, 0 b @080017B4 @080017B2: movs r0, 0x1 @080017B4: pop {r1} bx r1 thumb_func_end is_invalid_bg_id thumb_func_start do_nothing ; int do_nothing() do_nothing: ; 80017B8 movs r0, 0 bx lr thumb_func_end do_nothing thumb_func_start gpu_reset_bgs_and_dma3_busy_flags ; void gpu_reset_bgs_and_dma3_busy_flags(int a1) gpu_reset_bgs_and_dma3_busy_flags: ; 80017BC push {r4,lr} adds r4, r0, 0 bl gpu_init_bgs ldr r1, =0x03000938 movs r2, 0 adds r0, r1, 0 adds r0, 0xC @080017CC: str r2, [r0] subs r0, 0x4 cmp r0, r1 bge @080017CC ldr r0, =0x03002f54 str r4, [r0] pop {r4} pop {r0} bx r0 .align 2, 0 .pool thumb_func_end gpu_reset_bgs_and_dma3_busy_flags thumb_func_start bg_vram_setup ; void bg_vram_setup(u8 bg_mode, struct bg_config3 *bg_config3s, u8 entry_count) bg_vram_setup: ; 80017E8 push {r4-r7,lr} mov r7, r10 mov r6, r9 mov r5, r8 push {r5-r7} sub sp, 0x10 adds r5, r1, 0 lsls r0, 24 lsrs r0, 24 lsls r2, 24 lsrs r4, r2, 24 bl gpu_set_bg_mode bl gpu_reset_bg_configs cmp r4, 0 beq @08001894 movs r7, 0 ldr r0, =0x030008f8 mov r9, r0 movs r2, 0xC add r2, r9 mov r10, r2 adds r6, r5, 0 mov r8, r4 @0800181A: ldr r4, [r6] lsls r0, r4, 30 lsrs r5, r0, 30 cmp r5, 0x3 bhi @08001886 lsls r1, r4, 28 lsrs r1, 30 lsls r2, r4, 23 lsrs r2, 27 lsls r3, r4, 21 lsrs r3, 30 lsls r0, r4, 20 lsrs r0, 31 str r0, [sp] lsls r0, r4, 18 lsrs r0, 30 str r0, [sp, 0x4] str r7, [sp, 0x8] str r7, [sp, 0xC] adds r0, r5, 0 bl gpu_bg_config_set_fields lsls r4, r5, 4 mov r5, r9 adds r3, r4, r5 ldr r2, [r6] lsls r2, 8 lsrs r2, 22 ldrh r0, [r3] ldr r5, =0xfffffc00 adds r1, r5, 0 ands r0, r1 orrs r0, r2 strh r0, [r3] ldrb r0, [r3, 0x1] movs r2, 0x3D negs r2, r2 adds r1, r2, 0 ands r0, r1 strb r0, [r3, 0x1] ldr r0, [r3] ldr r1, =0x00003fff ands r0, r1 str r0, [r3] mov r0, r9 adds r0, 0x4 adds r0, r4, r0 str r7, [r0] mov r0, r9 adds r0, 0x8 adds r0, r4, r0 str r7, [r0] add r4, r10 str r7, [r4] @08001886: adds r6, 0x4 movs r5, 0x1 negs r5, r5 add r8, r5 mov r0, r8 cmp r0, 0 bne @0800181A @08001894: add sp, 0x10 pop {r3-r5} mov r8, r3 mov r9, r4 mov r10, r5 pop {r4-r7} pop {r0} bx r0 .align 2, 0 .pool thumb_func_end bg_vram_setup thumb_func_start bg_init_bg_config_2_from_bg_config_3 ; void bg_init_bg_config_2_from_bg_config_3(struct bg_config_3 *bg) bg_init_bg_config_2_from_bg_config_3: ; 80018B0 push {r4-r7,lr} sub sp, 0x10 adds r7, r0, 0 ldr r4, [r7] lsls r0, r4, 30 lsrs r5, r0, 30 cmp r5, 0x3 bhi @08001920 lsls r1, r4, 28 lsrs r1, 30 lsls r2, r4, 23 lsrs r2, 27 lsls r3, r4, 21 lsrs r3, 30 lsls r0, r4, 20 lsrs r0, 31 str r0, [sp] lsls r0, r4, 18 lsrs r0, 30 str r0, [sp, 0x4] movs r6, 0 str r6, [sp, 0x8] str r6, [sp, 0xC] adds r0, r5, 0 bl gpu_bg_config_set_fields ldr r4, =0x030008f8 lsls r5, 4 adds r3, r5, r4 ldr r1, [r7] lsls r1, 8 lsrs r1, 22 ldrh r2, [r3] ldr r0, =0xfffffc00 ands r0, r2 orrs r0, r1 strh r0, [r3] ldrb r1, [r3, 0x1] movs r0, 0x3D negs r0, r0 ands r0, r1 strb r0, [r3, 0x1] ldr r0, [r3] ldr r1, =0x00003fff ands r0, r1 str r0, [r3] adds r0, r4, 0x4 adds r0, r5, r0 str r6, [r0] adds r0, r4, 0 adds r0, 0x8 adds r0, r5, r0 str r6, [r0] adds r4, 0xC adds r5, r4 str r6, [r5] @08001920: add sp, 0x10 pop {r4-r7} pop {r0} bx r0 .align 2, 0 .pool thumb_func_end bg_init_bg_config_2_from_bg_config_3 thumb_func_start call_gpu_set_bg_mode ; void call_gpu_set_bg_mode(u8 bg_id) call_gpu_set_bg_mode: ; 8001934 push {lr} lsls r0, 24 lsrs r0, 24 bl gpu_set_bg_mode pop {r0} bx r0 thumb_func_end call_gpu_set_bg_mode thumb_func_start gpu_copy_bg_tile_pattern_data_to_vram ; s16 gpu_copy_bg_tile_pattern_data_to_vram(u8 bg_id, int src, u16 size, u16 offset) gpu_copy_bg_tile_pattern_data_to_vram: ; 8001944 push {r4-r7,lr} mov r7, r8 push {r7} sub sp, 0x4 adds r7, r1, 0 lsls r0, 24 lsrs r5, r0, 24 lsls r2, 16 lsrs r2, 16 mov r8, r2 lsls r3, 16 lsrs r4, r3, 16 adds r0, r5, 0 movs r1, 0x5 bl gpu_bg_config_get_field lsls r0, 16 cmp r0, 0 bne @08001980 ldr r1, =0x030008f8 lsls r0, r5, 4 adds r0, r1 ldrh r0, [r0] lsls r0, 22 lsrs r0, 22 adds r0, r4 lsls r0, 21 b @08001990 .align 2, 0 .pool @08001980: ldr r1, =0x030008f8 lsls r0, r5, 4 adds r0, r1 ldrh r0, [r0] lsls r0, 22 lsrs r0, 22 adds r0, r4 lsls r0, 22 @08001990: lsrs r4, r0, 16 movs r6, 0x1 str r6, [sp] adds r0, r5, 0 adds r1, r7, 0 mov r2, r8 adds r3, r4, 0 bl gpu_copy_to_vram_by_bg_id lsls r2, r0, 24 lsrs r1, r2, 24 adds r7, r1, 0 cmp r1, 0xFF bne @080019B8 ldr r0, =0x0000ffff b @080019E6 .align 2, 0 .pool @080019B8: ldr r0, =0x03000938 lsrs r2, 29 lsls r2, 2 adds r2, r0 movs r0, 0x1F ands r0, r1 adds r1, r6, 0 lsls r1, r0 ldr r0, [r2] orrs r0, r1 str r0, [r2] ldr r0, =0x03002f54 ldr r0, [r0] cmp r0, 0x1 bne @080019E4 lsrs r1, r4, 5 mov r0, r8 lsrs r2, r0, 5 adds r0, r5, 0 movs r3, 0x1 bl do_nothing @080019E4: adds r0, r7, 0 @080019E6: add sp, 0x4 pop {r3} mov r8, r3 pop {r4-r7} pop {r1} bx r1 .align 2, 0 .pool thumb_func_end gpu_copy_bg_tile_pattern_data_to_vram thumb_func_start gpu_copy_bg_tile_map_to_vram gpu_copy_bg_tile_map_to_vram: ; 80019FC push {r4,lr} sub sp, 0x4 lsls r0, 24 lsrs r0, 24 lsls r2, 16 lsrs r2, 16 lsls r3, 17 lsrs r3, 16 movs r4, 0x2 str r4, [sp] bl gpu_copy_to_vram_by_bg_id lsls r2, r0, 24 lsrs r3, r2, 24 cmp r3, 0xFF beq @08001A3C ldr r0, =0x03000938 lsrs r2, 29 lsls r2, 2 adds r2, r0 movs r0, 0x1F ands r0, r3 movs r1, 0x1 lsls r1, r0 ldr r0, [r2] orrs r0, r1 str r0, [r2] adds r0, r3, 0 b @08001A3E .align 2, 0 .pool @08001A3C: ldr r0, =0x0000ffff @08001A3E: add sp, 0x4 pop {r4} pop {r1} bx r1 .align 2, 0 .pool thumb_func_end gpu_copy_bg_tile_map_to_vram thumb_func_start unused_copy_palette unused_copy_palette: ; 8001A4C push {r4-r7,lr} adds r7, r1, 0 lsls r0, 24 lsrs r4, r0, 24 lsls r2, 16 lsrs r6, r2, 16 lsls r3, 16 lsrs r5, r3, 16 adds r0, r4, 0 bl is_invalid_bg_id_2 cmp r0, 0 bne @08001A98 ldr r1, =0x030008f8 lsls r0, r4, 4 adds r0, r1 ldrb r1, [r0, 0x1] lsls r1, 26 lsrs r1, 28 lsls r1, 5 lsls r0, r5, 1 adds r1, r0 lsls r1, 16 lsrs r1, 16 movs r0, 0xA0 lsls r0, 19 adds r1, r0 adds r0, r7, 0 adds r2, r6, 0 movs r3, 0 bl RequestDma3Copy lsls r3, r0, 24 asrs r1, r3, 24 movs r0, 0x1 negs r0, r0 cmp r1, r0 bne @08001AA4 @08001A98: ldr r0, =0x0000ffff b @08001AC8 .align 2, 0 .pool @08001AA4: ldr r4, =0x03000938 adds r0, r1, 0 cmp r1, 0 bge @08001AAE adds r0, 0x1F @08001AAE: asrs r0, 5 lsls r2, r0, 2 adds r2, r4 lsls r0, 5 subs r0, r1, r0 lsls r0, 24 asrs r0, 24 movs r1, 0x1 lsls r1, r0 ldr r0, [r2] orrs r0, r1 str r0, [r2] lsrs r0, r3, 24 @08001AC8: pop {r4-r7} pop {r1} bx r1 .align 2, 0 .pool thumb_func_end unused_copy_palette thumb_func_start is_dma3_queue_busy_with_gpu_copy ; int is_dma3_queue_busy_with_gpu_copy() is_dma3_queue_busy_with_gpu_copy: ; 8001AD4 push {r4-r7,lr} movs r5, 0 movs r7, 0x1 negs r7, r7 @08001ADC: adds r0, r5, 0 cmp r5, 0 bge @08001AE4 adds r0, 0x1F @08001AE4: asrs r0, 5 lsls r2, r0, 24 lsls r0, 5 subs r0, r5, r0 lsls r0, 24 lsrs r0, 24 ldr r1, =0x03000938 lsrs r2, 22 adds r4, r2, r1 movs r6, 0x1 lsls r6, r0 ldr r0, [r4] ands r0, r6 cmp r0, 0 beq @08001B22 lsls r0, r5, 16 asrs r0, 16 bl CheckForSpaceForDma3Request lsls r0, 24 asrs r0, 24 cmp r0, r7 bne @08001B1C movs r0, 0x1 b @08001B2A .align 2, 0 .pool @08001B1C: ldr r0, [r4] bics r0, r6 str r0, [r4] @08001B22: adds r5, 0x1 cmp r5, 0x7F ble @08001ADC movs r0, 0 @08001B2A: pop {r4-r7} pop {r1} bx r1 thumb_func_end is_dma3_queue_busy_with_gpu_copy thumb_func_start gpu_sync_bg_show ; void gpu_sync_bg_show(u8 bg_id) gpu_sync_bg_show: ; 8001B30 push {lr} lsls r0, 24 lsrs r0, 24 bl gpu_bg_show bl gpu_sync_bg_visibility_and_mode pop {r0} bx r0 thumb_func_end gpu_sync_bg_show thumb_func_start gpu_sync_bg_hide ; void gpu_sync_bg_hide(u8 bg_id) gpu_sync_bg_hide: ; 8001B44 push {lr} lsls r0, 24 lsrs r0, 24 bl gpu_bg_hide bl gpu_sync_bg_visibility_and_mode pop {r0} bx r0 thumb_func_end gpu_sync_bg_hide thumb_func_start gpu_bg_config_set_field ; int gpu_bg_config_set_field(u8 bg_id, bg_config_get_field field_id, u8 value) gpu_bg_config_set_field: ; 8001B58 push {r4,lr} sub sp, 0x10 lsls r0, 24 lsrs r4, r0, 24 lsls r1, 24 lsrs r1, 24 lsls r2, 24 lsrs r3, r2, 24 subs r0, r1, 0x1 cmp r0, 0x6 bhi @08001C12 lsls r0, 2 ldr r1, =@08001B7C adds r0, r1 ldr r0, [r0] mov pc, r0 .align 2, 0 .pool .align 2, 0 @08001B7C: .4byte @08001B98 .4byte @08001BA8 .4byte @08001BBA .4byte @08001BD0 .4byte @08001BE4 .4byte @08001BFC .4byte @08001BDA @08001B98: movs r0, 0xFF str r0, [sp] str r0, [sp, 0x4] str r0, [sp, 0x8] str r0, [sp, 0xC] adds r0, r4, 0 adds r1, r3, 0 b @08001BF2 @08001BA8: movs r0, 0xFF str r0, [sp] str r0, [sp, 0x4] str r0, [sp, 0x8] str r0, [sp, 0xC] adds r0, r4, 0 movs r1, 0xFF adds r2, r3, 0 b @08001BF4 @08001BBA: movs r0, 0xFF str r0, [sp] str r0, [sp, 0x4] str r0, [sp, 0x8] str r0, [sp, 0xC] adds r0, r4, 0 movs r1, 0xFF movs r2, 0xFF bl gpu_bg_config_set_fields b @08001C12 @08001BD0: str r3, [sp] movs r0, 0xFF str r0, [sp, 0x4] str r0, [sp, 0x8] b @08001BEC @08001BDA: movs r0, 0xFF str r0, [sp] str r3, [sp, 0x4] str r0, [sp, 0x8] b @08001BEC @08001BE4: movs r0, 0xFF str r0, [sp] str r0, [sp, 0x4] str r3, [sp, 0x8] @08001BEC: str r0, [sp, 0xC] adds r0, r4, 0 movs r1, 0xFF @08001BF2: movs r2, 0xFF @08001BF4: movs r3, 0xFF bl gpu_bg_config_set_fields b @08001C12 @08001BFC: movs r0, 0xFF str r0, [sp] str r0, [sp, 0x4] str r0, [sp, 0x8] str r3, [sp, 0xC] adds r0, r4, 0 movs r1, 0xFF movs r2, 0xFF movs r3, 0xFF bl gpu_bg_config_set_fields @08001C12: add sp, 0x10 pop {r4} pop {r0} bx r0 thumb_func_end gpu_bg_config_set_field thumb_func_start bg_get_field bg_get_field: ; 8001C1C push {r4,lr} lsls r0, 24 lsrs r4, r0, 24 lsls r1, 24 lsrs r1, 24 subs r0, r1, 0x1 cmp r0, 0x9 bhi @08001CF8 lsls r0, 2 ldr r1, =@08001C3C adds r0, r1 ldr r0, [r0] mov pc, r0 .align 2, 0 .pool .align 2, 0 @08001C3C: .4byte @08001C64 .4byte @08001C6E .4byte @08001C78 .4byte @08001C82 .4byte @08001C96 .4byte @08001CA0 .4byte @08001C8C .4byte @08001CAA .4byte @08001CD8 .4byte @08001CE4 @08001C64: adds r0, r4, 0 movs r1, 0x2 bl gpu_bg_config_get_field b @08001CDE @08001C6E: adds r0, r4, 0 movs r1, 0x3 bl gpu_bg_config_get_field b @08001CDE @08001C78: adds r0, r4, 0 movs r1, 0x4 bl gpu_bg_config_get_field b @08001CDE @08001C82: adds r0, r4, 0 movs r1, 0x5 bl gpu_bg_config_get_field b @08001CDE @08001C8C: adds r0, r4, 0 movs r1, 0x6 bl gpu_bg_config_get_field b @08001CDE @08001C96: adds r0, r4, 0 movs r1, 0x7 bl gpu_bg_config_get_field b @08001CDE @08001CA0: adds r0, r4, 0 movs r1, 0x8 bl gpu_bg_config_get_field b @08001CDE @08001CAA: adds r0, r4, 0 bl bg_get_type_by_bg_id cmp r0, 0 beq @08001CBC cmp r0, 0x1 beq @08001CCA movs r0, 0 b @08001CFA @08001CBC: adds r0, r4, 0 movs r1, 0 bl bg_get_screen_size_in_regular_mode lsls r0, 27 lsrs r0, 16 b @08001CFA @08001CCA: adds r0, r4, 0 movs r1, 0 bl bg_get_screen_size_in_affine_mode lsls r0, 24 lsrs r0, 16 b @08001CFA @08001CD8: adds r0, r4, 0 bl bg_get_type_by_bg_id @08001CDE: lsls r0, 16 lsrs r0, 16 b @08001CFA @08001CE4: ldr r0, =0x030008f8 lsls r1, r4, 4 adds r1, r0 ldrh r0, [r1] lsls r0, 22 lsrs r0, 22 b @08001CFA .align 2, 0 .pool @08001CF8: ldr r0, =0x0000ffff @08001CFA: pop {r4} pop {r1} bx r1 .align 2, 0 .pool thumb_func_end bg_get_field thumb_func_start bg_change_x_offset ; int bg_change_x_offset(u8 bg_id, int offset, u8 operation) bg_change_x_offset: ; 8001D04 push {r4-r6,lr} adds r6, r1, 0 lsls r0, 24 lsrs r4, r0, 24 lsls r2, 24 lsrs r5, r2, 24 adds r0, r4, 0 bl is_invalid_bg_id_2 cmp r0, 0 bne @08001D28 adds r0, r4, 0 movs r1, 0x1 bl gpu_bg_config_get_field lsls r0, 16 cmp r0, 0 bne @08001D2E @08001D28: movs r0, 0x1 negs r0, r0 b @08001E34 @08001D2E: cmp r5, 0x1 beq @08001D4C cmp r5, 0x1 ble @08001D3A cmp r5, 0x2 beq @08001D60 @08001D3A: ldr r0, =0x030008f8 lsls r1, r4, 4 adds r0, 0x8 adds r0, r1, r0 str r6, [r0] adds r5, r1, 0 b @08001D70 .align 2, 0 .pool @08001D4C: ldr r0, =0x030008f8 lsls r2, r4, 4 adds r0, 0x8 adds r0, r2, r0 ldr r1, [r0] adds r1, r6 b @08001D6C .align 2, 0 .pool @08001D60: ldr r0, =0x030008f8 lsls r2, r4, 4 adds r0, 0x8 adds r0, r2, r0 ldr r1, [r0] subs r1, r6 @08001D6C: str r1, [r0] adds r5, r2, 0 @08001D70: bl gpu_get_bg_mode lsls r0, 24 lsrs r0, 24 cmp r4, 0x1 beq @08001DAC cmp r4, 0x1 bgt @08001D8C cmp r4, 0 beq @08001D96 b @08001E2C .align 2, 0 .pool @08001D8C: cmp r4, 0x2 beq @08001DC0 cmp r4, 0x3 beq @08001DF8 b @08001E2C @08001D96: ldr r0, =0x030008f8 ldr r0, [r0, 0x8] lsls r0, 8 lsrs r1, r0, 16 movs r0, 0x10 bl lcd_io_set b @08001E2C .align 2, 0 .pool @08001DAC: ldr r0, =0x030008f8 ldr r0, [r0, 0x18] lsls r0, 8 lsrs r1, r0, 16 movs r0, 0x14 bl lcd_io_set b @08001E2C .align 2, 0 .pool @08001DC0: cmp r0, 0 bne @08001DD8 ldr r0, =0x030008f8 ldr r0, [r0, 0x28] lsls r0, 8 lsrs r1, r0, 16 movs r0, 0x18 bl lcd_io_set b @08001E2C .align 2, 0 .pool @08001DD8: ldr r0, =0x030008f8 ldr r0, [r0, 0x28] lsrs r1, r0, 16 lsls r0, 16 lsrs r4, r0, 16 movs r0, 0x2A bl lcd_io_set movs r0, 0x28 adds r1, r4, 0 bl lcd_io_set b @08001E2C .align 2, 0 .pool @08001DF8: cmp r0, 0 bne @08001E10 ldr r0, =0x030008f8 ldr r0, [r0, 0x38] lsls r0, 8 lsrs r1, r0, 16 movs r0, 0x1C bl lcd_io_set b @08001E2C .align 2, 0 .pool @08001E10: cmp r0, 0x2 bne @08001E2C ldr r0, =0x030008f8 ldr r0, [r0, 0x38] lsrs r1, r0, 16 lsls r0, 16 lsrs r4, r0, 16 movs r0, 0x3A bl lcd_io_set movs r0, 0x38 adds r1, r4, 0 bl lcd_io_set @08001E2C: ldr r0, =0x030008f8 adds r0, 0x8 adds r0, r5, r0 ldr r0, [r0] @08001E34: pop {r4-r6} pop {r1} bx r1 .align 2, 0 .pool thumb_func_end bg_change_x_offset thumb_func_start bg_get_x_offset ; int bg_get_x_offset(u8 bg_id) bg_get_x_offset: ; 8001E40 push {r4,lr} lsls r0, 24 lsrs r0, 24 adds r4, r0, 0 bl is_invalid_bg_id_2 cmp r0, 0 bne @08001E70 adds r0, r4, 0 movs r1, 0x1 bl gpu_bg_config_get_field lsls r0, 16 cmp r0, 0 beq @08001E70 ldr r0, =0x030008f8 lsls r1, r4, 4 adds r0, 0x8 adds r1, r0 ldr r0, [r1] b @08001E74 .align 2, 0 .pool @08001E70: movs r0, 0x1 negs r0, r0 @08001E74: pop {r4} pop {r1} bx r1 thumb_func_end bg_get_x_offset thumb_func_start bg_change_y_offset ; int bg_change_y_offset(u8 bg_id, int offset, u8 operation) bg_change_y_offset: ; 8001E7C push {r4-r6,lr} adds r6, r1, 0 lsls r0, 24 lsrs r4, r0, 24 lsls r2, 24 lsrs r5, r2, 24 adds r0, r4, 0 bl is_invalid_bg_id_2 cmp r0, 0 bne @08001EA0 adds r0, r4, 0 movs r1, 0x1 bl gpu_bg_config_get_field lsls r0, 16 cmp r0, 0 bne @08001EA6 @08001EA0: movs r0, 0x1 negs r0, r0 b @08001FAC @08001EA6: cmp r5, 0x1 beq @08001EC4 cmp r5, 0x1 ble @08001EB2 cmp r5, 0x2 beq @08001ED8 @08001EB2: ldr r0, =0x030008f8 lsls r1, r4, 4 adds r0, 0xC adds r0, r1, r0 str r6, [r0] adds r5, r1, 0 b @08001EE8 .align 2, 0 .pool @08001EC4: ldr r0, =0x030008f8 lsls r2, r4, 4 adds r0, 0xC adds r0, r2, r0 ldr r1, [r0] adds r1, r6 b @08001EE4 .align 2, 0 .pool @08001ED8: ldr r0, =0x030008f8 lsls r2, r4, 4 adds r0, 0xC adds r0, r2, r0 ldr r1, [r0] subs r1, r6 @08001EE4: str r1, [r0] adds r5, r2, 0 @08001EE8: bl gpu_get_bg_mode lsls r0, 24 lsrs r0, 24 cmp r4, 0x1 beq @08001F24 cmp r4, 0x1 bgt @08001F04 cmp r4, 0 beq @08001F0E b @08001FA4 .align 2, 0 .pool @08001F04: cmp r4, 0x2 beq @08001F38 cmp r4, 0x3 beq @08001F70 b @08001FA4 @08001F0E: ldr r0, =0x030008f8 ldr r0, [r0, 0xC] lsls r0, 8 lsrs r1, r0, 16 movs r0, 0x12 bl lcd_io_set b @08001FA4 .align 2, 0 .pool @08001F24: ldr r0, =0x030008f8 ldr r0, [r0, 0x1C] lsls r0, 8 lsrs r1, r0, 16 movs r0, 0x16 bl lcd_io_set b @08001FA4 .align 2, 0 .pool @08001F38: cmp r0, 0 bne @08001F50 ldr r0, =0x030008f8 ldr r0, [r0, 0x2C] lsls r0, 8 lsrs r1, r0, 16 movs r0, 0x1A bl lcd_io_set b @08001FA4 .align 2, 0 .pool @08001F50: ldr r0, =0x030008f8 ldr r0, [r0, 0x2C] lsrs r1, r0, 16 lsls r0, 16 lsrs r4, r0, 16 movs r0, 0x2E bl lcd_io_set movs r0, 0x2C adds r1, r4, 0 bl lcd_io_set b @08001FA4 .align 2, 0 .pool @08001F70: cmp r0, 0 bne @08001F88 ldr r0, =0x030008f8 ldr r0, [r0, 0x3C] lsls r0, 8 lsrs r1, r0, 16 movs r0, 0x1E bl lcd_io_set b @08001FA4 .align 2, 0 .pool @08001F88: cmp r0, 0x2 bne @08001FA4 ldr r0, =0x030008f8 ldr r0, [r0, 0x3C] lsrs r1, r0, 16 lsls r0, 16 lsrs r4, r0, 16 movs r0, 0x3E bl lcd_io_set movs r0, 0x3C adds r1, r4, 0 bl lcd_io_set @08001FA4: ldr r0, =0x030008f8 adds r0, 0xC adds r0, r5, r0 ldr r0, [r0] @08001FAC: pop {r4-r6} pop {r1} bx r1 .align 2, 0 .pool thumb_func_end bg_change_y_offset thumb_func_start bg_change_y_offset_to_copy_queue ; int bg_change_y_offset_to_copy_queue(u8 bg_id, int a2, u8 a3) bg_change_y_offset_to_copy_queue: ; 8001FB8 push {r4-r6,lr} adds r6, r1, 0 lsls r0, 24 lsrs r4, r0, 24 lsls r2, 24 lsrs r5, r2, 24 adds r0, r4, 0 bl is_invalid_bg_id_2 cmp r0, 0 bne @08001FDC adds r0, r4, 0 movs r1, 0x1 bl gpu_bg_config_get_field lsls r0, 16 cmp r0, 0 bne @08001FE2 @08001FDC: movs r0, 0x1 negs r0, r0 b @080020E8 @08001FE2: cmp r5, 0x1 beq @08002000 cmp r5, 0x1 ble @08001FEE cmp r5, 0x2 beq @08002014 @08001FEE: ldr r0, =0x030008f8 lsls r1, r4, 4 adds r0, 0xC adds r0, r1, r0 str r6, [r0] adds r5, r1, 0 b @08002024 .align 2, 0 .pool @08002000: ldr r0, =0x030008f8 lsls r2, r4, 4 adds r0, 0xC adds r0, r2, r0 ldr r1, [r0] adds r1, r6 b @08002020 .align 2, 0 .pool @08002014: ldr r0, =0x030008f8 lsls r2, r4, 4 adds r0, 0xC adds r0, r2, r0 ldr r1, [r0] subs r1, r6 @08002020: str r1, [r0] adds r5, r2, 0 @08002024: bl gpu_get_bg_mode lsls r0, 24 lsrs r0, 24 cmp r4, 0x1 beq @08002060 cmp r4, 0x1 bgt @08002040 cmp r4, 0 beq @0800204A b @080020E0 .align 2, 0 .pool @08002040: cmp r4, 0x2 beq @08002074 cmp r4, 0x3 beq @080020AC b @080020E0 @0800204A: ldr r0, =0x030008f8 ldr r0, [r0, 0xC] lsls r0, 8 lsrs r1, r0, 16 movs r0, 0x12 bl lcd_io_set_forced_blank b @080020E0 .align 2, 0 .pool @08002060: ldr r0, =0x030008f8 ldr r0, [r0, 0x1C] lsls r0, 8 lsrs r1, r0, 16 movs r0, 0x16 bl lcd_io_set_forced_blank b @080020E0 .align 2, 0 .pool @08002074: cmp r0, 0 bne @0800208C ldr r0, =0x030008f8 ldr r0, [r0, 0x2C] lsls r0, 8 lsrs r1, r0, 16 movs r0, 0x1A bl lcd_io_set_forced_blank b @080020E0 .align 2, 0 .pool @0800208C: ldr r0, =0x030008f8 ldr r0, [r0, 0x2C] lsrs r1, r0, 16 lsls r0, 16 lsrs r4, r0, 16 movs r0, 0x2E bl lcd_io_set_forced_blank movs r0, 0x2C adds r1, r4, 0 bl lcd_io_set_forced_blank b @080020E0 .align 2, 0 .pool @080020AC: cmp r0, 0 bne @080020C4 ldr r0, =0x030008f8 ldr r0, [r0, 0x3C] lsls r0, 8 lsrs r1, r0, 16 movs r0, 0x1E bl lcd_io_set_forced_blank b @080020E0 .align 2, 0 .pool @080020C4: cmp r0, 0x2 bne @080020E0 ldr r0, =0x030008f8 ldr r0, [r0, 0x3C] lsrs r1, r0, 16 lsls r0, 16 lsrs r4, r0, 16 movs r0, 0x3E bl lcd_io_set_forced_blank movs r0, 0x3C adds r1, r4, 0 bl lcd_io_set_forced_blank @080020E0: ldr r0, =0x030008f8 adds r0, 0xC adds r0, r5, r0 ldr r0, [r0] @080020E8: pop {r4-r6} pop {r1} bx r1 .align 2, 0 .pool thumb_func_end bg_change_y_offset_to_copy_queue thumb_func_start bg_get_y_offset ; int bg_get_y_offset(u8 bg_id) bg_get_y_offset: ; 80020F4 push {r4,lr} lsls r0, 24 lsrs r0, 24 adds r4, r0, 0 bl is_invalid_bg_id_2 cmp r0, 0 bne @08002124 adds r0, r4, 0 movs r1, 0x1 bl gpu_bg_config_get_field lsls r0, 16 cmp r0, 0 beq @08002124 ldr r0, =0x030008f8 lsls r1, r4, 4 adds r0, 0xC adds r1, r0 ldr r0, [r1] b @08002128 .align 2, 0 .pool @08002124: movs r0, 0x1 negs r0, r0 @08002128: pop {r4} pop {r1} bx r1 thumb_func_end bg_get_y_offset thumb_func_start call_gpu_bg_affine_set ; void call_gpu_bg_affine_set(u8 a1, int a2, int a3, u16 a4, s16 a5, s16 a6, s16 a7, s16 a8) call_gpu_bg_affine_set: ; 8002130 push {r4-r7,lr} mov r7, r8 push {r7} sub sp, 0x10 ldr r4, [sp, 0x28] ldr r5, [sp, 0x2C] ldr r6, [sp, 0x30] ldr r7, [sp, 0x34] lsls r0, 24 lsrs r0, 24 lsls r7, 16 lsrs r7, 16 lsls r3, 16 asrs r3, 16 lsls r4, 16 asrs r4, 16 str r4, [sp] lsls r5, 16 asrs r5, 16 str r5, [sp, 0x4] lsls r6, 16 asrs r6, 16 str r6, [sp, 0x8] str r7, [sp, 0xC] bl gpu_bg_affine_set add sp, 0x10 pop {r3} mov r8, r3 pop {r4-r7} pop {r0} bx r0 thumb_func_end call_gpu_bg_affine_set thumb_func_start mosaic_something mosaic_something: ; 8002170 push {r4-r6,lr} lsls r0, 24 lsrs r4, r0, 24 lsls r1, 24 lsrs r6, r1, 24 movs r0, 0x4C bl lcd_io_get lsls r0, 16 lsrs r5, r0, 16 movs r1, 0xF movs r3, 0xF ands r3, r5 lsrs r2, r0, 20 ands r2, r1 movs r0, 0xFF lsls r0, 8 ands r5, r0 cmp r6, 0x6 bhi @080021C4 lsls r0, r6, 2 ldr r1, =@080021A8 adds r0, r1 ldr r0, [r0] mov pc, r0 .align 2, 0 .pool .align 2, 0 @080021A8: .4byte @080021C4 .4byte @080021CC .4byte @080021D2 .4byte @080021E4 .4byte @080021FA .4byte @08002200 .4byte @08002212 @080021C4: movs r3, 0xF ands r3, r4 lsrs r2, r4, 4 b @08002226 @080021CC: movs r3, 0xF ands r3, r4 b @08002226 @080021D2: lsls r0, r3, 16 asrs r0, 16 adds r0, r4 cmp r0, 0xF ble @080021E0 movs r3, 0xF b @08002226 @080021E0: adds r0, r3, r4 b @080021F4 @080021E4: lsls r0, r3, 16 asrs r0, 16 subs r0, r4 cmp r0, 0 bge @080021F2 movs r3, 0 b @08002226 @080021F2: subs r0, r3, r4 @080021F4: lsls r0, 16 lsrs r3, r0, 16 b @08002226 @080021FA: movs r2, 0xF ands r2, r4 b @08002226 @08002200: lsls r0, r2, 16 asrs r0, 16 adds r0, r4 cmp r0, 0xF ble @0800220E movs r2, 0xF b @08002226 @0800220E: adds r0, r2, r4 b @08002222 @08002212: lsls r0, r2, 16 asrs r0, 16 subs r0, r4 cmp r0, 0 bge @08002220 movs r2, 0 b @08002226 @08002220: subs r0, r2, r4 @08002222: lsls r0, 16 lsrs r2, r0, 16 @08002226: lsls r0, r2, 16 asrs r0, 12 movs r1, 0xF0 ands r0, r1 orrs r5, r0 lsls r0, r3, 16 asrs r0, 16 movs r1, 0xF ands r0, r1 orrs r5, r0 lsls r0, r5, 16 lsrs r5, r0, 16 movs r0, 0x4C adds r1, r5, 0 bl lcd_io_set lsls r0, r5, 24 lsrs r0, 24 pop {r4-r6} pop {r1} bx r1 thumb_func_end mosaic_something thumb_func_start bg_set_tilemap ; void bg_set_tilemap(u8 bg_id, int tilemap) bg_set_tilemap: ; 8002250 push {r4,r5,lr} adds r5, r1, 0 lsls r0, 24 lsrs r4, r0, 24 adds r0, r4, 0 bl is_invalid_bg_id_2 cmp r0, 0 bne @0800227A adds r0, r4, 0 movs r1, 0x1 bl gpu_bg_config_get_field lsls r0, 16 cmp r0, 0 beq @0800227A ldr r0, =0x030008f8 lsls r1, r4, 4 adds r0, 0x4 adds r1, r0 str r5, [r1] @0800227A: pop {r4,r5} pop {r0} bx r0 .align 2, 0 .pool thumb_func_end bg_set_tilemap thumb_func_start bg_unset_tilemap ; void bg_unset_tilemap(u8 bg_id) bg_unset_tilemap: ; 8002284 push {r4,r5,lr} lsls r0, 24 lsrs r4, r0, 24 adds r0, r4, 0 bl is_invalid_bg_id_2 adds r5, r0, 0 cmp r5, 0 bne @080022AE adds r0, r4, 0 movs r1, 0x1 bl gpu_bg_config_get_field lsls r0, 16 cmp r0, 0 beq @080022AE ldr r0, =0x030008f8 lsls r1, r4, 4 adds r0, 0x4 adds r1, r0 str r5, [r1] @080022AE: pop {r4,r5} pop {r0} bx r0 .align 2, 0 .pool thumb_func_end bg_unset_tilemap thumb_func_start bg_get_tilemap ; int bg_get_tilemap(u8 bg_id) bg_get_tilemap: ; 80022B8 push {r4,lr} lsls r0, 24 lsrs r0, 24 adds r4, r0, 0 bl is_invalid_bg_id_2 cmp r0, 0 bne @080022E8 adds r0, r4, 0 movs r1, 0x1 bl gpu_bg_config_get_field lsls r0, 16 cmp r0, 0 beq @080022E8 ldr r0, =0x030008f8 lsls r1, r4, 4 adds r0, 0x4 adds r1, r0 ldr r0, [r1] b @080022EA .align 2, 0 .pool @080022E8: movs r0, 0 @080022EA: pop {r4} pop {r1} bx r1 thumb_func_end bg_get_tilemap thumb_func_start gpu_copy_to_wram_bg_tile_map ; void gpu_copy_to_wram_bg_tile_map(u8 bg_id, void *src, int mode, int dest_offset) gpu_copy_to_wram_bg_tile_map: ; 80022F0 push {r4-r7,lr} mov r7, r10 mov r6, r9 mov r5, r8 push {r5-r7} mov r10, r1 lsls r0, 24 lsrs r4, r0, 24 mov r9, r4 lsls r7, r2, 16 lsrs r6, r7, 16 lsls r3, 16 lsrs r5, r3, 16 mov r8, r5 adds r0, r4, 0 bl is_invalid_bg_id_2 cmp r0, 0 bne @08002358 adds r0, r4, 0 bl IsTileMapOutsideWram cmp r0, 0 bne @08002358 cmp r6, 0 beq @08002340 ldr r0, =0x030008f8 lsls r1, r4, 4 adds r0, 0x4 adds r1, r0 lsls r0, r5, 1 ldr r1, [r1] adds r1, r0 lsrs r2, r7, 17 mov r0, r10 bl CpuSet b @08002358 .align 2, 0 .pool @08002340: ldr r0, =0x030008f8 mov r2, r9 lsls r1, r2, 4 adds r0, 0x4 adds r1, r0 mov r2, r8 lsls r0, r2, 1 ldr r1, [r1] adds r1, r0 mov r0, r10 bl LZ77UnCompWram @08002358: pop {r3-r5} mov r8, r3 mov r9, r4 mov r10, r5 pop {r4-r7} pop {r0} bx r0 .align 2, 0 .pool thumb_func_end gpu_copy_to_wram_bg_tile_map thumb_func_start gpu_copy_wram_bg_tilemap_to_vram ; void gpu_copy_wram_bg_tilemap_to_vram(int bg_id) gpu_copy_wram_bg_tilemap_to_vram: ; 800236C push {r4,lr} sub sp, 0x4 lsls r0, 24 lsrs r4, r0, 24 adds r0, r4, 0 bl is_invalid_bg_id_2 cmp r0, 0 bne @080023C8 adds r0, r4, 0 bl IsTileMapOutsideWram cmp r0, 0 bne @080023C8 adds r0, r4, 0 bl bg_get_type_by_bg_id cmp r0, 0 beq @0800239A cmp r0, 0x1 beq @080023A6 movs r2, 0 b @080023B2 @0800239A: adds r0, r4, 0 movs r1, 0 bl bg_get_screen_size_in_regular_mode lsls r0, 27 b @080023B0 @080023A6: adds r0, r4, 0 movs r1, 0 bl bg_get_screen_size_in_affine_mode lsls r0, 24 @080023B0: lsrs r2, r0, 16 @080023B2: ldr r0, =0x030008f8 lsls r1, r4, 4 adds r0, 0x4 adds r1, r0 ldr r1, [r1] movs r0, 0x2 str r0, [sp] adds r0, r4, 0 movs r3, 0 bl gpu_copy_to_vram_by_bg_id @080023C8: add sp, 0x4 pop {r4} pop {r0} bx r0 .align 2, 0 .pool thumb_func_end gpu_copy_wram_bg_tilemap_to_vram thumb_func_start gpu_copy_to_iwram_tile_map_rect ; void gpu_copy_to_iwram_tile_map_rect(u8 bg_id, int first_tile_num, u8 tilemap_x, u8 tilemap_y, u8 width_in_tiles, u8 height_in_tiles) gpu_copy_to_iwram_tile_map_rect: ; 80023D4 push {r4-r7,lr} mov r7, r10 mov r6, r9 mov r5, r8 push {r5-r7} sub sp, 0x4 mov r8, r1 ldr r1, [sp, 0x24] ldr r4, [sp, 0x28] lsls r0, 24 lsrs r5, r0, 24 lsls r2, 24 lsrs r2, 24 mov r10, r2 lsls r3, 24 lsrs r7, r3, 24 lsls r1, 24 lsrs r1, 24 mov r9, r1 lsls r4, 24 lsrs r6, r4, 24 adds r0, r5, 0 bl is_invalid_bg_id_2 cmp r0, 0 bne @080024C4 adds r0, r5, 0 bl IsTileMapOutsideWram cmp r0, 0 bne @080024C4 adds r0, r5, 0 bl bg_get_type_by_bg_id cmp r0, 0 beq @08002422 cmp r0, 0x1 beq @08002470 b @080024C4 @08002422: mov r4, r8 adds r3, r7, 0 adds r0, r3, r6 cmp r3, r0 bge @080024C4 mov r12, r0 lsls r1, r5, 4 ldr r0, =0x030008fc adds r1, r0 mov r8, r1 @08002436: mov r2, r10 mov r1, r9 adds r0, r2, r1 adds r7, r3, 0x1 cmp r2, r0 bge @08002460 mov r1, r8 ldr r6, [r1] lsls r5, r3, 5 adds r3, r0, 0 @0800244A: adds r0, r5, r2 lsls r0, 1 adds r0, r6 ldrh r1, [r4] strh r1, [r0] adds r4, 0x2 adds r0, r2, 0x1 lsls r0, 16 lsrs r2, r0, 16 cmp r2, r3 blt @0800244A @08002460: lsls r0, r7, 16 lsrs r3, r0, 16 cmp r3, r12 blt @08002436 b @080024C4 .align 2, 0 .pool @08002470: mov r4, r8 adds r0, r5, 0 movs r1, 0x1 bl bg_get_screen_size_in_affine_mode lsls r0, 16 lsrs r0, 16 str r0, [sp] adds r3, r7, 0 adds r0, r3, r6 cmp r3, r0 bge @080024C4 mov r12, r0 lsls r5, 4 mov r8, r5 @0800248E: mov r2, r10 mov r1, r9 adds r0, r2, r1 adds r7, r3, 0x1 cmp r2, r0 bge @080024BC ldr r6, =0x030008fc add r6, r8 ldr r1, [sp] adds r5, r3, 0 muls r5, r1 adds r3, r0, 0 @080024A6: ldr r1, [r6] adds r0, r5, r2 adds r1, r0 ldrb r0, [r4] strb r0, [r1] adds r4, 0x1 adds r0, r2, 0x1 lsls r0, 16 lsrs r2, r0, 16 cmp r2, r3 blt @080024A6 @080024BC: lsls r0, r7, 16 lsrs r3, r0, 16 cmp r3, r12 blt @0800248E @080024C4: add sp, 0x4 pop {r3-r5} mov r8, r3 mov r9, r4 mov r10, r5 pop {r4-r7} pop {r0} bx r0 .align 2, 0 .pool thumb_func_end gpu_copy_to_iwram_tile_map_rect thumb_func_start bg_copy_tilemap_rect_simple ; void bg_copy_tilemap_rect_simple(u8 bg_id, void *src, u8 dest_x, u8 dest_y, u8 w, u8 h, u8 a7) bg_copy_tilemap_rect_simple: ; 80024D8 push {r4-r6,lr} sub sp, 0x24 ldr r4, [sp, 0x34] ldr r5, [sp, 0x38] ldr r6, [sp, 0x3C] lsls r0, 24 lsrs r0, 24 lsls r2, 24 lsrs r2, 24 lsls r3, 24 lsrs r3, 24 lsls r4, 24 lsrs r4, 24 lsls r5, 24 lsrs r5, 24 lsls r6, 24 lsrs r6, 24 str r4, [sp] str r5, [sp, 0x4] str r2, [sp, 0x8] str r3, [sp, 0xC] str r4, [sp, 0x10] str r5, [sp, 0x14] str r6, [sp, 0x18] movs r2, 0 str r2, [sp, 0x1C] str r2, [sp, 0x20] movs r3, 0 bl bg_copy_tilemap_rect add sp, 0x24 pop {r4-r6} pop {r0} bx r0 thumb_func_end bg_copy_tilemap_rect_simple thumb_func_start bg_copy_tilemap_rect ; void bg_copy_tilemap_rect(u8 bg_id, void *src, u8 src_x, u8 src_y, u8 src_w, int src_h, u8 dest_x, u8 dest_y, u8 dest_w, u8 dest_h, u8 a11, int tile_num_delta, s16 a13) bg_copy_tilemap_rect: ; 800251C push {r4-r7,lr} mov r7, r10 mov r6, r9 mov r5, r8 push {r5-r7} sub sp, 0x40 str r1, [sp, 0x8] ldr r1, [sp, 0x60] ldr r4, [sp, 0x68] ldr r5, [sp, 0x6C] ldr r6, [sp, 0x70] ldr r7, [sp, 0x74] mov r8, r7 ldr r7, [sp, 0x78] mov r9, r7 ldr r7, [sp, 0x7C] mov r10, r7 ldr r7, [sp, 0x80] mov r12, r7 lsls r0, 24 lsrs r0, 24 str r0, [sp, 0x4] lsls r2, 24 lsrs r2, 24 str r2, [sp, 0xC] lsls r3, 24 lsrs r3, 24 str r3, [sp, 0x10] lsls r1, 24 lsrs r7, r1, 24 lsls r4, 24 lsrs r4, 24 str r4, [sp, 0x14] lsls r5, 24 lsrs r5, 24 lsls r6, 24 lsrs r6, 24 str r6, [sp, 0x18] mov r0, r8 lsls r0, 24 lsrs r4, r0, 24 mov r1, r9 lsls r1, 24 lsrs r1, 24 str r1, [sp, 0x1C] mov r2, r10 lsls r2, 16 lsrs r2, 16 str r2, [sp, 0x20] mov r0, r12 lsls r0, 16 lsrs r0, 16 str r0, [sp, 0x24] ldr r0, [sp, 0x4] bl is_invalid_bg_id_2 cmp r0, 0 beq @08002592 b @080026EE @08002592: ldr r0, [sp, 0x4] bl IsTileMapOutsideWram cmp r0, 0 beq @0800259E b @080026EE @0800259E: ldr r0, [sp, 0x4] movs r1, 0x4 bl gpu_bg_config_get_field lsls r0, 16 lsrs r0, 16 str r0, [sp, 0x30] ldr r0, [sp, 0x4] movs r1, 0x1 bl bg_get_screen_size_in_regular_mode lsls r0, 21 lsrs r0, 16 str r0, [sp, 0x28] ldr r0, [sp, 0x4] movs r1, 0x2 bl bg_get_screen_size_in_regular_mode lsls r0, 21 lsrs r0, 16 str r0, [sp, 0x2C] ldr r0, [sp, 0x4] bl bg_get_type_by_bg_id cmp r0, 0 beq @080025D8 cmp r0, 0x1 beq @08002674 b @080026EE @080025D8: ldr r1, [sp, 0x10] adds r0, r1, 0 muls r0, r7 ldr r2, [sp, 0xC] adds r0, r2 lsls r0, 1 ldr r1, [sp, 0x8] adds r6, r1, r0 adds r0, r5, r4 cmp r5, r0 blt @080025F0 b @080026EE @080025F0: ldr r2, [sp, 0x18] subs r2, r7, r2 str r2, [sp, 0x34] str r0, [sp, 0x38] @080025F8: ldr r4, [sp, 0x14] ldr r7, [sp, 0x18] adds r0, r4, r7 adds r1, r5, 0x1 str r1, [sp, 0x3C] cmp r4, r0 bge @0800265A ldr r2, [sp, 0x4] lsls r0, r2, 4 ldr r1, =0x030008fc adds r0, r1 mov r10, r0 ldr r7, [sp, 0x20] lsls r7, 16 mov r9, r7 ldr r1, [sp, 0x24] lsls r0, r1, 16 asrs r0, 16 mov r8, r0 @0800261E: ldr r2, [sp, 0x2C] str r2, [sp] adds r0, r4, 0 adds r1, r5, 0 ldr r2, [sp, 0x30] ldr r3, [sp, 0x28] bl bg_get_index_from_tile_coords lsls r0, 16 lsrs r0, 15 mov r7, r10 ldr r1, [r7] adds r1, r0 mov r0, r8 str r0, [sp] adds r0, r6, 0 ldr r2, [sp, 0x1C] mov r7, r9 asrs r3, r7, 16 bl bg_copy_tilemap_entry_not_rotscale_mode adds r6, 0x2 adds r0, r4, 0x1 lsls r0, 16 lsrs r4, r0, 16 ldr r1, [sp, 0x14] ldr r2, [sp, 0x18] adds r0, r1, r2 cmp r4, r0 blt @0800261E @0800265A: ldr r5, [sp, 0x34] lsls r0, r5, 1 adds r6, r0 ldr r7, [sp, 0x3C] lsls r0, r7, 16 lsrs r5, r0, 16 ldr r0, [sp, 0x38] cmp r5, r0 blt @080025F8 b @080026EE .align 2, 0 .pool @08002674: ldr r1, [sp, 0x10] adds r0, r1, 0 muls r0, r7 ldr r2, [sp, 0xC] adds r0, r2 ldr r1, [sp, 0x8] adds r6, r1, r0 ldr r0, [sp, 0x4] movs r1, 0x1 bl bg_get_screen_size_in_affine_mode lsls r0, 16 lsrs r0, 16 mov r9, r0 adds r0, r5, r4 cmp r5, r0 bge @080026EE ldr r2, [sp, 0x18] subs r2, r7, r2 str r2, [sp, 0x34] str r0, [sp, 0x38] ldr r7, =0x030008fc mov r10, r7 ldr r0, [sp, 0x4] lsls r0, 4 mov r8, r0 @080026A8: ldr r4, [sp, 0x14] ldr r1, [sp, 0x18] adds r0, r4, r1 adds r2, r5, 0x1 str r2, [sp, 0x3C] cmp r4, r0 bge @080026DE mov r3, r8 add r3, r10 mov r7, r9 muls r7, r5 mov r12, r7 adds r2, r0, 0 @080026C2: ldr r1, [r3] mov r5, r12 adds r0, r5, r4 adds r1, r0 ldrb r0, [r6] ldr r7, [sp, 0x20] adds r0, r7 strb r0, [r1] adds r6, 0x1 adds r0, r4, 0x1 lsls r0, 16 lsrs r4, r0, 16 cmp r4, r2 blt @080026C2 @080026DE: ldr r0, [sp, 0x34] adds r6, r0 ldr r1, [sp, 0x3C] lsls r0, r1, 16 lsrs r5, r0, 16 ldr r2, [sp, 0x38] cmp r5, r2 blt @080026A8 @080026EE: add sp, 0x40 pop {r3-r5} mov r8, r3 mov r9, r4 mov r10, r5 pop {r4-r7} pop {r0} bx r0 .align 2, 0 .pool thumb_func_end bg_copy_tilemap_rect thumb_func_start bg_fill_tilemap_rect ; void bg_fill_tilemap_rect(u8 bg_id, s16 tile, u8 x, u8 y, u8 w, u8 h) bg_fill_tilemap_rect: ; 8002704 push {r4-r7,lr} mov r7, r10 mov r6, r9 mov r5, r8 push {r5-r7} sub sp, 0x4 ldr r4, [sp, 0x24] ldr r5, [sp, 0x28] lsls r0, 24 lsrs r6, r0, 24 lsls r1, 16 lsrs r1, 16 mov r8, r1 lsls r2, 24 lsrs r2, 24 mov r10, r2 lsls r3, 24 lsrs r7, r3, 24 lsls r4, 24 lsrs r4, 24 mov r9, r4 lsls r5, 24 lsrs r5, 24 adds r0, r6, 0 bl is_invalid_bg_id_2 cmp r0, 0 bne @080027F0 adds r0, r6, 0 bl IsTileMapOutsideWram cmp r0, 0 bne @080027F0 adds r0, r6, 0 bl bg_get_type_by_bg_id cmp r0, 0 beq @08002756 cmp r0, 0x1 beq @080027A0 b @080027F0 @08002756: adds r3, r7, 0 adds r5, r3, r5 cmp r3, r5 bge @080027F0 adds r7, r5, 0 lsls r1, r6, 4 ldr r0, =0x030008fc adds r1, r0 mov r12, r1 @08002768: mov r2, r10 mov r1, r9 adds r0, r2, r1 adds r6, r3, 0x1 cmp r2, r0 bge @08002790 mov r5, r12 ldr r4, [r5] lsls r3, 5 adds r1, r0, 0 @0800277C: adds r0, r3, r2 lsls r0, 1 adds r0, r4 mov r5, r8 strh r5, [r0] adds r0, r2, 0x1 lsls r0, 16 lsrs r2, r0, 16 cmp r2, r1 blt @0800277C @08002790: lsls r0, r6, 16 lsrs r3, r0, 16 cmp r3, r7 blt @08002768 b @080027F0 .align 2, 0 .pool @080027A0: adds r0, r6, 0 movs r1, 0x1 bl bg_get_screen_size_in_affine_mode lsls r0, 16 lsrs r0, 16 str r0, [sp] adds r3, r7, 0 adds r5, r3, r5 cmp r3, r5 bge @080027F0 adds r7, r5, 0 lsls r6, 4 mov r12, r6 @080027BC: mov r2, r10 mov r1, r9 adds r0, r2, r1 adds r6, r3, 0x1 cmp r2, r0 bge @080027E8 ldr r5, =0x030008fc add r5, r12 ldr r1, [sp] adds r4, r3, 0 muls r4, r1 adds r3, r0, 0 @080027D4: ldr r0, [r5] adds r1, r4, r2 adds r0, r1 mov r1, r8 strb r1, [r0] adds r0, r2, 0x1 lsls r0, 16 lsrs r2, r0, 16 cmp r2, r3 blt @080027D4 @080027E8: lsls r0, r6, 16 lsrs r3, r0, 16 cmp r3, r7 blt @080027BC @080027F0: add sp, 0x4 pop {r3-r5} mov r8, r3 mov r9, r4 mov r10, r5 pop {r4-r7} pop {r0} bx r0 .align 2, 0 .pool thumb_func_end bg_fill_tilemap_rect thumb_func_start Bg_FillWramTileMapRectWithTileAndPalette ; void Bg_FillWramTileMapRectWithTileAndPalette(u8 bg_id, s16 tile_num, u8 tilemap_x, u8 tilemap_y, u8 width_in_tiles, u8 height_in_tiles, u8 palette) Bg_FillWramTileMapRectWithTileAndPalette: ; 8002804 push {r4-r6,lr} sub sp, 0x10 ldr r4, [sp, 0x20] ldr r5, [sp, 0x24] ldr r6, [sp, 0x28] lsls r0, 24 lsrs r0, 24 lsls r1, 16 lsrs r1, 16 lsls r2, 24 lsrs r2, 24 lsls r3, 24 lsrs r3, 24 lsls r4, 24 lsrs r4, 24 lsls r5, 24 lsrs r5, 24 lsls r6, 24 lsrs r6, 24 str r4, [sp] str r5, [sp, 0x4] str r6, [sp, 0x8] movs r4, 0 str r4, [sp, 0xC] bl bg_write_sequence_to_wram_tile_map_rect add sp, 0x10 pop {r4-r6} pop {r0} bx r0 thumb_func_end Bg_FillWramTileMapRectWithTileAndPalette thumb_func_start bg_write_sequence_to_wram_tile_map_rect ; void bg_write_sequence_to_wram_tile_map_rect(u8 bg_id, s16 first_tile_num, u8 tilemap_x, u8 tilemap_y, u8 width_in_tiles, u8 height_in_tiles, u8 palette, u16 tile_num_inc_amount) bg_write_sequence_to_wram_tile_map_rect: ; 8002840 push {r4-r7,lr} mov r7, r10 mov r6, r9 mov r5, r8 push {r5-r7} sub sp, 0x2C ldr r4, [sp, 0x4C] ldr r5, [sp, 0x50] ldr r6, [sp, 0x54] ldr r7, [sp, 0x58] mov r8, r7 lsls r0, 24 lsrs r0, 24 mov r9, r0 add r0, sp, 0x4 strh r1, [r0] lsls r2, 24 lsrs r2, 24 str r2, [sp, 0x8] lsls r3, 24 lsrs r7, r3, 24 lsls r4, 24 lsrs r4, 24 mov r10, r4 lsls r5, 24 lsrs r4, r5, 24 lsls r6, 24 lsrs r6, 24 str r6, [sp, 0xC] mov r0, r8 lsls r0, 16 lsrs r0, 16 str r0, [sp, 0x10] mov r0, r9 bl is_invalid_bg_id_2 cmp r0, 0 beq @0800288E b @080029D4 @0800288E: mov r0, r9 bl IsTileMapOutsideWram cmp r0, 0 beq @0800289A b @080029D4 @0800289A: mov r0, r9 movs r1, 0x4 bl gpu_bg_config_get_field lsls r0, 16 lsrs r0, 16 str r0, [sp, 0x1C] mov r0, r9 movs r1, 0x1 bl bg_get_screen_size_in_regular_mode lsls r0, 21 lsrs r0, 16 str r0, [sp, 0x14] mov r0, r9 movs r1, 0x2 bl bg_get_screen_size_in_regular_mode lsls r0, 21 lsrs r0, 16 str r0, [sp, 0x18] mov r0, r9 bl bg_get_type_by_bg_id cmp r0, 0 beq @080028D4 cmp r0, 0x1 beq @0800295C b @080029D4 @080028D4: adds r5, r7, 0 adds r0, r5, r4 cmp r5, r0 bge @080029D4 str r0, [sp, 0x24] add r7, sp, 0x4 @080028E0: ldr r4, [sp, 0x8] mov r1, r10 adds r0, r4, r1 adds r2, r5, 0x1 mov r8, r2 cmp r4, r0 bge @08002944 mov r3, r9 lsls r1, r3, 4 ldr r0, =0x030008fc adds r6, r1, r0 @080028F6: ldr r0, [sp, 0x18] str r0, [sp] adds r0, r4, 0 adds r1, r5, 0 ldr r2, [sp, 0x1C] ldr r3, [sp, 0x14] bl bg_get_index_from_tile_coords lsls r0, 16 lsrs r0, 15 ldr r1, [r6] adds r1, r0 movs r0, 0 str r0, [sp] add r0, sp, 0x4 ldr r2, [sp, 0xC] movs r3, 0 bl bg_copy_tilemap_entry_not_rotscale_mode ldrh r0, [r7] movs r2, 0xFC lsls r2, 8 adds r1, r2, 0 adds r2, r0, 0 ands r2, r1 ldr r3, [sp, 0x10] adds r0, r3 ldr r3, =0x000003ff adds r1, r3, 0 ands r0, r1 adds r2, r0 strh r2, [r7] adds r0, r4, 0x1 lsls r0, 16 lsrs r4, r0, 16 ldr r0, [sp, 0x8] add r0, r10 cmp r4, r0 blt @080028F6 @08002944: mov r1, r8 lsls r0, r1, 16 lsrs r5, r0, 16 ldr r2, [sp, 0x24] cmp r5, r2 blt @080028E0 b @080029D4 .align 2, 0 .pool @0800295C: mov r0, r9 movs r1, 0x1 bl bg_get_screen_size_in_affine_mode lsls r0, 16 lsrs r0, 16 str r0, [sp, 0x20] adds r5, r7, 0 adds r0, r5, r4 cmp r5, r0 bge @080029D4 str r0, [sp, 0x24] mov r3, r9 lsls r3, 4 mov r12, r3 @0800297A: ldr r4, [sp, 0x8] mov r7, r10 adds r0, r4, r7 adds r1, r5, 0x1 mov r8, r1 cmp r4, r0 bge @080029C8 ldr r2, =0x030008fc add r2, r12 str r2, [sp, 0x28] ldr r7, [sp, 0x20] adds r3, r5, 0 muls r3, r7 add r2, sp, 0x4 movs r1, 0xFC lsls r1, 8 mov r9, r1 ldr r7, =0x000003ff adds r5, r7, 0 adds r6, r0, 0 @080029A2: ldr r0, [sp, 0x28] ldr r1, [r0] adds r0, r3, r4 adds r1, r0 ldrh r0, [r2] strb r0, [r1] ldrh r0, [r2] mov r1, r9 ands r1, r0 ldr r7, [sp, 0x10] adds r0, r7 ands r0, r5 adds r1, r0 strh r1, [r2] adds r0, r4, 0x1 lsls r0, 16 lsrs r4, r0, 16 cmp r4, r6 blt @080029A2 @080029C8: mov r1, r8 lsls r0, r1, 16 lsrs r5, r0, 16 ldr r2, [sp, 0x24] cmp r5, r2 blt @0800297A @080029D4: add sp, 0x2C pop {r3-r5} mov r8, r3 mov r9, r4 mov r10, r5 pop {r4-r7} pop {r0} bx r0 .align 2, 0 .pool thumb_func_end bg_write_sequence_to_wram_tile_map_rect thumb_func_start bg_get_screen_size_in_regular_mode ; int bg_get_screen_size_in_regular_mode(u8 bg_id, int mode) bg_get_screen_size_in_regular_mode: ; 80029EC push {r4,r5,lr} lsls r0, 24 lsrs r0, 24 lsls r1, 24 lsrs r4, r1, 24 adds r5, r4, 0 movs r1, 0x4 bl gpu_bg_config_get_field lsls r0, 24 lsrs r0, 24 cmp r4, 0x1 beq @08002A2C cmp r4, 0x1 bgt @08002A10 cmp r4, 0 beq @08002A16 b @08002A52 @08002A10: cmp r5, 0x2 beq @08002A3E b @08002A52 @08002A16: cmp r0, 0x2 bgt @08002A24 cmp r0, 0x1 bge @08002A4E @08002A1E: cmp r0, 0 beq @08002A46 b @08002A52 @08002A24: cmp r0, 0x3 bne @08002A52 movs r0, 0x4 b @08002A54 @08002A2C: cmp r0, 0x1 beq @08002A4E cmp r0, 0x1 ble @08002A1E cmp r0, 0x2 beq @08002A46 cmp r0, 0x3 bne @08002A52 b @08002A4E @08002A3E: cmp r0, 0 blt @08002A52 cmp r0, 0x1 bgt @08002A4A @08002A46: movs r0, 0x1 b @08002A54 @08002A4A: cmp r0, 0x3 bgt @08002A52 @08002A4E: movs r0, 0x2 b @08002A54 @08002A52: movs r0, 0 @08002A54: pop {r4,r5} pop {r1} bx r1 thumb_func_end bg_get_screen_size_in_regular_mode thumb_func_start bg_get_screen_size_in_affine_mode ; int bg_get_screen_size_in_affine_mode(u8 bg_id, u8 a2) bg_get_screen_size_in_affine_mode: ; 8002A5C push {r4,lr} lsls r0, 24 lsrs r0, 24 lsls r1, 24 lsrs r4, r1, 24 movs r1, 0x4 bl gpu_bg_config_get_field lsls r0, 24 lsrs r1, r0, 24 adds r0, r1, 0 cmp r4, 0 beq @08002A84 cmp r4, 0 blt @08002AAC cmp r4, 0x2 bgt @08002AAC movs r0, 0x10 lsls r0, r1 b @08002AAE @08002A84: cmp r1, 0x1 beq @08002AA0 cmp r1, 0x1 bgt @08002A92 cmp r1, 0 beq @08002A9C b @08002AAC @08002A92: cmp r0, 0x2 beq @08002AA4 cmp r0, 0x3 beq @08002AA8 b @08002AAC @08002A9C: movs r0, 0x1 b @08002AAE @08002AA0: movs r0, 0x4 b @08002AAE @08002AA4: movs r0, 0x10 b @08002AAE @08002AA8: movs r0, 0x40 b @08002AAE @08002AAC: movs r0, 0 @08002AAE: pop {r4} pop {r1} bx r1 thumb_func_end bg_get_screen_size_in_affine_mode thumb_func_start bg_get_index_from_tile_coords ; int bg_get_index_from_tile_coords(int tilemap_x, int tilemap_y, int screen_size, int tilemap_w, int tilemap_h) bg_get_index_from_tile_coords: ; 8002AB4 push {r4,lr} adds r4, r0, 0 ldr r0, [sp, 0x8] subs r3, 0x1 ands r4, r3 subs r0, 0x1 ands r1, r0 cmp r2, 0x1 beq @08002AD8 cmp r2, 0x1 ble @08002AE0 cmp r2, 0x2 beq @08002AE0 cmp r2, 0x3 bne @08002AE0 cmp r1, 0x1F ble @08002AD8 adds r1, 0x20 @08002AD8: cmp r4, 0x1F ble @08002AE0 subs r4, 0x20 adds r1, 0x20 @08002AE0: lsls r0, r1, 5 adds r0, r4 pop {r4} pop {r1} bx r1 thumb_func_end bg_get_index_from_tile_coords thumb_func_start bg_copy_tilemap_entry_not_rotscale_mode ; void bg_copy_tilemap_entry_not_rotscale_mode(u16 *tile_src, u16 *tile_dest, signed int palette, s16 a4, int a5) bg_copy_tilemap_entry_not_rotscale_mode: ; 8002AEC push {r4-r6,lr} adds r4, r0, 0 adds r6, r1, 0 ldr r5, [sp, 0x10] cmp r2, 0x10 beq @08002B14 cmp r2, 0x10 bgt @08002B34 cmp r2, 0 blt @08002B34 ldrh r0, [r4] adds r0, r3 ldr r3, =0x00000fff adds r1, r3, 0 ands r0, r1 adds r1, r2, r5 lsls r1, 12 b @08002B3A .align 2, 0 .pool @08002B14: ldrh r1, [r6] movs r0, 0xFC lsls r0, 8 ands r1, r0 lsls r2, r5, 12 adds r2, r1, r2 ldrh r0, [r4] adds r0, r3 ldr r3, =0x000003ff adds r1, r3, 0 ands r0, r1 orrs r0, r2 b @08002B3C .align 2, 0 .pool @08002B34: ldrh r0, [r4] adds r0, r3 lsls r1, r5, 12 @08002B3A: adds r0, r1 @08002B3C: lsls r0, 16 lsrs r1, r0, 16 strh r1, [r6] pop {r4-r6} pop {r0} bx r0 thumb_func_end bg_copy_tilemap_entry_not_rotscale_mode thumb_func_start bg_get_type_by_bg_id ; u16 bg_get_type_by_bg_id(u8 bg_id) bg_get_type_by_bg_id: ; 8002B48 push {r4,r5,lr} lsls r0, 24 lsrs r4, r0, 24 adds r5, r4, 0 bl gpu_get_bg_mode lsls r0, 24 lsrs r0, 24 cmp r4, 0x2 beq @08002B76 cmp r4, 0x2 ble @08002B66 cmp r4, 0x3 beq @08002B86 b @08002B8E @08002B66: cmp r5, 0 blt @08002B8E cmp r0, 0x1 bgt @08002B8E cmp r0, 0 blt @08002B8E @08002B72: movs r0, 0 b @08002B90 @08002B76: cmp r0, 0 beq @08002B72 cmp r0, 0 blt @08002B8E cmp r0, 0x2 bgt @08002B8E @08002B82: movs r0, 0x1 b @08002B90 @08002B86: cmp r0, 0 beq @08002B72 cmp r0, 0x2 beq @08002B82 @08002B8E: ldr r0, =0x0000ffff @08002B90: pop {r4,r5} pop {r1} bx r1 .align 2, 0 .pool thumb_func_end bg_get_type_by_bg_id thumb_func_start is_invalid_bg_id_2 ; int is_invalid_bg_id_2(u8 bg_id) is_invalid_bg_id_2: ; 8002B9C push {lr} lsls r0, 24 lsrs r0, 24 cmp r0, 0x3 bhi @08002BAA movs r0, 0 b @08002BAC @08002BAA: movs r0, 0x1 @08002BAC: pop {r1} bx r1 thumb_func_end is_invalid_bg_id_2 thumb_func_start IsTileMapOutsideWram ; bool IsTileMapOutsideWram(u8 bg_id) IsTileMapOutsideWram: ; 8002BB0 push {lr} lsls r0, 24 ldr r1, =0x030008f8 lsrs r0, 20 adds r1, 0x4 adds r0, r1 ldr r1, [r0] ldr r0, =0x03008000 cmp r1, r0 bhi @08002BD4 cmp r1, 0 beq @08002BD4 movs r0, 0 b @08002BD6 .align 2, 0 .pool @08002BD4: movs r0, 0x1 @08002BD6: pop {r1} bx r1 thumb_func_end IsTileMapOutsideWram