mirror of https://github.com/bsnes-emu/bsnes.git
44 lines
809 B
C++
44 lines
809 B
C++
//HuC6260 -- Video Color Encoder
|
|
|
|
struct VCE : Thread {
|
|
inline auto clock() const -> uint { return io.clock; }
|
|
|
|
static auto Enter() -> void;
|
|
auto main() -> void;
|
|
auto step(uint clocks) -> void;
|
|
auto refresh() -> void;
|
|
auto power() -> void;
|
|
|
|
//io.cpp
|
|
auto read(uint3 addr) -> uint8;
|
|
auto write(uint3 addr, uint8 data) -> void;
|
|
|
|
//serialization.cpp
|
|
auto serialize(serializer&) -> void;
|
|
|
|
private:
|
|
uint32 buffer[1365 * 263];
|
|
|
|
struct CRAM {
|
|
//memory.cpp
|
|
auto read(uint9 addr) -> uint9;
|
|
auto write(uint9 addr, bool a0, uint8 data) -> void;
|
|
|
|
uint9 data[0x200];
|
|
uint9 address;
|
|
} cram;
|
|
|
|
struct Timing {
|
|
uint hclock = 0;
|
|
uint vclock = 0;
|
|
} timing;
|
|
|
|
struct IO {
|
|
uint clock = 4;
|
|
bool extraLine = 0;
|
|
bool grayscale = 0;
|
|
} io;
|
|
};
|
|
|
|
extern VCE vce;
|