mirror of
https://github.com/sanni/cartreader.git
synced 2024-11-24 05:29:17 +01:00
Merge pull request #56 from jiyunomegami/master
SMS retrode plugin changes and small bug fix of flash error checking
This commit is contained in:
commit
6ffd175e7b
@ -1021,6 +1021,7 @@ int busyCheck29F032(uint32_t addr, byte c) {
|
|||||||
// Under these conditions DQ 5 will produce a “1”.
|
// Under these conditions DQ 5 will produce a “1”.
|
||||||
// This is a failure condition which indicates that the program or erase cycle was not successfully completed.
|
// This is a failure condition which indicates that the program or erase cycle was not successfully completed.
|
||||||
// Note : DQ 7 is rechecked even if DQ 5 = “1” because DQ 7 may change simultaneously with DQ 5 .
|
// Note : DQ 7 is rechecked even if DQ 5 = “1” because DQ 7 may change simultaneously with DQ 5 .
|
||||||
|
d = readByte_Flash(addr);
|
||||||
if ((d & 0x80) == (c & 0x80)) {
|
if ((d & 0x80) == (c & 0x80)) {
|
||||||
break;
|
break;
|
||||||
} else {
|
} else {
|
||||||
|
@ -16,12 +16,13 @@
|
|||||||
static const char SMSMenuItem1[] PROGMEM = "Read Rom";
|
static const char SMSMenuItem1[] PROGMEM = "Read Rom";
|
||||||
static const char SMSMenuItem2[] PROGMEM = "Read from SRAM";
|
static const char SMSMenuItem2[] PROGMEM = "Read from SRAM";
|
||||||
static const char SMSMenuItem3[] PROGMEM = "Write to SRAM";
|
static const char SMSMenuItem3[] PROGMEM = "Write to SRAM";
|
||||||
static const char SMSMenuItem4[] PROGMEM = "Toggle Retrode Mode";
|
static const char SMSMenuItem4[] PROGMEM = "Change Retrode Mode";
|
||||||
static const char SMSMenuItem5[] PROGMEM = "Reset";
|
static const char SMSMenuItem5[] PROGMEM = "Reset";
|
||||||
static const char* const menuOptionsSMS[] PROGMEM = {SMSMenuItem1, SMSMenuItem2, SMSMenuItem3, SMSMenuItem4, SMSMenuItem5};
|
static const char* const menuOptionsSMS[] PROGMEM = {SMSMenuItem1, SMSMenuItem2, SMSMenuItem3, SMSMenuItem4, SMSMenuItem5};
|
||||||
|
|
||||||
// Set retrode_mode to true when using a retrode SMS/GG adapter
|
// Set retrode_mode to true when using a retrode SMS/GG adapter
|
||||||
static bool retrode_mode = false;
|
static bool retrode_mode = false;
|
||||||
|
static bool retrode_mode_sms = false; // true: SMS/Mark3 false: GG
|
||||||
|
|
||||||
void _smsMenu() {
|
void _smsMenu() {
|
||||||
// create menu with title and 2 options to choose from
|
// create menu with title and 2 options to choose from
|
||||||
@ -29,7 +30,7 @@ void _smsMenu() {
|
|||||||
// Copy menuOptions out of progmem
|
// Copy menuOptions out of progmem
|
||||||
int noptions = sizeof(menuOptionsSMS) / sizeof(menuOptionsSMS[0]);
|
int noptions = sizeof(menuOptionsSMS) / sizeof(menuOptionsSMS[0]);
|
||||||
convertPgm(menuOptionsSMS, noptions);
|
convertPgm(menuOptionsSMS, noptions);
|
||||||
mainMenu = question_box(retrode_mode ? F("SMS/GG Retrode:YES") : F("SMS/GG Retrode:NO"), menuOptions, noptions, 0);
|
mainMenu = question_box(retrode_mode ? (retrode_mode_sms ? F("Retrode:SMS") : F("Retrode:GG")) : F("SMS/GG Retrode:NO"), menuOptions, noptions, 0);
|
||||||
|
|
||||||
// wait for user choice to come back from the question box menu
|
// wait for user choice to come back from the question box menu
|
||||||
switch (mainMenu)
|
switch (mainMenu)
|
||||||
@ -62,7 +63,17 @@ void _smsMenu() {
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case 3:
|
case 3:
|
||||||
retrode_mode = !retrode_mode;
|
if (!retrode_mode && !retrode_mode_sms) {
|
||||||
|
// first state (default)
|
||||||
|
retrode_mode = true; // Change to GG
|
||||||
|
} else if (retrode_mode && !retrode_mode_sms) {
|
||||||
|
// second state
|
||||||
|
retrode_mode_sms = true; // Change to SMS
|
||||||
|
} else {
|
||||||
|
// third state, reset to the first state
|
||||||
|
retrode_mode = false;
|
||||||
|
retrode_mode_sms = false;
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 4:
|
case 4:
|
||||||
@ -70,7 +81,7 @@ void _smsMenu() {
|
|||||||
resetArduino();
|
resetArduino();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
println_Msg(retrode_mode ? F("Retrode Mode On") : F("Retrode Mode Off"));
|
println_Msg(retrode_mode ? (retrode_mode_sms ? F("Retrode Mode SMS") : F("Retrode Mode GG")) : F("Retrode Mode Off"));
|
||||||
println_Msg(F(""));
|
println_Msg(F(""));
|
||||||
println_Msg(F("Press Button..."));
|
println_Msg(F("Press Button..."));
|
||||||
display_Update();
|
display_Update();
|
||||||
@ -145,7 +156,7 @@ void setup_SMS() {
|
|||||||
Low level functions
|
Low level functions
|
||||||
*****************************************/
|
*****************************************/
|
||||||
void writeByte_SMS(word myAddress, byte myData) {
|
void writeByte_SMS(word myAddress, byte myData) {
|
||||||
if (retrode_mode) {
|
if (retrode_mode && !retrode_mode_sms) {
|
||||||
// Set Data Pins (D8-D15) to Output
|
// Set Data Pins (D8-D15) to Output
|
||||||
DDRA = 0xFF;
|
DDRA = 0xFF;
|
||||||
} else {
|
} else {
|
||||||
@ -162,7 +173,7 @@ void writeByte_SMS(word myAddress, byte myData) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Output data
|
// Output data
|
||||||
if (retrode_mode) {
|
if (retrode_mode && !retrode_mode_sms) {
|
||||||
PORTA = myData;
|
PORTA = myData;
|
||||||
} else {
|
} else {
|
||||||
PORTC = myData;
|
PORTC = myData;
|
||||||
@ -198,7 +209,7 @@ void writeByte_SMS(word myAddress, byte myData) {
|
|||||||
// Leave WR high for at least 50ns
|
// Leave WR high for at least 50ns
|
||||||
__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");
|
||||||
|
|
||||||
if (retrode_mode) {
|
if (retrode_mode && !retrode_mode_sms) {
|
||||||
// Set Data Pins (D8-D15) to Input
|
// Set Data Pins (D8-D15) to Input
|
||||||
DDRA = 0x00;
|
DDRA = 0x00;
|
||||||
} else {
|
} else {
|
||||||
@ -208,7 +219,7 @@ void writeByte_SMS(word myAddress, byte myData) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
byte readByte_SMS(word myAddress) {
|
byte readByte_SMS(word myAddress) {
|
||||||
if (retrode_mode) {
|
if (retrode_mode && !retrode_mode_sms) {
|
||||||
// Set Data Pins (D8-D15) to Input
|
// Set Data Pins (D8-D15) to Input
|
||||||
DDRA = 0x00;
|
DDRA = 0x00;
|
||||||
} else {
|
} else {
|
||||||
@ -239,7 +250,7 @@ byte readByte_SMS(word myAddress) {
|
|||||||
__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");
|
||||||
|
|
||||||
// Read
|
// Read
|
||||||
byte tempByte = retrode_mode ? PINA : PINC;
|
byte tempByte = (retrode_mode && !retrode_mode_sms) ? PINA : PINC;
|
||||||
|
|
||||||
if (retrode_mode) {
|
if (retrode_mode) {
|
||||||
// Switch RD(PL6) and OE(PH6) to HIGH
|
// Switch RD(PL6) and OE(PH6) to HIGH
|
||||||
@ -293,11 +304,7 @@ void getCartInfo_SMS() {
|
|||||||
cartSize = 128 * 1024UL;
|
cartSize = 128 * 1024UL;
|
||||||
break;
|
break;
|
||||||
case 0x0:
|
case 0x0:
|
||||||
if (retrode_mode) {
|
cartSize = 256 * 1024UL;
|
||||||
cartSize = 512 * 1024UL;
|
|
||||||
} else {
|
|
||||||
cartSize = 256 * 1024UL;
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
case 0x1:
|
case 0x1:
|
||||||
cartSize = 512 * 1024UL;
|
cartSize = 512 * 1024UL;
|
||||||
@ -313,12 +320,41 @@ void getCartInfo_SMS() {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Read TMR Sega string
|
// Read TMR SEGA string
|
||||||
for (byte i = 0; i < 8; i++) {
|
for (byte i = 0; i < 8; i++) {
|
||||||
romName[i] = char(readByte_SMS(0x7ff0 + i));
|
romName[i] = char(readByte_SMS(0x7ff0 + i));
|
||||||
}
|
}
|
||||||
romName[8] = '\0';
|
romName[8] = '\0';
|
||||||
|
|
||||||
|
// Attempt to detect cart size by checking if TMR SEGA is mirrored
|
||||||
|
unsigned long mirror_offset = cartSize;
|
||||||
|
char romName2[9];
|
||||||
|
while (mirror_offset < 1024 * 1024UL) {
|
||||||
|
byte bank = 1 + (mirror_offset / (16 * 1024UL));
|
||||||
|
writeByte_SMS(0xFFFE, bank);
|
||||||
|
for (byte i = 0; i < 8; i++) {
|
||||||
|
romName2[i] = char(readByte_SMS(0x7ff0 + i));
|
||||||
|
}
|
||||||
|
romName2[8] = '\0';
|
||||||
|
// print_Msg(F("Name2: "));
|
||||||
|
// println_Msg(romName2);
|
||||||
|
// print_Msg(F("from bank "));
|
||||||
|
// print_Msg(bank);
|
||||||
|
// print_Msg(F(" offset "));
|
||||||
|
// print_Msg_PaddedHex32(mirror_offset + 0x7ff0);
|
||||||
|
// println_Msg(F(""));
|
||||||
|
if (strcmp(romName2, romName) == 0) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (cartSize == 48 * 1024UL) {
|
||||||
|
cartSize = 64 * 1024UL;
|
||||||
|
} else {
|
||||||
|
cartSize *= 2;
|
||||||
|
}
|
||||||
|
mirror_offset = cartSize;
|
||||||
|
}
|
||||||
|
writeByte_SMS(0xFFFE, 1);
|
||||||
|
|
||||||
display_Clear();
|
display_Clear();
|
||||||
println_Msg(F("Cart Info"));
|
println_Msg(F("Cart Info"));
|
||||||
println_Msg(F(" "));
|
println_Msg(F(" "));
|
||||||
@ -384,6 +420,21 @@ void readROM_SMS() {
|
|||||||
for (int currByte = 0; currByte < 512; currByte++) {
|
for (int currByte = 0; currByte < 512; currByte++) {
|
||||||
sdBuffer[currByte] = readByte_SMS(0x8000 + currBuffer + currByte);
|
sdBuffer[currByte] = readByte_SMS(0x8000 + currBuffer + currByte);
|
||||||
}
|
}
|
||||||
|
// hexdump for debugging:
|
||||||
|
// if (currBank == 0 && currBuffer == 0) {
|
||||||
|
// for (word xi = 0; xi < 0x100; xi++) {
|
||||||
|
// if (xi%16==0) {
|
||||||
|
// print_Msg_PaddedHex16(xi);
|
||||||
|
// print_Msg(F(" "));
|
||||||
|
// }
|
||||||
|
// print_Msg_PaddedHexByte(sdBuffer[xi]);
|
||||||
|
// if (xi>0&&((xi+1)%16)==0) {
|
||||||
|
// println_Msg(F(""));
|
||||||
|
// } else {
|
||||||
|
// print_Msg(F(" "));
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
// }
|
||||||
myFile.write(sdBuffer, 512);
|
myFile.write(sdBuffer, 512);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user