mirror of
https://github.com/TomHarte/CLK.git
synced 2025-01-12 15:31:09 +00:00
2332f72875
(obiter: the 1540 now appears to discern the correct sequence of bits. Framing is off in my test printfs but that's neither here nor there).
63 lines
1.5 KiB
C++
63 lines
1.5 KiB
C++
//
|
|
// DiskDrive.hpp
|
|
// Clock Signal
|
|
//
|
|
// Created by Thomas Harte on 14/07/2016.
|
|
// Copyright © 2016 Thomas Harte. All rights reserved.
|
|
//
|
|
|
|
#ifndef DiskDrive_hpp
|
|
#define DiskDrive_hpp
|
|
|
|
#include "Disk.hpp"
|
|
#include "DigitalPhaseLockedLoop.hpp"
|
|
#include "../TimedEventLoop.hpp"
|
|
|
|
namespace Storage {
|
|
|
|
class DiskDrive: public DigitalPhaseLockedLoop::Delegate, public TimedEventLoop {
|
|
public:
|
|
DiskDrive(unsigned int clock_rate, unsigned int clock_rate_multiplier, unsigned int revolutions_per_minute);
|
|
|
|
void set_expected_bit_length(Time bit_length);
|
|
|
|
void set_disk(std::shared_ptr<Disk> disk);
|
|
bool has_disk();
|
|
|
|
void run_for_cycles(int number_of_cycles);
|
|
|
|
bool get_is_track_zero();
|
|
void step(int direction);
|
|
void set_motor_on(bool motor_on);
|
|
|
|
// to satisfy DigitalPhaseLockedLoop::Delegate
|
|
void digital_phase_locked_loop_output_bit(int value);
|
|
|
|
protected:
|
|
virtual void process_input_bit(int value, unsigned int cycles_since_index_hole) = 0;
|
|
virtual void process_index_hole() = 0;
|
|
|
|
// for TimedEventLoop
|
|
virtual void process_next_event();
|
|
|
|
private:
|
|
Time _bit_length;
|
|
unsigned int _clock_rate;
|
|
unsigned int _clock_rate_multiplier;
|
|
unsigned int _revolutions_per_minute;
|
|
|
|
std::shared_ptr<DigitalPhaseLockedLoop> _pll;
|
|
std::shared_ptr<Disk> _disk;
|
|
std::shared_ptr<Track> _track;
|
|
int _head_position;
|
|
unsigned int _cycles_since_index_hole;
|
|
void set_track();
|
|
|
|
inline void get_next_event();
|
|
Track::Event _current_event;
|
|
};
|
|
|
|
}
|
|
|
|
#endif /* DiskDrive_hpp */
|