From a997b6c67768561a5684268102534fe9add1c873 Mon Sep 17 00:00:00 2001 From: Thomas Harte Date: Tue, 30 Apr 2024 22:18:17 -0400 Subject: [PATCH] Wire drives for IBM-style RDY. --- Machines/Acorn/Archimedes/FloppyDisc.hpp | 6 +++++- Machines/Acorn/Archimedes/InputOutputController.hpp | 3 ++- Storage/Disk/Controller/DiskController.cpp | 4 ++++ Storage/Disk/Controller/DiskController.hpp | 1 + 4 files changed, 12 insertions(+), 2 deletions(-) diff --git a/Machines/Acorn/Archimedes/FloppyDisc.hpp b/Machines/Acorn/Archimedes/FloppyDisc.hpp index ca9039e82..f203f84d6 100644 --- a/Machines/Acorn/Archimedes/FloppyDisc.hpp +++ b/Machines/Acorn/Archimedes/FloppyDisc.hpp @@ -16,7 +16,7 @@ template class FloppyDisc: public WD::WD1770, public WD::WD1770::Delegate { public: FloppyDisc(InterruptObserverT &observer) : WD::WD1770(P1772), observer_(observer) { - emplace_drives(1, 8000000, 300, 2); + emplace_drives(1, 8000000, 300, 2, Storage::Disk::Drive::ReadyType::IBMRDY); // A guess at RDY type. set_delegate(this); } @@ -40,6 +40,10 @@ public: get_drive(drive).set_disk(disk); } + bool ready() const { + return get_drive().get_is_ready(); + } + private: InterruptObserverT &observer_; }; diff --git a/Machines/Acorn/Archimedes/InputOutputController.hpp b/Machines/Acorn/Archimedes/InputOutputController.hpp index 64c752638..ebaa1f1bc 100644 --- a/Machines/Acorn/Archimedes/InputOutputController.hpp +++ b/Machines/Acorn/Archimedes/InputOutputController.hpp @@ -200,8 +200,9 @@ struct InputOutputController: public ClockingHint::Observer { case 0x00: { uint8_t value = control_ | 0xc0; - value &= ~(i2c_.clock() ? 0x02 : 0x00); value &= ~(i2c_.data() ? 0x01 : 0x00); + value &= ~(i2c_.clock() ? 0x02 : 0x00); + value &= ~(floppy_.ready() ? 0x04 : 0x00); value &= ~(video_.flyback_active() ? 0x00 : 0x80); // i.e. high during flyback. set_byte(value); // logger.error().append("IOC control read: C:%d D:%d", !(value & 2), !(value & 1)); diff --git a/Storage/Disk/Controller/DiskController.cpp b/Storage/Disk/Controller/DiskController.cpp index b2c8e5969..ddb625ad6 100644 --- a/Storage/Disk/Controller/DiskController.cpp +++ b/Storage/Disk/Controller/DiskController.cpp @@ -50,6 +50,10 @@ Drive &Controller::get_drive() { return *drive_; } +const Drive &Controller::get_drive() const { + return *drive_; +} + // MARK: - Drive::EventDelegate void Controller::process_event(const Drive::Event &event) { diff --git a/Storage/Disk/Controller/DiskController.hpp b/Storage/Disk/Controller/DiskController.hpp index dcf631978..ae7fbe163 100644 --- a/Storage/Disk/Controller/DiskController.hpp +++ b/Storage/Disk/Controller/DiskController.hpp @@ -117,6 +117,7 @@ class Controller: made about the lifetime or the exclusivity of the invented drive. */ Drive &get_drive(); + const Drive &get_drive() const; Drive &get_drive(size_t index) { return *drives_[index];