V7.7: Improve GB Camera dumping (thx to avapug)

This commit is contained in:
sanni 2022-02-23 15:08:25 +01:00
parent 2ff3e84d6f
commit c0abeac385
3 changed files with 101 additions and 38 deletions

View File

@ -4,8 +4,8 @@
This project represents a community-driven effort to provide This project represents a community-driven effort to provide
an easy to build and easy to modify cartridge dumper. an easy to build and easy to modify cartridge dumper.
Date: 15.02.2022 Date: 23.02.2022
Version: 7.6 Version: 7.7
SD lib: https://github.com/greiman/SdFat SD lib: https://github.com/greiman/SdFat
OLED lib: https://github.com/adafruit/Adafruit_SSD1306 OLED lib: https://github.com/adafruit/Adafruit_SSD1306
@ -45,7 +45,7 @@
**********************************************************************************/ **********************************************************************************/
char ver[5] = "7.6"; char ver[5] = "7.7";
/****************************************** /******************************************
Libraries Libraries
@ -813,7 +813,6 @@ void print_Error(const __FlashStringHelper *errorMessage, boolean forceReset) {
display_Update(); display_Update();
if (forceReset) { if (forceReset) {
#if (defined(enable_OLED) || defined(enable_LCD))
println_Msg(F("")); println_Msg(F(""));
println_Msg(F("Press Button...")); println_Msg(F("Press Button..."));
display_Update(); display_Update();
@ -825,17 +824,11 @@ void print_Error(const __FlashStringHelper *errorMessage, boolean forceReset) {
ignoreError = 0; ignoreError = 0;
display_Clear(); display_Clear();
println_Msg(F("")); println_Msg(F(""));
println_Msg(F("Error Overwrite"));
println_Msg(F("")); println_Msg(F(""));
println_Msg(F(""));
println_Msg(F(" Error Overwrite"));
display_Update(); display_Update();
delay(2000); delay(2000);
} }
#endif
#ifdef enable_serial
println_Msg(F("Fatal Error, please reset"));
while (1);
#endif
} }
} }
@ -1049,6 +1042,13 @@ unsigned char question_box(const __FlashStringHelper* question, char answers[7][
*****************************************/ *****************************************/
#ifdef enable_serial #ifdef enable_serial
void wait_serial() { void wait_serial() {
if (errorLvl) {
// Debug
#ifdef debug_mode
ignoreError = 1;
#endif
errorLvl = 0;
}
while (Serial.available() == 0) { while (Serial.available() == 0) {
} }
incomingByte = Serial.read() - 48; incomingByte = Serial.read() - 48;
@ -1307,7 +1307,9 @@ void wait_btn() {
if (b == 3) { if (b == 3) {
if (errorLvl) { if (errorLvl) {
// Debug // Debug
//ignoreError = 1; #ifdef debug_mode
ignoreError = 1;
#endif
errorLvl = 0; errorLvl = 0;
} }
break; break;
@ -1649,7 +1651,9 @@ void wait_btn() {
if (b == 3) { if (b == 3) {
if (errorLvl) { if (errorLvl) {
// Debug // Debug
//ignoreError = 1; #ifdef debug_mode
ignoreError = 1;
#endif
errorLvl = 0; errorLvl = 0;
} }
break; break;

View File

@ -494,7 +494,7 @@ void writeByte_GB(int myAddress, byte myData) {
__asm__("nop\n\t""nop\n\t""nop\n\t""nop\n\t"); __asm__("nop\n\t""nop\n\t""nop\n\t""nop\n\t");
} }
byte readByteSRAM_GB(word myAddress) { byte readByteCLK_GB(word myAddress) {
PORTF = myAddress & 0xFF; PORTF = myAddress & 0xFF;
PORTK = (myAddress >> 8) & 0xFF; PORTK = (myAddress >> 8) & 0xFF;
@ -510,17 +510,17 @@ byte readByteSRAM_GB(word myAddress) {
// Read // Read
byte tempByte = PINC; byte tempByte = PINC;
// Pull CS(PH3) CLK(PH1)(for FRAM MOD) HIGH
PORTH |= (1 << 3) | (1 << 1);
// Pull RD(PH6) HIGH // Pull RD(PH6) HIGH
PORTH |= (1 << 6); PORTH |= (1 << 6);
// Pull CS(PH3) CLK(PH1)(for FRAM MOD) HIGH
PORTH |= (1 << 3) | (1 << 1);
__asm__("nop\n\t""nop\n\t""nop\n\t""nop\n\t"); __asm__("nop\n\t""nop\n\t""nop\n\t""nop\n\t");
return tempByte; return tempByte;
} }
void writeByteSRAM_GB(int myAddress, byte myData) { void writeByteCLK_GB(int myAddress, byte myData) {
PORTF = myAddress & 0xFF; PORTF = myAddress & 0xFF;
PORTK = (myAddress >> 8) & 0xFF; PORTK = (myAddress >> 8) & 0xFF;
PORTC = myData; PORTC = myData;
@ -549,12 +549,12 @@ void writeByteSRAM_GB(int myAddress, byte myData) {
*****************************************/ *****************************************/
// Read Cartridge Header // Read Cartridge Header
void getCartInfo_GB() { void getCartInfo_GB() {
romType = readByte_GB(0x0147); romType = readByteCLK_GB(0x0147);
romSize = readByte_GB(0x0148); romSize = readByteCLK_GB(0x0148);
sramSize = readByte_GB(0x0149); sramSize = readByteCLK_GB(0x0149);
// ROM banks // ROM banks
switch (romSize){ switch (romSize) {
case 0x00: case 0x00:
romBanks = 2; romBanks = 2;
break; break;
@ -617,14 +617,14 @@ void getCartInfo_GB() {
} }
// Get Checksum as string // Get Checksum as string
sprintf(checksumStr, "%02X%02X", readByte_GB(0x014E), readByte_GB(0x014F)); sprintf(checksumStr, "%02X%02X", readByteCLK_GB(0x014E), readByteCLK_GB(0x014F));
// Get name // Get name
byte myByte = 0; byte myByte = 0;
byte myLength = 0; byte myLength = 0;
for (int addr = 0x0134; addr <= 0x13C; addr++) { for (int addr = 0x0134; addr <= 0x13C; addr++) {
myByte = readByte_GB(addr); myByte = readByteCLK_GB(addr);
if (((char(myByte) >= 48 && char(myByte) <= 57) || (char(myByte) >= 65 && char(myByte) <= 122)) && myLength < 15) { if (((char(myByte) >= 48 && char(myByte) <= 57) || (char(myByte) >= 65 && char(myByte) <= 122)) && myLength < 15) {
romName[myLength] = char(myByte); romName[myLength] = char(myByte);
myLength++; myLength++;
@ -664,6 +664,11 @@ void readROM_GB() {
word romAddress = 0; word romAddress = 0;
//Initialize progress bar
uint32_t processedProgressBar = 0;
uint32_t totalProgressBar = (uint32_t)(romBanks - 1);
draw_progressbar(0, totalProgressBar);
for (word currBank = 1; currBank < romBanks; currBank++) { for (word currBank = 1; currBank < romBanks; currBank++) {
// Switch data pins to output // Switch data pins to output
dataOut(); dataOut();
@ -690,11 +695,14 @@ void readROM_GB() {
// Read banks and save to SD // Read banks and save to SD
while (romAddress <= 0x7FFF) { while (romAddress <= 0x7FFF) {
for (int i = 0; i < 512; i++) { for (int i = 0; i < 512; i++) {
sdBuffer[i] = readByte_GB(romAddress + i); sdBuffer[i] = readByteCLK_GB(romAddress + i);
} }
myFile.write(sdBuffer, 512); myFile.write(sdBuffer, 512);
romAddress += 512; romAddress += 512;
} }
processedProgressBar += 1;
draw_progressbar(processedProgressBar, totalProgressBar);
} }
// Close the file: // Close the file:
@ -723,8 +731,8 @@ unsigned int calc_checksum_GB (char* fileName, char* folder) {
myFile.close(); myFile.close();
sd.chdir(); sd.chdir();
// Subtract checksum bytes // Subtract checksum bytes
calcChecksum -= readByte_GB(0x014E); calcChecksum -= readByteCLK_GB(0x014E);
calcChecksum -= readByte_GB(0x014F); calcChecksum -= readByteCLK_GB(0x014F);
// Return result // Return result
return (calcChecksum); return (calcChecksum);
@ -797,7 +805,7 @@ void readSRAM_GB() {
dataIn_GB(); dataIn_GB();
// MBC2 Fix // MBC2 Fix
readByte_GB(0x0134); readByteCLK_GB(0x0134);
dataOut(); dataOut();
if (romType <= 4) { if (romType <= 4) {
@ -816,7 +824,7 @@ void readSRAM_GB() {
dataIn_GB(); dataIn_GB();
for (word sramAddress = 0xA000; sramAddress <= lastByte; sramAddress += 64) { for (word sramAddress = 0xA000; sramAddress <= lastByte; sramAddress += 64) {
for (byte i = 0; i < 64; i++) { for (byte i = 0; i < 64; i++) {
sdBuffer[i] = readByteSRAM_GB(sramAddress + i); sdBuffer[i] = readByteCLK_GB(sramAddress + i);
} }
myFile.write(sdBuffer, 64); myFile.write(sdBuffer, 64);
} }
@ -854,7 +862,7 @@ void writeSRAM_GB() {
dataIn_GB(); dataIn_GB();
// MBC2 Fix // MBC2 Fix
readByte_GB(0x0134); readByteCLK_GB(0x0134);
dataOut(); dataOut();
@ -872,7 +880,7 @@ void writeSRAM_GB() {
// Write RAM // Write RAM
for (word sramAddress = 0xA000; sramAddress <= lastByte; sramAddress++) { for (word sramAddress = 0xA000; sramAddress <= lastByte; sramAddress++) {
writeByteSRAM_GB(sramAddress, myFile.read()); writeByteCLK_GB(sramAddress, myFile.read());
} }
} }
// Disable SRAM // Disable SRAM
@ -909,7 +917,7 @@ unsigned long verifySRAM_GB() {
dataIn_GB(); dataIn_GB();
// MBC2 Fix // MBC2 Fix
readByte_GB(0x0134); readByteCLK_GB(0x0134);
// Check SRAM size // Check SRAM size
if (lastByte > 0) { if (lastByte > 0) {
@ -932,7 +940,7 @@ unsigned long verifySRAM_GB() {
//fill sdBuffer //fill sdBuffer
myFile.read(sdBuffer, 64); myFile.read(sdBuffer, 64);
for (int c = 0; c < 64; c++) { for (int c = 0; c < 64; c++) {
if (readByteSRAM_GB(sramAddress + c) != sdBuffer[c]) { if (readByteCLK_GB(sramAddress + c) != sdBuffer[c]) {
writeErrors++; writeErrors++;
} }
} }
@ -978,9 +986,33 @@ void writeFlash29F_GB(byte MBC) {
myFile.seekSet(0); myFile.seekSet(0);
// ROM banks // ROM banks
romBanks = 2; // Default 32K switch (romSize) {
if (romSize >= 1) { // Calculate rom size case 0x00:
romBanks = 2 << romSize; romBanks = 2;
break;
case 0x01:
romBanks = 4;
break;
case 0x02:
romBanks = 8;
break;
case 0x03:
romBanks = 16;
break;
case 0x04:
romBanks = 32;
break;
case 0x05:
romBanks = 64;
break;
case 0x06:
romBanks = 128;
break;
case 0x07:
romBanks = 256;
break;
default:
romBanks = 2;
} }
// Set data pins to output // Set data pins to output
@ -1409,9 +1441,33 @@ bool writeCFI_GB() {
myFile.seekSet(0); myFile.seekSet(0);
// ROM banks // ROM banks
romBanks = 2; // Default 32K switch (romSize) {
if (romSize >= 1) { // Calculate rom size case 0x00:
romBanks = 2 << romSize; romBanks = 2;
break;
case 0x01:
romBanks = 4;
break;
case 0x02:
romBanks = 8;
break;
case 0x03:
romBanks = 16;
break;
case 0x04:
romBanks = 32;
break;
case 0x05:
romBanks = 64;
break;
case 0x06:
romBanks = 128;
break;
case 0x07:
romBanks = 256;
break;
default:
romBanks = 2;
} }
if (romBanks <= flashBanks) { if (romBanks <= flashBanks) {

View File

@ -46,6 +46,9 @@
// flashMenu, nesMenu or smsMenu for single slot Cart Readers // flashMenu, nesMenu or smsMenu for single slot Cart Readers
#define startMenu mainMenu #define startMenu mainMenu
//Ignores errors that normally force a reset if button 2 is pressed
//#define debug_mode
// Setup RTC if installed. // Setup RTC if installed.
// remove // if you have an RTC installed // remove // if you have an RTC installed
// #define RTC_installed // #define RTC_installed