mirror of
https://github.com/sanni/cartreader.git
synced 2025-01-12 04:59:07 +01:00
Fix N64 Controller Pak read/write
This commit is contained in:
parent
3082971d09
commit
e4246d8310
@ -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: 06.08.2022
|
Date: 17.08.2022
|
||||||
Version: 9.4
|
Version: 9.5
|
||||||
|
|
||||||
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
|
||||||
@ -60,7 +60,7 @@
|
|||||||
|
|
||||||
**********************************************************************************/
|
**********************************************************************************/
|
||||||
|
|
||||||
char ver[5] = "9.4";
|
char ver[5] = "9.5";
|
||||||
|
|
||||||
//******************************************
|
//******************************************
|
||||||
// !!! CHOOSE HARDWARE VERSION !!!
|
// !!! CHOOSE HARDWARE VERSION !!!
|
||||||
|
@ -2004,34 +2004,54 @@ void readMPK() {
|
|||||||
print_Error(F("Can't open file on SD"), true);
|
print_Error(F("Can't open file on SD"), true);
|
||||||
}
|
}
|
||||||
|
|
||||||
println_Msg(F("Please wait..."));
|
print_Msg(F("Saving N64/MPK/"));
|
||||||
|
println_Msg(fileName);
|
||||||
display_Update();
|
display_Update();
|
||||||
|
|
||||||
|
//Initialize progress bar
|
||||||
|
uint32_t processedProgressBar = 0;
|
||||||
|
uint32_t totalProgressBar = (uint32_t)(0x7FFF);
|
||||||
|
draw_progressbar(0, totalProgressBar);
|
||||||
|
|
||||||
// Controller paks, which all have 32kB of space, are mapped between 0x0000 – 0x7FFF
|
// Controller paks, which all have 32kB of space, are mapped between 0x0000 – 0x7FFF
|
||||||
for (word i = 0x0000; i < 0x8000; i += 32) {
|
for (word i = 0x0000; i < 0x8000; i += 32) {
|
||||||
// Read one block of the Controller Pak into array myBlock
|
// Read one block of the Controller Pak into array myBlock
|
||||||
readBlock(i);
|
readBlock(i);
|
||||||
|
|
||||||
|
// Delay to prevent write errors
|
||||||
|
delay(1);
|
||||||
|
|
||||||
// Write block to SD card
|
// Write block to SD card
|
||||||
for (byte j = 0; j < 32; j++) {
|
for (byte j = 0; j < 32; j++) {
|
||||||
myFile.write(myBlock[j]);
|
myFile.write(myBlock[j]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Blink led
|
||||||
|
blinkLED();
|
||||||
|
// Update progress bar
|
||||||
|
processedProgressBar += 32;
|
||||||
|
draw_progressbar(processedProgressBar, totalProgressBar);
|
||||||
}
|
}
|
||||||
// Close the file:
|
// Close the file:
|
||||||
myFile.close();
|
myFile.close();
|
||||||
print_Msg(F("Saved as N64/MPK/"));
|
|
||||||
println_Msg(fileName);
|
|
||||||
display_Update();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void writeMPK() {
|
void writeMPK() {
|
||||||
// Create filepath
|
// Create filepath
|
||||||
sprintf(filePath, "%s/%s", filePath, fileName);
|
sprintf(filePath, "%s/%s", filePath, fileName);
|
||||||
println_Msg(F("Writing..."));
|
print_Msg(F("Writing "));
|
||||||
println_Msg(filePath);
|
print_Msg(filePath);
|
||||||
|
println_Msg(F("..."));
|
||||||
display_Update();
|
display_Update();
|
||||||
|
|
||||||
// Open file on sd card
|
// Open file on sd card
|
||||||
if (myFile.open(filePath, O_READ)) {
|
if (myFile.open(filePath, O_READ)) {
|
||||||
|
|
||||||
|
//Initialize progress bar
|
||||||
|
uint32_t processedProgressBar = 0;
|
||||||
|
uint32_t totalProgressBar = (uint32_t)(0x7FFF);
|
||||||
|
draw_progressbar(0, totalProgressBar);
|
||||||
|
|
||||||
for (word myAddress = 0x0000; myAddress < 0x8000; myAddress += 32) {
|
for (word myAddress = 0x0000; myAddress < 0x8000; myAddress += 32) {
|
||||||
// Read 32 bytes into SD buffer
|
// Read 32 bytes into SD buffer
|
||||||
myFile.read(sdBuffer, 32);
|
myFile.read(sdBuffer, 32);
|
||||||
@ -2058,11 +2078,17 @@ void writeMPK() {
|
|||||||
N64_stop();
|
N64_stop();
|
||||||
// Enable interrupts
|
// Enable interrupts
|
||||||
interrupts();
|
interrupts();
|
||||||
|
|
||||||
|
// Blink led
|
||||||
|
blinkLED();
|
||||||
|
// Update progress bar
|
||||||
|
processedProgressBar += 32;
|
||||||
|
draw_progressbar(processedProgressBar, totalProgressBar);
|
||||||
|
// Delay to prevent write errors
|
||||||
|
delay(1);
|
||||||
}
|
}
|
||||||
// Close the file:
|
// Close the file:
|
||||||
myFile.close();
|
myFile.close();
|
||||||
println_Msg(F("Done"));
|
|
||||||
display_Update();
|
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
print_Error(F("Can't create file on SD"), true);
|
print_Error(F("Can't create file on SD"), true);
|
||||||
@ -2081,17 +2107,31 @@ void verifyMPK() {
|
|||||||
print_Error(F("Can't create file on SD"), true);
|
print_Error(F("Can't create file on SD"), true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//Initialize progress bar
|
||||||
|
uint32_t processedProgressBar = 0;
|
||||||
|
uint32_t totalProgressBar = (uint32_t)(0x7FFF);
|
||||||
|
draw_progressbar(0, totalProgressBar);
|
||||||
|
|
||||||
// Controller paks, which all have 32kB of space, are mapped between 0x0000 – 0x7FFF
|
// Controller paks, which all have 32kB of space, are mapped between 0x0000 – 0x7FFF
|
||||||
for (word i = 0x0000; i < 0x8000; i += 32) {
|
for (word i = 0x0000; i < 0x8000; i += 32) {
|
||||||
// Read one block of the Controller Pak into array myBlock
|
// Read one block of the Controller Pak into array myBlock
|
||||||
readBlock(i);
|
readBlock(i);
|
||||||
|
// Delay to prevent read errors
|
||||||
|
delay(1);
|
||||||
// Check against file on SD card
|
// Check against file on SD card
|
||||||
for (byte j = 0; j < 32; j++) {
|
for (byte j = 0; j < 32; j++) {
|
||||||
if (myFile.read() != myBlock[j]) {
|
if (myFile.read() != myBlock[j]) {
|
||||||
writeErrors++;
|
writeErrors++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Blink led
|
||||||
|
blinkLED();
|
||||||
|
// Update progress bar
|
||||||
|
processedProgressBar += 32;
|
||||||
|
draw_progressbar(processedProgressBar, totalProgressBar);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Close the file:
|
// Close the file:
|
||||||
myFile.close();
|
myFile.close();
|
||||||
if (writeErrors == 0) {
|
if (writeErrors == 0) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user