2014-10-19 14:19:06 +00:00
|
|
|
#include <UTFT.h>
|
|
|
|
#include <SD.h>
|
|
|
|
|
|
|
|
#include "ps2drv.h"
|
|
|
|
#include "memory.h"
|
|
|
|
#include "spiram.h"
|
|
|
|
|
2014-10-21 18:41:44 +00:00
|
|
|
#include "cpu.h"
|
2014-10-19 14:19:06 +00:00
|
|
|
#include "hardware.h"
|
|
|
|
|
|
|
|
Memory memory;
|
|
|
|
PS2Driver ps2;
|
|
|
|
spiram sram(SPIRAM_SIZE);
|
|
|
|
UTFT utft(TFT_MODEL, TFT_RS, TFT_WR, TFT_CS, TFT_RST);
|
2014-10-21 18:41:44 +00:00
|
|
|
static CPU *_cpu;
|
2014-10-19 14:19:06 +00:00
|
|
|
|
2014-10-21 18:41:44 +00:00
|
|
|
bool hardware_init(CPU &cpu) {
|
|
|
|
_cpu = &cpu;
|
2014-10-19 14:19:06 +00:00
|
|
|
ps2.begin(KBD_DATA, KBD_IRQ);
|
|
|
|
|
|
|
|
pinMode(SD_CS, OUTPUT);
|
|
|
|
bool sd = SD.begin(SD_CS, 3, SD_SPI);
|
|
|
|
|
|
|
|
#if defined(TFT_BACKLIGHT)
|
|
|
|
pinMode(TFT_BACKLIGHT, OUTPUT);
|
|
|
|
digitalWrite(TFT_BACKLIGHT, HIGH);
|
|
|
|
#endif
|
|
|
|
utft.InitLCD();
|
|
|
|
extern uint8_t SmallFont[];
|
|
|
|
utft.setFont(SmallFont);
|
|
|
|
|
|
|
|
sram.begin(SPIRAM_CS, SPIRAM_SPI);
|
|
|
|
|
2014-10-21 18:41:44 +00:00
|
|
|
cpu.reset();
|
2014-10-19 14:19:06 +00:00
|
|
|
return sd;
|
|
|
|
}
|
2014-10-21 18:41:44 +00:00
|
|
|
|
|
|
|
void hardware_checkpoint(Stream &s) {
|
|
|
|
_cpu->checkpoint(s);
|
|
|
|
Memory::Device *d = 0;
|
|
|
|
for (unsigned i = 0; i < 0x10000; i += Memory::page_size) {
|
|
|
|
Memory::Device *dev = memory.get(i);
|
|
|
|
if (dev && dev != d) {
|
|
|
|
d = dev;
|
|
|
|
d->checkpoint(s);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void hardware_restore(Stream &s) {
|
|
|
|
_cpu->restore(s);
|
|
|
|
Memory::Device *d = 0;
|
|
|
|
for (unsigned i = 0; i < 0x10000; i += Memory::page_size) {
|
|
|
|
Memory::Device *dev = memory.get(i);
|
|
|
|
if (dev && dev != d) {
|
|
|
|
d = dev;
|
|
|
|
d->restore(s);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|