mirror of
https://github.com/sanni/cartreader.git
synced 2024-11-13 08:25:05 +01:00
Update NES.ino
This commit is contained in:
parent
a9bf2b0cee
commit
20898cf3d3
@ -227,6 +227,11 @@ void nesMenu() {
|
|||||||
switch (answer) {
|
switch (answer) {
|
||||||
// Change Mapper
|
// Change Mapper
|
||||||
case 0:
|
case 0:
|
||||||
|
romName[0] = 'C';
|
||||||
|
romName[1] = 'A';
|
||||||
|
romName[2] = 'R';
|
||||||
|
romName[3] = 'T';
|
||||||
|
romName[4] = '\0';
|
||||||
setMapper();
|
setMapper();
|
||||||
checkMapperSize();
|
checkMapperSize();
|
||||||
setPRGSize();
|
setPRGSize();
|
||||||
@ -426,6 +431,27 @@ uint32_t uppow2(uint32_t n) {
|
|||||||
return n;
|
return n;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void printPRG() {
|
||||||
|
display_Clear();
|
||||||
|
println_Msg(F("Printing PRG at 0x8000"));
|
||||||
|
|
||||||
|
char myBuffer[3];
|
||||||
|
|
||||||
|
for (word currLine = 0; currLine < 512; currLine += 16) {
|
||||||
|
for (byte currByte = 0; currByte < 16; currByte++) {
|
||||||
|
itoa (read_prg_byte(0x8000 + currLine + currByte), myBuffer, 16);
|
||||||
|
for (word i = 0; i < 2 - strlen(myBuffer); i++) {
|
||||||
|
print_Msg(F("0"));
|
||||||
|
}
|
||||||
|
// Now print the significant bits
|
||||||
|
print_Msg(myBuffer);
|
||||||
|
print_Msg(" ");
|
||||||
|
}
|
||||||
|
println_Msg("");
|
||||||
|
}
|
||||||
|
display_Update();
|
||||||
|
}
|
||||||
|
|
||||||
boolean getMapping() {
|
boolean getMapping() {
|
||||||
display_Clear();
|
display_Clear();
|
||||||
println_Msg(F("Searching database"));
|
println_Msg(F("Searching database"));
|
||||||
@ -463,6 +489,7 @@ boolean getMapping() {
|
|||||||
romName[1] = 'A';
|
romName[1] = 'A';
|
||||||
romName[2] = 'R';
|
romName[2] = 'R';
|
||||||
romName[3] = 'T';
|
romName[3] = 'T';
|
||||||
|
romName[4] = '\0';
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
@ -720,6 +747,7 @@ boolean getMapping() {
|
|||||||
romName[1] = 'A';
|
romName[1] = 'A';
|
||||||
romName[2] = 'R';
|
romName[2] = 'R';
|
||||||
romName[3] = 'T';
|
romName[3] = 'T';
|
||||||
|
romName[4] = '\0';
|
||||||
}
|
}
|
||||||
|
|
||||||
// Save Mapper
|
// Save Mapper
|
||||||
@ -742,10 +770,12 @@ boolean getMapping() {
|
|||||||
println_Msg(F("Using manual selection"));
|
println_Msg(F("Using manual selection"));
|
||||||
display_Update();
|
display_Update();
|
||||||
delay(1000);
|
delay(1000);
|
||||||
|
printPRG();
|
||||||
romName[0] = 'C';
|
romName[0] = 'C';
|
||||||
romName[1] = 'A';
|
romName[1] = 'A';
|
||||||
romName[2] = 'R';
|
romName[2] = 'R';
|
||||||
romName[3] = 'T';
|
romName[3] = 'T';
|
||||||
|
romName[4] = '\0';
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1006,6 +1036,7 @@ void selectMapping() {
|
|||||||
romName[1] = 'A';
|
romName[1] = 'A';
|
||||||
romName[2] = 'R';
|
romName[2] = 'R';
|
||||||
romName[3] = 'T';
|
romName[3] = 'T';
|
||||||
|
romName[4] = '\0';
|
||||||
}
|
}
|
||||||
|
|
||||||
// Save Mapper
|
// Save Mapper
|
||||||
@ -3039,9 +3070,9 @@ void readPRG(boolean readrom) {
|
|||||||
banks = int_pow(2, prgsize);
|
banks = int_pow(2, prgsize);
|
||||||
for (int i = 0; i < banks; i++) { // 256K/512K
|
for (int i = 0; i < banks; i++) { // 256K/512K
|
||||||
if (flashfound)
|
if (flashfound)
|
||||||
write_prg_byte(0xC000+i, i); // Flashable
|
write_prg_byte(0xC000 + i, i); // Flashable
|
||||||
else
|
else
|
||||||
write_prg_byte(0x8000+i, i); // Non-Flashable
|
write_prg_byte(0x8000 + i, i); // Non-Flashable
|
||||||
for (word address = 0x0; address < 0x4000; address += 512) { // 16K Banks ($8000-$BFFF)
|
for (word address = 0x0; address < 0x4000; address += 512) { // 16K Banks ($8000-$BFFF)
|
||||||
dumpPRG(base, address);
|
dumpPRG(base, address);
|
||||||
}
|
}
|
||||||
@ -3275,7 +3306,7 @@ void readPRG(boolean readrom) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 93:
|
case 93:
|
||||||
banks = int_pow(2, prgsize);
|
banks = int_pow(2, prgsize);
|
||||||
for (int i = 0; i < banks; i++) {
|
for (int i = 0; i < banks; i++) {
|
||||||
@ -3286,7 +3317,7 @@ void readPRG(boolean readrom) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 94:
|
case 94:
|
||||||
banks = int_pow(2, prgsize);
|
banks = int_pow(2, prgsize);
|
||||||
for (int i = 0; i < banks; i++) { // 128K
|
for (int i = 0; i < banks; i++) { // 128K
|
||||||
|
Loading…
Reference in New Issue
Block a user