2017-09-07 00:15:28 +00:00
|
|
|
#pragma once
|
|
|
|
|
2017-10-05 10:24:36 +00:00
|
|
|
#include <cstdint>
|
|
|
|
#include <vector>
|
2017-10-23 23:04:13 +00:00
|
|
|
#include <string>
|
2017-09-14 22:48:49 +00:00
|
|
|
|
2017-09-07 00:15:28 +00:00
|
|
|
#include <Ram.h>
|
2018-11-04 16:38:57 +00:00
|
|
|
#include <Rom.h>
|
2017-09-07 00:15:28 +00:00
|
|
|
#include <Bus.h>
|
2017-10-23 23:04:13 +00:00
|
|
|
#include <Register.h>
|
2018-11-03 23:11:48 +00:00
|
|
|
#include <UnusedMemory.h>
|
2017-10-05 10:24:36 +00:00
|
|
|
|
2017-10-19 21:43:09 +00:00
|
|
|
#include "LR35902.h"
|
2017-10-05 10:24:36 +00:00
|
|
|
#include "IoRegisters.h"
|
2017-09-07 00:15:28 +00:00
|
|
|
|
|
|
|
namespace EightBit {
|
|
|
|
namespace GameBoy {
|
|
|
|
class Bus : public EightBit::Bus {
|
|
|
|
public:
|
|
|
|
|
|
|
|
enum CartridgeType {
|
|
|
|
ROM = 0,
|
|
|
|
ROM_MBC1 = 1,
|
|
|
|
ROM_MBC1_RAM = 2,
|
|
|
|
ROM_MBC1_RAM_BATTERY = 3,
|
|
|
|
};
|
|
|
|
|
|
|
|
enum {
|
2017-09-21 19:08:37 +00:00
|
|
|
CyclesPerSecond = 4 * 1024 * 1024,
|
|
|
|
FramesPerSecond = 60,
|
|
|
|
CyclesPerFrame = CyclesPerSecond / FramesPerSecond,
|
2017-09-07 00:15:28 +00:00
|
|
|
TotalLineCount = 154,
|
2017-09-21 19:08:37 +00:00
|
|
|
CyclesPerLine = CyclesPerFrame / TotalLineCount,
|
2017-09-07 00:15:28 +00:00
|
|
|
RomPageSize = 0x4000
|
|
|
|
};
|
|
|
|
|
2018-08-11 20:19:19 +00:00
|
|
|
Bus() noexcept;
|
2017-09-07 00:15:28 +00:00
|
|
|
|
2022-01-17 19:10:15 +00:00
|
|
|
void raisePOWER() noexcept override;
|
|
|
|
void lowerPOWER() noexcept override;
|
2018-11-12 00:38:03 +00:00
|
|
|
|
2020-11-07 09:41:12 +00:00
|
|
|
[[nodiscard]] auto& CPU() noexcept { return m_cpu; }
|
|
|
|
[[nodiscard]] auto& VRAM() noexcept { return m_videoRam; }
|
|
|
|
[[nodiscard]] auto& OAMRAM() noexcept { return m_oamRam; }
|
|
|
|
[[nodiscard]] auto& IO() noexcept { return m_ioPorts; }
|
2017-10-04 14:37:11 +00:00
|
|
|
|
2017-09-07 00:15:28 +00:00
|
|
|
void reset();
|
|
|
|
|
2020-11-07 09:41:12 +00:00
|
|
|
void disableGameRom() noexcept { m_disableGameRom = true; }
|
|
|
|
void enableGameRom() noexcept { m_disableGameRom = false; }
|
2017-09-07 00:15:28 +00:00
|
|
|
|
2020-11-07 09:41:12 +00:00
|
|
|
[[nodiscard]] bool gameRomDisabled() const noexcept { return m_disableGameRom; }
|
|
|
|
[[nodiscard]] bool gameRomEnabled() const noexcept { return !gameRomDisabled(); }
|
2017-09-07 00:15:28 +00:00
|
|
|
|
2020-11-07 09:41:12 +00:00
|
|
|
void loadBootRom(std::string path);
|
|
|
|
void loadGameRom(std::string path);
|
2017-09-07 00:15:28 +00:00
|
|
|
|
2019-11-18 00:54:52 +00:00
|
|
|
void runRasterLines();
|
|
|
|
void runVerticalBlankLines();
|
2017-10-23 23:04:13 +00:00
|
|
|
|
2017-09-07 00:15:28 +00:00
|
|
|
protected:
|
2021-07-18 13:28:40 +00:00
|
|
|
virtual MemoryMapping mapping(uint16_t address) noexcept override;
|
2017-09-07 00:15:28 +00:00
|
|
|
|
|
|
|
private:
|
2017-10-19 21:43:09 +00:00
|
|
|
LR35902 m_cpu;
|
|
|
|
|
2018-11-03 23:11:48 +00:00
|
|
|
Rom m_bootRom = 0x100; // 0x0000 - 0x00ff
|
|
|
|
std::vector<Rom> m_gameRomBanks; // 0x0000 - 0x3fff, 0x4000 - 0x7fff (switchable)
|
|
|
|
Ram m_videoRam = 0x2000; // 0x8000 - 0x9fff
|
|
|
|
std::vector<Ram> m_ramBanks; // 0xa000 - 0xbfff (switchable)
|
|
|
|
UnusedMemory m_unmapped2000 = { 0x2000, 0xff }; // 0xa000 - 0xbfff
|
|
|
|
Ram m_lowInternalRam = 0x2000; // 0xc000 - 0xdfff (mirrored at 0xe000)
|
|
|
|
Ram m_oamRam = 0xa0; // 0xfe00 - 0xfe9f
|
|
|
|
UnusedMemory m_unmapped60 = { 0x60, 0xff }; // 0xfea0 - 0xfeff
|
|
|
|
IoRegisters m_ioPorts; // 0xff00 - 0xff7f
|
|
|
|
Ram m_highInternalRam = 0x80; // 0xff80 - 0xffff
|
2017-09-07 00:15:28 +00:00
|
|
|
|
2017-11-11 11:12:09 +00:00
|
|
|
bool m_enabledLCD = false;
|
2017-10-23 23:04:13 +00:00
|
|
|
|
2017-11-11 11:12:09 +00:00
|
|
|
bool m_disableGameRom = false;
|
2017-09-07 00:15:28 +00:00
|
|
|
|
2017-11-11 11:12:09 +00:00
|
|
|
bool m_rom = false;
|
|
|
|
bool m_banked = false;
|
|
|
|
bool m_ram = false;
|
|
|
|
bool m_battery = false;
|
2017-09-07 00:15:28 +00:00
|
|
|
|
2017-11-11 11:12:09 +00:00
|
|
|
bool m_higherRomBank = true;
|
|
|
|
bool m_ramBankSwitching = false;
|
2017-09-07 00:15:28 +00:00
|
|
|
|
2017-11-11 11:12:09 +00:00
|
|
|
int m_romBank = 1;
|
|
|
|
int m_ramBank = 0;
|
2017-09-07 00:15:28 +00:00
|
|
|
|
2019-11-18 00:54:52 +00:00
|
|
|
int m_allowed = 0;
|
|
|
|
|
2017-09-07 00:15:28 +00:00
|
|
|
void validateCartridgeType();
|
2017-09-14 22:48:49 +00:00
|
|
|
|
2021-07-18 13:28:40 +00:00
|
|
|
void Bus_WrittenByte(EightBit::EventArgs) noexcept;
|
2017-10-23 23:04:13 +00:00
|
|
|
|
2019-11-18 00:54:52 +00:00
|
|
|
void runRasterLines(int lines);
|
|
|
|
void runVerticalBlankLines(int lines);
|
|
|
|
void runRasterLine(int suggested);
|
2017-09-07 00:15:28 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
}
|