From 818f982c756b1e84abf9832e42f9392248913f0d Mon Sep 17 00:00:00 2001 From: joevt Date: Wed, 1 May 2024 04:05:22 -0700 Subject: [PATCH] swim3: Create separate reset method. And set defaults for some class fields. --- devices/floppy/swim3.cpp | 32 ++++++++++++++++++++++++++++---- devices/floppy/swim3.h | 3 ++- 2 files changed, 30 insertions(+), 5 deletions(-) diff --git a/devices/floppy/swim3.cpp b/devices/floppy/swim3.cpp index 5e2b4ec..b041449 100644 --- a/devices/floppy/swim3.cpp +++ b/devices/floppy/swim3.cpp @@ -42,6 +42,16 @@ Swim3Ctrl::Swim3Ctrl() this->name = "SWIM3"; this->supported_types = HWCompType::FLOPPY_CTRL; + this->reset(); + + // Attach virtual Superdrive to the internal drive connector + // TODO: make SWIM3/drive wiring user selectable + this->int_drive = std::unique_ptr + (new MacSuperdrive::MacSuperDrive("Superdrive1")); +} + +void Swim3Ctrl::reset() +{ this->setup_reg = 0; this->mode_reg = 0; this->int_reg = 0; @@ -54,10 +64,24 @@ Swim3Ctrl::Swim3Ctrl() this->cur_state = SWIM3_IDLE; - // Attach virtual Superdrive to the internal drive connector - // TODO: make SWIM3/drive wiring user selectable - this->int_drive = std::unique_ptr - (new MacSuperdrive::MacSuperDrive("Superdrive1")); + this->cur_track = 0xFF; + this->cur_sector = 0x7F; + + this->timer_val = 0; + this->phase_lines = 0; + + if (this->one_us_timer_id) { + TimerManager::get_instance()->cancel_timer(this->one_us_timer_id); + this->one_us_timer_id = 0; + } + if (this->step_timer_id) { + TimerManager::get_instance()->cancel_timer(this->step_timer_id); + this->step_timer_id = 0; + } + if (this->access_timer_id) { + TimerManager::get_instance()->cancel_timer(this->access_timer_id); + this->access_timer_id = 0; + } } int Swim3Ctrl::device_postinit() diff --git a/devices/floppy/swim3.h b/devices/floppy/swim3.h index adc106f..ff20562 100644 --- a/devices/floppy/swim3.h +++ b/devices/floppy/swim3.h @@ -103,6 +103,7 @@ public: }; protected: + void reset(); void update_irq(); void start_stepping(); void do_step(); @@ -118,7 +119,7 @@ private: DmaBidirChannel* dma_ch; - uint8_t timer_val = 0; // internal timer that decrements at a 1 us rate + uint8_t timer_val; // internal timer that decrements at a 1 us rate uint8_t setup_reg; uint8_t mode_reg; uint8_t error;