From 012084b37b8706e69a5b13ac452197a2e6829014 Mon Sep 17 00:00:00 2001 From: Thomas Harte Date: Wed, 24 Nov 2021 17:25:32 -0500 Subject: [PATCH] Fix exclusive fill, sizing, eliminate ECS call-ins. The clock test now proceeds further, but still doesn't seem to pass. --- Machines/Amiga/Blitter.cpp | 28 +++++++++++-------- Machines/Amiga/Blitter.hpp | 4 +-- Machines/Amiga/Chipset.cpp | 4 +-- .../Clock SignalTests/AmigaBlitterTests.mm | 2 +- 4 files changed, 22 insertions(+), 16 deletions(-) diff --git a/Machines/Amiga/Blitter.cpp b/Machines/Amiga/Blitter.cpp index f5196d119..26d96130c 100644 --- a/Machines/Amiga/Blitter.cpp +++ b/Machines/Amiga/Blitter.cpp @@ -54,8 +54,12 @@ void Blitter::set_last_word_mask(uint16_t value) { } void Blitter::set_size(uint16_t value) { - width_ = (width_ & ~0x3f) | (value & 0x3f); - height_ = (height_ & ~0x3ff) | (value >> 6); +// width_ = (width_ & ~0x3f) | (value & 0x3f); +// height_ = (height_ & ~0x3ff) | (value >> 6); + width_ = value & 0x3f; + if(!width_) width_ = 0x40; + height_ = value >> 6; + if(!height_) height_ = 1024; LOG("Set size to " << std::dec << width_ << ", " << height_); // Current assumption: writing this register informs the @@ -67,14 +71,14 @@ void Blitter::set_minterms(uint16_t value) { minterms_ = value & 0xff; } -void Blitter::set_vertical_size([[maybe_unused]] uint16_t value) { - LOG("Set vertical size " << PADHEX(4) << value); - // TODO. This is ECS only, I think. Ditto set_horizontal_size. -} - -void Blitter::set_horizontal_size([[maybe_unused]] uint16_t value) { - LOG("Set horizontal size " << PADHEX(4) << value); -} +//void Blitter::set_vertical_size([[maybe_unused]] uint16_t value) { +// LOG("Set vertical size " << PADHEX(4) << value); +// // TODO. This is ECS only, I think. Ditto set_horizontal_size. +//} +// +//void Blitter::set_horizontal_size([[maybe_unused]] uint16_t value) { +// LOG("Set horizontal size " << PADHEX(4) << value); +//} void Blitter::set_data(int channel, uint16_t value) { LOG("Set data " << channel << " to " << PADHEX(4) << value); @@ -242,7 +246,7 @@ bool Blitter::advance_dma() { uint16_t a, b; // The barrel shifter shifts to the right in ascending address mode, - // but to the left othrwise + // but to the left otherwise if(!one_dot_) { a = uint16_t(a32_ >> shifts_[0]); b = uint16_t(b32_ >> shifts_[1]); @@ -277,6 +281,8 @@ bool Blitter::advance_dma() { if(inclusive_fill_) { pre_toggle &= ~flag; // Accept bits that would transition to set immediately. post_toggle &= flag; // Accept bits that would transition to clear after the fact. + } else { + post_toggle = 0; // Just do the pre toggle. } flag ^= pre_toggle; diff --git a/Machines/Amiga/Blitter.hpp b/Machines/Amiga/Blitter.hpp index 334ade11f..7ca0b1da3 100644 --- a/Machines/Amiga/Blitter.hpp +++ b/Machines/Amiga/Blitter.hpp @@ -31,8 +31,8 @@ class Blitter: public DMADevice<4, 4> { void set_size(uint16_t value); void set_minterms(uint16_t value); - void set_vertical_size(uint16_t value); - void set_horizontal_size(uint16_t value); +// void set_vertical_size(uint16_t value); +// void set_horizontal_size(uint16_t value); void set_data(int channel, uint16_t value); uint16_t get_status(); diff --git a/Machines/Amiga/Chipset.cpp b/Machines/Amiga/Chipset.cpp index 463044a69..3c99b91e2 100644 --- a/Machines/Amiga/Chipset.cpp +++ b/Machines/Amiga/Chipset.cpp @@ -929,8 +929,8 @@ void Chipset::perform(const CPU::MC68000::Microcycle &cycle) { case Write(0x058): blitter_.set_size(cycle.value16()); break; case Write(0x05a): blitter_.set_minterms(cycle.value16()); break; - case Write(0x05c): blitter_.set_vertical_size(cycle.value16()); break; - case Write(0x05e): blitter_.set_horizontal_size(cycle.value16()); break; +// case Write(0x05c): blitter_.set_vertical_size(cycle.value16()); break; +// case Write(0x05e): blitter_.set_horizontal_size(cycle.value16()); break; case Write(0x060): blitter_.set_modulo<2>(cycle.value16()); break; case Write(0x062): blitter_.set_modulo<1>(cycle.value16()); break; diff --git a/OSBindings/Mac/Clock SignalTests/AmigaBlitterTests.mm b/OSBindings/Mac/Clock SignalTests/AmigaBlitterTests.mm index e325922cf..8fe6216bf 100644 --- a/OSBindings/Mac/Clock SignalTests/AmigaBlitterTests.mm +++ b/OSBindings/Mac/Clock SignalTests/AmigaBlitterTests.mm @@ -40,7 +40,7 @@ using WriteVector = std::vector>; - (BOOL)verifyWrites:(WriteVector &)writes blitter:(Amiga::Blitter &)blitter ram:(uint16_t *)ram { // Run for however much time the Blitter wants. while(blitter.get_status() & 0x4000) { - blitter.advance(); + blitter.advance_dma(); } for(const auto &write: writes) {