2017-03-18 21:01:58 -04:00
|
|
|
//
|
|
|
|
// Bus.h
|
|
|
|
// Clock Signal
|
|
|
|
//
|
|
|
|
// Created by Thomas Harte on 18/03/2017.
|
2018-05-13 15:19:52 -04:00
|
|
|
// Copyright 2017 Thomas Harte. All rights reserved.
|
2017-03-18 21:01:58 -04:00
|
|
|
//
|
|
|
|
|
|
|
|
#ifndef Atari2600_Bus_hpp
|
|
|
|
#define Atari2600_Bus_hpp
|
|
|
|
|
2017-04-03 21:16:39 -04:00
|
|
|
#include "Atari2600.hpp"
|
2017-03-18 21:01:58 -04:00
|
|
|
#include "PIA.hpp"
|
2017-04-03 21:16:39 -04:00
|
|
|
#include "TIA.hpp"
|
2017-12-17 21:26:06 -05:00
|
|
|
#include "TIASound.hpp"
|
2017-07-25 20:20:55 -04:00
|
|
|
|
2018-03-07 14:26:07 -05:00
|
|
|
#include "../../Analyser/Dynamic/ConfidenceCounter.hpp"
|
2017-07-25 20:20:55 -04:00
|
|
|
#include "../../ClockReceiver/ClockReceiver.hpp"
|
2017-12-18 21:39:23 -05:00
|
|
|
#include "../../Outputs/Speaker/Implementation/LowpassSpeaker.hpp"
|
2017-03-18 21:01:58 -04:00
|
|
|
|
|
|
|
namespace Atari2600 {
|
|
|
|
|
|
|
|
class Bus {
|
|
|
|
public:
|
|
|
|
Bus() :
|
2017-12-17 21:26:06 -05:00
|
|
|
tia_sound_(audio_queue_),
|
2018-03-07 14:26:07 -05:00
|
|
|
speaker_(tia_sound_) {}
|
2017-03-18 21:01:58 -04:00
|
|
|
|
2018-03-22 21:59:19 -04:00
|
|
|
virtual ~Bus() {
|
|
|
|
audio_queue_.flush();
|
|
|
|
}
|
|
|
|
|
2017-07-27 22:05:29 -04:00
|
|
|
virtual void run_for(const Cycles cycles) = 0;
|
2018-03-07 14:26:07 -05:00
|
|
|
virtual void apply_confidence(Analyser::Dynamic::ConfidenceCounter &confidence_counter) = 0;
|
2017-03-18 21:01:58 -04:00
|
|
|
virtual void set_reset_line(bool state) = 0;
|
|
|
|
|
|
|
|
// the RIOT, TIA and speaker
|
|
|
|
PIA mos6532_;
|
2018-11-29 18:26:05 -08:00
|
|
|
TIA tia_;
|
2017-12-17 21:26:06 -05:00
|
|
|
|
|
|
|
Concurrency::DeferringAsyncTaskQueue audio_queue_;
|
|
|
|
TIASound tia_sound_;
|
|
|
|
Outputs::Speaker::LowpassSpeaker<TIASound> speaker_;
|
2017-03-18 21:01:58 -04:00
|
|
|
|
|
|
|
// joystick state
|
2018-03-07 14:26:07 -05:00
|
|
|
uint8_t tia_input_value_[2] = {0xff, 0xff};
|
2017-03-18 21:01:58 -04:00
|
|
|
|
|
|
|
protected:
|
|
|
|
// speaker backlog accumlation counter
|
2017-07-25 07:15:31 -04:00
|
|
|
Cycles cycles_since_speaker_update_;
|
2017-03-18 21:01:58 -04:00
|
|
|
inline void update_audio() {
|
2017-12-17 21:26:06 -05:00
|
|
|
speaker_.run_for(audio_queue_, cycles_since_speaker_update_.divide(Cycles(CPUTicksPerAudioTick * 3)));
|
2017-03-18 21:01:58 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
// video backlog accumulation counter
|
2017-07-24 22:53:13 -04:00
|
|
|
Cycles cycles_since_video_update_;
|
2017-03-18 21:01:58 -04:00
|
|
|
inline void update_video() {
|
2018-11-29 18:26:05 -08:00
|
|
|
tia_.run_for(cycles_since_video_update_.flush());
|
2017-03-18 21:01:58 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
// RIOT backlog accumulation counter
|
2017-07-24 22:53:13 -04:00
|
|
|
Cycles cycles_since_6532_update_;
|
2017-03-18 21:01:58 -04:00
|
|
|
inline void update_6532() {
|
2017-07-25 20:42:51 -04:00
|
|
|
mos6532_.run_for(cycles_since_6532_update_.flush());
|
2017-03-18 21:01:58 -04:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* Atari2600_Bus_hpp */
|