1
0
mirror of https://github.com/TomHarte/CLK.git synced 2025-01-12 00:30:31 +00:00

Fix sprite bit ordering.

This commit is contained in:
Thomas Harte 2021-10-22 21:10:01 -07:00
parent 7ec21edc2f
commit 2121e32409

View File

@ -205,7 +205,7 @@ template <int cycle> void Chipset::output() {
// QUICK HACK: dump sprite pixels: // QUICK HACK: dump sprite pixels:
// //
// (i) always on top, regardless of current priority; // (i) always on top, regardless of current priority;
// (ii) assuming two-colour sprites; and // (ii) assuming four-colour sprites; and
// (iii) not using the proper triggering mechanism. // (iii) not using the proper triggering mechanism.
// //
// (and assuming visible area is a subset of the fetch area, but elsewhere // (and assuming visible area is a subset of the fetch area, but elsewhere
@ -220,8 +220,8 @@ template <int cycle> void Chipset::output() {
}; };
const int colours[] = { const int colours[] = {
int((pixels[0] >> 31) | ((pixels[1] >> 30) & 2)), int((pixels[1] >> 31) | ((pixels[0] >> 30) & 2)),
int(((pixels[0] >> 30)&1) | ((pixels[1] >> 29) & 2)) int(((pixels[1] >> 30)&1) | ((pixels[0] >> 29) & 2))
}; };
const int base = ((c&~1) << 1) + 16; const int base = ((c&~1) << 1) + 16;
@ -606,7 +606,7 @@ void Chipset::perform(const CPU::MC68000::Microcycle &cycle) {
case Read(0x00a): case Read(0x00a):
case Read(0x00c): case Read(0x00c):
// LOG("TODO: Joystick/mouse position " << PADHEX(4) << *cycle.address); // LOG("TODO: Joystick/mouse position " << PADHEX(4) << *cycle.address);
cycle.set_value16(0x8080); cycle.set_value16(0x0000);
break; break;
case Write(0x034): case Write(0x034):
@ -711,9 +711,9 @@ void Chipset::perform(const CPU::MC68000::Microcycle &cycle) {
LOG("Fetch window start set to " << std::dec << fetch_window_[0]); LOG("Fetch window start set to " << std::dec << fetch_window_[0]);
break; break;
case Write(0x094): case Write(0x094):
// TODO: something in my interpretation of ddfstart and ddfend // TODO: something in my interpretation of ddfstart and ddfstop
// means a + 8 is needed below for high-res displays. Investigate. // means a + 8 is needed below for high-res displays. Investigate.
fetch_window_[1] = cycle.value16(); fetch_window_[1] = cycle.value16() + 8;
LOG("Fetch window stop set to " << std::dec << fetch_window_[1]); LOG("Fetch window stop set to " << std::dec << fetch_window_[1]);
break; break;