mirror of
https://github.com/sanni/cartreader.git
synced 2025-01-25 19:31:12 +01:00
Add support for the Game Boy MBC6 mapper (save write)
This commit is contained in:
parent
f7d9051b95
commit
9d42ce0964
@ -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();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/******************************************
|
/******************************************
|
||||||
|
Loading…
x
Reference in New Issue
Block a user