mirror of
https://github.com/sanni/cartreader.git
synced 2024-11-13 08:25:05 +01:00
N64.ino: Assorted low-hanging fruits
More sizeof() use, avoiding high-level loops when a callee can do it without the call overhead on every iteration, a bit of source code factorisation, avoiding initializers for large variables.
This commit is contained in:
parent
d9daadb1f9
commit
bea06e55fe
@ -1649,7 +1649,7 @@ void readMPK() {
|
|||||||
}
|
}
|
||||||
// This will take 1300us
|
// This will take 1300us
|
||||||
blinkLED();
|
blinkLED();
|
||||||
myFile.write(sdBuffer, 512);
|
myFile.write(sdBuffer, sizeof(sdBuffer));
|
||||||
// Blink led
|
// Blink led
|
||||||
blinkLED();
|
blinkLED();
|
||||||
// Update progress bar
|
// Update progress bar
|
||||||
@ -1870,12 +1870,12 @@ void verifyMPK() {
|
|||||||
draw_progressbar(0, totalProgressBar);
|
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 currSdBuffer = 0x0000; currSdBuffer < 0x8000; currSdBuffer += 512) {
|
for (word currSdBuffer = 0x0000; currSdBuffer < 0x8000; currSdBuffer += sizeof(sdBuffer)) {
|
||||||
// Read 512 bytes into SD buffer
|
// Read 512 bytes into SD buffer
|
||||||
myFile.read(sdBuffer, 512);
|
myFile.read(sdBuffer, sizeof(sdBuffer));
|
||||||
|
|
||||||
// Compare 32 byte block
|
// Compare 32 byte block
|
||||||
for (word currBlock = 0; currBlock < 512; currBlock += 32) {
|
for (word currBlock = 0; currBlock < sizeof(sdBuffer); currBlock += 32) {
|
||||||
// Read one block of the Controller Pak into array myBlock
|
// Read one block of the Controller Pak into array myBlock
|
||||||
readBlock(currSdBuffer + currBlock);
|
readBlock(currSdBuffer + currBlock);
|
||||||
|
|
||||||
@ -2078,8 +2078,8 @@ void printCartInfo_N64() {
|
|||||||
|
|
||||||
// look-up cart id in file n64.txt on sd card
|
// look-up cart id in file n64.txt on sd card
|
||||||
void getCartInfo_N64() {
|
void getCartInfo_N64() {
|
||||||
char tempStr2[2];
|
|
||||||
char tempStr[9];
|
char tempStr[9];
|
||||||
|
int read_bytes;
|
||||||
|
|
||||||
// cart not in list
|
// cart not in list
|
||||||
cartSize = 0;
|
cartSize = 0;
|
||||||
@ -2101,26 +2101,18 @@ void getCartInfo_N64() {
|
|||||||
// Skip over the CRC32 checksum
|
// Skip over the CRC32 checksum
|
||||||
myFile.seekCur(9);
|
myFile.seekCur(9);
|
||||||
|
|
||||||
// Read 8 bytes into String, do it one at a time so byte order doesn't get mixed up
|
// Read 8 bytes into String
|
||||||
sprintf(tempStr, "%c", myFile.read());
|
read_bytes = myFile.read(tempStr, 8);
|
||||||
for (byte i = 0; i < 7; i++) {
|
tempStr[read_bytes == -1 ? 0 : read_bytes] = 0;
|
||||||
sprintf(tempStr2, "%c", myFile.read());
|
|
||||||
strcat(tempStr, tempStr2);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Check if string is a match
|
// Check if string is a match
|
||||||
if (strcmp(tempStr, checksumStr) == 0) {
|
if (strcmp(tempStr, checksumStr) == 0) {
|
||||||
// Skip the , in the file
|
// Skip the , in the file
|
||||||
myFile.seekCur(1);
|
myFile.seekCur(1);
|
||||||
|
|
||||||
// Read the next ascii character and subtract 48 to convert to decimal
|
read_bytes = myFile.read(tempStr, 2);
|
||||||
cartSize = myFile.read() - 48;
|
tempStr[read_bytes == -1 ? 0 : read_bytes] = 0;
|
||||||
// Remove leading 0 for single digit cart sizes
|
cartSize = atoi(tempStr);
|
||||||
if (cartSize != 0) {
|
|
||||||
cartSize = cartSize * 10 + myFile.read() - 48;
|
|
||||||
} else {
|
|
||||||
cartSize = myFile.read() - 48;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Skip the , in the file
|
// Skip the , in the file
|
||||||
myFile.seekCur(1);
|
myFile.seekCur(1);
|
||||||
@ -2738,7 +2730,7 @@ void readEeprom() {
|
|||||||
interrupts();
|
interrupts();
|
||||||
|
|
||||||
// Write 64 pages at once to the SD card
|
// Write 64 pages at once to the SD card
|
||||||
myFile.write(sdBuffer, 512);
|
myFile.write(sdBuffer, sizeof(sdBuffer));
|
||||||
}
|
}
|
||||||
// Close the file:
|
// Close the file:
|
||||||
myFile.close();
|
myFile.close();
|
||||||
@ -2797,7 +2789,7 @@ unsigned long verifyEeprom() {
|
|||||||
interrupts();
|
interrupts();
|
||||||
|
|
||||||
// Check sdBuffer content against file on sd card
|
// Check sdBuffer content against file on sd card
|
||||||
for (int c = 0; c < 512; c++) {
|
for (size_t c = 0; c < sizeof(sdBuffer); c++) {
|
||||||
if (myFile.read() != sdBuffer[c]) {
|
if (myFile.read() != sdBuffer[c]) {
|
||||||
writeErrors++;
|
writeErrors++;
|
||||||
}
|
}
|
||||||
@ -3304,30 +3296,25 @@ redumpsamefolder:
|
|||||||
print_Error(sd_error_STR, true);
|
print_Error(sd_error_STR, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
// dumping rom slow
|
|
||||||
#ifndef fastcrc
|
|
||||||
// get current time
|
// get current time
|
||||||
unsigned long startTime = millis();
|
unsigned long startTime = millis();
|
||||||
|
#ifndef fastcrc
|
||||||
|
// dumping rom slow
|
||||||
|
|
||||||
for (unsigned long currByte = romBase; currByte < (romBase + (cartSize * 1024 * 1024)); currByte += 512) {
|
for (unsigned long currByte = romBase; currByte < (romBase + (cartSize * 1024 * 1024)); currByte += 512) {
|
||||||
// Blink led
|
// Blink led
|
||||||
if (currByte % 16384 == 0)
|
if ((currByte & 0x3FFF) == 0)
|
||||||
blinkLED();
|
blinkLED();
|
||||||
|
|
||||||
// Set the address for the next 512 bytes
|
// Set the address for the next 512 bytes
|
||||||
setAddress_N64(currByte);
|
setAddress_N64(currByte);
|
||||||
|
|
||||||
for (int c = 0; c < 512; c += 2) {
|
for (word c = 0; c < sizeof(sdBuffer); c += 2) {
|
||||||
// split word
|
|
||||||
word myWord = readWord_N64();
|
word myWord = readWord_N64();
|
||||||
byte loByte = myWord & 0xFF;
|
sdBuffer[c] = myWord >> 8;
|
||||||
byte hiByte = myWord >> 8;
|
sdBuffer[c + 1] = myWord & 0xFF;
|
||||||
|
|
||||||
// write to buffer
|
|
||||||
sdBuffer[c] = hiByte;
|
|
||||||
sdBuffer[c + 1] = loByte;
|
|
||||||
}
|
}
|
||||||
myFile.write(sdBuffer, 512);
|
myFile.write(sdBuffer, sizeof(sdBuffer));
|
||||||
}
|
}
|
||||||
// Close the file:
|
// Close the file:
|
||||||
myFile.close();
|
myFile.close();
|
||||||
@ -3335,10 +3322,7 @@ redumpsamefolder:
|
|||||||
if (compareCRC("n64.txt", 0, 1, 0)) {
|
if (compareCRC("n64.txt", 0, 1, 0)) {
|
||||||
#else
|
#else
|
||||||
// dumping rom fast
|
// dumping rom fast
|
||||||
byte buffer[1024] = { 0 };
|
byte buffer[1024];
|
||||||
|
|
||||||
// get current time
|
|
||||||
unsigned long startTime = millis();
|
|
||||||
|
|
||||||
//Initialize progress bar
|
//Initialize progress bar
|
||||||
uint32_t processedProgressBar = 0;
|
uint32_t processedProgressBar = 0;
|
||||||
|
Loading…
Reference in New Issue
Block a user