Add support for the Game Boy MBC6 mapper (save write)

This commit is contained in:
Lesserkuma 2022-09-28 18:52:52 +02:00
parent f7d9051b95
commit 9d42ce0964

View File

@ -310,7 +310,7 @@ void gbMenu() {
// Change working dir to root // Change working dir to root
sd.chdir("/"); sd.chdir("/");
if (romType == 32) if (romType == 32)
readSRAMFLASH_GB_MBC6(); readSRAMFLASH_MBC6_GB();
else else
readSRAM_GB(); readSRAM_GB();
} }
@ -328,18 +328,24 @@ void gbMenu() {
sd.chdir("/"); sd.chdir("/");
filePath[0] = '\0'; filePath[0] = '\0';
fileBrowser(F("Select sav file")); fileBrowser(F("Select sav file"));
writeSRAM_GB();
unsigned long wrErrors; if (romType == 32) {
wrErrors = verifySRAM_GB(); writeSRAMFLASH_MBC6_GB();
if (wrErrors == 0) {
println_Msg(F("Verified OK"));
display_Update();
} }
else { else {
print_Msg(F("Error: ")); writeSRAM_GB();
print_Msg(wrErrors); unsigned long wrErrors;
println_Msg(F(" bytes ")); wrErrors = verifySRAM_GB();
print_Error(F("did not verify."), false); if (wrErrors == 0) {
println_Msg(F("Verified OK"));
display_Update();
}
else {
print_Msg(F("Error: "));
print_Msg(wrErrors);
println_Msg(F(" bytes "));
print_Error(F("did not verify."), false);
}
} }
} }
else { else {
@ -1268,8 +1274,8 @@ unsigned long verifySRAM_GB() {
} }
} }
// Read SRAM + FLASH save data of MBC6 // Read MBC6 (SRAM + FLASH) save data
void readSRAMFLASH_GB_MBC6() { void readSRAMFLASH_MBC6_GB() {
// Get name, add extension and convert to char array for sd lib // Get name, add extension and convert to char array for sd lib
strcpy(fileName, romName); strcpy(fileName, romName);
strcat(fileName, ".sav"); strcat(fileName, ".sav");
@ -1329,14 +1335,13 @@ void readSRAMFLASH_GB_MBC6() {
writeByte_GB(0x2800, 0x08); writeByte_GB(0x2800, 0x08);
writeByte_GB(0x3800, 0x08); writeByte_GB(0x3800, 0x08);
word romAddress = 0x4000; // Switch FLASH banks
for (byte currBank = 0; currBank < 128; currBank++) { for (byte currBank = 0; currBank < 128; currBank++) {
writeByte_GB(0x2800, 8); word romAddress = 0x4000;
writeByte_GB(0x3800, 8);
writeByte_GB(0x2000, currBank); writeByte_GB(0x2000, currBank);
writeByte_GB(0x3000, currBank); writeByte_GB(0x3000, currBank);
romAddress = 0x4000;
// Read banks and save to SD // Read banks and save to SD
while (romAddress <= 0x5FFF) { while (romAddress <= 0x5FFF) {
for (int i = 0; i < 512; i++) { for (int i = 0; i < 512; i++) {
@ -1364,100 +1369,146 @@ void readSRAMFLASH_GB_MBC6() {
display_Update(); display_Update();
} }
// Read SRAM + FLASH save data of MBC6 // Write MBC6 (SRAM + FLASH) save data
void readSRAMFLASH_GB_MBC6() { void writeSRAMFLASH_MBC6_GB() {
// Get name, add extension and convert to char array for sd lib // Create filepath
strcpy(fileName, romName); sprintf(filePath, "%s/%s", filePath, fileName);
strcat(fileName, ".sav");
// create a new folder for the save file
EEPROM_readAnything(0, foldern);
sprintf(folder, "GB/SAVE/%s/%d", romName, foldern);
sd.mkdir(folder, true);
sd.chdir(folder);
display_Clear();
print_Msg(F("Saving to "));
print_Msg(folder);
println_Msg(F("/..."));
display_Update();
// write new folder number back to eeprom
foldern = foldern + 1;
EEPROM_writeAnything(0, foldern);
//open file on sd card //open file on sd card
if (!myFile.open(fileName, O_RDWR | O_CREAT)) { if (myFile.open(filePath, O_READ)) {
print_Error(F("SD Error"), true); display_Clear();
} println_Msg(F("Writing MBC6 save..."));
display_Update();
//Initialize progress bar //Initialize progress bar
uint32_t processedProgressBar = 0; uint32_t processedProgressBar = 0;
uint32_t totalProgressBar = 0x108000; uint32_t totalProgressBar = 0x108000;
draw_progressbar(0, totalProgressBar); draw_progressbar(0, totalProgressBar);
// Enable Mapper and SRAM // Enable Mapper and SRAM
writeByte_GB(0x0000, 0x0A); writeByte_GB(0x0000, 0x0A);
// Switch SRAM banks // Switch SRAM banks
for (byte currBank = 0; currBank < sramBanks; currBank++) { for (byte currBank = 0; currBank < sramBanks; currBank++) {
writeByte_GB(0x0400, currBank); writeByte_GB(0x0400, currBank);
writeByte_GB(0x0800, currBank); writeByte_GB(0x0800, currBank);
// Read SRAM // Write SRAM
for (word sramAddress = 0xA000; sramAddress <= lastByte; sramAddress += 64) { for (word sramAddress = 0xA000; sramAddress <= lastByte; sramAddress++) {
for (byte i = 0; i < 64; i++) { writeByteSRAM_GB(sramAddress, myFile.read());
sdBuffer[i] = readByteSRAM_GB(sramAddress + i);
} }
myFile.write(sdBuffer, 64);
processedProgressBar += 64; processedProgressBar += (lastByte + 1) - 0xA000;
draw_progressbar(processedProgressBar, totalProgressBar); draw_progressbar(processedProgressBar, totalProgressBar);
} }
}
// Disable SRAM // Disable SRAM
writeByte_GB(0x0000, 0x00); writeByte_GB(0x0000, 0x00);
// Enable flash save memory (map to ROM) // Enable flash save memory (map to ROM)
writeByte_GB(0x1000, 0x01); writeByte_GB(0x1000, 0x01);
writeByte_GB(0x0C00, 0x01); writeByte_GB(0x0C00, 0x01);
writeByte_GB(0x1000, 0x00); writeByte_GB(0x1000, 0x01);
writeByte_GB(0x2800, 0x08); writeByte_GB(0x2800, 0x08);
writeByte_GB(0x3800, 0x08); writeByte_GB(0x3800, 0x08);
word romAddress = 0x4000; for (byte currBank = 0; currBank < 128; currBank++) {
for (byte currBank = 0; currBank < 128; currBank++) { word romAddress = 0x4000;
writeByte_GB(0x2800, 8);
writeByte_GB(0x3800, 8);
writeByte_GB(0x2000, currBank);
writeByte_GB(0x3000, currBank);
romAddress = 0x4000; // Erase FLASH sector
// Read banks and save to SD if (((processedProgressBar - 0x8000) % 0x20000) == 0) {
while (romAddress <= 0x5FFF) { writeByte_GB(0x2800, 0x08);
for (int i = 0; i < 512; i++) { writeByte_GB(0x3800, 0x08);
sdBuffer[i] = readByte_GB(romAddress + i); writeByte_GB(0x2000, 0x01);
writeByte_GB(0x3000, 0x02);
writeByte_GB(0x7555, 0xAA);
writeByte_GB(0x4AAA, 0x55);
writeByte_GB(0x7555, 0x80);
writeByte_GB(0x7555, 0xAA);
writeByte_GB(0x4AAA, 0x55);
writeByte_GB(0x2800, 0x08);
writeByte_GB(0x3800, 0x08);
writeByte_GB(0x2000, currBank);
writeByte_GB(0x3000, currBank);
writeByte_GB(0x4000, 0x30);
byte lives = 100;
while (1) {
byte sr = readByte_GB(0x4000);
if (sr == 0x80) break;
delay(1);
if (lives-- <= 0) {
// Disable flash save memory
writeByte_GB(0x1000, 0x01);
writeByte_GB(0x0C00, 0x00);
writeByte_GB(0x1000, 0x00);
writeByte_GB(0x2800, 0x00);
writeByte_GB(0x3800, 0x00);
myFile.close();
display_Clear();
print_Error(F("Error erasing FLASH sector."), true);
}
}
}
else {
writeByte_GB(0x2800, 0x08);
writeByte_GB(0x3800, 0x08);
writeByte_GB(0x2000, currBank);
writeByte_GB(0x3000, currBank);
}
// Write to FLASH
while (romAddress <= 0x5FFF) {
writeByte_GB(0x2000, 0x01);
writeByte_GB(0x3000, 0x02);
writeByte_GB(0x7555, 0xAA);
writeByte_GB(0x4AAA, 0x55);
writeByte_GB(0x7555, 0xA0);
writeByte_GB(0x2800, 0x08);
writeByte_GB(0x3800, 0x08);
writeByte_GB(0x2000, currBank);
writeByte_GB(0x3000, currBank);
for (int i = 0; i < 128; i++) {
writeByte_GB(romAddress++, myFile.read());
}
writeByte_GB(romAddress - 1, 0x00);
byte lives = 100;
while (1) {
byte sr = readByte_GB(romAddress - 1);
if (sr == 0x80) break;
delay(1);
if (lives-- <= 0) {
// Disable flash save memory
writeByte_GB(0x1000, 0x01);
writeByte_GB(0x0C00, 0x00);
writeByte_GB(0x1000, 0x00);
writeByte_GB(0x2800, 0x00);
writeByte_GB(0x3800, 0x00);
myFile.close();
display_Clear();
print_Error(F("Error writing to FLASH."), true);
}
}
writeByte_GB(romAddress - 1, 0xF0);
processedProgressBar += 128;
draw_progressbar(processedProgressBar, totalProgressBar);
} }
myFile.write(sdBuffer, 512);
romAddress += 512;
processedProgressBar += 512;
draw_progressbar(processedProgressBar, totalProgressBar);
} }
// Disable flash save memory
writeByte_GB(0x1000, 0x01);
writeByte_GB(0x0C00, 0x00);
writeByte_GB(0x1000, 0x00);
writeByte_GB(0x2800, 0x00);
writeByte_GB(0x3800, 0x00);
// Close the file:
myFile.close();
println_Msg(F("Save writing finished"));
display_Update();
}
else {
print_Error(F("File doesnt exist"), false);
} }
// Disable flash save memory
writeByte_GB(0x1000, 0x01);
writeByte_GB(0x0C00, 0x00);
writeByte_GB(0x1000, 0x00);
writeByte_GB(0x2800, 0x00);
writeByte_GB(0x3800, 0x00);
// Close the file:
myFile.close();
// Signal end of process
println_Msg(F("OK"));
display_Update();
} }
/****************************************** /******************************************