Merge branch 'master' of github.com:pret/pokefirered into region_map

This commit is contained in:
PikalaxALT
2020-01-06 13:59:20 -05:00
20 changed files with 605 additions and 1389 deletions
+5 -5
View File
@@ -2854,7 +2854,7 @@ sub_80849A0: @ 80849A0
ands r0, r1
cmp r0, 0
bne _080849DC
bl sub_8055FC4
bl BGMusicStopped
lsls r0, 24
lsrs r0, 24
cmp r0, 0x1
@@ -3878,7 +3878,7 @@ sub_8085168: @ 8085168
ands r0, r1
cmp r0, 0
bne _080851A0
bl sub_8055FC4
bl BGMusicStopped
lsls r0, 24
lsrs r0, 24
cmp r0, 0x1
@@ -4383,7 +4383,7 @@ sub_808554C: @ 808554C
ands r0, r1
cmp r0, 0
bne _08085584
bl sub_8055FC4
bl BGMusicStopped
lsls r0, 24
lsrs r0, 24
cmp r0, 0x1
@@ -4601,7 +4601,7 @@ _08085702:
ands r0, r1
cmp r0, 0
bne _08085750
bl sub_8055FC4
bl BGMusicStopped
lsls r0, 24
lsrs r0, 24
cmp r0, 0x1
@@ -5400,7 +5400,7 @@ sub_8085D34: @ 8085D34
ands r0, r1
cmp r0, 0
bne _08085D70
bl sub_8055FC4
bl BGMusicStopped
lsls r0, 24
lsrs r0, 24
cmp r0, 0x1
+3 -3
View File
@@ -2691,8 +2691,8 @@ _080DC234: .4byte gFieldEffectObjectTemplatePointers
_080DC238: .4byte gSprites
thumb_func_end FldEff_Unknown22
thumb_func_start ash
ash: @ 80DC23C
thumb_func_start StartAshFieldEffect
StartAshFieldEffect: @ 80DC23C
push {r4,lr}
lsls r2, 16
lsrs r2, 16
@@ -2718,7 +2718,7 @@ ash: @ 80DC23C
bx r0
.align 2, 0
_080DC26C: .4byte gFieldEffectArguments
thumb_func_end ash
thumb_func_end StartAshFieldEffect
thumb_func_start oei_ash
oei_ash: @ 80DC270
-623
View File
@@ -5,629 +5,6 @@
.text
thumb_func_start UpdateFlashLevelEffect
UpdateFlashLevelEffect: @ 807EEB8
push {r4-r6,lr}
lsls r0, 24
lsrs r5, r0, 24
lsls r0, r5, 2
adds r0, r5
lsls r0, 3
ldr r1, _0807EEDC @ =gTasks+0x8
adds r4, r0, r1
movs r1, 0
ldrsh r0, [r4, r1]
cmp r0, 0x1
beq _0807EF14
cmp r0, 0x1
bgt _0807EEE0
cmp r0, 0
beq _0807EEE6
b _0807EF76
.align 2, 0
_0807EEDC: .4byte gTasks+0x8
_0807EEE0:
cmp r0, 0x2
beq _0807EF6C
b _0807EF76
_0807EEE6:
ldr r0, _0807EF0C @ =gScanlineEffect
ldrb r1, [r0, 0x14]
lsls r0, r1, 4
subs r0, r1
lsls r0, 7
ldr r1, _0807EF10 @ =gScanlineEffectRegBuffers
adds r0, r1
movs r2, 0x2
ldrsh r1, [r4, r2]
movs r3, 0x4
ldrsh r2, [r4, r3]
movs r5, 0x6
ldrsh r3, [r4, r5]
bl SetFlashScanlineEffectWindowBoundaries
movs r0, 0x1
strh r0, [r4]
b _0807EF76
.align 2, 0
_0807EF0C: .4byte gScanlineEffect
_0807EF10: .4byte gScanlineEffectRegBuffers
_0807EF14:
ldr r0, _0807EF5C @ =gScanlineEffect
ldrb r1, [r0, 0x14]
lsls r0, r1, 4
subs r0, r1
lsls r0, 7
ldr r1, _0807EF60 @ =gScanlineEffectRegBuffers
adds r0, r1
movs r6, 0x2
ldrsh r1, [r4, r6]
movs r3, 0x4
ldrsh r2, [r4, r3]
movs r6, 0x6
ldrsh r3, [r4, r6]
bl SetFlashScanlineEffectWindowBoundaries
movs r0, 0
strh r0, [r4]
ldrh r0, [r4, 0xA]
ldrh r1, [r4, 0x6]
adds r0, r1
strh r0, [r4, 0x6]
lsls r0, 16
asrs r0, 16
movs r2, 0x8
ldrsh r1, [r4, r2]
cmp r0, r1
ble _0807EF76
movs r3, 0xC
ldrsh r0, [r4, r3]
cmp r0, 0x1
bne _0807EF64
bl ScanlineEffect_Stop
movs r0, 0x2
strh r0, [r4]
b _0807EF76
.align 2, 0
_0807EF5C: .4byte gScanlineEffect
_0807EF60: .4byte gScanlineEffectRegBuffers
_0807EF64:
adds r0, r5, 0
bl DestroyTask
b _0807EF76
_0807EF6C:
bl ScanlineEffect_Clear
adds r0, r5, 0
bl DestroyTask
_0807EF76:
pop {r4-r6}
pop {r0}
bx r0
thumb_func_end UpdateFlashLevelEffect
thumb_func_start sub_807EF7C
sub_807EF7C: @ 807EF7C
push {r4,lr}
lsls r0, 24
lsrs r4, r0, 24
ldr r0, _0807EFA0 @ =UpdateFlashLevelEffect
bl FuncIsActiveTask
lsls r0, 24
cmp r0, 0
bne _0807EF98
bl EnableBothScriptContexts
adds r0, r4, 0
bl DestroyTask
_0807EF98:
pop {r4}
pop {r0}
bx r0
.align 2, 0
_0807EFA0: .4byte UpdateFlashLevelEffect
thumb_func_end sub_807EF7C
thumb_func_start sub_807EFA4
sub_807EFA4: @ 807EFA4
push {r4,lr}
ldr r4, _0807EFC4 @ =sub_807EF7C
adds r0, r4, 0
bl FuncIsActiveTask
lsls r0, 24
cmp r0, 0
bne _0807EFBC
adds r0, r4, 0
movs r1, 0x50
bl CreateTask
_0807EFBC:
pop {r4}
pop {r0}
bx r0
.align 2, 0
_0807EFC4: .4byte sub_807EF7C
thumb_func_end sub_807EFA4
thumb_func_start sub_807EFC8
sub_807EFC8: @ 807EFC8
push {r4-r7,lr}
mov r7, r9
mov r6, r8
push {r6,r7}
mov r8, r0
mov r9, r1
adds r5, r2, 0
adds r4, r3, 0
ldr r6, [sp, 0x1C]
ldr r0, [sp, 0x20]
lsls r0, 24
lsrs r7, r0, 24
ldr r0, _0807F00C @ =UpdateFlashLevelEffect
movs r1, 0x50
bl CreateTask
lsls r0, 24
lsrs r2, r0, 24
lsls r0, r2, 2
adds r0, r2
lsls r0, 3
ldr r1, _0807F010 @ =gTasks+0x8
adds r1, r0, r1
strh r5, [r1, 0x6]
strh r4, [r1, 0x8]
mov r0, r8
strh r0, [r1, 0x2]
mov r0, r9
strh r0, [r1, 0x4]
strh r6, [r1, 0xC]
cmp r5, r4
bge _0807F014
strh r7, [r1, 0xA]
b _0807F018
.align 2, 0
_0807F00C: .4byte UpdateFlashLevelEffect
_0807F010: .4byte gTasks+0x8
_0807F014:
negs r0, r7
strh r0, [r1, 0xA]
_0807F018:
adds r0, r2, 0
pop {r3,r4}
mov r8, r3
mov r9, r4
pop {r4-r7}
pop {r1}
bx r1
thumb_func_end sub_807EFC8
thumb_func_start sub_807F028
sub_807F028: @ 807F028
push {r4,r5,lr}
sub sp, 0x8
lsls r0, 24
lsrs r0, 24
adds r4, r0, 0
bl Overworld_GetFlashLevel
lsls r0, 24
lsrs r0, 24
movs r5, 0
cmp r4, 0
bne _0807F042
movs r5, 0x1
_0807F042:
ldr r1, _0807F070 @ =sFlashLevelPixelRadii
lsls r0, 1
adds r0, r1
ldrh r2, [r0]
lsls r0, r4, 1
adds r0, r1
ldrh r3, [r0]
str r5, [sp]
movs r0, 0x2
str r0, [sp, 0x4]
movs r0, 0x78
movs r1, 0x50
bl sub_807EFC8
bl sub_807EFA4
bl ScriptContext2_Enable
add sp, 0x8
pop {r4,r5}
pop {r0}
bx r0
.align 2, 0
_0807F070: .4byte sFlashLevelPixelRadii
thumb_func_end sub_807F028
thumb_func_start WriteFlashScanlineEffectBuffer
WriteFlashScanlineEffectBuffer: @ 807F074
push {r4,lr}
lsls r0, 24
lsrs r0, 24
cmp r0, 0
beq _0807F0A2
ldr r4, _0807F0A8 @ =gScanlineEffectRegBuffers
ldr r1, _0807F0AC @ =sFlashLevelPixelRadii
lsls r0, 1
adds r0, r1
ldrh r3, [r0]
adds r0, r4, 0
movs r1, 0x78
movs r2, 0x50
bl SetFlashScanlineEffectWindowBoundaries
movs r0, 0xF0
lsls r0, 3
adds r1, r4, r0
movs r2, 0xF0
lsls r2, 1
adds r0, r4, 0
bl CpuFastSet
_0807F0A2:
pop {r4}
pop {r0}
bx r0
.align 2, 0
_0807F0A8: .4byte gScanlineEffectRegBuffers
_0807F0AC: .4byte sFlashLevelPixelRadii
thumb_func_end WriteFlashScanlineEffectBuffer
thumb_func_start sub_807F0B0
sub_807F0B0: @ 807F0B0
push {lr}
bl Overworld_FadeOutMapMusic
ldr r0, _0807F0C4 @ =task50_0807F0C8
movs r1, 0x50
bl CreateTask
pop {r0}
bx r0
.align 2, 0
_0807F0C4: .4byte task50_0807F0C8
thumb_func_end sub_807F0B0
thumb_func_start task50_0807F0C8
task50_0807F0C8: @ 807F0C8
push {r4,lr}
lsls r0, 24
lsrs r4, r0, 24
bl sub_8055FC4
lsls r0, 24
lsrs r0, 24
cmp r0, 0x1
bne _0807F0E4
adds r0, r4, 0
bl DestroyTask
bl EnableBothScriptContexts
_0807F0E4:
pop {r4}
pop {r0}
bx r0
thumb_func_end task50_0807F0C8
thumb_func_start sub_807F0EC
sub_807F0EC: @ 807F0EC
push {lr}
ldr r0, _0807F10C @ =sub_807F204
movs r1, 0x50
bl CreateTask
lsls r0, 24
lsrs r0, 24
ldr r2, _0807F110 @ =gTasks
lsls r1, r0, 2
adds r1, r0
lsls r1, 3
adds r1, r2
movs r0, 0
strh r0, [r1, 0x1C]
pop {r0}
bx r0
.align 2, 0
_0807F10C: .4byte sub_807F204
_0807F110: .4byte gTasks
thumb_func_end sub_807F0EC
thumb_func_start sub_807F114
sub_807F114: @ 807F114
push {lr}
ldr r0, _0807F134 @ =sub_807F204
movs r1, 0x50
bl CreateTask
lsls r0, 24
lsrs r0, 24
ldr r2, _0807F138 @ =gTasks
lsls r1, r0, 2
adds r1, r0
lsls r1, 3
adds r1, r2
movs r0, 0x1
strh r0, [r1, 0x1C]
pop {r0}
bx r0
.align 2, 0
_0807F134: .4byte sub_807F204
_0807F138: .4byte gTasks
thumb_func_end sub_807F114
thumb_func_start sub_807F13C
sub_807F13C: @ 807F13C
push {r4,lr}
lsls r0, 24
lsrs r0, 24
lsls r4, r0, 2
adds r4, r0
lsls r4, 3
ldr r0, _0807F19C @ =gTasks+0x8
adds r4, r0
movs r0, 0
bl GetGpuReg
strh r0, [r4]
movs r0, 0x48
bl GetGpuReg
strh r0, [r4, 0x2]
movs r0, 0x4A
bl GetGpuReg
strh r0, [r4, 0x4]
movs r0, 0x50
bl GetGpuReg
strh r0, [r4, 0x6]
movs r0, 0x52
bl GetGpuReg
strh r0, [r4, 0x8]
movs r0, 0x40
bl GetGpuReg
strh r0, [r4, 0xA]
movs r0, 0x44
bl GetGpuReg
strh r0, [r4, 0xC]
movs r0, 0x42
bl GetGpuReg
strh r0, [r4, 0xE]
movs r0, 0x46
bl GetGpuReg
strh r0, [r4, 0x10]
pop {r4}
pop {r0}
bx r0
.align 2, 0
_0807F19C: .4byte gTasks+0x8
thumb_func_end sub_807F13C
thumb_func_start sub_807F1A0
sub_807F1A0: @ 807F1A0
push {r4,lr}
lsls r0, 24
lsrs r0, 24
lsls r4, r0, 2
adds r4, r0
lsls r4, 3
ldr r0, _0807F200 @ =gTasks+0x8
adds r4, r0
ldrh r1, [r4]
movs r0, 0
bl SetGpuReg
ldrh r1, [r4, 0x2]
movs r0, 0x48
bl SetGpuReg
ldrh r1, [r4, 0x4]
movs r0, 0x4A
bl SetGpuReg
ldrh r1, [r4, 0x6]
movs r0, 0x50
bl SetGpuReg
ldrh r1, [r4, 0x8]
movs r0, 0x52
bl SetGpuReg
ldrh r1, [r4, 0xA]
movs r0, 0x40
bl SetGpuReg
ldrh r1, [r4, 0xC]
movs r0, 0x44
bl SetGpuReg
ldrh r1, [r4, 0xE]
movs r0, 0x42
bl SetGpuReg
ldrh r1, [r4, 0x10]
movs r0, 0x46
bl SetGpuReg
pop {r4}
pop {r0}
bx r0
.align 2, 0
_0807F200: .4byte gTasks+0x8
thumb_func_end sub_807F1A0
thumb_func_start sub_807F204
sub_807F204: @ 807F204
push {r4,r5,lr}
lsls r0, 24
lsrs r4, r0, 24
lsls r0, r4, 2
adds r0, r4
lsls r0, 3
ldr r1, _0807F228 @ =gTasks+0x8
adds r5, r0, r1
movs r1, 0x12
ldrsh r0, [r5, r1]
cmp r0, 0x1
beq _0807F2BC
cmp r0, 0x1
bgt _0807F22C
cmp r0, 0
beq _0807F236
b _0807F2F4
.align 2, 0
_0807F228: .4byte gTasks+0x8
_0807F22C:
cmp r0, 0x2
beq _0807F2D0
cmp r0, 0x3
beq _0807F2E8
b _0807F2F4
_0807F236:
adds r0, r4, 0
bl sub_807F13C
movs r1, 0x80
lsls r1, 6
movs r0, 0
bl SetGpuRegBits
movs r1, 0x80
lsls r1, 7
movs r0, 0
bl SetGpuRegBits
movs r1, 0x14
ldrsh r0, [r5, r1]
cmp r0, 0
bne _0807F280
movs r0, 0x40
movs r1, 0
bl SetGpuReg
ldr r1, _0807F27C @ =0x0000f0ff
movs r0, 0x42
bl SetGpuReg
movs r0, 0x44
movs r1, 0xFF
bl SetGpuReg
movs r0, 0x46
movs r1, 0xFF
bl SetGpuReg
b _0807F2A0
.align 2, 0
_0807F27C: .4byte 0x0000f0ff
_0807F280:
movs r0, 0x40
movs r1, 0x78
bl SetGpuReg
movs r0, 0x44
movs r1, 0xFF
bl SetGpuReg
ldr r1, _0807F2B8 @ =0x000078ff
movs r0, 0x42
bl SetGpuReg
movs r0, 0x46
movs r1, 0xFF
bl SetGpuReg
_0807F2A0:
movs r0, 0x48
movs r1, 0
bl SetGpuReg
movs r0, 0x4A
movs r1, 0x3F
bl SetGpuReg
movs r0, 0x1
strh r0, [r5, 0x12]
b _0807F2F4
.align 2, 0
_0807F2B8: .4byte 0x000078ff
_0807F2BC:
ldr r0, _0807F2CC @ =sub_807F2FC
movs r1, 0x50
bl CreateTask
movs r0, 0x2
strh r0, [r5, 0x12]
b _0807F2F4
.align 2, 0
_0807F2CC: .4byte sub_807F2FC
_0807F2D0:
ldr r0, _0807F2E4 @ =sub_807F2FC
bl FuncIsActiveTask
lsls r0, 24
cmp r0, 0
bne _0807F2F4
movs r0, 0x3
strh r0, [r5, 0x12]
b _0807F2F4
.align 2, 0
_0807F2E4: .4byte sub_807F2FC
_0807F2E8:
adds r0, r4, 0
bl sub_807F1A0
adds r0, r4, 0
bl DestroyTask
_0807F2F4:
pop {r4,r5}
pop {r0}
bx r0
thumb_func_end sub_807F204
thumb_func_start sub_807F2FC
sub_807F2FC: @ 807F2FC
push {r4-r7,lr}
mov r7, r8
push {r7}
lsls r0, 24
lsrs r5, r0, 24
mov r8, r5
lsls r0, r5, 2
adds r0, r5
lsls r0, 3
ldr r4, _0807F348 @ =gTasks+0x8
adds r6, r0, r4
ldr r0, _0807F34C @ =sub_807F204
bl FindTaskIdByFunc
lsls r0, 24
lsrs r0, 24
lsls r1, r0, 2
adds r1, r0
lsls r1, 3
adds r4, r1
movs r1, 0x14
ldrsh r0, [r4, r1]
cmp r0, 0
bne _0807F350
ldrh r4, [r6]
movs r0, 0xF0
subs r0, r4
lsls r0, 16
lsrs r7, r0, 16
lsls r0, r4, 16
asrs r0, 16
cmp r0, 0x78
ble _0807F36C
adds r0, r5, 0
bl DestroyTask
b _0807F39A
.align 2, 0
_0807F348: .4byte gTasks+0x8
_0807F34C: .4byte sub_807F204
_0807F350:
ldrh r0, [r6]
movs r1, 0x78
subs r1, r0
lsls r1, 16
adds r0, 0x78
lsls r0, 16
lsrs r7, r0, 16
lsrs r4, r1, 16
cmp r1, 0
bge _0807F36C
mov r0, r8
bl DestroyTask
b _0807F39A
_0807F36C:
lsls r4, 16
lsrs r1, r4, 16
movs r0, 0x40
bl SetGpuReg
lsls r1, r7, 16
asrs r1, 8
movs r0, 0xF0
orrs r1, r0
lsls r1, 16
lsrs r1, 16
movs r0, 0x42
bl SetGpuReg
asrs r4, 16
cmp r4, 0x59
bgt _0807F394
ldrh r0, [r6]
adds r0, 0x4
b _0807F398
_0807F394:
ldrh r0, [r6]
adds r0, 0x2
_0807F398:
strh r0, [r6]
_0807F39A:
pop {r3}
mov r8, r3
pop {r4-r7}
pop {r0}
bx r0
thumb_func_end sub_807F2FC
thumb_func_start sub_807F3A4
sub_807F3A4: @ 807F3A4
push {r4-r7,lr}
-697
View File
@@ -1,697 +0,0 @@
.include "asm/macros.inc"
.include "constants/constants.inc"
.syntax unified
.text
thumb_func_start task_per_step_callback_manager
task_per_step_callback_manager: @ 806E810
push {lr}
lsls r0, 24
lsrs r0, 24
ldr r2, _0806E834 @ =gTasks
lsls r1, r0, 2
adds r1, r0
lsls r1, 3
adds r1, r2
movs r2, 0x8
ldrsh r1, [r1, r2]
ldr r2, _0806E838 @ =gUnknown_83A7310
lsls r1, 2
adds r1, r2
ldr r1, [r1]
bl _call_via_r1
pop {r0}
bx r0
.align 2, 0
_0806E834: .4byte gTasks
_0806E838: .4byte gUnknown_83A7310
thumb_func_end task_per_step_callback_manager
thumb_func_start sub_806E83C
sub_806E83C: @ 806E83C
push {r4,lr}
lsls r0, 24
lsrs r0, 24
lsls r1, r0, 2
adds r1, r0
lsls r1, 3
ldr r0, _0806E874 @ =gTasks+0x8
adds r4, r1, r0
bl ScriptContext2_IsEnabled
lsls r0, 24
cmp r0, 0
bne _0806E86C
ldr r0, _0806E878 @ =gUnknown_203ADFA
ldrb r0, [r0]
subs r0, 0x2
lsls r0, 24
lsrs r0, 24
cmp r0, 0x1
bls _0806E86C
adds r0, r4, 0x2
adds r1, r4, 0x4
bl sub_8056078
_0806E86C:
pop {r4}
pop {r0}
bx r0
.align 2, 0
_0806E874: .4byte gTasks+0x8
_0806E878: .4byte gUnknown_203ADFA
thumb_func_end sub_806E83C
thumb_func_start sub_806E87C
sub_806E87C: @ 806E87C
push {r4,r5,lr}
ldr r5, _0806E8C4 @ =task_per_step_callback_manager
adds r0, r5, 0
bl FuncIsActiveTask
lsls r0, 24
lsrs r4, r0, 24
cmp r4, 0
bne _0806E8A6
adds r0, r5, 0
movs r1, 0x50
bl CreateTask
lsls r0, 24
lsrs r0, 24
ldr r2, _0806E8C8 @ =gTasks
lsls r1, r0, 2
adds r1, r0
lsls r1, 3
adds r1, r2
strh r4, [r1, 0x8]
_0806E8A6:
ldr r4, _0806E8CC @ =sub_806E83C
adds r0, r4, 0
bl FuncIsActiveTask
lsls r0, 24
cmp r0, 0
bne _0806E8BC
adds r0, r4, 0
movs r1, 0x50
bl CreateTask
_0806E8BC:
pop {r4,r5}
pop {r0}
bx r0
.align 2, 0
_0806E8C4: .4byte task_per_step_callback_manager
_0806E8C8: .4byte gTasks
_0806E8CC: .4byte sub_806E83C
thumb_func_end sub_806E87C
thumb_func_start ActivatePerStepCallback
ActivatePerStepCallback: @ 806E8D0
push {r4,lr}
lsls r0, 24
lsrs r4, r0, 24
ldr r0, _0806E908 @ =task_per_step_callback_manager
bl FindTaskIdByFunc
lsls r0, 24
lsrs r1, r0, 24
cmp r1, 0xFF
beq _0806E912
lsls r0, r1, 2
adds r0, r1
lsls r0, 3
ldr r1, _0806E90C @ =gTasks+0x8
adds r1, r0, r1
movs r2, 0
adds r0, r1, 0
adds r0, 0x1E
_0806E8F4:
strh r2, [r0]
subs r0, 0x2
cmp r0, r1
bge _0806E8F4
cmp r4, 0x7
bls _0806E910
movs r0, 0
strh r0, [r1]
b _0806E912
.align 2, 0
_0806E908: .4byte task_per_step_callback_manager
_0806E90C: .4byte gTasks+0x8
_0806E910:
strh r4, [r1]
_0806E912:
pop {r4}
pop {r0}
bx r0
thumb_func_end ActivatePerStepCallback
thumb_func_start wild_encounter_reset_coro_args
wild_encounter_reset_coro_args: @ 806E918
push {lr}
ldr r0, _0806E948 @ =task_per_step_callback_manager
bl FindTaskIdByFunc
lsls r0, 24
lsrs r1, r0, 24
ldr r0, _0806E94C @ =sub_806E83C
bl FindTaskIdByFunc
lsls r0, 24
lsrs r1, r0, 24
cmp r1, 0xFF
beq _0806E942
lsls r0, r1, 2
adds r0, r1
lsls r0, 3
ldr r1, _0806E950 @ =gTasks+0x8
adds r0, r1
movs r1, 0
strh r1, [r0, 0x2]
strh r1, [r0, 0x4]
_0806E942:
pop {r0}
bx r0
.align 2, 0
_0806E948: .4byte task_per_step_callback_manager
_0806E94C: .4byte sub_806E83C
_0806E950: .4byte gTasks+0x8
thumb_func_end wild_encounter_reset_coro_args
thumb_func_start nullsub_40
nullsub_40: @ 806E954
bx lr
thumb_func_end nullsub_40
thumb_func_start sub_806E958
sub_806E958: @ 806E958
push {r4,r5,lr}
movs r3, 0
ldr r4, _0806E988 @ =gUnknown_83A7330
lsls r0, 16
asrs r5, r0, 16
lsls r1, 16
asrs r1, 16
_0806E966:
lsls r2, r3, 1
adds r0, r2, r4
ldrb r0, [r0]
adds r0, 0x7
cmp r0, r5
bne _0806E98C
adds r0, r4, 0x1
adds r0, r2, r0
ldrb r0, [r0]
adds r0, 0x7
cmp r0, r1
bne _0806E98C
adds r0, r3, 0x1
bl FlagSet
b _0806E996
.align 2, 0
_0806E988: .4byte gUnknown_83A7330
_0806E98C:
adds r0, r3, 0x1
lsls r0, 24
lsrs r3, r0, 24
cmp r3, 0x8
bls _0806E966
_0806E996:
pop {r4,r5}
pop {r0}
bx r0
thumb_func_end sub_806E958
thumb_func_start sub_806E99C
sub_806E99C: @ 806E99C
push {r4-r7,lr}
movs r4, 0
ldr r6, _0806E9D8 @ =gUnknown_83A7330
adds r7, r6, 0x1
_0806E9A4:
adds r5, r4, 0x1
adds r0, r5, 0
bl FlagGet
lsls r0, 24
lsrs r0, 24
cmp r0, 0x1
bne _0806E9C8
lsls r1, r4, 1
adds r0, r1, r6
ldrb r0, [r0]
adds r0, 0x7
adds r1, r7
ldrb r1, [r1]
adds r1, 0x7
ldr r2, _0806E9DC @ =0x0000035a
bl MapGridSetMetatileIdAt
_0806E9C8:
lsls r0, r5, 24
lsrs r4, r0, 24
cmp r4, 0x8
bls _0806E9A4
pop {r4-r7}
pop {r0}
bx r0
.align 2, 0
_0806E9D8: .4byte gUnknown_83A7330
_0806E9DC: .4byte 0x0000035a
thumb_func_end sub_806E99C
thumb_func_start sub_806E9E0
sub_806E9E0: @ 806E9E0
push {r4-r6,lr}
sub sp, 0x4
lsls r0, 24
lsrs r0, 24
lsls r1, r0, 2
adds r1, r0
lsls r1, 3
ldr r0, _0806EA04 @ =gTasks+0x8
adds r5, r1, r0
movs r1, 0x2
ldrsh r0, [r5, r1]
cmp r0, 0x1
beq _0806EA2A
cmp r0, 0x1
bgt _0806EA08
cmp r0, 0
beq _0806EA12
b _0806EB42
.align 2, 0
_0806EA04: .4byte gTasks+0x8
_0806EA08:
cmp r0, 0x2
beq _0806EAB0
cmp r0, 0x3
beq _0806EAF4
b _0806EB42
_0806EA12:
mov r4, sp
adds r4, 0x2
mov r0, sp
adds r1, r4, 0
bl PlayerGetDestCoords
mov r0, sp
ldrh r0, [r0]
strh r0, [r5, 0x4]
ldrh r0, [r4]
strh r0, [r5, 0x6]
b _0806EB3E
_0806EA2A:
mov r4, sp
adds r4, 0x2
mov r0, sp
adds r1, r4, 0
bl PlayerGetDestCoords
mov r0, sp
ldrh r2, [r0]
movs r3, 0
ldrsh r1, [r0, r3]
movs r3, 0x4
ldrsh r0, [r5, r3]
cmp r1, r0
bne _0806EA52
movs r0, 0
ldrsh r1, [r4, r0]
movs r3, 0x6
ldrsh r0, [r5, r3]
cmp r1, r0
beq _0806EB42
_0806EA52:
strh r2, [r5, 0x4]
ldrh r0, [r4]
strh r0, [r5, 0x6]
mov r0, sp
movs r1, 0
ldrsh r0, [r0, r1]
movs r2, 0
ldrsh r1, [r4, r2]
bl MapGridGetMetatileBehaviorAt
lsls r0, 24
lsrs r6, r0, 24
adds r0, r6, 0
bl MetatileBehavior_IsThinIce
lsls r0, 24
lsrs r0, 24
cmp r0, 0x1
bne _0806EA8E
mov r0, sp
movs r3, 0
ldrsh r0, [r0, r3]
movs r2, 0
ldrsh r1, [r4, r2]
bl sub_806E958
movs r0, 0x4
strh r0, [r5, 0xC]
movs r0, 0x2
b _0806EAA2
_0806EA8E:
adds r0, r6, 0
bl MetatileBehavior_IsCrackedIce
lsls r0, 24
lsrs r0, 24
cmp r0, 0x1
bne _0806EB42
movs r0, 0x4
strh r0, [r5, 0xC]
movs r0, 0x3
_0806EAA2:
strh r0, [r5, 0x2]
mov r0, sp
ldrh r0, [r0]
strh r0, [r5, 0x8]
ldrh r0, [r4]
strh r0, [r5, 0xA]
b _0806EB42
_0806EAB0:
ldrh r1, [r5, 0xC]
movs r3, 0xC
ldrsh r0, [r5, r3]
cmp r0, 0
bne _0806EAFE
mov r1, sp
ldrh r0, [r5, 0x8]
strh r0, [r1]
mov r4, sp
adds r4, 0x2
ldrh r0, [r5, 0xA]
strh r0, [r4]
movs r0, 0x24
bl PlaySE
mov r0, sp
movs r1, 0
ldrsh r0, [r0, r1]
movs r2, 0
ldrsh r1, [r4, r2]
ldr r2, _0806EAF0 @ =0x0000035a
bl MapGridSetMetatileIdAt
mov r0, sp
movs r3, 0
ldrsh r0, [r0, r3]
movs r2, 0
ldrsh r1, [r4, r2]
bl CurrentMapDrawMetatileAt
b _0806EB3E
.align 2, 0
_0806EAF0: .4byte 0x0000035a
_0806EAF4:
ldrh r1, [r5, 0xC]
movs r3, 0xC
ldrsh r0, [r5, r3]
cmp r0, 0
beq _0806EB04
_0806EAFE:
subs r0, r1, 0x1
strh r0, [r5, 0xC]
b _0806EB42
_0806EB04:
mov r1, sp
ldrh r0, [r5, 0x8]
strh r0, [r1]
mov r4, sp
adds r4, 0x2
ldrh r0, [r5, 0xA]
strh r0, [r4]
movs r0, 0x23
bl PlaySE
mov r0, sp
movs r1, 0
ldrsh r0, [r0, r1]
movs r2, 0
ldrsh r1, [r4, r2]
ldr r2, _0806EB4C @ =0x0000035b
bl MapGridSetMetatileIdAt
mov r0, sp
movs r3, 0
ldrsh r0, [r0, r3]
movs r2, 0
ldrsh r1, [r4, r2]
bl CurrentMapDrawMetatileAt
ldr r0, _0806EB50 @ =0x00004001
movs r1, 0x1
bl VarSet
_0806EB3E:
movs r0, 0x1
strh r0, [r5, 0x2]
_0806EB42:
add sp, 0x4
pop {r4-r6}
pop {r0}
bx r0
.align 2, 0
_0806EB4C: .4byte 0x0000035b
_0806EB50: .4byte 0x00004001
thumb_func_end sub_806E9E0
thumb_func_start sub_806EB54
sub_806EB54: @ 806EB54
push {r4,r5,lr}
sub sp, 0x4
lsls r0, 24
lsrs r0, 24
lsls r1, r0, 2
adds r1, r0
lsls r1, 3
ldr r0, _0806EBD8 @ =gTasks+0x8
adds r5, r1, r0
mov r4, sp
adds r4, 0x2
mov r0, sp
adds r1, r4, 0
bl PlayerGetDestCoords
mov r0, sp
ldrh r2, [r0]
movs r3, 0
ldrsh r1, [r0, r3]
movs r3, 0x2
ldrsh r0, [r5, r3]
cmp r1, r0
bne _0806EB8E
movs r0, 0
ldrsh r1, [r4, r0]
movs r3, 0x4
ldrsh r0, [r5, r3]
cmp r1, r0
beq _0806EBF6
_0806EB8E:
strh r2, [r5, 0x2]
ldrh r0, [r4]
strh r0, [r5, 0x4]
mov r0, sp
movs r1, 0
ldrsh r0, [r0, r1]
movs r2, 0
ldrsh r1, [r4, r2]
bl MapGridGetMetatileBehaviorAt
lsls r0, 24
lsrs r0, 24
bl MetatileBehavior_ReturnFalse_4
lsls r0, 24
cmp r0, 0
beq _0806EBF6
mov r0, sp
movs r3, 0
ldrsh r0, [r0, r3]
movs r2, 0
ldrsh r1, [r4, r2]
bl MapGridGetMetatileIdAt
ldr r1, _0806EBDC @ =0x0000020a
cmp r0, r1
bne _0806EBE4
mov r0, sp
movs r3, 0
ldrsh r0, [r0, r3]
movs r2, 0
ldrsh r1, [r4, r2]
ldr r2, _0806EBE0 @ =0x00000212
movs r3, 0x4
bl ash
b _0806EBF6
.align 2, 0
_0806EBD8: .4byte gTasks+0x8
_0806EBDC: .4byte 0x0000020a
_0806EBE0: .4byte 0x00000212
_0806EBE4:
mov r0, sp
movs r3, 0
ldrsh r0, [r0, r3]
movs r2, 0
ldrsh r1, [r4, r2]
ldr r2, _0806EC00 @ =0x00000206
movs r3, 0x4
bl ash
_0806EBF6:
add sp, 0x4
pop {r4,r5}
pop {r0}
bx r0
.align 2, 0
_0806EC00: .4byte 0x00000206
thumb_func_end sub_806EB54
thumb_func_start sub_806EC04
sub_806EC04: @ 806EC04
push {r4,r5,lr}
lsls r0, 16
asrs r5, r0, 16
lsls r1, 16
asrs r4, r1, 16
adds r0, r5, 0
adds r1, r4, 0
bl MapGridGetMetatileIdAt
ldr r1, _0806EC38 @ =0x0000022f
ldr r2, _0806EC3C @ =0x00000237
cmp r0, r1
bne _0806EC20
subs r2, 0x31
_0806EC20:
adds r0, r5, 0
adds r1, r4, 0
bl MapGridSetMetatileIdAt
adds r0, r5, 0
adds r1, r4, 0
bl CurrentMapDrawMetatileAt
pop {r4,r5}
pop {r0}
bx r0
.align 2, 0
_0806EC38: .4byte 0x0000022f
_0806EC3C: .4byte 0x00000237
thumb_func_end sub_806EC04
thumb_func_start sub_806EC40
sub_806EC40: @ 806EC40
push {r4-r7,lr}
sub sp, 0x4
lsls r0, 24
lsrs r0, 24
lsls r1, r0, 2
adds r1, r0
lsls r1, 3
ldr r0, _0806ED10 @ =gTasks+0x8
adds r5, r1, r0
mov r4, sp
adds r4, 0x2
mov r0, sp
adds r1, r4, 0
bl PlayerGetDestCoords
mov r0, sp
movs r1, 0
ldrsh r0, [r0, r1]
movs r2, 0
ldrsh r1, [r4, r2]
bl MapGridGetMetatileBehaviorAt
lsls r0, 16
lsrs r7, r0, 16
ldrh r1, [r5, 0x8]
movs r3, 0x8
ldrsh r0, [r5, r3]
adds r6, r4, 0
cmp r0, 0
beq _0806EC92
subs r0, r1, 0x1
strh r0, [r5, 0x8]
lsls r0, 16
cmp r0, 0
bne _0806EC92
movs r1, 0xA
ldrsh r0, [r5, r1]
movs r2, 0xC
ldrsh r1, [r5, r2]
bl sub_806EC04
_0806EC92:
ldrh r1, [r5, 0xE]
movs r3, 0xE
ldrsh r0, [r5, r3]
cmp r0, 0
beq _0806ECB2
subs r0, r1, 0x1
strh r0, [r5, 0xE]
lsls r0, 16
cmp r0, 0
bne _0806ECB2
movs r1, 0x10
ldrsh r0, [r5, r1]
movs r2, 0x12
ldrsh r1, [r5, r2]
bl sub_806EC04
_0806ECB2:
mov r0, sp
ldrh r2, [r0]
movs r3, 0
ldrsh r1, [r0, r3]
movs r3, 0x4
ldrsh r0, [r5, r3]
cmp r1, r0
bne _0806ECCE
movs r0, 0
ldrsh r1, [r6, r0]
movs r3, 0x6
ldrsh r0, [r5, r3]
cmp r1, r0
beq _0806ED2E
_0806ECCE:
strh r2, [r5, 0x4]
adds r4, r6, 0
ldrh r0, [r4]
strh r0, [r5, 0x6]
lsls r0, r7, 24
lsrs r0, 24
bl MetatileBehavior_ReturnFalse_13
lsls r0, 24
cmp r0, 0
beq _0806ED2E
bl GetPlayerSpeed
lsls r0, 16
asrs r0, 16
cmp r0, 0x4
beq _0806ECF8
ldr r0, _0806ED14 @ =0x00004030
movs r1, 0
bl VarSet
_0806ECF8:
movs r1, 0x8
ldrsh r0, [r5, r1]
cmp r0, 0
bne _0806ED18
movs r0, 0x3
strh r0, [r5, 0x8]
mov r0, sp
ldrh r0, [r0]
strh r0, [r5, 0xA]
ldrh r0, [r4]
strh r0, [r5, 0xC]
b _0806ED2E
.align 2, 0
_0806ED10: .4byte gTasks+0x8
_0806ED14: .4byte 0x00004030
_0806ED18:
movs r2, 0xE
ldrsh r0, [r5, r2]
cmp r0, 0
bne _0806ED2E
movs r0, 0x3
strh r0, [r5, 0xE]
mov r0, sp
ldrh r0, [r0]
strh r0, [r5, 0x10]
ldrh r0, [r6]
strh r0, [r5, 0x12]
_0806ED2E:
add sp, 0x4
pop {r4-r7}
pop {r0}
bx r0
thumb_func_end sub_806EC40
thumb_func_start sub_806ED38
sub_806ED38: @ 806ED38
push {lr}
ldr r0, _0806ED4C @ =0x00000829
bl FlagSet
ldr r0, _0806ED50 @ =0x00000828
bl FlagSet
pop {r0}
bx r0
.align 2, 0
_0806ED4C: .4byte 0x00000829
_0806ED50: .4byte 0x00000828
thumb_func_end sub_806ED38
.align 2, 0 @ Don't pad with nop.
+17 -17
View File
@@ -1737,7 +1737,7 @@ _080558D4:
bl RoamerMove
bl sub_8110920
bl DoCurrentWeather
bl wild_encounter_reset_coro_args
bl ResetFieldTasksArgs
bl mapheader_run_script_with_tag_x5
bl sub_80561B4
ldr r1, _0805591C @ =gMapHeader
@@ -2640,15 +2640,15 @@ _08055FB8:
_08055FC0: .4byte 0x00004001
thumb_func_end sub_8055F88
thumb_func_start sub_8055FC4
sub_8055FC4: @ 8055FC4
thumb_func_start BGMusicStopped
BGMusicStopped: @ 8055FC4
push {lr}
bl IsNotWaitingForBGMStop
lsls r0, 24
lsrs r0, 24
pop {r1}
bx r1
thumb_func_end sub_8055FC4
thumb_func_end BGMusicStopped
thumb_func_start Overworld_FadeOutMapMusic
Overworld_FadeOutMapMusic: @ 8055FD4
@@ -3941,8 +3941,8 @@ VBlankCB_Field: @ 8056A14
bx r0
thumb_func_end VBlankCB_Field
thumb_func_start sub_8056A34
sub_8056A34: @ 8056A34
thumb_func_start InitCurrentFlashLevelScanlineEffect
InitCurrentFlashLevelScanlineEffect: @ 8056A34
push {lr}
bl Overworld_GetFlashLevel
lsls r0, 24
@@ -3950,7 +3950,7 @@ sub_8056A34: @ 8056A34
cmp r0, 0
beq _08056A52
bl WriteFlashScanlineEffectBuffer
ldr r2, _08056A58 @ =gUnknown_826D330
ldr r2, _08056A58 @ =gFlashEffectParams
ldr r0, [r2]
ldr r1, [r2, 0x4]
ldr r2, [r2, 0x8]
@@ -3959,8 +3959,8 @@ _08056A52:
pop {r0}
bx r0
.align 2, 0
_08056A58: .4byte gUnknown_826D330
thumb_func_end sub_8056A34
_08056A58: .4byte gFlashEffectParams
thumb_func_end InitCurrentFlashLevelScanlineEffect
thumb_func_start sub_8056A5C
sub_8056A5C: @ 8056A5C
@@ -4015,7 +4015,7 @@ _08056ACE:
bl sub_812B35C
b _08056B62
_08056AE4:
bl sub_8056A34
bl InitCurrentFlashLevelScanlineEffect
bl sub_8056F1C
b _08056B62
_08056AEE:
@@ -4157,7 +4157,7 @@ _08056C16:
.align 2, 0
_08056C1C: .4byte gUnknown_203ADFA
_08056C20:
bl sub_8056A34
bl InitCurrentFlashLevelScanlineEffect
bl sub_8056F1C
b _08056CCA
_08056C2A:
@@ -4346,7 +4346,7 @@ _08056DAE:
bl sub_812B35C
b _08056E3E
_08056DC0:
bl sub_8056A34
bl InitCurrentFlashLevelScanlineEffect
bl sub_8056F1C
b _08056E3E
_08056DCA:
@@ -4513,7 +4513,7 @@ _08056F04: .4byte 0x81000800
thumb_func_start sub_8056F08
sub_8056F08: @ 8056F08
push {lr}
bl sub_8056A34
bl InitCurrentFlashLevelScanlineEffect
bl sub_8056F1C
bl mapdata_load_assets_to_gpu_and_full_redraw
pop {r0}
@@ -4648,7 +4648,7 @@ _08057056:
bl sub_807B1B8
cmp r4, 0
bne _0805706A
bl sub_806E87C
bl SetUpFieldTasks
_0805706A:
bl mapheader_run_script_with_tag_x5
pop {r4}
@@ -5057,7 +5057,7 @@ _080573AE:
bl sub_8057114
b _08057412
_080573B8:
bl sub_8056A34
bl InitCurrentFlashLevelScanlineEffect
bl sub_8056F1C
b _08057412
_080573C2:
@@ -5402,11 +5402,11 @@ _0805769C:
bl FieldEffectActiveListClear
bl sub_8079C08
bl sub_807B1B8
bl sub_806E87C
bl SetUpFieldTasks
bl mapheader_run_script_with_tag_x5
b _0805772A
_080576C2:
bl sub_8056A34
bl InitCurrentFlashLevelScanlineEffect
bl sub_8056F1C
b _0805772A
_080576CC: