From f5be0f933e5debf150fdb4369c0e573117b96b7d Mon Sep 17 00:00:00 2001 From: chordtoll Date: Sun, 13 Oct 2024 23:47:31 -0700 Subject: [PATCH 1/2] Decompile dg_object functions --- ...9_022E1A40.inc => overlay_29_022E1AAC.inc} | 15 ++++--- ...ay_29_022E1A40.s => overlay_29_022E1AAC.s} | 42 +------------------ include/dg_object.h | 3 ++ main.lsf | 2 +- src/dg_object.c | 24 +++++++++++ 5 files changed, 36 insertions(+), 50 deletions(-) rename asm/include/{overlay_29_022E1A40.inc => overlay_29_022E1AAC.inc} (98%) rename asm/{overlay_29_022E1A40.s => overlay_29_022E1AAC.s} (97%) diff --git a/asm/include/overlay_29_022E1A40.inc b/asm/include/overlay_29_022E1AAC.inc similarity index 98% rename from asm/include/overlay_29_022E1A40.inc rename to asm/include/overlay_29_022E1AAC.inc index 1d7d3d1f..fdb5119f 100644 --- a/asm/include/overlay_29_022E1A40.inc +++ b/asm/include/overlay_29_022E1AAC.inc @@ -1,9 +1,7 @@ #pragma once -.public _020A1AE8 -.public abs .public CanSeeInvisibleMonsters -.public DrawMinimapTile .public DUNGEON_PTR +.public DrawMinimapTile .public DungeonGetSpriteIndex .public EntityIsValid__022E1A1C .public EntityIsValid__022E32E8 @@ -19,6 +17,12 @@ .public IsPositionActuallyInSight .public IsPositionInSight .public ItemIsActive__022E330C +.public SECONDARY_TERRAIN_TYPES +.public StringFromId +.public TeamMemberHasEnabledIqSkill +.public UpdateMinimap +.public UpdateTrapsVisibility +.public abs .public ov29_022DE954 .public ov29_022DE9F8 .public ov29_022DEA10 @@ -39,11 +43,6 @@ .public ov29_0237C754 .public ov29_0237C79C .public ov29_0237C84C -.public SECONDARY_TERRAIN_TYPES .public strcpy -.public StringFromId .public sub_02009194 .public sub_020091B0 -.public TeamMemberHasEnabledIqSkill -.public UpdateMinimap -.public UpdateTrapsVisibility diff --git a/asm/overlay_29_022E1A40.s b/asm/overlay_29_022E1AAC.s similarity index 97% rename from asm/overlay_29_022E1A40.s rename to asm/overlay_29_022E1AAC.s index caf4100a..db2765a0 100644 --- a/asm/overlay_29_022E1A40.s +++ b/asm/overlay_29_022E1AAC.s @@ -1,48 +1,8 @@ .include "asm/macros.inc" - .include "overlay_29_022E1A40.inc" + .include "overlay_29_022E1AAC.inc" .text - arm_func_start UpdateEntityPixelPos -UpdateEntityPixelPos: ; 0x022E1A40 - cmp r1, #0 - ldrne r2, [r1] - strne r2, [r0, #0xc] - ldrne r1, [r1, #4] - bne _022E1A7C - ldrsh r2, [r0, #4] - mov r1, #0x18 - smulbb r2, r2, r1 - add r2, r2, #0xc - mov r2, r2, lsl #8 - str r2, [r0, #0xc] - ldrsh r2, [r0, #6] - smulbb r1, r2, r1 - add r1, r1, #0x10 - mov r1, r1, lsl #8 -_022E1A7C: - str r1, [r0, #0x10] - bx lr - arm_func_end UpdateEntityPixelPos - - arm_func_start ov29_022E1A84 -ov29_022E1A84: ; 0x022E1A84 - str r1, [r0, #0xc] - str r2, [r0, #0x10] - bx lr - arm_func_end ov29_022E1A84 - - arm_func_start ov29_022E1A90 -ov29_022E1A90: ; 0x022E1A90 - ldr r3, [r0, #0xc] - add r1, r3, r1 - str r1, [r0, #0xc] - ldr r1, [r0, #0x10] - add r1, r1, r2 - str r1, [r0, #0x10] - bx lr - arm_func_end ov29_022E1A90 - arm_func_start ov29_022E1AAC ov29_022E1AAC: ; 0x022E1AAC stmdb sp!, {r3, r4, r5, lr} diff --git a/include/dg_object.h b/include/dg_object.h index c9bee943..cf59b0ef 100644 --- a/include/dg_object.h +++ b/include/dg_object.h @@ -7,5 +7,8 @@ // entity: entity pointer // return: bool u8 EntityIsValid__022E1A1C(struct entity *entity); +void UpdateEntityPixelPos(struct entity *entity, struct pixel_position *pixel_pos); +void ov29_022E1A84(struct entity *entity, u32 x, u32 y); +void ov29_022E1A84(struct entity *entity, u32 x, u32 y); #endif //PMDSKY_OVERLAY_29_022E1A1C_H diff --git a/main.lsf b/main.lsf index 992556e0..6030d5c0 100644 --- a/main.lsf +++ b/main.lsf @@ -187,7 +187,7 @@ Overlay OVY_29 Object src/dg.o Object asm/overlay_29_022E0378.o Object src/dg_object.o - Object asm/overlay_29_022E1A40.o + Object asm/overlay_29_022E1AAC.o Object src/dg_camera.o Object asm/overlay_29_022E330C.o Object src/dg_effect.o diff --git a/src/dg_object.c b/src/dg_object.c index b3cf702d..06f7951c 100644 --- a/src/dg_object.c +++ b/src/dg_object.c @@ -10,3 +10,27 @@ u8 EntityIsValid__022E1A1C(struct entity *entity) } return entity->type != ENTITY_NOTHING; } + +void UpdateEntityPixelPos(struct entity *entity, struct pixel_position *pixel_pos) +{ + if (pixel_pos != 0) { + entity->pixel_pos.x = pixel_pos->x; + entity->pixel_pos.y = pixel_pos->y; + } + else { + entity->pixel_pos.x = ((((entity->pos.x)*0x18)+0x0c)<<8); + entity->pixel_pos.y = ((((entity->pos.y)*0x18)+0x10)<<8); + } +} + +void ov29_022E1A84(struct entity *entity, u32 x, u32 y) +{ + entity->pixel_pos.x = x; + entity->pixel_pos.y = y; +} + +void ov29_022E1A84(struct entity *entity, u32 x, u32 y) +{ + entity->pixel_pos.x += x; + entity->pixel_pos.y += y; +} From f4784e8bb73b90e3a2eea47afd23408113ec1aa1 Mon Sep 17 00:00:00 2001 From: chordtoll Date: Sun, 13 Oct 2024 23:55:55 -0700 Subject: [PATCH 2/2] Give newly decompiled functions more meaningful names --- asm/include/overlay_29_022DC2B8.inc | 2 +- asm/include/overlay_29_023047DC.inc | 2 +- asm/include/overlay_29_0231F594.inc | 4 ++-- asm/include/overlay_29_0231FC20.inc | 2 +- asm/include/overlay_29_023201A0.inc | 2 +- asm/include/overlay_29_0232A3FC.inc | 4 ++-- asm/include/overlay_29_023456BC.inc | 4 ++-- asm/include/overlay_29_02347BC8.inc | 2 +- asm/overlay_29_022DC2B8.s | 2 +- asm/overlay_29_023047DC.s | 2 +- asm/overlay_29_0231F594.s | 4 ++-- asm/overlay_29_0231FC20.s | 2 +- asm/overlay_29_023201A0.s | 2 +- asm/overlay_29_0232A3FC.s | 6 +++--- asm/overlay_29_023456BC.s | 16 ++++++++-------- asm/overlay_29_02347BC8.s | 4 ++-- include/dg_object.h | 4 ++-- src/dg_object.c | 4 ++-- 18 files changed, 34 insertions(+), 34 deletions(-) diff --git a/asm/include/overlay_29_022DC2B8.inc b/asm/include/overlay_29_022DC2B8.inc index 39d5586d..6470d225 100644 --- a/asm/include/overlay_29_022DC2B8.inc +++ b/asm/include/overlay_29_022DC2B8.inc @@ -91,7 +91,7 @@ .public ov29_022E15C8 .public ov29_022E1604 .public ov29_022E1640 -.public ov29_022E1A84 +.public SetEntityPixelPosXY .public ov29_022E2B68 .public ov29_022E2DFC .public ov29_022E34B0 diff --git a/asm/include/overlay_29_023047DC.inc b/asm/include/overlay_29_023047DC.inc index c65ee832..48d1a586 100644 --- a/asm/include/overlay_29_023047DC.inc +++ b/asm/include/overlay_29_023047DC.inc @@ -17,7 +17,7 @@ .public GetTileAtEntity .public IsFloorOver .public IsWaterTileset -.public ov29_022E1A90 +.public IncrementEntityPixelPosXY .public ov29_022E8104 .public ov29_022EA370 .public ov29_022EF9BC diff --git a/asm/include/overlay_29_0231F594.inc b/asm/include/overlay_29_0231F594.inc index 594a8424..f104b7d6 100644 --- a/asm/include/overlay_29_0231F594.inc +++ b/asm/include/overlay_29_0231F594.inc @@ -16,8 +16,8 @@ .public LogMessageByIdWithPopupCheckUser .public MemAlloc .public MemFree -.public ov29_022E1A84 -.public ov29_022E1A90 +.public SetEntityPixelPosXY +.public IncrementEntityPixelPosXY .public ov29_022E56A0 .public ov29_022F62CC .public ov29_02304B64 diff --git a/asm/include/overlay_29_0231FC20.inc b/asm/include/overlay_29_0231FC20.inc index ad504c93..eeb6a08b 100644 --- a/asm/include/overlay_29_0231FC20.inc +++ b/asm/include/overlay_29_0231FC20.inc @@ -14,7 +14,7 @@ .public LogMessageByIdWithPopupCheckUserTarget .public MoveMonsterToPos .public ov10_022C4570 -.public ov29_022E1A90 +.public IncrementEntityPixelPosXY .public ov29_022E56A0 .public ov29_022F9C74 .public ov29_022FFB90 diff --git a/asm/include/overlay_29_023201A0.inc b/asm/include/overlay_29_023201A0.inc index c045f99a..f309d450 100644 --- a/asm/include/overlay_29_023201A0.inc +++ b/asm/include/overlay_29_023201A0.inc @@ -16,7 +16,7 @@ .public LogMessageByIdWithPopupCheckUser .public LogMessageByIdWithPopupCheckUserTarget .public MoveMonsterToPos -.public ov29_022E1A90 +.public IncrementEntityPixelPosXY .public ov29_022E5560 .public ov29_022E55F0 .public ov29_022E56A0 diff --git a/asm/include/overlay_29_0232A3FC.inc b/asm/include/overlay_29_0232A3FC.inc index 47828c23..f194c4b9 100644 --- a/asm/include/overlay_29_0232A3FC.inc +++ b/asm/include/overlay_29_0232A3FC.inc @@ -63,8 +63,8 @@ .public ov10_022C5DE0 .public ov10_022C6321 .public ov10_022C6322 -.public ov29_022E1A84 -.public ov29_022E1A90 +.public SetEntityPixelPosXY +.public IncrementEntityPixelPosXY .public ov29_022E2CA0 .public ov29_022ED868 .public ov29_022F8FF8 diff --git a/asm/include/overlay_29_023456BC.inc b/asm/include/overlay_29_023456BC.inc index 9b29813f..24a7443d 100644 --- a/asm/include/overlay_29_023456BC.inc +++ b/asm/include/overlay_29_023456BC.inc @@ -62,8 +62,8 @@ .public ov10_022C48EC .public ov10_022C4CD8 .public ov29_022E09E8 -.public ov29_022E1A84 -.public ov29_022E1A90 +.public SetEntityPixelPosXY +.public IncrementEntityPixelPosXY .public ov29_022E563C .public ov29_022E9488 .public ov29_022EACBC diff --git a/asm/include/overlay_29_02347BC8.inc b/asm/include/overlay_29_02347BC8.inc index d1c432ea..86404493 100644 --- a/asm/include/overlay_29_02347BC8.inc +++ b/asm/include/overlay_29_02347BC8.inc @@ -41,7 +41,7 @@ .public ov29_022E0DE4 .public ov29_022E0DFC .public ov29_022E0E44 -.public ov29_022E1A84 +.public SetEntityPixelPosXY .public ov29_022E2CA0 .public ov29_022E9488 .public ov29_022FB9BC diff --git a/asm/overlay_29_022DC2B8.s b/asm/overlay_29_022DC2B8.s index 0179d0fe..6e0a9c01 100644 --- a/asm/overlay_29_022DC2B8.s +++ b/asm/overlay_29_022DC2B8.s @@ -4164,7 +4164,7 @@ _022DF9B0: add r0, sp, #0x18 mov r1, r1, lsl #8 mov r2, r2, lsl #8 - bl ov29_022E1A84 + bl SetEntityPixelPosXY mov r3, #0 mov r0, r4 add r1, sp, #0x18 diff --git a/asm/overlay_29_023047DC.s b/asm/overlay_29_023047DC.s index ee87decd..95da371d 100644 --- a/asm/overlay_29_023047DC.s +++ b/asm/overlay_29_023047DC.s @@ -792,7 +792,7 @@ _023051C4: mov r0, r7 ldr r1, [r8, #0x10] ldr r2, [r8, #0x14] - bl ov29_022E1A90 + bl IncrementEntityPixelPosXY ldrb r0, [sb, #7] cmp r0, #0 beq _02305258 diff --git a/asm/overlay_29_0231F594.s b/asm/overlay_29_0231F594.s index 12e62a4d..a6999228 100644 --- a/asm/overlay_29_0231F594.s +++ b/asm/overlay_29_0231F594.s @@ -200,7 +200,7 @@ _0231F7A0: add r2, r2, #4 mov r1, r1, lsl #8 mov r2, r2, lsl #8 - bl ov29_022E1A84 + bl SetEntityPixelPosXY mov r1, #0 strh r1, [r5, #0x26] mov r1, #1 @@ -405,7 +405,7 @@ _0231FA9C: ldr r1, [r2, #0x2f4] ldr r2, [r2, #0x2f8] str r0, [sp, #4] - bl ov29_022E1A90 + bl IncrementEntityPixelPosXY mov r0, r8 bl sub_020018D0 mov r1, #0xc diff --git a/asm/overlay_29_0231FC20.s b/asm/overlay_29_0231FC20.s index b87daac4..861635f2 100644 --- a/asm/overlay_29_0231FC20.s +++ b/asm/overlay_29_0231FC20.s @@ -259,7 +259,7 @@ _0231FF84: ldr r1, [sp, #0x18] ldr r2, [sp, #0x1c] mov r0, sb - bl ov29_022E1A90 + bl IncrementEntityPixelPosXY mov r0, sb bl ShouldDisplayEntityWrapper cmp r0, #0 diff --git a/asm/overlay_29_023201A0.s b/asm/overlay_29_023201A0.s index 9fbfc116..7e6743f3 100644 --- a/asm/overlay_29_023201A0.s +++ b/asm/overlay_29_023201A0.s @@ -89,7 +89,7 @@ _023202C4: mov r0, sl mov r1, r6 mov r2, r7 - bl ov29_022E1A90 + bl IncrementEntityPixelPosXY mov r0, sl bl ShouldDisplayEntityWrapper cmp r0, #0 diff --git a/asm/overlay_29_0232A3FC.s b/asm/overlay_29_0232A3FC.s index b4c76a9d..bc12a947 100644 --- a/asm/overlay_29_0232A3FC.s +++ b/asm/overlay_29_0232A3FC.s @@ -418,7 +418,7 @@ ov29_0232A834: ; 0x0232A834 add r3, r3, #4 mov r1, r3, lsl #8 mov r2, r2, lsl #8 - bl ov29_022E1A84 + bl SetEntityPixelPosXY mov r0, #0 add r1, sp, #8 mov r2, r0 @@ -528,7 +528,7 @@ _0232AA28: mov r0, sb mov r1, r5 mov r2, r4 - bl ov29_022E1A90 + bl IncrementEntityPixelPosXY mov r0, fp bl AdvanceFrame add r6, r6, #1 @@ -627,7 +627,7 @@ _0232ABA0: mov r0, sb mov r1, r5 mov r2, r6 - bl ov29_022E1A90 + bl IncrementEntityPixelPosXY mov r0, r4 bl AdvanceFrame add r7, r7, #1 diff --git a/asm/overlay_29_023456BC.s b/asm/overlay_29_023456BC.s index d4300628..85c94503 100644 --- a/asm/overlay_29_023456BC.s +++ b/asm/overlay_29_023456BC.s @@ -290,7 +290,7 @@ SpawnDroppedItemWrapper: ; 0x02345A3C add r3, r3, #4 mov r1, r3, lsl #8 mov r2, r2, lsl #8 - bl ov29_022E1A84 + bl SetEntityPixelPosXY mov r0, #0 strh r0, [sp, #0x2e] str r0, [sp] @@ -595,7 +595,7 @@ _02345E90: mov r1, r7 mov r2, r8 str r5, [sl, #0x1c] - bl ov29_022E1A84 + bl SetEntityPixelPosXY mov r6, #0 _02345EE0: sub r5, r5, #0x800 @@ -614,7 +614,7 @@ _02345EE0: mov r0, sl mov r1, r7 mov r2, r8 - bl ov29_022E1A84 + bl SetEntityPixelPosXY mov r2, #0 str r2, [sl, #0x1c] mov r0, sl @@ -1057,7 +1057,7 @@ _023464C4: add r2, r2, #4 mov r1, r1, lsl #8 mov r2, r2, lsl #8 - bl ov29_022E1A84 + bl SetEntityPixelPosXY mov r0, #0 strh r0, [r6, #0x26] mov r0, r8, lsl #2 @@ -1156,7 +1156,7 @@ _0234665C: ldr r1, [r1, r8, lsl #3] ldr r2, [r2, #4] str r0, [sp, #0xc] - bl ov29_022E1A90 + bl IncrementEntityPixelPosXY mov r0, fp bl sub_020018D0 mov r1, #0xc @@ -2368,7 +2368,7 @@ _023474CC: mov r0, sl mov r1, r8 mov r2, sb - bl ov29_022E1A84 + bl SetEntityPixelPosXY mov r5, #0 str r5, [sl, #0x1c] cmp r4, #0 @@ -2439,7 +2439,7 @@ ov29_02347518: ; 0x02347518 add r1, r3, #4 mov r1, r1, lsl #8 mov r2, r2, lsl #8 - bl ov29_022E1A84 + bl SetEntityPixelPosXY #ifdef JAPAN mov r0, #0 #else @@ -2623,7 +2623,7 @@ _02347750: #else mov r2, fp #endif - bl ov29_022E1A90 + bl IncrementEntityPixelPosXY bl IsWaterTileset cmp r0, #0 ldr r0, [r4, #0xd8] diff --git a/asm/overlay_29_02347BC8.s b/asm/overlay_29_02347BC8.s index ec7a85e1..cc166bee 100644 --- a/asm/overlay_29_02347BC8.s +++ b/asm/overlay_29_02347BC8.s @@ -44,7 +44,7 @@ ov29_02347BC8: ; 0x02347BC8 add r3, r3, #4 mov r1, r3, lsl #8 mov r2, r2, lsl #8 - bl ov29_022E1A84 + bl SetEntityPixelPosXY mov r0, r5 str r0, [sp, #0x2c] strh r0, [r4, #0xf2] @@ -137,7 +137,7 @@ _02347D84: add r8, r8, r0 add r0, r4, #0xcc mov fp, r6, asr #8 - bl ov29_022E1A84 + bl SetEntityPixelPosXY bl IsWaterTileset cmp r0, #0 ldr r1, [sp, #0x34] diff --git a/include/dg_object.h b/include/dg_object.h index cf59b0ef..4357aa21 100644 --- a/include/dg_object.h +++ b/include/dg_object.h @@ -8,7 +8,7 @@ // return: bool u8 EntityIsValid__022E1A1C(struct entity *entity); void UpdateEntityPixelPos(struct entity *entity, struct pixel_position *pixel_pos); -void ov29_022E1A84(struct entity *entity, u32 x, u32 y); -void ov29_022E1A84(struct entity *entity, u32 x, u32 y); +void SetEntityPixelPosXY(struct entity *entity, u32 x, u32 y); +void IncrementEntityPixelPosXY(struct entity *entity, u32 x, u32 y); #endif //PMDSKY_OVERLAY_29_022E1A1C_H diff --git a/src/dg_object.c b/src/dg_object.c index 06f7951c..7b51e01f 100644 --- a/src/dg_object.c +++ b/src/dg_object.c @@ -23,13 +23,13 @@ void UpdateEntityPixelPos(struct entity *entity, struct pixel_position *pixel_po } } -void ov29_022E1A84(struct entity *entity, u32 x, u32 y) +void SetEntityPixelPosXY(struct entity *entity, u32 x, u32 y) { entity->pixel_pos.x = x; entity->pixel_pos.y = y; } -void ov29_022E1A84(struct entity *entity, u32 x, u32 y) +void IncrementEntityPixelPosXY(struct entity *entity, u32 x, u32 y) { entity->pixel_pos.x += x; entity->pixel_pos.y += y;