mirror of
https://github.com/Ninjdai1/pokeemerald.git
synced 2024-11-16 11:37:40 +01:00
move ram save variables to C
This commit is contained in:
parent
a3f602f17c
commit
ddf85539c1
150
asm/save.s
150
asm/save.s
@ -6,156 +6,6 @@
|
||||
.text
|
||||
|
||||
|
||||
|
||||
thumb_func_start sub_815355C
|
||||
sub_815355C: @ 815355C
|
||||
push {r4-r7,lr}
|
||||
ldr r5, =gFastSaveSection
|
||||
ldr r0, =gUnknown_0203ABBC
|
||||
str r0, [r5]
|
||||
adds r7, r0, 0
|
||||
ldr r0, =gFlashMemoryPresent
|
||||
ldr r4, [r0]
|
||||
cmp r4, 0x1
|
||||
beq _0815358C
|
||||
b _081535C8
|
||||
.pool
|
||||
_0815357C:
|
||||
ldrb r1, [r7, 0xA]
|
||||
ldrb r0, [r7, 0xB]
|
||||
adds r1, r0
|
||||
ldrb r0, [r7, 0xC]
|
||||
adds r1, r0
|
||||
ldrb r0, [r7, 0xD]
|
||||
adds r0, r1
|
||||
b _081535CA
|
||||
_0815358C:
|
||||
bl UpdateSaveAddresses
|
||||
ldr r0, =gRamSaveSectionLocations
|
||||
bl GetSaveValidStatus
|
||||
ldr r0, =gSaveCounter
|
||||
ldr r1, [r0]
|
||||
ands r1, r4
|
||||
lsls r0, r1, 3
|
||||
subs r0, r1
|
||||
lsls r0, 17
|
||||
lsrs r6, r0, 16
|
||||
movs r4, 0
|
||||
_081535A6:
|
||||
adds r0, r4, r6
|
||||
lsls r0, 24
|
||||
lsrs r0, 24
|
||||
ldr r1, [r5]
|
||||
bl DoReadFlashWholeSection
|
||||
ldr r0, [r5]
|
||||
ldr r1, =0x00000ff4
|
||||
adds r0, r1
|
||||
ldrh r0, [r0]
|
||||
cmp r0, 0
|
||||
beq _0815357C
|
||||
adds r0, r4, 0x1
|
||||
lsls r0, 16
|
||||
lsrs r4, r0, 16
|
||||
cmp r4, 0xD
|
||||
bls _081535A6
|
||||
_081535C8:
|
||||
movs r0, 0
|
||||
_081535CA:
|
||||
pop {r4-r7}
|
||||
pop {r1}
|
||||
bx r1
|
||||
.pool
|
||||
thumb_func_end sub_815355C
|
||||
|
||||
thumb_func_start sub_81535DC
|
||||
sub_81535DC: @ 81535DC
|
||||
push {r4-r6,lr}
|
||||
adds r6, r1, 0
|
||||
lsls r0, 24
|
||||
lsrs r1, r0, 24
|
||||
movs r2, 0xE2
|
||||
lsls r2, 24
|
||||
adds r0, r2
|
||||
lsrs r0, 24
|
||||
cmp r0, 0x1
|
||||
bhi _08153608
|
||||
ldr r4, =gUnknown_0203ABBC
|
||||
movs r3, 0x80
|
||||
lsls r3, 5
|
||||
adds r0, r1, 0
|
||||
movs r1, 0
|
||||
adds r2, r4, 0
|
||||
bl ReadFlash
|
||||
ldr r1, [r4]
|
||||
ldr r0, =0x0000b39d
|
||||
cmp r1, r0
|
||||
beq _08153614
|
||||
_08153608:
|
||||
movs r0, 0xFF
|
||||
b _0815362A
|
||||
.pool
|
||||
_08153614:
|
||||
movs r3, 0
|
||||
ldr r5, =0x00000ffb
|
||||
adds r2, r4, 0x4
|
||||
_0815361A:
|
||||
adds r0, r6, r3
|
||||
adds r1, r2, r3
|
||||
ldrb r1, [r1]
|
||||
strb r1, [r0]
|
||||
adds r3, 0x1
|
||||
cmp r3, r5
|
||||
ble _0815361A
|
||||
movs r0, 0x1
|
||||
_0815362A:
|
||||
pop {r4-r6}
|
||||
pop {r1}
|
||||
bx r1
|
||||
.pool
|
||||
thumb_func_end sub_81535DC
|
||||
|
||||
thumb_func_start sub_8153634
|
||||
sub_8153634: @ 8153634
|
||||
push {r4-r7,lr}
|
||||
adds r5, r1, 0
|
||||
lsls r0, 24
|
||||
lsrs r6, r0, 24
|
||||
movs r1, 0xE2
|
||||
lsls r1, 24
|
||||
adds r0, r1
|
||||
lsrs r0, 24
|
||||
cmp r0, 0x1
|
||||
bhi _08153680
|
||||
ldr r7, =gUnknown_0203ABBC
|
||||
ldr r0, =0x0000b39d
|
||||
adds r3, r7, 0
|
||||
stm r3!, {r0}
|
||||
movs r2, 0
|
||||
ldr r4, =0x00000ffb
|
||||
_08153654:
|
||||
adds r0, r3, r2
|
||||
adds r1, r5, r2
|
||||
ldrb r1, [r1]
|
||||
strb r1, [r0]
|
||||
adds r2, 0x1
|
||||
cmp r2, r4
|
||||
ble _08153654
|
||||
adds r0, r6, 0
|
||||
adds r1, r7, 0
|
||||
bl ProgramFlashSectorAndVerify
|
||||
cmp r0, 0
|
||||
bne _08153680
|
||||
movs r0, 0x1
|
||||
b _08153682
|
||||
.pool
|
||||
_08153680:
|
||||
movs r0, 0xFF
|
||||
_08153682:
|
||||
pop {r4-r7}
|
||||
pop {r1}
|
||||
bx r1
|
||||
thumb_func_end sub_8153634
|
||||
|
||||
thumb_func_start sub_8153688
|
||||
sub_8153688: @ 8153688
|
||||
push {r4,lr}
|
||||
|
@ -594,7 +594,7 @@ sub_8179514: @ 8179514
|
||||
push {r4,lr}
|
||||
lsls r0, 16
|
||||
lsrs r0, 16
|
||||
ldr r4, =gUnknown_0203ABBC
|
||||
ldr r4, =gSaveDataBuffer
|
||||
movs r3, 0x80
|
||||
lsls r3, 5
|
||||
movs r1, 0
|
||||
|
10
common_syms/save.txt
Normal file
10
common_syms/save.txt
Normal file
@ -0,0 +1,10 @@
|
||||
gLastWrittenSector
|
||||
gLastSaveCounter
|
||||
gLastKnownGoodSector
|
||||
gDamagedSaveSectors
|
||||
gSaveCounter
|
||||
gFastSaveSection
|
||||
gUnknown_03006208
|
||||
gSaveUnusedVar
|
||||
gUnknown_03006210
|
||||
gGameContinueCallback
|
@ -89,4 +89,4 @@ u16 CalculateChecksum(void *, u16);
|
||||
//u8 unref_sub_8126068(u8 sector, u8 *data, u32 size);
|
||||
//u8 unref_sub_8126080(u8 sector, u8 *data);
|
||||
|
||||
#endif
|
||||
#endif // GUARD_SAVE_H
|
||||
|
131
src/save.c
131
src/save.c
@ -3,17 +3,31 @@
|
||||
#include "save.h"
|
||||
#include "game_stat.h"
|
||||
|
||||
extern u32 gSaveCounter;
|
||||
extern u16 gLastWrittenSector;
|
||||
extern u32 gDamagedSaveSectors;
|
||||
extern u16 gLastKnownGoodSector;
|
||||
extern u32 gLastSaveCounter;
|
||||
extern u16 gUnknown_03006208;
|
||||
extern struct SaveSection *gFastSaveSection;
|
||||
extern struct SaveSection *gUnknown_0203ABBC;
|
||||
extern struct SaveSectionOffsets gSaveSectionOffsets[0xE];
|
||||
extern struct SaveSectionLocation gRamSaveSectionLocations[0xE];
|
||||
extern void *gUnknown_03005D94;
|
||||
extern u8 gDecompressionBuffer[];
|
||||
extern u32 gFlashMemoryPresent;
|
||||
extern u16 gUnknown_03006294;
|
||||
|
||||
bool32 ProgramFlashSectorAndVerify(u8 sector, u8 *data);
|
||||
void ReadFlash(u8 secotr, u32 arg1, u8* data, u32 size);
|
||||
extern void DoSaveFailedScreen(u8); // save_failed_screen
|
||||
extern void LoadSerializedGame(void); // load_save
|
||||
extern bool32 ProgramFlashSectorAndVerify(u8 sector, u8 *data);
|
||||
extern void ReadFlash(u8 sector, u32 arg1, void* data, u32 size);
|
||||
|
||||
// iwram common
|
||||
u16 gLastWrittenSector;
|
||||
u32 gLastSaveCounter;
|
||||
u16 gLastKnownGoodSector;
|
||||
u32 gDamagedSaveSectors;
|
||||
u32 gSaveCounter;
|
||||
struct SaveSection *gFastSaveSection;
|
||||
u16 gUnknown_03006208;
|
||||
u16 gSaveUnusedVar;
|
||||
u16 gUnknown_03006210;
|
||||
void (*gGameContinueCallback)(void);
|
||||
|
||||
EWRAM_DATA struct SaveSection gSaveDataBuffer = {0};
|
||||
|
||||
void ClearSaveData(void)
|
||||
{
|
||||
@ -59,7 +73,7 @@ u8 save_write_to_flash(u16 a1, const struct SaveSectionLocation *location)
|
||||
u32 retVal;
|
||||
u16 i;
|
||||
|
||||
gFastSaveSection = (struct SaveSection *)&gUnknown_0203ABBC;
|
||||
gFastSaveSection = &gSaveDataBuffer;
|
||||
|
||||
if (a1 != 0xFFFF) // for link
|
||||
{
|
||||
@ -120,7 +134,7 @@ u8 HandleWriteSector(u16 a1, const struct SaveSectionLocation *location)
|
||||
u8 HandleWriteSectorNBytes(u8 sector, u8 *data, u16 size)
|
||||
{
|
||||
u16 i;
|
||||
struct SaveSection *section = (struct SaveSection *)&gUnknown_0203ABBC;
|
||||
struct SaveSection *section = &gSaveDataBuffer;
|
||||
|
||||
for (i = 0; i < sizeof(struct SaveSection); i++)
|
||||
((char *)section)[i] = 0;
|
||||
@ -150,7 +164,7 @@ u8 TryWriteSector(u8 sector, u8 *data)
|
||||
|
||||
u32 RestoreSaveBackupVarsAndIncrement(const struct SaveSectionLocation *location) // location is unused
|
||||
{
|
||||
gFastSaveSection = (struct SaveSection *)&gUnknown_0203ABBC;
|
||||
gFastSaveSection = &gSaveDataBuffer;
|
||||
gLastKnownGoodSector = gLastWrittenSector;
|
||||
gLastSaveCounter = gSaveCounter;
|
||||
gLastWrittenSector++;
|
||||
@ -163,7 +177,7 @@ u32 RestoreSaveBackupVarsAndIncrement(const struct SaveSectionLocation *location
|
||||
|
||||
u32 RestoreSaveBackupVars(const struct SaveSectionLocation *location) // only ever called once, and gSaveBlock2 is passed to this function. location is unused
|
||||
{
|
||||
gFastSaveSection = (struct SaveSection *)&gUnknown_0203ABBC;
|
||||
gFastSaveSection = &gSaveDataBuffer;
|
||||
gLastKnownGoodSector = gLastWrittenSector;
|
||||
gLastSaveCounter = gSaveCounter;
|
||||
gUnknown_03006208 = 0;
|
||||
@ -356,7 +370,7 @@ u8 sub_8152D44(u16 a1, const struct SaveSectionLocation *location)
|
||||
u8 sub_8152DD0(u16 a1, const struct SaveSectionLocation *location)
|
||||
{
|
||||
u8 retVal;
|
||||
gFastSaveSection = (struct SaveSection *)&gUnknown_0203ABBC;
|
||||
gFastSaveSection = &gSaveDataBuffer;
|
||||
if (a1 != 0xFFFF)
|
||||
{
|
||||
retVal = 0xFF;
|
||||
@ -524,7 +538,7 @@ u8 GetSaveValidStatus(const struct SaveSectionLocation *location)
|
||||
u8 sub_81530DC(u8 a1, u8 *data, u16 size)
|
||||
{
|
||||
u16 i;
|
||||
struct SaveSection *section = (struct SaveSection *)&gUnknown_0203ABBC;
|
||||
struct SaveSection *section = &gSaveDataBuffer;
|
||||
DoReadFlashWholeSection(a1, section);
|
||||
if (section->security == UNKNOWN_CHECK_VALUE)
|
||||
{
|
||||
@ -563,17 +577,13 @@ u16 CalculateChecksum(void *data, u16 size)
|
||||
return ((checksum >> 16) + checksum);
|
||||
}
|
||||
|
||||
extern struct SaveSectionOffsets gSaveSectionOffsets[0xE]; // gSaveSectionOffsets
|
||||
extern struct SaveSectionLocation gRamSaveSectionLocations[0xE]; // gRamSaveSectionLocations
|
||||
extern void *gUnknown_03005D94;
|
||||
|
||||
#ifdef NONMATCHING
|
||||
// the initial allocation of the pointer and toAdd variable doesnt match up with the original function. however, forcing it is impossible since gRamSaveSectionLocations is loaded first.
|
||||
void UpdateSaveAddresses(void)
|
||||
{
|
||||
int i;
|
||||
gRamSaveSectionLocations[0].data = gSaveBlock2Ptr + gSaveSectionOffsets[0].toAdd;
|
||||
gRamSaveSectionLocations[0].size = gSaveSectionOffsets[0].size;
|
||||
int i = 0;
|
||||
gRamSaveSectionLocations[i].data = gSaveBlock2Ptr + gSaveSectionOffsets[0].toAdd;
|
||||
gRamSaveSectionLocations[i].size = gSaveSectionOffsets[0].size;
|
||||
|
||||
for(i = 1; i < 5; i++)
|
||||
{
|
||||
@ -704,10 +714,6 @@ u8 HandleSavingData(u8 saveType)
|
||||
return 0;
|
||||
}
|
||||
|
||||
extern u32 gFlashMemoryPresent;
|
||||
extern void DoSaveFailedScreen(u8); // save_failed_screen
|
||||
extern u16 gUnknown_03006294;
|
||||
|
||||
u8 TrySavingData(u8 saveType) // TrySave
|
||||
{
|
||||
if(gFlashMemoryPresent == TRUE)
|
||||
@ -794,11 +800,6 @@ bool8 sub_8153474(void)
|
||||
return retVal;
|
||||
}
|
||||
|
||||
extern u16 gUnknown_03006210;
|
||||
extern void LoadSerializedGame(void); // load_save
|
||||
extern void (*gGameContinueCallback)(void);
|
||||
extern u8 gDecompressionBuffer[];
|
||||
|
||||
u8 sub_81534D0(u8 a1)
|
||||
{
|
||||
u8 result;
|
||||
@ -828,3 +829,69 @@ u8 sub_81534D0(u8 a1)
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
u16 sub_815355C(void)
|
||||
{
|
||||
u16 i, v3;
|
||||
struct SaveSection* savSection;
|
||||
|
||||
savSection = gFastSaveSection = &gSaveDataBuffer;
|
||||
if (gFlashMemoryPresent != 1)
|
||||
return 0;
|
||||
UpdateSaveAddresses();
|
||||
GetSaveValidStatus(gRamSaveSectionLocations);
|
||||
v3 = 0xE * (gSaveCounter % 2);
|
||||
for (i = 0; i < 14; i++)
|
||||
{
|
||||
DoReadFlashWholeSection(i + v3, gFastSaveSection);
|
||||
if (gFastSaveSection->id == 0)
|
||||
return savSection->data[10] +
|
||||
savSection->data[11] +
|
||||
savSection->data[12] +
|
||||
savSection->data[13];
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
u32 sub_81535DC(u8 sector, u8* dst)
|
||||
{
|
||||
s32 i;
|
||||
s32 size;
|
||||
u8* savData;
|
||||
|
||||
if (sector != 30 && sector != 31)
|
||||
return 0xFF;
|
||||
ReadFlash(sector, 0, &gSaveDataBuffer, sizeof(struct SaveSection));
|
||||
if (*(u32*)(&gSaveDataBuffer.data[0]) != 0xB39D)
|
||||
return 0xFF;
|
||||
// copies whole save section except u32 counter
|
||||
i = 0;
|
||||
size = 0xFFB;
|
||||
savData = &gSaveDataBuffer.data[4];
|
||||
for (; i <= size; i++)
|
||||
dst[i] = savData[i];
|
||||
return 1;
|
||||
}
|
||||
|
||||
u32 sub_8153634(u8 sector, u8* src)
|
||||
{
|
||||
s32 i;
|
||||
s32 size;
|
||||
u8* savData;
|
||||
void* savDataBuffer;
|
||||
|
||||
if (sector != 30 && sector != 31)
|
||||
return 0xFF;
|
||||
savDataBuffer = &gSaveDataBuffer;
|
||||
*(u32*)(savDataBuffer) = 0xB39D;
|
||||
|
||||
// copies whole save section except u32 counter
|
||||
i = 0;
|
||||
size = 0xFFB;
|
||||
savData = &gSaveDataBuffer.data[4];
|
||||
for (; i <= size; i++)
|
||||
savData[i] = src[i];
|
||||
if (ProgramFlashSectorAndVerify(sector, savDataBuffer) != 0)
|
||||
return 0xFF;
|
||||
return 1;
|
||||
}
|
||||
|
@ -392,32 +392,9 @@ gUnknown_030061E8: @ 30061E8
|
||||
gUnknown_030061EC: @ 30061EC
|
||||
.space 0x4
|
||||
|
||||
gLastWrittenSector: @ 30061F0
|
||||
.space 0x4
|
||||
|
||||
gLastSaveCounter: @ 30061F4
|
||||
.space 0x4
|
||||
|
||||
gLastKnownGoodSector: @ 30061F8
|
||||
.space 0x4
|
||||
|
||||
gDamagedSaveSectors: @ 30061FC
|
||||
.space 0x4
|
||||
|
||||
gSaveCounter: @ 3006200
|
||||
.space 0x4
|
||||
|
||||
gFastSaveSection: @ 3006204
|
||||
.space 0x4
|
||||
|
||||
gUnknown_03006208: @ 3006208
|
||||
.space 0x8
|
||||
|
||||
gUnknown_03006210: @ 3006210
|
||||
.space 0x4
|
||||
|
||||
gGameContinueCallback: @ 3006214
|
||||
.space 0xC
|
||||
.include"save.o"
|
||||
|
||||
.space 0x8
|
||||
|
||||
gRamSaveSectionLocations: @ 3006220
|
||||
.space 0x74
|
||||
|
@ -1653,8 +1653,9 @@ gUnknown_0203ABB5: @ 203ABB5
|
||||
gUnknown_0203ABB8: @ 203ABB8
|
||||
.space 0x4
|
||||
|
||||
gUnknown_0203ABBC: @ 203ABBC
|
||||
.space 0x1004
|
||||
.include "src/save.o"
|
||||
|
||||
.space 0x4 /*unused var?*/
|
||||
|
||||
gUnknown_0203BBC0: @ 203BBC0
|
||||
.space 0x74
|
||||
|
Loading…
Reference in New Issue
Block a user