mirror of
https://github.com/MoleskiCoder/EightBit.git
synced 2025-01-05 07:32:15 +00:00
Add the concept of a clocked chip
This commit is contained in:
parent
71daf6aa38
commit
9755a5fcd2
@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
#include <cstdint>
|
#include <cstdint>
|
||||||
|
|
||||||
#include <Chip.h>
|
#include <ClockedChip.h>
|
||||||
|
|
||||||
/*
|
/*
|
||||||
PIA 6532 combined timer, IO and 128 bytes RAM
|
PIA 6532 combined timer, IO and 128 bytes RAM
|
||||||
@ -177,7 +177,7 @@
|
|||||||
|
|
||||||
|
|
||||||
namespace EightBit {
|
namespace EightBit {
|
||||||
class M6532 final : public Chip {
|
class M6532 final : public ClockedChip {
|
||||||
public:
|
public:
|
||||||
M6532() noexcept;
|
M6532() noexcept;
|
||||||
virtual ~M6532() = default;
|
virtual ~M6532() = default;
|
||||||
|
@ -118,7 +118,9 @@ void Board::updateAciaPins(const EightBit::Chip::PinLevel rw) {
|
|||||||
|
|
||||||
bool Board::accessAcia() {
|
bool Board::accessAcia() {
|
||||||
ACIA().raise(ACIA().E());
|
ACIA().raise(ACIA().E());
|
||||||
const bool accessed = ACIA().tick();
|
const bool activated = ACIA().activated();
|
||||||
|
if (activated)
|
||||||
|
ACIA().step();
|
||||||
ACIA().lower(ACIA().E());
|
ACIA().lower(ACIA().E());
|
||||||
return accessed;
|
return activated;
|
||||||
}
|
}
|
||||||
|
@ -2,12 +2,14 @@
|
|||||||
|
|
||||||
#include <cstdint>
|
#include <cstdint>
|
||||||
|
|
||||||
#include <Chip.h>
|
#include <ClockedChip.h>
|
||||||
#include <Signal.h>
|
#include <Signal.h>
|
||||||
|
|
||||||
namespace EightBit {
|
namespace EightBit {
|
||||||
class mc6850 : public Chip {
|
class mc6850 final : public ClockedChip {
|
||||||
public:
|
public:
|
||||||
|
void powerOn() final;
|
||||||
|
|
||||||
// +--------+----------------------------------------------------------------------------------+
|
// +--------+----------------------------------------------------------------------------------+
|
||||||
// | | Buffer address |
|
// | | Buffer address |
|
||||||
// | +------------------+------------------+--------------------+-----------------------+
|
// | +------------------+------------------+--------------------+-----------------------+
|
||||||
@ -242,8 +244,9 @@ namespace EightBit {
|
|||||||
// Receive data register;
|
// Receive data register;
|
||||||
auto& RDR() { return m_RDR; }
|
auto& RDR() { return m_RDR; }
|
||||||
|
|
||||||
bool tick();
|
void step();
|
||||||
|
|
||||||
|
bool activated() { return powered() && raised(E()) && selected(); }
|
||||||
bool selected();
|
bool selected();
|
||||||
|
|
||||||
void markTransmitComplete();
|
void markTransmitComplete();
|
||||||
@ -318,6 +321,7 @@ namespace EightBit {
|
|||||||
uint8_t m_TDR = 0;
|
uint8_t m_TDR = 0;
|
||||||
uint8_t m_RDR = 0;
|
uint8_t m_RDR = 0;
|
||||||
|
|
||||||
bool m_powered = false;
|
enum StartupCondition { ColdStart, WarmStart, Unknown };
|
||||||
|
StartupCondition m_startup = WarmStart;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
Binary file not shown.
24
inc/ClockedChip.h
Normal file
24
inc/ClockedChip.h
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include "Chip.h"
|
||||||
|
#include "EventArgs.h"
|
||||||
|
#include "Signal.h"
|
||||||
|
|
||||||
|
namespace EightBit {
|
||||||
|
class ClockedChip : public Chip {
|
||||||
|
public:
|
||||||
|
~ClockedChip() {};
|
||||||
|
|
||||||
|
Signal<EventArgs> Ticked;
|
||||||
|
|
||||||
|
[[nodiscard]] auto cycles() const noexcept { return m_cycles; }
|
||||||
|
|
||||||
|
protected:
|
||||||
|
void resetCycles() noexcept { m_cycles = 0; }
|
||||||
|
void tick(const int extra) { for (int i = 0; i < extra; ++i) tick(); }
|
||||||
|
void tick() { ++m_cycles; Ticked.fire(EventArgs::empty()); }
|
||||||
|
|
||||||
|
private:
|
||||||
|
int m_cycles = 0;
|
||||||
|
};
|
||||||
|
}
|
@ -2,15 +2,14 @@
|
|||||||
|
|
||||||
#include <cstdint>
|
#include <cstdint>
|
||||||
|
|
||||||
#include "Chip.h"
|
#include "ClockedChip.h"
|
||||||
#include "Bus.h"
|
#include "Bus.h"
|
||||||
#include "Register.h"
|
#include "Register.h"
|
||||||
#include "Signal.h"
|
|
||||||
|
|
||||||
#include "EightBitCompilerDefinitions.h"
|
#include "EightBitCompilerDefinitions.h"
|
||||||
|
|
||||||
namespace EightBit {
|
namespace EightBit {
|
||||||
class Processor : public Chip {
|
class Processor : public ClockedChip {
|
||||||
public:
|
public:
|
||||||
// b: number of bits representing the number in x
|
// b: number of bits representing the number in x
|
||||||
// x: sign extend this b-bit number to r
|
// x: sign extend this b-bit number to r
|
||||||
@ -18,8 +17,6 @@ namespace EightBit {
|
|||||||
|
|
||||||
~Processor() {};
|
~Processor() {};
|
||||||
|
|
||||||
Signal<EventArgs> Ticked;
|
|
||||||
|
|
||||||
[[nodiscard]] auto& PC() noexcept { return m_pc; }
|
[[nodiscard]] auto& PC() noexcept { return m_pc; }
|
||||||
|
|
||||||
[[nodiscard]] auto& RESET() noexcept { return m_resetLine; }
|
[[nodiscard]] auto& RESET() noexcept { return m_resetLine; }
|
||||||
@ -35,8 +32,6 @@ namespace EightBit {
|
|||||||
virtual int execute() = 0;
|
virtual int execute() = 0;
|
||||||
int execute(uint8_t value);
|
int execute(uint8_t value);
|
||||||
|
|
||||||
[[nodiscard]] auto cycles() const noexcept { return m_cycles; }
|
|
||||||
|
|
||||||
[[nodiscard]] virtual register16_t peekWord(register16_t address) = 0;
|
[[nodiscard]] virtual register16_t peekWord(register16_t address) = 0;
|
||||||
virtual void pokeWord(register16_t address, register16_t value) = 0;
|
virtual void pokeWord(register16_t address, register16_t value) = 0;
|
||||||
|
|
||||||
@ -108,14 +103,9 @@ namespace EightBit {
|
|||||||
|
|
||||||
virtual void ret();
|
virtual void ret();
|
||||||
|
|
||||||
void resetCycles() noexcept { m_cycles = 0; }
|
|
||||||
void tick(const int extra) { for (int i = 0; i < extra; ++i) tick(); }
|
|
||||||
void tick() { ++m_cycles; Ticked.fire(EventArgs::empty()); }
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Bus& m_bus;
|
Bus& m_bus;
|
||||||
uint8_t m_opcode = Mask8;
|
uint8_t m_opcode = Mask8;
|
||||||
int m_cycles = 0;
|
|
||||||
register16_t m_pc;
|
register16_t m_pc;
|
||||||
|
|
||||||
PinLevel m_intLine = PinLevel::Low;
|
PinLevel m_intLine = PinLevel::Low;
|
||||||
|
@ -145,6 +145,7 @@
|
|||||||
<ClInclude Include="..\inc\BigEndianProcessor.h" />
|
<ClInclude Include="..\inc\BigEndianProcessor.h" />
|
||||||
<ClInclude Include="..\inc\Bus.h" />
|
<ClInclude Include="..\inc\Bus.h" />
|
||||||
<ClInclude Include="..\inc\Chip.h" />
|
<ClInclude Include="..\inc\Chip.h" />
|
||||||
|
<ClInclude Include="..\inc\ClockedChip.h" />
|
||||||
<ClInclude Include="..\inc\Device.h" />
|
<ClInclude Include="..\inc\Device.h" />
|
||||||
<ClInclude Include="..\inc\EightBitCompilerDefinitions.h" />
|
<ClInclude Include="..\inc\EightBitCompilerDefinitions.h" />
|
||||||
<ClInclude Include="..\inc\EventArgs.h" />
|
<ClInclude Include="..\inc\EventArgs.h" />
|
||||||
|
@ -71,6 +71,9 @@
|
|||||||
<ClInclude Include="..\inc\Mapper.h">
|
<ClInclude Include="..\inc\Mapper.h">
|
||||||
<Filter>Header Files</Filter>
|
<Filter>Header Files</Filter>
|
||||||
</ClInclude>
|
</ClInclude>
|
||||||
|
<ClInclude Include="..\inc\ClockedChip.h">
|
||||||
|
<Filter>Header Files</Filter>
|
||||||
|
</ClInclude>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<ClCompile Include="stdafx.cpp">
|
<ClCompile Include="stdafx.cpp">
|
||||||
|
Loading…
Reference in New Issue
Block a user