mirror of
https://github.com/sanni/cartreader.git
synced 2025-01-13 21:49:07 +01:00
various: work on SNES SA-1 init / reset; LED: skip red in attract mode, as red usually indicates an error to the user
This commit is contained in:
parent
b8552090c8
commit
6c2b9a9732
@ -39,6 +39,8 @@
|
|||||||
Gens-gs - Megadrive checksum
|
Gens-gs - Megadrive checksum
|
||||||
|
|
||||||
**********************************************************************************/
|
**********************************************************************************/
|
||||||
|
#include <SdFat.h>
|
||||||
|
|
||||||
char ver[5] = "3.6";
|
char ver[5] = "3.6";
|
||||||
|
|
||||||
/******************************************
|
/******************************************
|
||||||
@ -71,7 +73,6 @@ char ver[5] = "3.6";
|
|||||||
#include <avr/wdt.h>
|
#include <avr/wdt.h>
|
||||||
|
|
||||||
// SD Card
|
// SD Card
|
||||||
#include <SdFat.h>
|
|
||||||
#define sdSpeed SPI_FULL_SPEED
|
#define sdSpeed SPI_FULL_SPEED
|
||||||
// SD Card (Pin 50 = MISO, Pin 51 = MOSI, Pin 52 = SCK, Pin 53 = SS)
|
// SD Card (Pin 50 = MISO, Pin 51 = MOSI, Pin 52 = SCK, Pin 53 = SS)
|
||||||
#define chipSelectPin 53
|
#define chipSelectPin 53
|
||||||
@ -1158,6 +1159,9 @@ unsigned char questionBox_OLED(const __FlashStringHelper* question, char answers
|
|||||||
if ((millis() - idleTime) % 4000 == 0) {
|
if ((millis() - idleTime) % 4000 == 0) {
|
||||||
if (currentColor < 7) {
|
if (currentColor < 7) {
|
||||||
currentColor++;
|
currentColor++;
|
||||||
|
if (currentColor == 1) {
|
||||||
|
currentColor = 2; // skip red as that signifies an error to the user
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
currentColor = 0;
|
currentColor = 0;
|
||||||
|
@ -216,6 +216,11 @@ void snesMenu() {
|
|||||||
DDRH |= (1 << 0);
|
DDRH |= (1 << 0);
|
||||||
// Switch RST(PH0) to LOW
|
// Switch RST(PH0) to LOW
|
||||||
PORTH &= ~(1 << 0);
|
PORTH &= ~(1 << 0);
|
||||||
|
|
||||||
|
// Note: It is probably not intended to reset CIC or clocks here
|
||||||
|
// But if that's false, uncomment this:
|
||||||
|
// stopSnesClocks_resetCic_resetCart();
|
||||||
|
|
||||||
display_Clear();
|
display_Clear();
|
||||||
print_Msg(F("Resetting..."));
|
print_Msg(F("Resetting..."));
|
||||||
display_Update();
|
display_Update();
|
||||||
@ -224,6 +229,7 @@ void snesMenu() {
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case 5:
|
case 5:
|
||||||
|
stopSnesClocks_resetCic_resetCart();
|
||||||
resetArduino();
|
resetArduino();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -270,11 +276,22 @@ void confMenu() {
|
|||||||
|
|
||||||
case 4:
|
case 4:
|
||||||
// Reset
|
// Reset
|
||||||
|
stopSnesClocks_resetCic_resetCart();
|
||||||
resetArduino();
|
resetArduino();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void stopSnesClocks_resetCic_resetCart() {
|
||||||
|
DDRG |= (1 << 1); // Set cicrstPin(PG1) to Output
|
||||||
|
PORTG |= (1 << 1); // pull high = reset CIC
|
||||||
|
DDRH |= (1 << 0); // Set RST(PH0) pin to Output
|
||||||
|
PORTH &= ~(1 << 0); // Switch RST(PH0) to LOW
|
||||||
|
clockgen.output_enable(SI5351_CLK1, 0); // CPU clock
|
||||||
|
clockgen.output_enable(SI5351_CLK2, 0); // CIC clock
|
||||||
|
clockgen.output_enable(SI5351_CLK0, 0); // master clock
|
||||||
|
}
|
||||||
|
|
||||||
/******************************************
|
/******************************************
|
||||||
Setup
|
Setup
|
||||||
*****************************************/
|
*****************************************/
|
||||||
@ -286,16 +303,6 @@ void setup_Snes() {
|
|||||||
// Set cichstPin(PG0) to Input
|
// Set cichstPin(PG0) to Input
|
||||||
DDRG &= ~(1 << 0);
|
DDRG &= ~(1 << 0);
|
||||||
|
|
||||||
// Adafruit Clock Generator
|
|
||||||
clockgen.init(SI5351_CRYSTAL_LOAD_8PF, 0, 0);
|
|
||||||
clockgen.set_pll(SI5351_PLL_FIXED, SI5351_PLLA);
|
|
||||||
clockgen.set_pll(SI5351_PLL_FIXED, SI5351_PLLB);
|
|
||||||
clockgen.set_freq(2147727200ULL, SI5351_CLK0);
|
|
||||||
clockgen.set_freq(307200000ULL, SI5351_CLK2);
|
|
||||||
clockgen.output_enable(SI5351_CLK0, 1);
|
|
||||||
clockgen.output_enable(SI5351_CLK1, 0);
|
|
||||||
clockgen.output_enable(SI5351_CLK2, 1);
|
|
||||||
|
|
||||||
// Set Address Pins to Output
|
// Set Address Pins to Output
|
||||||
//A0-A7
|
//A0-A7
|
||||||
DDRF = 0xFF;
|
DDRF = 0xFF;
|
||||||
@ -327,7 +334,7 @@ void setup_Snes() {
|
|||||||
// Activate Internal Pullup Resistors
|
// Activate Internal Pullup Resistors
|
||||||
//PORTH |= (1 << 4);
|
//PORTH |= (1 << 4);
|
||||||
|
|
||||||
// Set expand(PG5) to Imput
|
// Set expand(PG5) to Input
|
||||||
DDRG &= ~(1 << 5);
|
DDRG &= ~(1 << 5);
|
||||||
// Activate Internal Pullup Resistors
|
// Activate Internal Pullup Resistors
|
||||||
//PORTG |= (1 << 5);
|
//PORTG |= (1 << 5);
|
||||||
@ -348,11 +355,25 @@ void setup_Snes() {
|
|||||||
DDRJ |= (1 << 0);
|
DDRJ |= (1 << 0);
|
||||||
//PORTJ &= ~(1 << 0);
|
//PORTJ &= ~(1 << 0);
|
||||||
|
|
||||||
|
// Adafruit Clock Generator
|
||||||
|
clockgen.init(SI5351_CRYSTAL_LOAD_8PF, 0, 0);
|
||||||
|
clockgen.set_pll(SI5351_PLL_FIXED, SI5351_PLLA);
|
||||||
|
clockgen.set_pll(SI5351_PLL_FIXED, SI5351_PLLB);
|
||||||
|
clockgen.set_freq(2147727200ULL, SI5351_CLK0);
|
||||||
|
clockgen.set_freq(357954500ULL, SI5351_CLK1);
|
||||||
|
clockgen.set_freq(307200000ULL, SI5351_CLK2);
|
||||||
|
|
||||||
|
// start outputting master clock, CIC clock
|
||||||
|
clockgen.output_enable(SI5351_CLK1, 0); // no CPU clock yet; seems to affect SA-1 success a lot
|
||||||
|
clockgen.output_enable(SI5351_CLK2, 1); // CIC clock (should go before master clock)
|
||||||
|
clockgen.output_enable(SI5351_CLK0, 1); // master clock
|
||||||
|
delay(8);
|
||||||
|
|
||||||
// Start CIC by outputting a low signal to cicrstPin(PG1)
|
// Start CIC by outputting a low signal to cicrstPin(PG1)
|
||||||
PORTG &= ~(1 << 1);
|
PORTG &= ~(1 << 1);
|
||||||
|
|
||||||
// Wait for CIC reset
|
// Wait for CIC reset
|
||||||
delay(1000);
|
delay(320);
|
||||||
|
|
||||||
// Print all the info
|
// Print all the info
|
||||||
getCartInfo_SNES();
|
getCartInfo_SNES();
|
||||||
@ -1310,7 +1331,6 @@ void writeSRAM (boolean browseFile) {
|
|||||||
else if (romType == SA) {
|
else if (romType == SA) {
|
||||||
long lastByte = (long(sramSize) * 128);
|
long lastByte = (long(sramSize) * 128);
|
||||||
// Enable CPU Clock
|
// Enable CPU Clock
|
||||||
clockgen.set_freq(357954500ULL, SI5351_CLK1);
|
|
||||||
clockgen.output_enable(SI5351_CLK1, 1);
|
clockgen.output_enable(SI5351_CLK1, 1);
|
||||||
|
|
||||||
// Direct writes to BW-RAM (SRAM) in banks 0x40-0x43 don't work
|
// Direct writes to BW-RAM (SRAM) in banks 0x40-0x43 don't work
|
||||||
@ -1689,10 +1709,9 @@ unsigned long verifySRAM() {
|
|||||||
}
|
}
|
||||||
display_Update();
|
display_Update();
|
||||||
wait();
|
wait();
|
||||||
// Set reset pin to output (PH0)
|
|
||||||
DDRH |= (1 << 0);
|
stopSnesClocks_resetCic_resetCart();
|
||||||
// Switch RST(PH0) to LOW
|
|
||||||
PORTH &= ~(1 << 0);
|
|
||||||
display_Clear();
|
display_Clear();
|
||||||
print_Msg(F("Resetting..."));
|
print_Msg(F("Resetting..."));
|
||||||
display_Update();
|
display_Update();
|
||||||
@ -1808,7 +1827,6 @@ boolean eraseSRAM (byte b) {
|
|||||||
else if (romType == SA) {
|
else if (romType == SA) {
|
||||||
long lastByte = (long(sramSize) * 128);
|
long lastByte = (long(sramSize) * 128);
|
||||||
// Enable CPU Clock
|
// Enable CPU Clock
|
||||||
clockgen.set_freq(357954500ULL, SI5351_CLK1);
|
|
||||||
clockgen.output_enable(SI5351_CLK1, 1);
|
clockgen.output_enable(SI5351_CLK1, 1);
|
||||||
|
|
||||||
// Direct writes to BW-RAM (SRAM) in banks 0x40-0x43 don't work
|
// Direct writes to BW-RAM (SRAM) in banks 0x40-0x43 don't work
|
||||||
|
Loading…
x
Reference in New Issue
Block a user