mirror of
https://github.com/sanni/cartreader.git
synced 2024-11-15 01:15:06 +01:00
Output clock signal during self test
This commit is contained in:
parent
324de5463b
commit
dcadcde877
@ -357,49 +357,49 @@ byte iNES_HEADER[16];
|
|||||||
//******************************************
|
//******************************************
|
||||||
// CRC32 lookup table // 256 entries
|
// CRC32 lookup table // 256 entries
|
||||||
constexpr uint32_t crc_32_tab[] PROGMEM = { /* CRC polynomial 0xedb88320 */
|
constexpr uint32_t crc_32_tab[] PROGMEM = { /* CRC polynomial 0xedb88320 */
|
||||||
0x00000000, 0x77073096, 0xee0e612c, 0x990951ba, 0x076dc419, 0x706af48f,
|
0x00000000, 0x77073096, 0xee0e612c, 0x990951ba, 0x076dc419, 0x706af48f,
|
||||||
0xe963a535, 0x9e6495a3, 0x0edb8832, 0x79dcb8a4, 0xe0d5e91e, 0x97d2d988,
|
0xe963a535, 0x9e6495a3, 0x0edb8832, 0x79dcb8a4, 0xe0d5e91e, 0x97d2d988,
|
||||||
0x09b64c2b, 0x7eb17cbd, 0xe7b82d07, 0x90bf1d91, 0x1db71064, 0x6ab020f2,
|
0x09b64c2b, 0x7eb17cbd, 0xe7b82d07, 0x90bf1d91, 0x1db71064, 0x6ab020f2,
|
||||||
0xf3b97148, 0x84be41de, 0x1adad47d, 0x6ddde4eb, 0xf4d4b551, 0x83d385c7,
|
0xf3b97148, 0x84be41de, 0x1adad47d, 0x6ddde4eb, 0xf4d4b551, 0x83d385c7,
|
||||||
0x136c9856, 0x646ba8c0, 0xfd62f97a, 0x8a65c9ec, 0x14015c4f, 0x63066cd9,
|
0x136c9856, 0x646ba8c0, 0xfd62f97a, 0x8a65c9ec, 0x14015c4f, 0x63066cd9,
|
||||||
0xfa0f3d63, 0x8d080df5, 0x3b6e20c8, 0x4c69105e, 0xd56041e4, 0xa2677172,
|
0xfa0f3d63, 0x8d080df5, 0x3b6e20c8, 0x4c69105e, 0xd56041e4, 0xa2677172,
|
||||||
0x3c03e4d1, 0x4b04d447, 0xd20d85fd, 0xa50ab56b, 0x35b5a8fa, 0x42b2986c,
|
0x3c03e4d1, 0x4b04d447, 0xd20d85fd, 0xa50ab56b, 0x35b5a8fa, 0x42b2986c,
|
||||||
0xdbbbc9d6, 0xacbcf940, 0x32d86ce3, 0x45df5c75, 0xdcd60dcf, 0xabd13d59,
|
0xdbbbc9d6, 0xacbcf940, 0x32d86ce3, 0x45df5c75, 0xdcd60dcf, 0xabd13d59,
|
||||||
0x26d930ac, 0x51de003a, 0xc8d75180, 0xbfd06116, 0x21b4f4b5, 0x56b3c423,
|
0x26d930ac, 0x51de003a, 0xc8d75180, 0xbfd06116, 0x21b4f4b5, 0x56b3c423,
|
||||||
0xcfba9599, 0xb8bda50f, 0x2802b89e, 0x5f058808, 0xc60cd9b2, 0xb10be924,
|
0xcfba9599, 0xb8bda50f, 0x2802b89e, 0x5f058808, 0xc60cd9b2, 0xb10be924,
|
||||||
0x2f6f7c87, 0x58684c11, 0xc1611dab, 0xb6662d3d, 0x76dc4190, 0x01db7106,
|
0x2f6f7c87, 0x58684c11, 0xc1611dab, 0xb6662d3d, 0x76dc4190, 0x01db7106,
|
||||||
0x98d220bc, 0xefd5102a, 0x71b18589, 0x06b6b51f, 0x9fbfe4a5, 0xe8b8d433,
|
0x98d220bc, 0xefd5102a, 0x71b18589, 0x06b6b51f, 0x9fbfe4a5, 0xe8b8d433,
|
||||||
0x7807c9a2, 0x0f00f934, 0x9609a88e, 0xe10e9818, 0x7f6a0dbb, 0x086d3d2d,
|
0x7807c9a2, 0x0f00f934, 0x9609a88e, 0xe10e9818, 0x7f6a0dbb, 0x086d3d2d,
|
||||||
0x91646c97, 0xe6635c01, 0x6b6b51f4, 0x1c6c6162, 0x856530d8, 0xf262004e,
|
0x91646c97, 0xe6635c01, 0x6b6b51f4, 0x1c6c6162, 0x856530d8, 0xf262004e,
|
||||||
0x6c0695ed, 0x1b01a57b, 0x8208f4c1, 0xf50fc457, 0x65b0d9c6, 0x12b7e950,
|
0x6c0695ed, 0x1b01a57b, 0x8208f4c1, 0xf50fc457, 0x65b0d9c6, 0x12b7e950,
|
||||||
0x8bbeb8ea, 0xfcb9887c, 0x62dd1ddf, 0x15da2d49, 0x8cd37cf3, 0xfbd44c65,
|
0x8bbeb8ea, 0xfcb9887c, 0x62dd1ddf, 0x15da2d49, 0x8cd37cf3, 0xfbd44c65,
|
||||||
0x4db26158, 0x3ab551ce, 0xa3bc0074, 0xd4bb30e2, 0x4adfa541, 0x3dd895d7,
|
0x4db26158, 0x3ab551ce, 0xa3bc0074, 0xd4bb30e2, 0x4adfa541, 0x3dd895d7,
|
||||||
0xa4d1c46d, 0xd3d6f4fb, 0x4369e96a, 0x346ed9fc, 0xad678846, 0xda60b8d0,
|
0xa4d1c46d, 0xd3d6f4fb, 0x4369e96a, 0x346ed9fc, 0xad678846, 0xda60b8d0,
|
||||||
0x44042d73, 0x33031de5, 0xaa0a4c5f, 0xdd0d7cc9, 0x5005713c, 0x270241aa,
|
0x44042d73, 0x33031de5, 0xaa0a4c5f, 0xdd0d7cc9, 0x5005713c, 0x270241aa,
|
||||||
0xbe0b1010, 0xc90c2086, 0x5768b525, 0x206f85b3, 0xb966d409, 0xce61e49f,
|
0xbe0b1010, 0xc90c2086, 0x5768b525, 0x206f85b3, 0xb966d409, 0xce61e49f,
|
||||||
0x5edef90e, 0x29d9c998, 0xb0d09822, 0xc7d7a8b4, 0x59b33d17, 0x2eb40d81,
|
0x5edef90e, 0x29d9c998, 0xb0d09822, 0xc7d7a8b4, 0x59b33d17, 0x2eb40d81,
|
||||||
0xb7bd5c3b, 0xc0ba6cad, 0xedb88320, 0x9abfb3b6, 0x03b6e20c, 0x74b1d29a,
|
0xb7bd5c3b, 0xc0ba6cad, 0xedb88320, 0x9abfb3b6, 0x03b6e20c, 0x74b1d29a,
|
||||||
0xead54739, 0x9dd277af, 0x04db2615, 0x73dc1683, 0xe3630b12, 0x94643b84,
|
0xead54739, 0x9dd277af, 0x04db2615, 0x73dc1683, 0xe3630b12, 0x94643b84,
|
||||||
0x0d6d6a3e, 0x7a6a5aa8, 0xe40ecf0b, 0x9309ff9d, 0x0a00ae27, 0x7d079eb1,
|
0x0d6d6a3e, 0x7a6a5aa8, 0xe40ecf0b, 0x9309ff9d, 0x0a00ae27, 0x7d079eb1,
|
||||||
0xf00f9344, 0x8708a3d2, 0x1e01f268, 0x6906c2fe, 0xf762575d, 0x806567cb,
|
0xf00f9344, 0x8708a3d2, 0x1e01f268, 0x6906c2fe, 0xf762575d, 0x806567cb,
|
||||||
0x196c3671, 0x6e6b06e7, 0xfed41b76, 0x89d32be0, 0x10da7a5a, 0x67dd4acc,
|
0x196c3671, 0x6e6b06e7, 0xfed41b76, 0x89d32be0, 0x10da7a5a, 0x67dd4acc,
|
||||||
0xf9b9df6f, 0x8ebeeff9, 0x17b7be43, 0x60b08ed5, 0xd6d6a3e8, 0xa1d1937e,
|
0xf9b9df6f, 0x8ebeeff9, 0x17b7be43, 0x60b08ed5, 0xd6d6a3e8, 0xa1d1937e,
|
||||||
0x38d8c2c4, 0x4fdff252, 0xd1bb67f1, 0xa6bc5767, 0x3fb506dd, 0x48b2364b,
|
0x38d8c2c4, 0x4fdff252, 0xd1bb67f1, 0xa6bc5767, 0x3fb506dd, 0x48b2364b,
|
||||||
0xd80d2bda, 0xaf0a1b4c, 0x36034af6, 0x41047a60, 0xdf60efc3, 0xa867df55,
|
0xd80d2bda, 0xaf0a1b4c, 0x36034af6, 0x41047a60, 0xdf60efc3, 0xa867df55,
|
||||||
0x316e8eef, 0x4669be79, 0xcb61b38c, 0xbc66831a, 0x256fd2a0, 0x5268e236,
|
0x316e8eef, 0x4669be79, 0xcb61b38c, 0xbc66831a, 0x256fd2a0, 0x5268e236,
|
||||||
0xcc0c7795, 0xbb0b4703, 0x220216b9, 0x5505262f, 0xc5ba3bbe, 0xb2bd0b28,
|
0xcc0c7795, 0xbb0b4703, 0x220216b9, 0x5505262f, 0xc5ba3bbe, 0xb2bd0b28,
|
||||||
0x2bb45a92, 0x5cb36a04, 0xc2d7ffa7, 0xb5d0cf31, 0x2cd99e8b, 0x5bdeae1d,
|
0x2bb45a92, 0x5cb36a04, 0xc2d7ffa7, 0xb5d0cf31, 0x2cd99e8b, 0x5bdeae1d,
|
||||||
0x9b64c2b0, 0xec63f226, 0x756aa39c, 0x026d930a, 0x9c0906a9, 0xeb0e363f,
|
0x9b64c2b0, 0xec63f226, 0x756aa39c, 0x026d930a, 0x9c0906a9, 0xeb0e363f,
|
||||||
0x72076785, 0x05005713, 0x95bf4a82, 0xe2b87a14, 0x7bb12bae, 0x0cb61b38,
|
0x72076785, 0x05005713, 0x95bf4a82, 0xe2b87a14, 0x7bb12bae, 0x0cb61b38,
|
||||||
0x92d28e9b, 0xe5d5be0d, 0x7cdcefb7, 0x0bdbdf21, 0x86d3d2d4, 0xf1d4e242,
|
0x92d28e9b, 0xe5d5be0d, 0x7cdcefb7, 0x0bdbdf21, 0x86d3d2d4, 0xf1d4e242,
|
||||||
0x68ddb3f8, 0x1fda836e, 0x81be16cd, 0xf6b9265b, 0x6fb077e1, 0x18b74777,
|
0x68ddb3f8, 0x1fda836e, 0x81be16cd, 0xf6b9265b, 0x6fb077e1, 0x18b74777,
|
||||||
0x88085ae6, 0xff0f6a70, 0x66063bca, 0x11010b5c, 0x8f659eff, 0xf862ae69,
|
0x88085ae6, 0xff0f6a70, 0x66063bca, 0x11010b5c, 0x8f659eff, 0xf862ae69,
|
||||||
0x616bffd3, 0x166ccf45, 0xa00ae278, 0xd70dd2ee, 0x4e048354, 0x3903b3c2,
|
0x616bffd3, 0x166ccf45, 0xa00ae278, 0xd70dd2ee, 0x4e048354, 0x3903b3c2,
|
||||||
0xa7672661, 0xd06016f7, 0x4969474d, 0x3e6e77db, 0xaed16a4a, 0xd9d65adc,
|
0xa7672661, 0xd06016f7, 0x4969474d, 0x3e6e77db, 0xaed16a4a, 0xd9d65adc,
|
||||||
0x40df0b66, 0x37d83bf0, 0xa9bcae53, 0xdebb9ec5, 0x47b2cf7f, 0x30b5ffe9,
|
0x40df0b66, 0x37d83bf0, 0xa9bcae53, 0xdebb9ec5, 0x47b2cf7f, 0x30b5ffe9,
|
||||||
0xbdbdf21c, 0xcabac28a, 0x53b39330, 0x24b4a3a6, 0xbad03605, 0xcdd70693,
|
0xbdbdf21c, 0xcabac28a, 0x53b39330, 0x24b4a3a6, 0xbad03605, 0xcdd70693,
|
||||||
0x54de5729, 0x23d967bf, 0xb3667a2e, 0xc4614ab8, 0x5d681b02, 0x2a6f2b94,
|
0x54de5729, 0x23d967bf, 0xb3667a2e, 0xc4614ab8, 0x5d681b02, 0x2a6f2b94,
|
||||||
0xb40bbe37, 0xc30c8ea1, 0x5a05df1b, 0x2d02ef8d
|
0xb40bbe37, 0xc30c8ea1, 0x5a05df1b, 0x2d02ef8d
|
||||||
};
|
};
|
||||||
|
|
||||||
// Defined as a macros, as compiler disregards inlining requests and these are
|
// Defined as a macros, as compiler disregards inlining requests and these are
|
||||||
@ -677,7 +677,7 @@ void createFolder(const char* system, const char* subfolder, const char* gameNam
|
|||||||
|
|
||||||
// create a new folder for the rom file
|
// create a new folder for the rom file
|
||||||
EEPROM_readAnything(0, foldern);
|
EEPROM_readAnything(0, foldern);
|
||||||
if(subfolder == NULL) {
|
if (subfolder == NULL) {
|
||||||
sprintf(folder, "%s/%s/%d", system, gameName, foldern);
|
sprintf(folder, "%s/%s/%d", system, gameName, foldern);
|
||||||
} else {
|
} else {
|
||||||
sprintf(folder, "%s/%s/%s/%d", system, subfolder, gameName, foldern);
|
sprintf(folder, "%s/%s/%s/%d", system, subfolder, gameName, foldern);
|
||||||
@ -688,7 +688,7 @@ void createFolder(const char* system, const char* subfolder, const char* gameNam
|
|||||||
|
|
||||||
void printAndIncrementFolder(bool displayClear = false) {
|
void printAndIncrementFolder(bool displayClear = false) {
|
||||||
// Save location
|
// Save location
|
||||||
if(displayClear) {
|
if (displayClear) {
|
||||||
display_Clear();
|
display_Clear();
|
||||||
}
|
}
|
||||||
print_STR(saving_to_STR, 0);
|
print_STR(saving_to_STR, 0);
|
||||||
@ -711,38 +711,35 @@ void createFolderAndOpenFile(const char* system, const char* subfolder, const ch
|
|||||||
|
|
||||||
// move file pointer to first game line with matching letter. If no match is found the last database entry is selected
|
// move file pointer to first game line with matching letter. If no match is found the last database entry is selected
|
||||||
void seek_first_letter_in_database(FsFile& database, byte myLetter) {
|
void seek_first_letter_in_database(FsFile& database, byte myLetter) {
|
||||||
char gamename_str[3];
|
char gamename_str[3];
|
||||||
#ifdef ENABLE_GLOBAL_LOG
|
#ifdef ENABLE_GLOBAL_LOG
|
||||||
// Disable log to prevent unnecessary logging
|
// Disable log to prevent unnecessary logging
|
||||||
println_Log(F("Select Mapping from List"));
|
println_Log(F("Select Mapping from List"));
|
||||||
dont_log = true;
|
dont_log = true;
|
||||||
#endif
|
#endif
|
||||||
database.rewind();
|
database.rewind();
|
||||||
// Skip ahead to selected starting letter
|
// Skip ahead to selected starting letter
|
||||||
if ((myLetter > 0) && (myLetter <= 26)) {
|
if ((myLetter > 0) && (myLetter <= 26)) {
|
||||||
myLetter += 'A' - 1;
|
myLetter += 'A' - 1;
|
||||||
do {
|
do {
|
||||||
// Read current name
|
// Read current name
|
||||||
get_line(gamename_str, &database, 2);
|
get_line(gamename_str, &database, 2);
|
||||||
// Skip data line
|
// Skip data line
|
||||||
skip_line(&database);
|
skip_line(&database);
|
||||||
// Skip empty line
|
// Skip empty line
|
||||||
skip_line(&database);
|
skip_line(&database);
|
||||||
|
|
||||||
} while (database.available() && gamename_str[0] != myLetter);
|
} while (database.available() && gamename_str[0] != myLetter);
|
||||||
rewind_line(database, 3);
|
rewind_line(database, 3);
|
||||||
}
|
}
|
||||||
#ifdef ENABLE_GLOBAL_LOG
|
#ifdef ENABLE_GLOBAL_LOG
|
||||||
// Enable log again
|
// Enable log again
|
||||||
dont_log = false;
|
dont_log = false;
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
#if ( \
|
#if ( \
|
||||||
defined(ENABLE_ARC) || defined(ENABLE_FAIRCHILD) || defined(ENABLE_VECTREX) || defined(ENABLE_BALLY) || \
|
defined(ENABLE_ARC) || defined(ENABLE_FAIRCHILD) || defined(ENABLE_VECTREX) || defined(ENABLE_BALLY) || defined(ENABLE_PV1000) || defined(ENABLE_PYUUTA) || defined(ENABLE_RCA) || defined(ENABLE_TRS80) || defined(ENABLE_LEAP) || defined(ENABLE_LJ) || defined(ENABLE_VSMILE))
|
||||||
defined(ENABLE_PV1000) || defined(ENABLE_PYUUTA) || defined(ENABLE_RCA) || defined(ENABLE_TRS80) || \
|
|
||||||
defined(ENABLE_LEAP) || defined(ENABLE_LJ) || defined(ENABLE_VSMILE)\
|
|
||||||
)
|
|
||||||
// read single digit data line as byte
|
// read single digit data line as byte
|
||||||
void readDataLineSingleDigit(FsFile& database, void* byteData) {
|
void readDataLineSingleDigit(FsFile& database, void* byteData) {
|
||||||
// Read rom size
|
// Read rom size
|
||||||
@ -754,9 +751,7 @@ void readDataLineSingleDigit(FsFile& database, void* byteData) {
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if ( \
|
#if ( \
|
||||||
defined(ENABLE_ODY2) || defined(ENABLE_5200) || defined(ENABLE_7800) || defined(ENABLE_C64) || \
|
defined(ENABLE_ODY2) || defined(ENABLE_5200) || defined(ENABLE_7800) || defined(ENABLE_C64) || defined(ENABLE_VIC20) || defined(ENABLE_ATARI8))
|
||||||
defined(ENABLE_VIC20)|| defined(ENABLE_ATARI8)\
|
|
||||||
)
|
|
||||||
struct database_entry_mapper_size {
|
struct database_entry_mapper_size {
|
||||||
byte gameMapper;
|
byte gameMapper;
|
||||||
byte gameSize;
|
byte gameSize;
|
||||||
@ -770,7 +765,7 @@ void readDataLineMapperSize(FsFile& database, void* entry) {
|
|||||||
|
|
||||||
// if next char is not a semicolon expect an additional digit
|
// if next char is not a semicolon expect an additional digit
|
||||||
char temp = database.read();
|
char temp = database.read();
|
||||||
if(temp != ',') {
|
if (temp != ',') {
|
||||||
castEntry->gameMapper = (castEntry->gameMapper * 10) + (temp - 48);
|
castEntry->gameMapper = (castEntry->gameMapper * 10) + (temp - 48);
|
||||||
// Skip over semicolon
|
// Skip over semicolon
|
||||||
database.seekCur(1);
|
database.seekCur(1);
|
||||||
@ -800,17 +795,17 @@ boolean checkCartSelection(FsFile& database, void (*readData)(FsFile&, void*), v
|
|||||||
#endif
|
#endif
|
||||||
display_Clear();
|
display_Clear();
|
||||||
|
|
||||||
get_line(gamename, &database, sizeof(gamename));
|
get_line(gamename, &database, sizeof(gamename));
|
||||||
|
|
||||||
readData(database, data);
|
readData(database, data);
|
||||||
|
|
||||||
skip_line(&database);
|
skip_line(&database);
|
||||||
|
|
||||||
println_Msg(F("Select your cartridge"));
|
println_Msg(F("Select your cartridge"));
|
||||||
println_Msg(FS(FSTRING_EMPTY));
|
println_Msg(FS(FSTRING_EMPTY));
|
||||||
println_Msg(gamename);
|
println_Msg(gamename);
|
||||||
|
|
||||||
if(printDataLine) {
|
if (printDataLine) {
|
||||||
printDataLine(data);
|
printDataLine(data);
|
||||||
}
|
}
|
||||||
println_Msg(FS(FSTRING_EMPTY));
|
println_Msg(FS(FSTRING_EMPTY));
|
||||||
@ -835,8 +830,8 @@ boolean checkCartSelection(FsFile& database, void (*readData)(FsFile&, void*), v
|
|||||||
display_Update();
|
display_Update();
|
||||||
|
|
||||||
#ifdef ENABLE_GLOBAL_LOG
|
#ifdef ENABLE_GLOBAL_LOG
|
||||||
// Enable log again
|
// Enable log again
|
||||||
dont_log = false;
|
dont_log = false;
|
||||||
#endif
|
#endif
|
||||||
uint8_t b = 0;
|
uint8_t b = 0;
|
||||||
while (1) {
|
while (1) {
|
||||||
@ -866,7 +861,7 @@ boolean checkCartSelection(FsFile& database, void (*readData)(FsFile&, void*), v
|
|||||||
|
|
||||||
// Selection
|
// Selection
|
||||||
else if (b == 3) {
|
else if (b == 3) {
|
||||||
if(setRomName) {
|
if (setRomName) {
|
||||||
setRomName(gamename);
|
setRomName(gamename);
|
||||||
}
|
}
|
||||||
database.close();
|
database.close();
|
||||||
@ -886,50 +881,44 @@ boolean checkCartSelection(FsFile& database, void (*readData)(FsFile&, void*), v
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
# if ( \
|
#if ( \
|
||||||
defined(ENABLE_ODY2) || defined(ENABLE_ARC) || defined(ENABLE_FAIRCHILD) || defined(ENABLE_MSX) || \
|
defined(ENABLE_ODY2) || defined(ENABLE_ARC) || defined(ENABLE_FAIRCHILD) || defined(ENABLE_MSX) || defined(ENABLE_POKE) || defined(ENABLE_2600) || defined(ENABLE_5200) || defined(ENABLE_7800) || defined(ENABLE_C64) || defined(ENABLE_VECTREX) || defined(ENABLE_NES) || defined(ENABLE_GBX) || defined(ENABLE_BALLY) || defined(ENABLE_PV1000) || defined(ENABLE_PYUUTA) || defined(ENABLE_RCA) || defined(ENABLE_TRS80) || defined(ENABLE_VIC20) || defined(ENABLE_LEAP) || defined(ENABLE_LJ) || defined(ENABLE_VSMILE) || defined(ENABLE_TI99) || defined(ENABLE_ATARI8))
|
||||||
defined(ENABLE_POKE) || defined(ENABLE_2600) || defined(ENABLE_5200) || defined(ENABLE_7800) || \
|
|
||||||
defined(ENABLE_C64) || defined(ENABLE_VECTREX) || defined(ENABLE_NES) || defined(ENABLE_GBX) || \
|
|
||||||
defined(ENABLE_BALLY) || defined(ENABLE_PV1000) || defined(ENABLE_PYUUTA) || defined(ENABLE_RCA) || \
|
|
||||||
defined(ENABLE_TRS80) || defined(ENABLE_VIC20) || defined(ENABLE_LEAP) || defined(ENABLE_LJ) || \
|
|
||||||
defined(ENABLE_VSMILE)|| defined(ENABLE_TI99) || defined(ENABLE_ATARI8)\
|
|
||||||
)
|
|
||||||
void printInstructions() {
|
void printInstructions() {
|
||||||
println_Msg(FS(FSTRING_EMPTY));
|
println_Msg(FS(FSTRING_EMPTY));
|
||||||
|
|
||||||
# if defined(ENABLE_OLED)
|
#if defined(ENABLE_OLED)
|
||||||
print_STR(press_to_change_STR, 1);
|
print_STR(press_to_change_STR, 1);
|
||||||
print_STR(right_to_select_STR, 1);
|
print_STR(right_to_select_STR, 1);
|
||||||
# elif defined(ENABLE_LCD)
|
#elif defined(ENABLE_LCD)
|
||||||
print_STR(rotate_to_change_STR, 1);
|
print_STR(rotate_to_change_STR, 1);
|
||||||
print_STR(press_to_select_STR, 1);
|
print_STR(press_to_select_STR, 1);
|
||||||
# elif defined(SERIAL_MONITOR)
|
#elif defined(SERIAL_MONITOR)
|
||||||
println_Msg(F("U/D to Change"));
|
println_Msg(F("U/D to Change"));
|
||||||
println_Msg(F("Space/Zero to Select"));
|
println_Msg(F("Space/Zero to Select"));
|
||||||
# endif /* ENABLE_OLED | ENABLE_LCD | SERIAL_MONITOR */
|
#endif /* ENABLE_OLED | ENABLE_LCD | SERIAL_MONITOR */
|
||||||
|
|
||||||
display_Update();
|
display_Update();
|
||||||
}
|
}
|
||||||
|
|
||||||
# if (defined(ENABLE_OLED) || defined(ENABLE_LCD))
|
#if (defined(ENABLE_OLED) || defined(ENABLE_LCD))
|
||||||
int navigateMenu(int min, int max, void (*printSelection)(int)) {
|
int navigateMenu(int min, int max, void (*printSelection)(int)) {
|
||||||
uint8_t b = 0;
|
uint8_t b = 0;
|
||||||
int i = min;
|
int i = min;
|
||||||
|
|
||||||
// Check Button Status
|
// Check Button Status
|
||||||
# if defined(ENABLE_OLED)
|
#if defined(ENABLE_OLED)
|
||||||
buttonVal1 = (PIND & (1 << 7)); // PD7
|
buttonVal1 = (PIND & (1 << 7)); // PD7
|
||||||
# elif defined(ENABLE_LCD)
|
#elif defined(ENABLE_LCD)
|
||||||
boolean buttonVal1 = (PING & (1 << 2)); //PG2
|
boolean buttonVal1 = (PING & (1 << 2)); //PG2
|
||||||
# endif /* ENABLE_OLED | ENABLE_LCD */
|
#endif /* ENABLE_OLED | ENABLE_LCD */
|
||||||
|
|
||||||
if (buttonVal1 == LOW) { // Button Pressed
|
if (buttonVal1 == LOW) { // Button Pressed
|
||||||
while (1) { // Scroll Mapper List
|
while (1) { // Scroll Mapper List
|
||||||
# if defined(ENABLE_OLED)
|
#if defined(ENABLE_OLED)
|
||||||
buttonVal1 = (PIND & (1 << 7)); // PD7
|
buttonVal1 = (PIND & (1 << 7)); // PD7
|
||||||
# elif defined(ENABLE_LCD)
|
#elif defined(ENABLE_LCD)
|
||||||
buttonVal1 = (PING & (1 << 2)); // PG2
|
buttonVal1 = (PING & (1 << 2)); // PG2
|
||||||
# endif /* ENABLE_OLED | ENABLE_LCD */
|
#endif /* ENABLE_OLED | ENABLE_LCD */
|
||||||
|
|
||||||
if (buttonVal1 == HIGH) { // Button Released
|
if (buttonVal1 == HIGH) { // Button Released
|
||||||
// Correct Overshoot
|
// Correct Overshoot
|
||||||
@ -981,26 +970,26 @@ int navigateMenu(int min, int max, void (*printSelection)(int)) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
#elif defined(SERIAL_MONITOR)
|
#elif defined(SERIAL_MONITOR)
|
||||||
int navigateMenu(__attribute__((unused)) int min,__attribute__((unused)) int max, void (*printSelection)(int)) {
|
int navigateMenu(__attribute__((unused)) int min, __attribute__((unused)) int max, void (*printSelection)(int)) {
|
||||||
printSelection(0);
|
printSelection(0);
|
||||||
Serial.println(F("Enter number to change:_"));
|
Serial.println(F("Enter number to change:_"));
|
||||||
while (Serial.available() == 0) {}
|
while (Serial.available() == 0) {}
|
||||||
int selectedNumber = Serial.parseInt();
|
int selectedNumber = Serial.parseInt();
|
||||||
delay(200);
|
delay(200);
|
||||||
return selectedNumber;
|
return selectedNumber;
|
||||||
}
|
}
|
||||||
# endif /* (ENABLE_OLED | ENABLE_LCD) */
|
#endif /* (ENABLE_OLED | ENABLE_LCD) */
|
||||||
# endif /* ENABLE_<CORES> */
|
#endif /* ENABLE_<CORES> */
|
||||||
|
|
||||||
# if (defined(ENABLE_OLED) || defined(ENABLE_LCD))
|
#if (defined(ENABLE_OLED) || defined(ENABLE_LCD))
|
||||||
void starting_letter__subDraw(byte selection, byte line) {
|
void starting_letter__subDraw(byte selection, byte line) {
|
||||||
display.setDrawColor(0);
|
display.setDrawColor(0);
|
||||||
for (uint8_t i = 0; i < 4; i++) display.drawLine(0, 10 + i * 16, 128, 10 + i * 16);
|
for (uint8_t i = 0; i < 4; i++) display.drawLine(0, 10 + i * 16, 128, 10 + i * 16);
|
||||||
display.setDrawColor(1);
|
display.setDrawColor(1);
|
||||||
display.drawLine(4 + selection * 16, 10 + line * 16, 9 + selection * 16, 10 + line * 16);
|
display.drawLine(4 + selection * 16, 10 + line * 16, 9 + selection * 16, 10 + line * 16);
|
||||||
display_Update();
|
display_Update();
|
||||||
}
|
}
|
||||||
# endif /* (ENABLE_OLED | ENABLE_LCD) */
|
#endif /* (ENABLE_OLED | ENABLE_LCD) */
|
||||||
|
|
||||||
byte starting_letter() {
|
byte starting_letter() {
|
||||||
#ifdef ENABLE_GLOBAL_LOG
|
#ifdef ENABLE_GLOBAL_LOG
|
||||||
@ -1040,8 +1029,7 @@ byte starting_letter() {
|
|||||||
selection--;
|
selection--;
|
||||||
}
|
}
|
||||||
starting_letter__subDraw(selection, line);
|
starting_letter__subDraw(selection, line);
|
||||||
}
|
} else if (b == 1) { // Next
|
||||||
else if (b == 1) { // Next
|
|
||||||
if ((selection == 6) && (line < 3)) {
|
if ((selection == 6) && (line < 3)) {
|
||||||
line++;
|
line++;
|
||||||
selection = 0;
|
selection = 0;
|
||||||
@ -1052,8 +1040,7 @@ byte starting_letter() {
|
|||||||
selection++;
|
selection++;
|
||||||
}
|
}
|
||||||
starting_letter__subDraw(selection, line);
|
starting_letter__subDraw(selection, line);
|
||||||
}
|
} else if (b == 3) { // Long Press - Execute
|
||||||
else if (b == 3) { // Long Press - Execute
|
|
||||||
if ((selection + line * 7) != 27) {
|
if ((selection + line * 7) != 27) {
|
||||||
display_Clear();
|
display_Clear();
|
||||||
println_Msg(F("Please wait..."));
|
println_Msg(F("Please wait..."));
|
||||||
@ -1268,11 +1255,11 @@ uint8_t pageMenu(const __FlashStringHelper* question, const char* const* menuStr
|
|||||||
currPage = 1;
|
currPage = 1;
|
||||||
lastPage = 1;
|
lastPage = 1;
|
||||||
|
|
||||||
numPages = (entryCount / 7) + ( (entryCount % 7) != 0 );
|
numPages = (entryCount / 7) + ((entryCount % 7) != 0);
|
||||||
|
|
||||||
do {
|
do {
|
||||||
option_offset = (currPage - 1) * 7;
|
option_offset = (currPage - 1) * 7;
|
||||||
num_answers = ( (entryCount < (option_offset + 7)) ? entryCount - option_offset : 7);
|
num_answers = ((entryCount < (option_offset + 7)) ? entryCount - option_offset : 7);
|
||||||
|
|
||||||
// Copy menuOptions out of progmem
|
// Copy menuOptions out of progmem
|
||||||
convertPgm(menuStrings + option_offset, num_answers);
|
convertPgm(menuStrings + option_offset, num_answers);
|
||||||
@ -1464,7 +1451,7 @@ void mainMenu() {
|
|||||||
setup_LYNX();
|
setup_LYNX();
|
||||||
return lynxMenu();
|
return lynxMenu();
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef ENABLE_VECTREX
|
#ifdef ENABLE_VECTREX
|
||||||
case SYSTEM_MENU_VECTREX:
|
case SYSTEM_MENU_VECTREX:
|
||||||
@ -1559,9 +1546,9 @@ void mainMenu() {
|
|||||||
|
|
||||||
#ifdef ENABLE_FLASH
|
#ifdef ENABLE_FLASH
|
||||||
case SYSTEM_MENU_FLASH:
|
case SYSTEM_MENU_FLASH:
|
||||||
# ifdef ENABLE_VSELECT
|
#ifdef ENABLE_VSELECT
|
||||||
setup_FlashVoltage();
|
setup_FlashVoltage();
|
||||||
# endif
|
#endif
|
||||||
return flashMenu();
|
return flashMenu();
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
@ -1605,24 +1592,18 @@ void selfTest() {
|
|||||||
println_Msg(F("Self Test"));
|
println_Msg(F("Self Test"));
|
||||||
println_Msg(FS(FSTRING_EMPTY));
|
println_Msg(FS(FSTRING_EMPTY));
|
||||||
println_Msg(F("Remove all Cartridges"));
|
println_Msg(F("Remove all Cartridges"));
|
||||||
println_Msg(F("before continuing!!!"));
|
println_Msg(F("before continuing!"));
|
||||||
|
#if (defined(HW3) || defined(HW2))
|
||||||
|
println_Msg(F("And turn the EEP switch on."));
|
||||||
|
#else
|
||||||
println_Msg(FS(FSTRING_EMPTY));
|
println_Msg(FS(FSTRING_EMPTY));
|
||||||
print_STR(press_button_STR, 1);
|
|
||||||
display_Update();
|
|
||||||
wait();
|
|
||||||
display_Clear();
|
|
||||||
|
|
||||||
#if defined(HW3)
|
|
||||||
println_Msg(F("Self Test"));
|
|
||||||
println_Msg(FS(FSTRING_EMPTY));
|
|
||||||
println_Msg(F("Turn the EEP switch on."));
|
|
||||||
println_Msg(FS(FSTRING_EMPTY));
|
|
||||||
println_Msg(FS(FSTRING_EMPTY));
|
|
||||||
print_STR(press_button_STR, 1);
|
|
||||||
display_Update();
|
|
||||||
wait();
|
|
||||||
display_Clear();
|
|
||||||
#endif
|
#endif
|
||||||
|
println_Msg(FS(FSTRING_EMPTY));
|
||||||
|
println_Msg(FS(FSTRING_EMPTY));
|
||||||
|
print_STR(press_button_STR, 1);
|
||||||
|
display_Update();
|
||||||
|
wait();
|
||||||
|
display_Clear();
|
||||||
|
|
||||||
// Test if pin 7 is held high by 1K resistor
|
// Test if pin 7 is held high by 1K resistor
|
||||||
pinMode(7, INPUT);
|
pinMode(7, INPUT);
|
||||||
@ -1636,8 +1617,8 @@ void selfTest() {
|
|||||||
println_Msg(FS(FSTRING_EMPTY));
|
println_Msg(FS(FSTRING_EMPTY));
|
||||||
print_STR(press_button_STR, 1);
|
print_STR(press_button_STR, 1);
|
||||||
display_Update();
|
display_Update();
|
||||||
//wait();
|
wait();
|
||||||
//resetArduino();
|
resetArduino();
|
||||||
}
|
}
|
||||||
|
|
||||||
println_Msg(F("Testing short to GND"));
|
println_Msg(F("Testing short to GND"));
|
||||||
@ -1727,8 +1708,22 @@ void selfTest() {
|
|||||||
display_Update();
|
display_Update();
|
||||||
wait();
|
wait();
|
||||||
resetArduino();
|
resetArduino();
|
||||||
|
} else {
|
||||||
|
//clockgen.set_correction(cal_factor, SI5351_PLL_INPUT_XO);
|
||||||
|
clockgen.set_pll(SI5351_PLL_FIXED, SI5351_PLLA);
|
||||||
|
clockgen.set_pll(SI5351_PLL_FIXED, SI5351_PLLB);
|
||||||
|
//clockgen.pll_reset(SI5351_PLLA);
|
||||||
|
//clockgen.pll_reset(SI5351_PLLB);
|
||||||
|
clockgen.set_freq(400000000ULL, SI5351_CLK0);
|
||||||
|
clockgen.set_freq(100000000ULL, SI5351_CLK1);
|
||||||
|
clockgen.set_freq(307200000ULL, SI5351_CLK2);
|
||||||
|
clockgen.output_enable(SI5351_CLK1, 1);
|
||||||
|
clockgen.output_enable(SI5351_CLK2, 1);
|
||||||
|
clockgen.output_enable(SI5351_CLK0, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
println_Msg(FS(FSTRING_EMPTY));
|
||||||
|
println_Msg(F("All tests passed."));
|
||||||
println_Msg(FS(FSTRING_EMPTY));
|
println_Msg(FS(FSTRING_EMPTY));
|
||||||
print_STR(press_button_STR, 1);
|
print_STR(press_button_STR, 1);
|
||||||
display_Update();
|
display_Update();
|
||||||
@ -2185,90 +2180,90 @@ int32_t initializeClockOffset() {
|
|||||||
void setup() {
|
void setup() {
|
||||||
// Set Button Pin PG2 to Input
|
// Set Button Pin PG2 to Input
|
||||||
DDRG &= ~(1 << 2);
|
DDRG &= ~(1 << 2);
|
||||||
# if defined(HW5) && !defined(ENABLE_VSELECT)
|
#if defined(HW5) && !defined(ENABLE_VSELECT)
|
||||||
/**
|
/**
|
||||||
* HW5 has status LED connected to PD7
|
* HW5 has status LED connected to PD7
|
||||||
* Set LED Pin PD7 to Output
|
* Set LED Pin PD7 to Output
|
||||||
**/
|
**/
|
||||||
DDRD |= (1 << 7);
|
DDRD |= (1 << 7);
|
||||||
PORTD |= (1 << 7);
|
PORTD |= (1 << 7);
|
||||||
# elif defined(ENABLE_VSELECT)
|
#elif defined(ENABLE_VSELECT)
|
||||||
/**
|
/**
|
||||||
* VSELECT uses pin PD7
|
* VSELECT uses pin PD7
|
||||||
* Set LED Pin PD7 to Output
|
* Set LED Pin PD7 to Output
|
||||||
**/
|
**/
|
||||||
DDRD |= (1 << 7);
|
DDRD |= (1 << 7);
|
||||||
# else /* !defined(HW5) && !defined(ENABLE_VSELECT) */
|
#else /* !defined(HW5) && !defined(ENABLE_VSELECT) */
|
||||||
/**
|
/**
|
||||||
* HW1-3 have button connected to PD7
|
* HW1-3 have button connected to PD7
|
||||||
* Set pin PD7 to input for button
|
* Set pin PD7 to input for button
|
||||||
**/
|
**/
|
||||||
DDRD &= ~(1 << 7);
|
DDRD &= ~(1 << 7);
|
||||||
# endif /* HW5 &| ENABLE_VSELECT */
|
#endif /* HW5 &| ENABLE_VSELECT */
|
||||||
|
|
||||||
// Set power to low to protect carts
|
// Set power to low to protect carts
|
||||||
setVoltage(VOLTS_SET_3V3);
|
setVoltage(VOLTS_SET_3V3);
|
||||||
|
|
||||||
# if defined(ENABLE_3V3FIX)
|
#if defined(ENABLE_3V3FIX)
|
||||||
// Set clock high during setup
|
// Set clock high during setup
|
||||||
setClockScale(CLKSCALE_16MHZ);
|
setClockScale(CLKSCALE_16MHZ);
|
||||||
delay(10);
|
delay(10);
|
||||||
# endif /* ENABLE_3V3FIX */
|
#endif /* ENABLE_3V3FIX */
|
||||||
|
|
||||||
# if !defined(ENABLE_SERIAL) && defined(ENABLE_UPDATER)
|
#if !defined(ENABLE_SERIAL) && defined(ENABLE_UPDATER)
|
||||||
ClockedSerial.begin(UPD_BAUD);
|
ClockedSerial.begin(UPD_BAUD);
|
||||||
printVersionToSerial();
|
printVersionToSerial();
|
||||||
ClockedSerial.flush();
|
ClockedSerial.flush();
|
||||||
# endif /* ENABLE_UPDATER */
|
#endif /* ENABLE_UPDATER */
|
||||||
|
|
||||||
// Read current folder number out of the EEPROM
|
// Read current folder number out of the EEPROM
|
||||||
EEPROM_readAnything(0, foldern);
|
EEPROM_readAnything(0, foldern);
|
||||||
if (foldern < 0) foldern = 0;
|
if (foldern < 0) foldern = 0;
|
||||||
|
|
||||||
# ifdef ENABLE_LCD
|
#ifdef ENABLE_LCD
|
||||||
display.begin();
|
display.begin();
|
||||||
display.setContrast(40);
|
display.setContrast(40);
|
||||||
display.setFont(u8g2_font_haxrcorp4089_tr);
|
display.setFont(u8g2_font_haxrcorp4089_tr);
|
||||||
# endif /* ENABLE_LCD */
|
#endif /* ENABLE_LCD */
|
||||||
|
|
||||||
# ifdef ENABLE_NEOPIXEL
|
#ifdef ENABLE_NEOPIXEL
|
||||||
pixels.begin();
|
pixels.begin();
|
||||||
setColor_RGB(0, 0, 100);
|
setColor_RGB(0, 0, 100);
|
||||||
|
|
||||||
// Set TX0 LED Pin(PE1) to Output for status indication during flashing for HW4
|
// Set TX0 LED Pin(PE1) to Output for status indication during flashing for HW4
|
||||||
# if !(defined(ENABLE_SERIAL) || defined(HW5))
|
#if !(defined(ENABLE_SERIAL) || defined(HW5))
|
||||||
DDRE |= (1 << 1);
|
DDRE |= (1 << 1);
|
||||||
# endif /* ENABLE_SERIAL */
|
#endif /* ENABLE_SERIAL */
|
||||||
# else /* !ENABLE_NEOPIXEL */
|
#else /* !ENABLE_NEOPIXEL */
|
||||||
# ifndef ENABLE_LCD
|
#ifndef ENABLE_LCD
|
||||||
# ifdef ENABLE_CA_LED
|
#ifdef ENABLE_CA_LED
|
||||||
// Turn LED off
|
// Turn LED off
|
||||||
digitalWrite(12, 1);
|
digitalWrite(12, 1);
|
||||||
digitalWrite(11, 1);
|
digitalWrite(11, 1);
|
||||||
digitalWrite(10, 1);
|
digitalWrite(10, 1);
|
||||||
# endif /* ENABLE_CA_LED */
|
#endif /* ENABLE_CA_LED */
|
||||||
// Configure 4 Pin RGB LED pins as output
|
// Configure 4 Pin RGB LED pins as output
|
||||||
DDRB |= (1 << DDB6); // Red LED (pin 12)
|
DDRB |= (1 << DDB6); // Red LED (pin 12)
|
||||||
DDRB |= (1 << DDB5); // Green LED (pin 11)
|
DDRB |= (1 << DDB5); // Green LED (pin 11)
|
||||||
DDRB |= (1 << DDB4); // Blue LED (pin 10)
|
DDRB |= (1 << DDB4); // Blue LED (pin 10)
|
||||||
# endif /* ENABLE_LCD */
|
#endif /* ENABLE_LCD */
|
||||||
# endif /* ENABLE_NEOPIXEL */
|
#endif /* ENABLE_NEOPIXEL */
|
||||||
|
|
||||||
# ifdef ENABLE_RTC
|
#ifdef ENABLE_RTC
|
||||||
// Start RTC
|
// Start RTC
|
||||||
RTCStart();
|
RTCStart();
|
||||||
|
|
||||||
// Set Date/Time Callback Funtion
|
// Set Date/Time Callback Funtion
|
||||||
SdFile::dateTimeCallback(dateTime);
|
SdFile::dateTimeCallback(dateTime);
|
||||||
# endif /* ENABLE_RTC */
|
#endif /* ENABLE_RTC */
|
||||||
|
|
||||||
# ifdef ENABLE_OLED
|
#ifdef ENABLE_OLED
|
||||||
display.begin();
|
display.begin();
|
||||||
//isplay.setContrast(40);
|
//isplay.setContrast(40);
|
||||||
display.setFont(u8g2_font_haxrcorp4089_tr);
|
display.setFont(u8g2_font_haxrcorp4089_tr);
|
||||||
# endif /* ENABLE_OLED */
|
#endif /* ENABLE_OLED */
|
||||||
|
|
||||||
# ifdef ENABLE_SERIAL
|
#ifdef ENABLE_SERIAL
|
||||||
// Serial Begin
|
// Serial Begin
|
||||||
Serial.begin(9600);
|
Serial.begin(9600);
|
||||||
Serial.println(FS(FSTRING_EMPTY));
|
Serial.println(FS(FSTRING_EMPTY));
|
||||||
@ -2276,12 +2271,12 @@ void setup() {
|
|||||||
Serial.println(F("2024 github.com/sanni"));
|
Serial.println(F("2024 github.com/sanni"));
|
||||||
// LED Error
|
// LED Error
|
||||||
rgbLed(blue_color);
|
rgbLed(blue_color);
|
||||||
# endif /* ENABLE_SERIAL */
|
#endif /* ENABLE_SERIAL */
|
||||||
|
|
||||||
// Init SD card
|
// Init SD card
|
||||||
if (!sd.begin(SS)) {
|
if (!sd.begin(SS)) {
|
||||||
display_Clear();
|
display_Clear();
|
||||||
# ifdef ENABLE_VSELECT
|
#ifdef ENABLE_VSELECT
|
||||||
print_STR(sd_error_STR, 1);
|
print_STR(sd_error_STR, 1);
|
||||||
println_Msg(FS(FSTRING_EMPTY));
|
println_Msg(FS(FSTRING_EMPTY));
|
||||||
println_Msg(F("Press button to enable 5V for"));
|
println_Msg(F("Press button to enable 5V for"));
|
||||||
@ -2289,7 +2284,7 @@ void setup() {
|
|||||||
display_Update();
|
display_Update();
|
||||||
wait();
|
wait();
|
||||||
display_Clear();
|
display_Clear();
|
||||||
setVoltage(VOLTS_SET_5V); // Set voltage high for flashing
|
setVoltage(VOLTS_SET_5V); // Set voltage high for flashing
|
||||||
println_Msg(F(" ======== UPDATE MODE ======== "));
|
println_Msg(F(" ======== UPDATE MODE ======== "));
|
||||||
println_Msg(F("Waiting for update..."));
|
println_Msg(F("Waiting for update..."));
|
||||||
println_Msg(FS(FSTRING_EMPTY));
|
println_Msg(FS(FSTRING_EMPTY));
|
||||||
@ -2297,51 +2292,51 @@ void setup() {
|
|||||||
display_Update();
|
display_Update();
|
||||||
wait();
|
wait();
|
||||||
resetArduino();
|
resetArduino();
|
||||||
# else /* !ENABLE_VSELECT */
|
#else /* !ENABLE_VSELECT */
|
||||||
print_FatalError(sd_error_STR);
|
print_FatalError(sd_error_STR);
|
||||||
# endif /* ENABLE_VSELECT */
|
#endif /* ENABLE_VSELECT */
|
||||||
}
|
}
|
||||||
|
|
||||||
# if defined(ENABLE_CONFIG)
|
#if defined(ENABLE_CONFIG)
|
||||||
configInit();
|
configInit();
|
||||||
# if defined(ENABLE_GLOBAL_LOG)
|
#if defined(ENABLE_GLOBAL_LOG)
|
||||||
loggingEnabled = !!configGetLong(F("oscr.logging"), 1);
|
loggingEnabled = !!configGetLong(F("oscr.logging"), 1);
|
||||||
# endif /*ENABLE_CONFIG*/
|
#endif /*ENABLE_CONFIG*/
|
||||||
|
|
||||||
// Change LCD background if config specified
|
// Change LCD background if config specified
|
||||||
# ifdef ENABLE_NEOPIXEL
|
#ifdef ENABLE_NEOPIXEL
|
||||||
setColor_RGB(0, 0, 100);
|
setColor_RGB(0, 0, 100);
|
||||||
# endif /* ENABLE_NEOPIXEL */
|
#endif /* ENABLE_NEOPIXEL */
|
||||||
# endif /* ENABLE_CONFIG */
|
#endif /* ENABLE_CONFIG */
|
||||||
|
|
||||||
# ifdef ENABLE_GLOBAL_LOG
|
#ifdef ENABLE_GLOBAL_LOG
|
||||||
if (!myLog.open("OSCR_LOG.txt", O_RDWR | O_CREAT | O_APPEND)) {
|
if (!myLog.open("OSCR_LOG.txt", O_RDWR | O_CREAT | O_APPEND)) {
|
||||||
print_FatalError(sd_error_STR);
|
print_FatalError(sd_error_STR);
|
||||||
}
|
}
|
||||||
println_Msg(FS(FSTRING_EMPTY));
|
println_Msg(FS(FSTRING_EMPTY));
|
||||||
# if defined(HW1)
|
#if defined(HW1)
|
||||||
print_Msg(F("OSCR HW1"));
|
print_Msg(F("OSCR HW1"));
|
||||||
# elif defined(HW2)
|
#elif defined(HW2)
|
||||||
print_Msg(F("OSCR HW2"));
|
print_Msg(F("OSCR HW2"));
|
||||||
# elif defined(HW3)
|
#elif defined(HW3)
|
||||||
print_Msg(F("OSCR HW3"));
|
print_Msg(F("OSCR HW3"));
|
||||||
# elif defined(HW4)
|
#elif defined(HW4)
|
||||||
print_Msg(F("OSCR HW4"));
|
print_Msg(F("OSCR HW4"));
|
||||||
# elif defined(HW5)
|
#elif defined(HW5)
|
||||||
print_Msg(F("OSCR HW5"));
|
print_Msg(F("OSCR HW5"));
|
||||||
# elif defined(SERIAL_MONITOR)
|
#elif defined(SERIAL_MONITOR)
|
||||||
print_Msg(F("OSCR Serial"));
|
print_Msg(F("OSCR Serial"));
|
||||||
# endif /* HWn */
|
#endif /* HWn */
|
||||||
print_Msg(FS(FSTRING_SPACE));
|
print_Msg(FS(FSTRING_SPACE));
|
||||||
println_Msg(FS(FSTRING_VERSION));
|
println_Msg(FS(FSTRING_VERSION));
|
||||||
# endif /* ENABLE_GLOBAL_LOG */
|
#endif /* ENABLE_GLOBAL_LOG */
|
||||||
|
|
||||||
// Turn status LED on
|
// Turn status LED on
|
||||||
statusLED(true);
|
statusLED(true);
|
||||||
|
|
||||||
# if defined(ENABLE_3V3FIX)
|
#if defined(ENABLE_3V3FIX)
|
||||||
setClockScale(CLKSCALE_8MHZ); // Set clock back to low after setup
|
setClockScale(CLKSCALE_8MHZ); // Set clock back to low after setup
|
||||||
# endif /* ENABLE_3V3FIX */
|
#endif /* ENABLE_3V3FIX */
|
||||||
|
|
||||||
// Start menu system
|
// Start menu system
|
||||||
mainMenu();
|
mainMenu();
|
||||||
@ -2369,9 +2364,9 @@ void dataIn() {
|
|||||||
// Set RGB color
|
// Set RGB color
|
||||||
void setColor_RGB(byte r, byte g, byte b) {
|
void setColor_RGB(byte r, byte g, byte b) {
|
||||||
#if defined(ENABLE_NEOPIXEL)
|
#if defined(ENABLE_NEOPIXEL)
|
||||||
# if defined(ENABLE_3V3FIX)
|
#if defined(ENABLE_3V3FIX)
|
||||||
if (clock == CS_8MHZ) return;
|
if (clock == CS_8MHZ) return;
|
||||||
# endif
|
#endif
|
||||||
// Dim Neopixel LEDs
|
// Dim Neopixel LEDs
|
||||||
if (r >= 100) r = 100;
|
if (r >= 100) r = 100;
|
||||||
if (g >= 100) g = 100;
|
if (g >= 100) g = 100;
|
||||||
@ -2379,7 +2374,7 @@ void setColor_RGB(byte r, byte g, byte b) {
|
|||||||
|
|
||||||
pixels.clear();
|
pixels.clear();
|
||||||
|
|
||||||
# if defined(ENABLE_CONFIG)
|
#if defined(ENABLE_CONFIG)
|
||||||
uint8_t lcdConfColor = configGetLong(F("lcd.confColor"));
|
uint8_t lcdConfColor = configGetLong(F("lcd.confColor"));
|
||||||
|
|
||||||
if (lcdConfColor > 0) {
|
if (lcdConfColor > 0) {
|
||||||
@ -2391,9 +2386,9 @@ void setColor_RGB(byte r, byte g, byte b) {
|
|||||||
} else {
|
} else {
|
||||||
pixels.setPixelColor(0, pixels.Color(OPTION_LCD_BG_COLOR));
|
pixels.setPixelColor(0, pixels.Color(OPTION_LCD_BG_COLOR));
|
||||||
}
|
}
|
||||||
# else /* !ENABLE_CONFIG */
|
#else /* !ENABLE_CONFIG */
|
||||||
pixels.setPixelColor(0, pixels.Color(OPTION_LCD_BG_COLOR));
|
pixels.setPixelColor(0, pixels.Color(OPTION_LCD_BG_COLOR));
|
||||||
# endif /* ENABLE_CONFIG */
|
#endif /* ENABLE_CONFIG */
|
||||||
pixels.setPixelColor(1, pixels.Color(g, r, b));
|
pixels.setPixelColor(1, pixels.Color(g, r, b));
|
||||||
pixels.setPixelColor(2, pixels.Color(g, r, b));
|
pixels.setPixelColor(2, pixels.Color(g, r, b));
|
||||||
pixels.show();
|
pixels.show();
|
||||||
@ -2863,12 +2858,12 @@ void blinkLED() {
|
|||||||
#elif defined(ENABLE_OLED)
|
#elif defined(ENABLE_OLED)
|
||||||
// 5mm LED on D10, above SD slot
|
// 5mm LED on D10, above SD slot
|
||||||
PORTB ^= (1 << 4);
|
PORTB ^= (1 << 4);
|
||||||
#elif defined(ENABLE_LCD) // HW4
|
#elif defined(ENABLE_LCD) // HW4
|
||||||
// TX LED on D1, build-in
|
// TX LED on D1, build-in
|
||||||
PORTE ^= (1 << 1);
|
PORTE ^= (1 << 1);
|
||||||
#elif defined(ENABLE_SERIAL)
|
#elif defined(ENABLE_SERIAL)
|
||||||
// 5mm LED on D10, above SD slot (HW3)
|
// 5mm LED on D10, above SD slot (HW3)
|
||||||
PORTB ^= (1 << 4); //HW4/HW5 LCD RST connects there now too
|
PORTB ^= (1 << 4); //HW4/HW5 LCD RST connects there now too
|
||||||
// 3mm LED on D38, front of PCB (HW5)
|
// 3mm LED on D38, front of PCB (HW5)
|
||||||
PORTB ^= (1 << 7);
|
PORTB ^= (1 << 7);
|
||||||
#endif
|
#endif
|
||||||
@ -3106,26 +3101,21 @@ void checkUpdater() {
|
|||||||
if (ClockedSerial.available() > 0) {
|
if (ClockedSerial.available() > 0) {
|
||||||
String cmd = ClockedSerial.readStringUntil('\n');
|
String cmd = ClockedSerial.readStringUntil('\n');
|
||||||
cmd.trim();
|
cmd.trim();
|
||||||
if (cmd == "VERCHK")
|
if (cmd == "VERCHK") { // VERCHK: Gets OSCR version and features
|
||||||
{ // VERCHK: Gets OSCR version and features
|
|
||||||
delay(500);
|
delay(500);
|
||||||
printVersionToSerial();
|
printVersionToSerial();
|
||||||
}
|
} else if (cmd == "GETCLOCK") { // GETCLOCK: Gets the MEGA's current clock speed.
|
||||||
else if (cmd == "GETCLOCK")
|
#if defined(ENABLE_3V3FIX)
|
||||||
{ // GETCLOCK: Gets the MEGA's current clock speed.
|
|
||||||
# if defined(ENABLE_3V3FIX)
|
|
||||||
ClockedSerial.print(F("Clock is running at "));
|
ClockedSerial.print(F("Clock is running at "));
|
||||||
ClockedSerial.print((clock == CS_16MHZ) ? 16UL : 8UL);
|
ClockedSerial.print((clock == CS_16MHZ) ? 16UL : 8UL);
|
||||||
ClockedSerial.println(F("MHz"));
|
ClockedSerial.println(F("MHz"));
|
||||||
# else /* !ENABLE_3V3FIX */
|
#else /* !ENABLE_3V3FIX */
|
||||||
ClockedSerial.println(FS(FSTRING_MODULE_NOT_ENABLED));
|
ClockedSerial.println(FS(FSTRING_MODULE_NOT_ENABLED));
|
||||||
# endif /* ENABLE_3V3FIX */
|
#endif /* ENABLE_3V3FIX */
|
||||||
}
|
} else if (cmd.substring(1, 8) == "ETVOLTS") { // (G/S)ETVOLTS: Get and set the voltage.
|
||||||
else if (cmd.substring(1, 8) == "ETVOLTS")
|
#if defined(ENABLE_VSELECT)
|
||||||
{ // (G/S)ETVOLTS: Get and set the voltage.
|
|
||||||
# if defined(ENABLE_VSELECT)
|
|
||||||
if (cmd != "GETVOLTS") {
|
if (cmd != "GETVOLTS") {
|
||||||
switch(cmd.substring(9, 10).toInt()) {
|
switch (cmd.substring(9, 10).toInt()) {
|
||||||
case 3: setVoltage(VOLTS_SET_3V3); break;
|
case 3: setVoltage(VOLTS_SET_3V3); break;
|
||||||
case 5: setVoltage(VOLTS_SET_5V); break;
|
case 5: setVoltage(VOLTS_SET_5V); break;
|
||||||
}
|
}
|
||||||
@ -3133,23 +3123,22 @@ void checkUpdater() {
|
|||||||
ClockedSerial.print(F("Voltage is set to "));
|
ClockedSerial.print(F("Voltage is set to "));
|
||||||
ClockedSerial.print((voltage == VOLTS_SET_5V) ? 5 : 3.3);
|
ClockedSerial.print((voltage == VOLTS_SET_5V) ? 5 : 3.3);
|
||||||
ClockedSerial.println(F("V"));
|
ClockedSerial.println(F("V"));
|
||||||
# else /* !ENABLE_VSELECT */
|
#else /* !ENABLE_VSELECT */
|
||||||
ClockedSerial.println(FS(FSTRING_MODULE_NOT_ENABLED));
|
ClockedSerial.println(FS(FSTRING_MODULE_NOT_ENABLED));
|
||||||
# endif /* ENABLE_VSELECT */
|
#endif /* ENABLE_VSELECT */
|
||||||
}
|
}
|
||||||
// RTC commands
|
// RTC commands
|
||||||
else if (cmd.substring(1, 7) == "ETTIME")
|
else if (cmd.substring(1, 7) == "ETTIME") { // (G/S)ETTIME: Get and set the date/time.
|
||||||
{ // (G/S)ETTIME: Get and set the date/time.
|
#if defined(ENABLE_RTC)
|
||||||
# if defined(ENABLE_RTC)
|
|
||||||
if (cmd != "GETTIME") {
|
if (cmd != "GETTIME") {
|
||||||
ClockedSerial.println(F("Setting Time..."));
|
ClockedSerial.println(F("Setting Time..."));
|
||||||
rtc.adjust(DateTime(cmd.substring(8).toInt()));
|
rtc.adjust(DateTime(cmd.substring(8).toInt()));
|
||||||
}
|
}
|
||||||
ClockedSerial.print(F("Current Time: "));
|
ClockedSerial.print(F("Current Time: "));
|
||||||
ClockedSerial.println(RTCStamp());
|
ClockedSerial.println(RTCStamp());
|
||||||
# else /* !ENABLE_RTC */
|
#else /* !ENABLE_RTC */
|
||||||
ClockedSerial.println(FS(FSTRING_MODULE_NOT_ENABLED));
|
ClockedSerial.println(FS(FSTRING_MODULE_NOT_ENABLED));
|
||||||
# endif /* ENABLE_RTC */
|
#endif /* ENABLE_RTC */
|
||||||
} else {
|
} else {
|
||||||
ClockedSerial.print(FS(FSTRING_OSCR));
|
ClockedSerial.print(FS(FSTRING_OSCR));
|
||||||
ClockedSerial.println(F(": Unknown Command"));
|
ClockedSerial.println(F(": Unknown Command"));
|
||||||
@ -3661,153 +3650,153 @@ page:
|
|||||||
void loop() {
|
void loop() {
|
||||||
switch (mode) {
|
switch (mode) {
|
||||||
#ifdef ENABLE_N64
|
#ifdef ENABLE_N64
|
||||||
case CORE_N64_CART: return n64CartMenu();
|
case CORE_N64_CART: return n64CartMenu();
|
||||||
case CORE_N64_CONTROLLER: return n64ControllerMenu();
|
case CORE_N64_CONTROLLER: return n64ControllerMenu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_SNES
|
#ifdef ENABLE_SNES
|
||||||
case CORE_SNES: return snesMenu();
|
case CORE_SNES: return snesMenu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_SFM
|
#ifdef ENABLE_SFM
|
||||||
case CORE_SFM: return sfmMenu();
|
case CORE_SFM: return sfmMenu();
|
||||||
# ifdef ENABLE_FLASH
|
#ifdef ENABLE_FLASH
|
||||||
case CORE_SFM_FLASH: return sfmFlashMenu();
|
case CORE_SFM_FLASH: return sfmFlashMenu();
|
||||||
# endif
|
#endif
|
||||||
case CORE_SFM_GAME: return sfmGameOptions();
|
case CORE_SFM_GAME: return sfmGameOptions();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_GBX
|
#ifdef ENABLE_GBX
|
||||||
case CORE_GB: return gbMenu();
|
case CORE_GB: return gbMenu();
|
||||||
case CORE_GBA: return gbaMenu();
|
case CORE_GBA: return gbaMenu();
|
||||||
case CORE_GBM: return gbmMenu();
|
case CORE_GBM: return gbmMenu();
|
||||||
case CORE_GB_GBSMART: return gbSmartMenu();
|
case CORE_GB_GBSMART: return gbSmartMenu();
|
||||||
case CORE_GB_GBSMART_FLASH: return gbSmartFlashMenu();
|
case CORE_GB_GBSMART_FLASH: return gbSmartFlashMenu();
|
||||||
case CORE_GB_GBSMART_GAME: return gbSmartGameOptions();
|
case CORE_GB_GBSMART_GAME: return gbSmartGameOptions();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_FLASH
|
#ifdef ENABLE_FLASH
|
||||||
case CORE_FLASH8: return flashromMenu8();
|
case CORE_FLASH8: return flashromMenu8();
|
||||||
# ifdef ENABLE_FLASH16
|
#ifdef ENABLE_FLASH16
|
||||||
case CORE_FLASH16: return flashromMenu16();
|
case CORE_FLASH16: return flashromMenu16();
|
||||||
case CORE_EPROM: return epromMenu();
|
case CORE_EPROM: return epromMenu();
|
||||||
# endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_MD
|
#ifdef ENABLE_MD
|
||||||
case CORE_MD_CART: return mdCartMenu();
|
case CORE_MD_CART: return mdCartMenu();
|
||||||
case CORE_SEGA_CD: return segaCDMenu();
|
case CORE_SEGA_CD: return segaCDMenu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_PCE
|
#ifdef ENABLE_PCE
|
||||||
case CORE_PCE: return pceMenu();
|
case CORE_PCE: return pceMenu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_SV
|
#ifdef ENABLE_SV
|
||||||
case CORE_SV: return svMenu();
|
case CORE_SV: return svMenu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_NES
|
#ifdef ENABLE_NES
|
||||||
case CORE_NES: return nesMenu();
|
case CORE_NES: return nesMenu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_SMS
|
#ifdef ENABLE_SMS
|
||||||
case CORE_SMS: return smsMenu();
|
case CORE_SMS: return smsMenu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_WS
|
#ifdef ENABLE_WS
|
||||||
case CORE_WS: return wsMenu();
|
case CORE_WS: return wsMenu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_NGP
|
#ifdef ENABLE_NGP
|
||||||
case CORE_NGP: return ngpMenu();
|
case CORE_NGP: return ngpMenu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_INTV
|
#ifdef ENABLE_INTV
|
||||||
case CORE_INTV: return intvMenu();
|
case CORE_INTV: return intvMenu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_COLV
|
#ifdef ENABLE_COLV
|
||||||
case CORE_COL: return colMenu();
|
case CORE_COL: return colMenu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_VBOY
|
#ifdef ENABLE_VBOY
|
||||||
case CORE_VBOY: return vboyMenu();
|
case CORE_VBOY: return vboyMenu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_WSV
|
#ifdef ENABLE_WSV
|
||||||
case CORE_WSV: return wsvMenu();
|
case CORE_WSV: return wsvMenu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_PCW
|
#ifdef ENABLE_PCW
|
||||||
case CORE_PCW: return pcwMenu();
|
case CORE_PCW: return pcwMenu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_ODY2
|
#ifdef ENABLE_ODY2
|
||||||
case CORE_ODY2: return ody2Menu();
|
case CORE_ODY2: return ody2Menu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_ARC
|
#ifdef ENABLE_ARC
|
||||||
case CORE_ARC: return arcMenu();
|
case CORE_ARC: return arcMenu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_FAIRCHILD
|
#ifdef ENABLE_FAIRCHILD
|
||||||
case CORE_FAIRCHILD: return fairchildMenu();
|
case CORE_FAIRCHILD: return fairchildMenu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_SUPRACAN
|
#ifdef ENABLE_SUPRACAN
|
||||||
case CORE_SUPRACAN: return suprAcanMenu();
|
case CORE_SUPRACAN: return suprAcanMenu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_MSX
|
#ifdef ENABLE_MSX
|
||||||
case CORE_MSX: return msxMenu();
|
case CORE_MSX: return msxMenu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_POKE
|
#ifdef ENABLE_POKE
|
||||||
case CORE_POKE: return pokeMenu();
|
case CORE_POKE: return pokeMenu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_LOOPY
|
#ifdef ENABLE_LOOPY
|
||||||
case CORE_LOOPY: return loopyMenu();
|
case CORE_LOOPY: return loopyMenu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_C64
|
#ifdef ENABLE_C64
|
||||||
case CORE_C64: return c64Menu();
|
case CORE_C64: return c64Menu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_2600
|
#ifdef ENABLE_2600
|
||||||
case CORE_2600: return a2600Menu();
|
case CORE_2600: return a2600Menu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_5200
|
#ifdef ENABLE_5200
|
||||||
case CORE_5200: return a5200Menu();
|
case CORE_5200: return a5200Menu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_7800
|
#ifdef ENABLE_7800
|
||||||
case CORE_7800: return a7800Menu();
|
case CORE_7800: return a7800Menu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_LYNX
|
#ifdef ENABLE_LYNX
|
||||||
case CORE_LYNX: return lynxMenu();
|
case CORE_LYNX: return lynxMenu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_VECTREX
|
#ifdef ENABLE_VECTREX
|
||||||
case CORE_VECTREX: return vectrexMenu();
|
case CORE_VECTREX: return vectrexMenu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_ST
|
#ifdef ENABLE_ST
|
||||||
case CORE_ST: return stMenu();
|
case CORE_ST: return stMenu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_GPC
|
#ifdef ENABLE_GPC
|
||||||
case CORE_GPC: return gpcMenu();
|
case CORE_GPC: return gpcMenu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_ATARI8
|
#ifdef ENABLE_ATARI8
|
||||||
case CORE_ATARI8: return atari8Menu();
|
case CORE_ATARI8: return atari8Menu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_BALLY
|
#ifdef ENABLE_BALLY
|
||||||
case CORE_BALLY: return ballyMenu();
|
case CORE_BALLY: return ballyMenu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_LJ
|
#ifdef ENABLE_LJ
|
||||||
case CORE_LJ: return ljMenu();
|
case CORE_LJ: return ljMenu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_LJPRO
|
#ifdef ENABLE_LJPRO
|
||||||
case CORE_LJPRO: return ljproMenu();
|
case CORE_LJPRO: return ljproMenu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_PV1000
|
#ifdef ENABLE_PV1000
|
||||||
case CORE_PV1000: return pv1000Menu();
|
case CORE_PV1000: return pv1000Menu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_VIC20
|
#ifdef ENABLE_VIC20
|
||||||
case CORE_VIC20: return vic20Menu();
|
case CORE_VIC20: return vic20Menu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_LEAP
|
#ifdef ENABLE_LEAP
|
||||||
case CORE_LEAP: return leapMenu();
|
case CORE_LEAP: return leapMenu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_RCA
|
#ifdef ENABLE_RCA
|
||||||
case CORE_RCA: return rcaMenu();
|
case CORE_RCA: return rcaMenu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_TI99
|
#ifdef ENABLE_TI99
|
||||||
case CORE_TI99: return ti99Menu();
|
case CORE_TI99: return ti99Menu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_PYUUTA
|
#ifdef ENABLE_PYUUTA
|
||||||
case CORE_PYUUTA: return pyuutaMenu();
|
case CORE_PYUUTA: return pyuutaMenu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_TRS80
|
#ifdef ENABLE_TRS80
|
||||||
case CORE_TRS80: return trs80Menu();
|
case CORE_TRS80: return trs80Menu();
|
||||||
#endif
|
#endif
|
||||||
#ifdef ENABLE_VSMILE
|
#ifdef ENABLE_VSMILE
|
||||||
case CORE_VSMILE: return vsmileMenu();
|
case CORE_VSMILE: return vsmileMenu();
|
||||||
#endif
|
#endif
|
||||||
case CORE_MAX: return resetArduino();
|
case CORE_MAX: return resetArduino();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user