2017-09-07 00:15:28 +00:00
|
|
|
#pragma once
|
|
|
|
|
2017-10-05 10:24:36 +00:00
|
|
|
#include <cstdint>
|
|
|
|
#include <vector>
|
2017-09-14 22:48:49 +00:00
|
|
|
|
2017-09-07 00:15:28 +00:00
|
|
|
#include <Rom.h>
|
|
|
|
#include <Ram.h>
|
|
|
|
#include <Bus.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
|
|
|
|
};
|
|
|
|
|
|
|
|
Bus();
|
|
|
|
|
2017-10-04 14:37:11 +00:00
|
|
|
Ram& VRAM() { return m_videoRam; }
|
|
|
|
Ram& OAMRAM() { return m_oamRam; }
|
2017-10-05 10:24:36 +00:00
|
|
|
IoRegisters& IO() { return m_ioPorts; }
|
2017-10-04 14:37:11 +00:00
|
|
|
|
2017-09-07 00:15:28 +00:00
|
|
|
void reset();
|
|
|
|
|
|
|
|
void disableGameRom() { m_disableGameRom = true; }
|
|
|
|
void enableGameRom() { m_disableGameRom = false; }
|
|
|
|
|
|
|
|
bool gameRomDisabled() const { return m_disableGameRom; }
|
|
|
|
bool gameRomEnabled() const { return !gameRomDisabled(); }
|
|
|
|
|
|
|
|
void loadBootRom(const std::string& path);
|
|
|
|
void loadGameRom(const std::string& path);
|
|
|
|
|
|
|
|
protected:
|
2017-10-05 10:24:36 +00:00
|
|
|
virtual uint8_t& reference(uint16_t address, bool& rom);
|
2017-09-07 00:15:28 +00:00
|
|
|
|
|
|
|
private:
|
|
|
|
Rom m_bootRom; // 0x0000 - 0x00ff
|
|
|
|
std::vector<Rom> m_gameRomBanks; // 0x0000 - 0x3fff, 0x4000 - 0x7fff (switchable)
|
|
|
|
Ram m_videoRam; // 0x8000 - 0x9fff
|
|
|
|
std::vector<Ram> m_ramBanks; // 0xa000 - 0xbfff (switchable)
|
|
|
|
Ram m_lowInternalRam; // 0xc000 - 0xdfff (mirrored at 0xe000)
|
|
|
|
Ram m_oamRam; // 0xfe00 - 0xfe9f
|
2017-10-05 10:24:36 +00:00
|
|
|
IoRegisters m_ioPorts; // 0xff00 - 0xff7f
|
2017-09-07 00:15:28 +00:00
|
|
|
Ram m_highInternalRam; // 0xff80 - 0xffff
|
|
|
|
|
|
|
|
bool m_disableGameRom;
|
|
|
|
|
|
|
|
bool m_rom;
|
|
|
|
bool m_banked;
|
|
|
|
bool m_ram;
|
|
|
|
bool m_battery;
|
|
|
|
|
|
|
|
bool m_higherRomBank;
|
|
|
|
bool m_ramBankSwitching;
|
|
|
|
|
|
|
|
int m_romBank;
|
|
|
|
int m_ramBank;
|
|
|
|
|
|
|
|
void validateCartridgeType();
|
2017-09-14 22:48:49 +00:00
|
|
|
|
|
|
|
void Bus_WrittenByte(uint16_t address);
|
2017-09-07 00:15:28 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
}
|