r65emu/hardware.cpp

114 lines
2.0 KiB
C++
Raw Permalink Normal View History

#include "hardware.h"
2014-11-02 17:34:19 +00:00
#include <SPI.h>
2018-11-10 09:32:33 +00:00
#if defined(USE_SD)
2014-10-19 14:19:06 +00:00
#include <SD.h>
2018-11-29 18:11:29 +00:00
#elif defined(USE_SPIFFS)
#include <SPIFFS.h>
#elif defined(USE_LITTLEFS)
2018-11-14 20:24:38 +00:00
#include <FS.h>
#include <LittleFS.h>
2018-11-14 20:24:38 +00:00
#endif
2018-08-14 09:23:45 +00:00
#include "memory.h"
#include "CPU.h"
2018-11-16 10:25:23 +00:00
#if defined(USE_SPIRAM)
2014-11-02 17:34:19 +00:00
#include <SpiRAM.h>
#include "spiram.h"
spiram sram(SPIRAM_SIZE);
#endif
2014-10-19 14:19:06 +00:00
Memory memory;
2021-02-27 12:01:52 +00:00
#if defined(USE_KBD)
#include "ps2drv.h"
2014-10-19 14:19:06 +00:00
PS2Driver ps2;
2021-02-27 12:01:52 +00:00
#endif
2018-08-10 12:47:06 +00:00
2014-10-21 18:41:44 +00:00
static CPU *_cpu;
2014-10-19 14:19:06 +00:00
bool hardware_reset() {
2018-08-10 12:47:06 +00:00
bool success = true;
2018-11-16 10:25:23 +00:00
#if defined(USE_SPIRAM)
2014-11-02 17:34:19 +00:00
extern SPIClass SPIRAM_DEV;
SPIRAM_DEV.begin();
2021-02-16 08:57:30 +00:00
#if defined(SPIRAM_MODULE)
SPIRAM_DEV.setModule(SPIRAM_MODULE);
#endif
#if defined(SPIRAM_CLKDIV)
SPIRAM_DEV.setClockDivider(SPIRAM_CLKDIV);
2021-02-15 21:00:20 +00:00
#endif
2014-11-02 17:34:19 +00:00
SPIRAM_DEV.setDataMode(SPI_MODE0);
2018-08-10 12:47:06 +00:00
#endif
2014-10-19 14:19:06 +00:00
2018-11-10 09:32:33 +00:00
#if defined(USE_SD)
2018-11-29 18:11:29 +00:00
#if defined(SD_SPI)
2018-08-10 12:47:06 +00:00
success = SD.begin(SD_CS, 2, SD_SPI);
2014-11-02 17:34:19 +00:00
pinMode(SPI_CS, OUTPUT); // without this, the SPI-RAM isn't seen
2018-11-29 18:11:29 +00:00
#else
success = SD.begin(SD_CS);
#endif
2018-08-10 12:47:06 +00:00
2018-11-14 20:24:38 +00:00
#elif defined(USE_SPIFFS)
2018-09-06 12:09:19 +00:00
success = SPIFFS.begin(true);
2018-11-14 20:24:38 +00:00
#elif defined(USE_LITTLEFS)
success = LittleFS.begin();
#endif
2014-10-19 14:19:06 +00:00
#if defined(TFT_BACKLIGHT)
digitalWrite(TFT_BACKLIGHT, HIGH);
#endif
_cpu->reset();
2018-08-10 12:47:06 +00:00
return success;
2014-10-19 14:19:06 +00:00
}
2014-10-21 18:41:44 +00:00
void hardware_init(CPU &cpu) {
_cpu = &cpu;
memory.begin();
2021-02-27 12:01:52 +00:00
#if defined(USE_KBD)
ps2.begin(KBD_DATA, KBD_IRQ);
2021-02-27 12:01:52 +00:00
#endif
2014-11-02 17:34:19 +00:00
#if defined(TFT_BACKLIGHT)
pinMode(TFT_BACKLIGHT, OUTPUT);
#endif
2018-08-10 12:47:06 +00:00
2018-11-10 09:32:33 +00:00
#if defined(USE_SD)
2014-11-02 17:34:19 +00:00
pinMode(SD_CS, OUTPUT);
digitalWrite(SD_CS, HIGH);
2018-08-10 12:47:06 +00:00
#endif
2018-11-16 10:25:23 +00:00
#if defined(USE_SPIRAM)
2014-11-02 17:34:19 +00:00
pinMode(SPIRAM_CS, OUTPUT);
digitalWrite(SPIRAM_CS, HIGH);
2018-08-10 12:47:06 +00:00
#endif
}
2019-02-24 11:50:10 +00:00
#if !defined(NO_CHECKPOINT)
2014-10-21 18:41:44 +00:00
void hardware_checkpoint(Stream &s) {
2014-10-22 18:47:06 +00:00
unsigned ds = 0;
for (unsigned i = 0; i < 0x10000; i += ds) {
2014-10-21 18:41:44 +00:00
Memory::Device *dev = memory.get(i);
2014-10-31 17:44:37 +00:00
dev->checkpoint(s);
ds = dev->pages() * Memory::page_size;
2014-10-21 18:41:44 +00:00
}
2014-10-22 18:47:06 +00:00
_cpu->checkpoint(s);
2014-10-21 18:41:44 +00:00
}
void hardware_restore(Stream &s) {
2014-10-22 18:47:06 +00:00
unsigned ds = 0;
for (unsigned i = 0; i < 0x10000; i += ds) {
2014-10-21 18:41:44 +00:00
Memory::Device *dev = memory.get(i);
2014-10-31 17:44:37 +00:00
dev->restore(s);
ds = dev->pages() * Memory::page_size;
2014-10-21 18:41:44 +00:00
}
2014-10-22 18:47:06 +00:00
_cpu->restore(s);
2014-10-21 18:41:44 +00:00
}
2019-02-24 11:50:10 +00:00
#endif