Skip to content

Commit

Permalink
Improve EUR address handling
Browse files Browse the repository at this point in the history
- Combine linker scripts
- Use macro for game addresses in C code
  • Loading branch information
Kewlan committed Apr 27, 2024
1 parent 01793f2 commit 4941685
Show file tree
Hide file tree
Showing 90 changed files with 381 additions and 2,229 deletions.
7 changes: 3 additions & 4 deletions code/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -55,21 +55,21 @@ CFLAGS += $(INCLUDE) -DARM11 -D_3DS $(VERFLAGS)

CXXFLAGS := $(CFLAGS) -fno-rtti -fno-exceptions -std=gnu++11

LDFLAGS = -g $(ARCH) -Wl,-Map,$(notdir $*.map) -T $(TOPDIR)/oot.ld $(VERFLAGS) -lgcc

ifeq ($(USA), $(REGION))
LINK_SCRIPT := oot.ld
ASFLAGS += -D _USA_=1 -D _EUR_=0 -D _JP_=0
CFLAGS += -g -DVersion_USA
BUILD := build_usa
TARGET := code_usa
else
ifeq ($(EUR), $(REGION))
LINK_SCRIPT := oot_e.ld
LDFLAGS += -Wl,--defsym,_EUR_=1
ASFLAGS += -D _USA_=0 -D _EUR_=1 -D _JP_=0
CFLAGS += -g -DVersion_EUR
BUILD := build_eur
TARGET := code_eur
ifeq ($(JP), $(REGION))
LINK_SCRIPT := oot_j.ld
ASFLAGS += -D _USA_=0 -D _EUR_=0 -D _JP_=1
CFLAGS += -g -DVersion_JP
BUILD := build_jp
Expand All @@ -79,7 +79,6 @@ endif
endif

ASFLAGS += -g $(ARCH) $(VERFLAGS)
LDFLAGS = -g $(ARCH) -Wl,-Map,$(notdir $*.map) -T $(TOPDIR)/$(LINK_SCRIPT) $(VERFLAGS) -lgcc

LIBS := -lgcc

Expand Down
133 changes: 55 additions & 78 deletions code/include/z3D/z3D.h
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,21 @@

// #include "hid.h"

#ifdef Version_EUR
#define GAME_ADDR(addr) \
({ \
int finalAddr = (addr); \
if (addr >= 0x41A144 && addr <= 0x43668B) { \
finalAddr += 0x24; \
} else if (addr >= 0x436690 && addr <= 0x4A5ADF) { \
finalAddr += 0x20; \
} \
finalAddr; \
})
#else
#define GAME_ADDR(addr) (addr)
#endif

#define TRUE 1
#define FALSE 0

Expand Down Expand Up @@ -746,170 +761,132 @@ typedef enum {
#define Z3D_BOTTOM_SCREEN_2 0x143D86C0

typedef void (*Item_Give_proc)(GlobalContext* globalCtx, u8 item);
#define Item_Give_addr 0x376A78
#define Item_Give ((Item_Give_proc)Item_Give_addr)
#define Item_Give ((Item_Give_proc)GAME_ADDR(0x376A78))

typedef void (*DisplayTextbox_proc)(GlobalContext* globalCtx, u16 textId, Actor* actor);
#define DisplayTextbox_addr 0x367C7C
#define DisplayTextbox ((DisplayTextbox_proc)DisplayTextbox_addr)
#define DisplayTextbox ((DisplayTextbox_proc)GAME_ADDR(0x367C7C))

typedef u32 (*EventCheck_proc)(u32 flag);
#define EventCheck_addr 0x350CF4
#define EventCheck ((EventCheck_proc)EventCheck_addr)
#define EventCheck ((EventCheck_proc)GAME_ADDR(0x350CF4))

typedef void (*EventSet_proc)(u32 flag);
#define EventSet_addr 0x34CBF8
#define EventSet ((EventSet_proc)EventSet_addr)
#define EventSet ((EventSet_proc)GAME_ADDR(0x34CBF8))

typedef void (*Rupees_ChangeBy_proc)(s16 rupeeChange);
#define Rupees_ChangeBy_addr 0x376A60
#define Rupees_ChangeBy ((Rupees_ChangeBy_proc)Rupees_ChangeBy_addr)
#define Rupees_ChangeBy ((Rupees_ChangeBy_proc)GAME_ADDR(0x376A60))

typedef void (*LinkDamage_proc)(GlobalContext* globalCtx, Player* player, s32 arg2, f32 arg3, f32 arg4, s16 arg5,
s32 arg6);
#define LinkDamage_addr 0x35D304
#define LinkDamage ((LinkDamage_proc)LinkDamage_addr)
#define LinkDamage ((LinkDamage_proc)GAME_ADDR(0x35D304))

typedef u32 (*Inventory_HasEmptyBottle_proc)(void);
#define Inventory_HasEmptyBottle_addr 0x377A04
#define Inventory_HasEmptyBottle ((Inventory_HasEmptyBottle_proc)Inventory_HasEmptyBottle_addr)
#define Inventory_HasEmptyBottle ((Inventory_HasEmptyBottle_proc)GAME_ADDR(0x377A04))

typedef void (*PlaySound_proc)(u32);
#define PlaySound_addr 0x35C528
// This function plays sound effects and music tracks, overlaid on top of the current BGM
#define PlaySound ((PlaySound_proc)PlaySound_addr)
#define PlaySound ((PlaySound_proc)GAME_ADDR(0x35C528))

typedef Actor* (*Actor_Spawn_proc)(ActorContext* actorCtx, GlobalContext* globalCtx, s16 actorId, float posX,
float posY, float posZ, s16 rotX, s16 rotY, s16 rotZ, s16 params,
s32 initImmediately) __attribute__((pcs("aapcs-vfp")));
#define Actor_Spawn_addr 0x3738D0
#define Actor_Spawn ((Actor_Spawn_proc)Actor_Spawn_addr)
#define Actor_Spawn ((Actor_Spawn_proc)GAME_ADDR(0x3738D0))

typedef Actor* (*Actor_Find_proc)(ActorContext* actorCtx, s16 actorId, u8 actorType);
#define Actor_Find_addr 0x372D64
#define Actor_Find ((Actor_Find_proc)Actor_Find_addr)
#define Actor_Find ((Actor_Find_proc)GAME_ADDR(0x372D64))

typedef void (*Actor_GetScreenPos_proc)(GlobalContext* globalCtx, Actor* actor, s16* outX, s16* outY);
#define Actor_GetScreenPos_addr 0x363A20
#define Actor_GetScreenPos ((Actor_GetScreenPos_proc)Actor_GetScreenPos_addr)
#define Actor_GetScreenPos ((Actor_GetScreenPos_proc)GAME_ADDR(0x363A20))

typedef void (*FireDamage_proc)(Actor* player, GlobalContext* globalCtx, int flamesColor);
#define FireDamage_addr 0x35D8D8
#define FireDamage ((FireDamage_proc)FireDamage_addr)
#define FireDamage ((FireDamage_proc)GAME_ADDR(0x35D8D8))

typedef void (*Flags_SetEnv_proc)(GlobalContext* globalCtx, s16 flag);
#define Flags_SetEnv_addr 0x366704
#define Flags_SetEnv ((Flags_SetEnv_proc)Flags_SetEnv_addr)
#define Flags_SetEnv ((Flags_SetEnv_proc)GAME_ADDR(0x366704))

typedef void (*GiveItem_proc)(Actor* actor, GlobalContext* globalCtx, s32 getItemId, f32 xzRange, f32 yRange)
__attribute__((pcs("aapcs-vfp")));
#define GiveItem_addr 0x3724DC
#define GiveItem ((GiveItem_proc)GiveItem_addr)
#define GiveItem ((GiveItem_proc)GAME_ADDR(0x3724DC))

typedef void (*Message_CloseTextbox_proc)(GlobalContext* globalCtx);
#define Message_CloseTextbox_addr 0x3725E0
#define Message_CloseTextbox ((Message_CloseTextbox_proc)Message_CloseTextbox_addr)
#define Message_CloseTextbox ((Message_CloseTextbox_proc)GAME_ADDR(0x3725E0))

typedef void (*SetupItemInWater_proc)(Player* player, GlobalContext* globalCtx);
#define SetupItemInWater_addr 0x354894
#define SetupItemInWater ((SetupItemInWater_proc)SetupItemInWater_addr)
#define SetupItemInWater ((SetupItemInWater_proc)GAME_ADDR(0x354894))

typedef void (*Health_ChangeBy_proc)(GlobalContext* arg1, u32 arg2);
#define Health_ChangeBy_addr 0x352DBC
#define Health_ChangeBy ((Health_ChangeBy_proc)Health_ChangeBy_addr)
#define Health_ChangeBy ((Health_ChangeBy_proc)GAME_ADDR(0x352DBC))

typedef void (*PlaySFX_proc)(u32 sfxId, Vec3f* pos, u32 token, f32* freqScale, f32* a4, s8* reverbAdd);
#define PlaySFX_addr 0x37547C
#define PlaySFX ((PlaySFX_proc)PlaySFX_addr)
#define PlaySFX ((PlaySFX_proc)GAME_ADDR(0x37547C))

typedef void (*Flags_SetSwitch_proc)(GlobalContext* globalCtx, u32 flag);
#define Flags_SetSwitch_addr 0x375C10
#define Flags_SetSwitch ((Flags_SetSwitch_proc)Flags_SetSwitch_addr)
#define Flags_SetSwitch ((Flags_SetSwitch_proc)GAME_ADDR(0x375C10))

typedef u32 (*Flags_GetSwitch_proc)(GlobalContext* globalCtx, u32 flag);
#define Flags_GetSwitch_addr 0x36E864
#define Flags_GetSwitch ((Flags_GetSwitch_proc)Flags_GetSwitch_addr)
#define Flags_GetSwitch ((Flags_GetSwitch_proc)GAME_ADDR(0x36E864))

typedef u32 (*Flags_GetCollectible_proc)(GlobalContext* globalCtx, u32 flag);
#define Flags_GetCollectible_addr 0x36405C
#define Flags_GetCollectible ((Flags_GetCollectible_proc)Flags_GetCollectible_addr)
#define Flags_GetCollectible ((Flags_GetCollectible_proc)GAME_ADDR(0x36405C))

typedef void (*Player_SetEquipmentData_proc)(GlobalContext* globalCtx, Player* player);
#define Player_SetEquipmentData_addr 0x34913C
#define Player_SetEquipmentData ((Player_SetEquipmentData_proc)Player_SetEquipmentData_addr)
#define Player_SetEquipmentData ((Player_SetEquipmentData_proc)GAME_ADDR(0x34913C))

typedef s32 (*BossChallenge_IsActive_proc)(void);
#define BossChallenge_IsActive_addr 0x35B164
#define BossChallenge_IsActive ((BossChallenge_IsActive_proc)BossChallenge_IsActive_addr)
#define BossChallenge_IsActive ((BossChallenge_IsActive_proc)GAME_ADDR(0x35B164))

typedef s32 (*Audio_PlayActorSfx2_proc)(Actor* actor, s32 sfxID);
#define Audio_PlayActorSfx2_addr 0x375BCC
#define Audio_PlayActorSfx2 ((Audio_PlayActorSfx2_proc)Audio_PlayActorSfx2_addr)
#define Audio_PlayActorSfx2 ((Audio_PlayActorSfx2_proc)GAME_ADDR(0x375BCC))

typedef s32 (*Model_GetMeshGroupCount_proc)(SkeletonAnimationModel* skelAnimeModel);
#define Model_GetMeshGroupCount ((Model_GetMeshGroupCount_proc)0x2BB71C)
#define Model_GetMeshGroupCount ((Model_GetMeshGroupCount_proc)GAME_ADDR(0x2BB71C))

typedef s32 (*Model_IsMeshGroupUsed_proc)(SkeletonAnimationModel* skelAnimeModel, s32 param);
#define Model_IsMeshGroupUsed ((Model_IsMeshGroupUsed_proc)0x4C6880)
#define Model_IsMeshGroupUsed ((Model_IsMeshGroupUsed_proc)GAME_ADDR(0x4C6880))

typedef void (*Model_EnableMeshGroupByIndex_proc)(SkeletonAnimationModel* skel, u32 index);
#define Model_EnableMeshGroupByIndex ((Model_EnableMeshGroupByIndex_proc)0x37266C)
#define Model_EnableMeshGroupByIndex ((Model_EnableMeshGroupByIndex_proc)GAME_ADDR(0x37266C))

typedef void (*Model_DisableMeshGroupByIndex_proc)(SkeletonAnimationModel* skel, u32 index);
#define Model_DisableMeshGroupByIndex ((Model_DisableMeshGroupByIndex_proc)0x36932C)
#define Model_DisableMeshGroupByIndex ((Model_DisableMeshGroupByIndex_proc)GAME_ADDR(0x36932C))

typedef s32 (*Player_InBlockingCsMode_proc)(GlobalContext* globalCtx, Player* player);
#define Player_InBlockingCsMode ((Player_InBlockingCsMode_proc)0x35DB20)
#define Player_InBlockingCsMode ((Player_InBlockingCsMode_proc)GAME_ADDR(0x35DB20))

typedef u32 (*PauseContext_GetState_proc)(void);
#define PauseContext_GetState ((PauseContext_GetState_proc)0x3695F8)
#define PauseContext_GetState ((PauseContext_GetState_proc)GAME_ADDR(0x3695F8))

typedef s32 (*Camera_CheckWater_proc)(Camera* camera);
#define Camera_CheckWater ((Camera_CheckWater_proc)0x2D06A0)
#define Camera_CheckWater ((Camera_CheckWater_proc)GAME_ADDR(0x2D06A0))

typedef void (*Camera_UpdateInterface_proc)(u32 flags);
#define Camera_UpdateInterface ((Camera_UpdateInterface_proc)0x330D84)
#define Camera_UpdateInterface ((Camera_UpdateInterface_proc)GAME_ADDR(0x330D84))

typedef f32 (*Camera_BGCheckInfo_proc)(Camera* camera, Vec3f* from, CamColChk* to);
#define Camera_BGCheckInfo ((Camera_BGCheckInfo_proc)0x3553FC)
#define Camera_BGCheckInfo ((Camera_BGCheckInfo_proc)GAME_ADDR(0x3553FC))

typedef s32 (*Quake_Update_proc)(Camera* camera, ShakeInfo* camShake);
#ifdef Version_EUR
#define Quake_Update_addr 0x4787E8
#else
#define Quake_Update_addr 0x4787C8
#endif
#define Quake_Update ((Quake_Update_proc)Quake_Update_addr)
#define Quake_Update ((Quake_Update_proc)GAME_ADDR(0x4787C8))

typedef s16 (*Camera_GetCamDataId_proc)(CollisionContext* colCtx, CollisionPoly* poly, s32 bgId);
#ifdef Version_EUR
#define Camera_GetCamDataId_addr 0x47BFF8
#else
#define Camera_GetCamDataId_addr 0x47BFD8
#endif
#define Camera_GetCamDataId ((Camera_GetCamDataId_proc)Camera_GetCamDataId_addr)
#define Camera_GetCamDataId ((Camera_GetCamDataId_proc)GAME_ADDR(0x47BFD8))

typedef s32 (*Animation_GetLastFrame_proc)(SkelAnime* anime, s32 animation_index);
#define Animation_GetLastFrame_addr 0x36AE14
#define Animation_GetLastFrame ((Animation_GetLastFrame_proc)Animation_GetLastFrame_addr)
#define Animation_GetLastFrame ((Animation_GetLastFrame_proc)GAME_ADDR(0x36AE14))

typedef void (*Animation_Change_proc)(SkelAnime* anime, s32 animation_index, f32 play_speed, f32 start_frame,
f32 end_frame, f32 morph_frames, s32 mode) __attribute__((pcs("aapcs-vfp")));
#define Animation_Change_addr 0x375C08
#define Animation_Change ((Animation_Change_proc)Animation_Change_addr)
#define Animation_Change ((Animation_Change_proc)GAME_ADDR(0x375C08))

typedef void (*EffectSsDeadDb_Spawn_proc)(GlobalContext* globalCtx, Vec3f* position, Vec3f* velocity,
Vec3f* acceleration, s16 scale, s16 scale_step, s16 prim_r, s16 prim_g,
s16 prim_b, s16 prim_a, s16 env_r, s16 env_g, s16 env_b, s16 unused,
s32 frame_duration, s16 play_sound);
#define EffectSsDeadDb_Spawn_addr 0x3642F4
#define EffectSsDeadDb_Spawn ((EffectSsDeadDb_Spawn_proc)EffectSsDeadDb_Spawn_addr)
#define EffectSsDeadDb_Spawn ((EffectSsDeadDb_Spawn_proc)GAME_ADDR(0x3642F4))

typedef void (*SaveGame_proc)(GlobalContext* globalCtx, u8 isSaveFileCreation);
#define SaveGame_addr 0x2FDAC8
#define SaveGame ((SaveGame_proc)SaveGame_addr)
#define SaveGame ((SaveGame_proc)GAME_ADDR(0x2FDAC8))

typedef s32 (*Message_GetState_proc)(void);
#define Message_GetState ((Message_GetState_proc)0x3769d8)
#define Message_GetState ((Message_GetState_proc)GAME_ADDR(0x3769d8))

#endif //_Z3D_H_
11 changes: 5 additions & 6 deletions code/include/z3D/z3Dactor.h
Original file line number Diff line number Diff line change
Expand Up @@ -336,23 +336,22 @@ void Actor_Kill(Actor* actor);
#define gActorOverlayTable ((ActorOverlay*)0x50CD84)

typedef u32 (*Actor_HasParent_proc)(Actor* actor, struct GlobalContext* globalCtx);
#define Actor_HasParent_addr 0x371E40
#define Actor_HasParent ((Actor_HasParent_proc)Actor_HasParent_addr)
#define Actor_HasParent ((Actor_HasParent_proc)GAME_ADDR(0x371E40))

typedef f32 (*Actor_WorldDistXYZToActor_proc)(Actor* a, Actor* b) __attribute__((pcs("aapcs-vfp")));
#define Actor_WorldDistXYZToActor ((Actor_WorldDistXYZToActor_proc)0x3306C4)
#define Actor_WorldDistXYZToActor ((Actor_WorldDistXYZToActor_proc)GAME_ADDR(0x3306C4))

typedef void (*ActorShape_Init_proc)(ActorShape* shape, f32 yOffset, void* shadowDrawFunc, f32 shadowScale)
__attribute__((pcs("aapcs-vfp")));
#define ActorShape_Init ((ActorShape_Init_proc)0x372D4C)
#define ActorShape_Init ((ActorShape_Init_proc)GAME_ADDR(0x372D4C))

typedef void (*Actor_SetFeetPos_proc)(Actor* actor, nn_math_MTX34* mtx, int param_3, int param_4, Vec3f* param_5,
int param_6, Vec3f* param_7);
#define Actor_SetFeetPos ((Actor_SetFeetPos_proc)0x34CBB4)
#define Actor_SetFeetPos ((Actor_SetFeetPos_proc)GAME_ADDR(0x34CBB4))

typedef void (*Actor_UpdateBgCheckInfo_proc)(struct GlobalContext* globalCtx, Actor* actor, f32 wallCheckHeight,
f32 wallCheckRadius, f32 ceilingCheckHeight, s32 flags)
__attribute__((pcs("aapcs-vfp")));
#define Actor_UpdateBgCheckInfo ((Actor_UpdateBgCheckInfo_proc)0x376340)
#define Actor_UpdateBgCheckInfo ((Actor_UpdateBgCheckInfo_proc)GAME_ADDR(0x376340))

#endif
10 changes: 5 additions & 5 deletions code/include/z3D/z3Dcollision_check.h
Original file line number Diff line number Diff line change
Expand Up @@ -99,21 +99,21 @@ typedef struct {
_Static_assert(sizeof(ColliderCylinderInit) == 0x38, "ColliderCylinderInit size");

typedef void (*Collider_InitCylinder_proc)(struct GlobalContext* globalCtx, ColliderCylinder* collider);
#define Collider_InitCylinder ((Collider_InitCylinder_proc)0x353DD0)
#define Collider_InitCylinder ((Collider_InitCylinder_proc)GAME_ADDR(0x353DD0))

typedef void (*Collider_SetCylinder_proc)(struct GlobalContext* globalCtx, ColliderCylinder* collider,
struct Actor* actor, void* cylinderInitData);
#define Collider_SetCylinder ((Collider_SetCylinder_proc)0x353D24)
#define Collider_SetCylinder ((Collider_SetCylinder_proc)GAME_ADDR(0x353D24))

typedef void (*Collider_UpdateCylinder_proc)(struct Actor* actor, ColliderCylinder* collider);
#define Collider_UpdateCylinder ((Collider_UpdateCylinder_proc)0x37632C)
#define Collider_UpdateCylinder ((Collider_UpdateCylinder_proc)GAME_ADDR(0x37632C))

typedef void (*CollisionCheck_SetOC_proc)(struct GlobalContext* globalCtx, struct CollisionCheckContext* colChkCtx,
void* collider);
#define CollisionCheck_SetOC ((CollisionCheck_SetOC_proc)0x3762A4)
#define CollisionCheck_SetOC ((CollisionCheck_SetOC_proc)GAME_ADDR(0x3762A4))

typedef void (*CollisionCheck_SetAC_proc)(struct GlobalContext* globalCtx, struct CollisionCheckContext* colChkCtx,
void* collider);
#define CollisionCheck_SetAC ((CollisionCheck_SetAC_proc)0x376168)
#define CollisionCheck_SetAC ((CollisionCheck_SetAC_proc)GAME_ADDR(0x376168))

#endif //_Z3DCOLLISION_CHECK_H_
10 changes: 4 additions & 6 deletions code/include/z3D/z3Dmath.h
Original file line number Diff line number Diff line change
Expand Up @@ -2,19 +2,17 @@
#define _Z3DMATH_H_

typedef f32 (*Math_SinS_proc)(s16 angle) __attribute__((pcs("aapcs-vfp")));
#define Math_SinS ((Math_SinS_proc)0x2CFCA0)
#define Math_SinS ((Math_SinS_proc)GAME_ADDR(0x2CFCA0))

typedef f32 (*Math_CosS_proc)(s16 angle) __attribute__((pcs("aapcs-vfp")));
#define Math_CosS ((Math_CosS_proc)0x338F60)
#define Math_CosS ((Math_CosS_proc)GAME_ADDR(0x338F60))

typedef void (*Matrix_Multiply_proc)(nn_math_MTX34* dst, nn_math_MTX34* lhs, nn_math_MTX44* rhs)
__attribute__((pcs("aapcs-vfp")));
#define Matrix_Multiply_addr 0x36C174
#define Matrix_Multiply ((Matrix_Multiply_proc)Matrix_Multiply_addr)
#define Matrix_Multiply ((Matrix_Multiply_proc)GAME_ADDR(0x36C174))

typedef void (*Matrix_UpdatePosition_proc)(nn_math_MTX34* dst, nn_math_MTX34* src, Vec3f* vec)
__attribute__((pcs("aapcs-vfp")));
#define Matrix_UpdatePosition_addr 0x372070
#define Matrix_UpdatePosition ((Matrix_UpdatePosition_proc)Matrix_UpdatePosition_addr)
#define Matrix_UpdatePosition ((Matrix_UpdatePosition_proc)GAME_ADDR(0x372070))

#endif
Loading

0 comments on commit 4941685

Please sign in to comment.