1
0
mirror of https://github.com/TomHarte/CLK.git synced 2024-11-01 10:05:55 +00:00
CLK/Machines/Atari2600/Bus.hpp

61 lines
1.3 KiB
C++
Raw Normal View History

//
// Bus.h
// Clock Signal
//
// Created by Thomas Harte on 18/03/2017.
// Copyright © 2017 Thomas Harte. All rights reserved.
//
#ifndef Atari2600_Bus_hpp
#define Atari2600_Bus_hpp
2017-04-04 01:16:39 +00:00
#include "Atari2600.hpp"
#include "PIA.hpp"
#include "Speaker.hpp"
2017-04-04 01:16:39 +00:00
#include "TIA.hpp"
#include "../../ClockReceiver/ClockReceiver.hpp"
namespace Atari2600 {
class Bus {
public:
Bus() :
tia_input_value_{0xff, 0xff},
cycles_since_speaker_update_(0) {}
virtual void run_for(const Cycles cycles) = 0;
virtual void set_reset_line(bool state) = 0;
// the RIOT, TIA and speaker
PIA mos6532_;
std::shared_ptr<TIA> tia_;
std::shared_ptr<Speaker> speaker_;
// joystick state
uint8_t tia_input_value_[2];
protected:
// speaker backlog accumlation counter
Cycles cycles_since_speaker_update_;
inline void update_audio() {
speaker_->run_for(cycles_since_speaker_update_.divide(Cycles(CPUTicksPerAudioTick * 3)));
}
// video backlog accumulation counter
Cycles cycles_since_video_update_;
inline void update_video() {
2017-07-26 00:42:51 +00:00
tia_->run_for(cycles_since_video_update_.flush());
}
// RIOT backlog accumulation counter
Cycles cycles_since_6532_update_;
inline void update_6532() {
2017-07-26 00:42:51 +00:00
mos6532_.run_for(cycles_since_6532_update_.flush());
}
};
}
#endif /* Atari2600_Bus_hpp */