aboutsummaryrefslogtreecommitdiff
path: root/src/NDSCart.cpp
diff options
context:
space:
mode:
authorRSDuck <rsduck@users.noreply.github.com>2020-11-11 13:38:05 +0100
committerRSDuck <rsduck@users.noreply.github.com>2020-11-11 13:38:05 +0100
commit62e3f41f20866388287329218810d2fd8cea3515 (patch)
tree8897e0f86f3ce3e23d8943de800f7da1a766cda1 /src/NDSCart.cpp
parent2720df965025b75a77656db523606dadbcbb6067 (diff)
delay savefile flush to the end of the frame
Diffstat (limited to 'src/NDSCart.cpp')
-rw-r--r--src/NDSCart.cpp27
1 files changed, 20 insertions, 7 deletions
diff --git a/src/NDSCart.cpp b/src/NDSCart.cpp
index 077bf48..2d8396a 100644
--- a/src/NDSCart.cpp
+++ b/src/NDSCart.cpp
@@ -37,6 +37,7 @@ u8* SRAM;
u32 SRAMLength;
char SRAMPath[1024];
+bool SRAMFileDirty;
void (*WriteFunc)(u8 val, bool islast);
@@ -445,14 +446,21 @@ void Write(u8 val, u32 hold)
break;
}
- if (islast && (CurCmd == 0x02 || CurCmd == 0x0A) && (SRAMLength > 0))
+ SRAMFileDirty |= islast && (CurCmd == 0x02 || CurCmd == 0x0A) && (SRAMLength > 0);
+}
+
+void FlushSRAMFile()
+{
+ if (!SRAMFileDirty)
+ return;
+
+ SRAMFileDirty = false;
+
+ FILE* f = Platform::OpenFile(SRAMPath, "wb");
+ if (f)
{
- FILE* f = Platform::OpenFile(SRAMPath, "wb");
- if (f)
- {
- fwrite(SRAM, SRAMLength, 1, f);
- fclose(f);
- }
+ fwrite(SRAM, SRAMLength, 1, f);
+ fclose(f);
}
}
@@ -1034,6 +1042,11 @@ void RelocateSave(const char* path, bool write)
NDSCart_SRAM::RelocateSave(path, write);
}
+void FlushSRAMFile()
+{
+ NDSCart_SRAM::FlushSRAMFile();
+}
+
int ImportSRAM(const u8* data, u32 length)
{
memcpy(NDSCart_SRAM::SRAM, data, std::min(length, NDSCart_SRAM::SRAMLength));