From d2b9a5d9b95b5a72ff560c863ec4d826f38c4563 Mon Sep 17 00:00:00 2001 From: Gabriel Marcano Date: Sun, 22 Dec 2024 22:00:13 -0800 Subject: [PATCH] Update GB.ino - Move shared GB port initialization into its own function --- Cart_Reader/GB.ino | 90 ++++++++++++++++++---------------------------- 1 file changed, 35 insertions(+), 55 deletions(-) diff --git a/Cart_Reader/GB.ino b/Cart_Reader/GB.ino index bbbf6d9..d6e2327 100644 --- a/Cart_Reader/GB.ino +++ b/Cart_Reader/GB.ino @@ -71,7 +71,7 @@ bool gbxFlashCFI() { sd.chdir("/"); // Launch filebrowser filePath[0] = '\0'; - sd.chdir("/"); + fileBrowser(FS(FSTRING_SELECT_FILE)); display_Clear(); identifyCFI_GB(); @@ -95,6 +95,36 @@ void feedbackPressAndReset() { resetArduino(); } +// Common code for setting up GB port used by GB carts, Datel, +// Pelican Codebreaker, MonsterBrain +void setup_GBPort() { + // Set Address Pins to Output + //A0-A7 + DDRF = 0xFF; + //A8-A15 + DDRK = 0xFF; + + // Set Control Pins to Output RST(PH0) CLK(PH1) CS(PH3) WR(PH5) RD(PH6) + DDRH |= (1 << 0) | (1 << 1) | (1 << 3) | (1 << 5) | (1 << 6); + // Output a high signal on all pins, pins are active low therefore everything is disabled now + PORTH |= (1 << 3) | (1 << 5) | (1 << 6); + // Output a low signal on CLK(PH1) to disable writing GB Camera RAM + // Output a low signal on RST(PH0) to initialize MMC correctly + PORTH &= ~((1 << 0) | (1 << 1)); + + /* FIXME setup_GB sets this up too. Should this also for Datel and others? + // Set Audio-In(PH4) to Input + DDRH &= ~(1 << 4); + // Enable Internal Pullup + PORTH |= (1 << 4); + */ + + // Set Data Pins (D0-D7) to Input + DDRC = 0x00; + // Enable Internal Pullups + PORTC = 0xFF; +} + // Start menu for both GB and GBA void gbxMenu() { // create menu with title and 5 options to choose from @@ -368,24 +398,7 @@ void gbxMenu() { case 4: // Read or Write a Pelican Codebreaker or MonsterBrain - // Set Address Pins to Output - //A0-A7 - DDRF = 0xFF; - //A8-A15 - DDRK = 0xFF; - - // Set Control Pins to Output RST(PH0) CLK(PH1) CS(PH3) WR(PH5) RD(PH6) - DDRH |= (1 << 0) | (1 << 1) | (1 << 3) | (1 << 5) | (1 << 6); - // Output a high signal on all pins, pins are active low therefore everything is disabled now - PORTH |= (1 << 3) | (1 << 5) | (1 << 6); - // Output a low signal on CLK(PH1) to disable writing GB Camera RAM - // Output a low signal on RST(PH0) to initialize MMC correctly - PORTH &= ~((1 << 0) | (1 << 1)); - - // Set Data Pins (D0-D7) to Input - DDRC = 0x00; - // Enable Internal Pullups - PORTC = 0xFF; + setup_GBPort(); delay(400); @@ -415,24 +428,7 @@ void gbxMenu() { case 5: // Read or Write a Datel Device (Mega Memory Card and Gameshark) - // Set Address Pins to Output - //A0-A7 - DDRF = 0xFF; - //A8-A15 - DDRK = 0xFF; - - // Set Control Pins to Output RST(PH0) CLK(PH1) CS(PH3) WR(PH5) RD(PH6) - DDRH |= (1 << 0) | (1 << 1) | (1 << 3) | (1 << 5) | (1 << 6); - // Output a high signal on all pins, pins are active low therefore everything is disabled now - PORTH |= (1 << 3) | (1 << 5) | (1 << 6); - // Output a low signal on CLK(PH1) to disable writing GB Camera RAM - // Output a low signal on RST(PH0) to initialize MMC correctly - PORTH &= ~((1 << 0) | (1 << 1)); - - // Set Data Pins (D0-D7) to Input - DDRC = 0x00; - // Enable Internal Pullups - PORTC = 0xFF; + setup_GBPort(); delay(400); @@ -567,30 +563,14 @@ void setup_GB() { // Request 5V setVoltage(VOLTS_SET_5V); - // Set Address Pins to Output - //A0-A7 - DDRF = 0xFF; - //A8-A15 - DDRK = 0xFF; - - // Set Control Pins to Output RST(PH0) CLK(PH1) CS(PH3) WR(PH5) RD(PH6) - DDRH |= (1 << 0) | (1 << 1) | (1 << 3) | (1 << 5) | (1 << 6); - // Output a high signal on all pins, pins are active low therefore everything is disabled now - PORTH |= (1 << 3) | (1 << 5) | (1 << 6); - // Output a low signal on CLK(PH1) to disable writing GB Camera RAM - // Output a low signal on RST(PH0) to initialize MMC correctly - PORTH &= ~((1 << 0) | (1 << 1)); + setup_GBPort(); + // FIXME for now setup_GBPort doesn't set these ones up // Set Audio-In(PH4) to Input DDRH &= ~(1 << 4); // Enable Internal Pullup PORTH |= (1 << 4); - // Set Data Pins (D0-D7) to Input - DDRC = 0x00; - // Enable Internal Pullups - PORTC = 0xFF; - delay(400); // RST(PH0) to HIGH