mirror of
https://github.com/TomHarte/CLK.git
synced 2025-01-15 20:31:36 +00:00
Switched to looking backwards rather than forwards.
This commit is contained in:
parent
106ddae907
commit
91d3453cc1
@ -23,7 +23,8 @@ Machine::Machine() :
|
|||||||
_rom(nullptr),
|
_rom(nullptr),
|
||||||
_piaDataValue{0xff, 0xff},
|
_piaDataValue{0xff, 0xff},
|
||||||
_tiaInputValue{0xff, 0xff},
|
_tiaInputValue{0xff, 0xff},
|
||||||
_upcomingEventsPointer(0)
|
_upcomingEventsPointer(0),
|
||||||
|
_objectCounterPointer(0)
|
||||||
{
|
{
|
||||||
memset(_collisions, 0xff, sizeof(_collisions));
|
memset(_collisions, 0xff, sizeof(_collisions));
|
||||||
set_reset_line(true);
|
set_reset_line(true);
|
||||||
@ -80,10 +81,15 @@ Machine::~Machine()
|
|||||||
|
|
||||||
void Machine::update_timers(int mask)
|
void Machine::update_timers(int mask)
|
||||||
{
|
{
|
||||||
unsigned int upcomingPointerPlus1 = (_upcomingEventsPointer + 1)%number_of_upcoming_events;
|
|
||||||
unsigned int upcomingPointerPlus2 = (_upcomingEventsPointer + 2)%number_of_upcoming_events;
|
|
||||||
unsigned int upcomingPointerPlus4 = (_upcomingEventsPointer + 4)%number_of_upcoming_events;
|
unsigned int upcomingPointerPlus4 = (_upcomingEventsPointer + 4)%number_of_upcoming_events;
|
||||||
|
|
||||||
|
_objectCounterPointer = (_objectCounterPointer + 1)%number_of_recorded_counters;
|
||||||
|
ObjectCounter *oneClockAgo = _objectCounter[(_objectCounterPointer - 1 + number_of_recorded_counters)%number_of_recorded_counters];
|
||||||
|
ObjectCounter *fourClocksAgo = _objectCounter[(_objectCounterPointer - 4 + number_of_recorded_counters)%number_of_recorded_counters];
|
||||||
|
ObjectCounter *fiveClocksAgo = _objectCounter[(_objectCounterPointer - 5 + number_of_recorded_counters)%number_of_recorded_counters];
|
||||||
|
ObjectCounter *sixClocksAgo = _objectCounter[(_objectCounterPointer - 6 + number_of_recorded_counters)%number_of_recorded_counters];
|
||||||
|
ObjectCounter *now = _objectCounter[_objectCounterPointer];
|
||||||
|
|
||||||
// grab the background now, for application in four clocks
|
// grab the background now, for application in four clocks
|
||||||
if(mask & (1 << 5) && !(_horizontalTimer&3))
|
if(mask & (1 << 5) && !(_horizontalTimer&3))
|
||||||
{
|
{
|
||||||
@ -95,8 +101,15 @@ void Machine::update_timers(int mask)
|
|||||||
if(mask & (1 << 4))
|
if(mask & (1 << 4))
|
||||||
{
|
{
|
||||||
// the ball becomes visible whenever it hits zero, regardless of whether its status
|
// the ball becomes visible whenever it hits zero, regardless of whether its status
|
||||||
// is the result of a counter rollover or a programmatic reset
|
// is the result of a counter rollover or a programmatic reset, and there's a four
|
||||||
if(!_objectCounter[4].count) _objectCounter[4].pixel = 0;
|
// clock delay on that triggering the start signal
|
||||||
|
now[4].count = (oneClockAgo[4].count + 1)%160;
|
||||||
|
now[4].pixel = oneClockAgo[4].pixel + 1;
|
||||||
|
if(!fourClocksAgo[4].count) now[4].pixel = 0;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
now[4] = oneClockAgo[4];
|
||||||
}
|
}
|
||||||
|
|
||||||
// check for player and missle triggers
|
// check for player and missle triggers
|
||||||
@ -104,89 +117,80 @@ void Machine::update_timers(int mask)
|
|||||||
{
|
{
|
||||||
if(mask & (1 << c))
|
if(mask & (1 << c))
|
||||||
{
|
{
|
||||||
// the players and missles become visible only upon overflow to zero, so schedule for
|
// update the count
|
||||||
// 1/2 clocks ahead from 159
|
now[c].count = (oneClockAgo[c].count + 1)%160;
|
||||||
if(_objectCounter[c].count == 159)
|
|
||||||
{
|
|
||||||
unsigned int actionSlot = (c < 2) ? upcomingPointerPlus2 : upcomingPointerPlus1;
|
|
||||||
_upcomingEvents[actionSlot].pixelCounterResetMask &= ~(1 << c);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// otherwise visibility is determined by an appropriate repeat mask and hitting any of 12, 28 or 60,
|
|
||||||
// in which case the counter reset (and hence the start of drawing) will occur in 4/5 cycles
|
|
||||||
uint8_t repeatMask = _playerAndMissileSize[c&1] & 7;
|
uint8_t repeatMask = _playerAndMissileSize[c&1] & 7;
|
||||||
if(
|
ObjectCounter *rollover;
|
||||||
( _objectCounter[c].count == 16 && ((repeatMask == 1) || (repeatMask == 3)) ) ||
|
ObjectCounter *equality;
|
||||||
( _objectCounter[c].count == 32 && ((repeatMask == 2) || (repeatMask == 3) || (repeatMask == 6)) ) ||
|
|
||||||
( _objectCounter[c].count == 64 && ((repeatMask == 4) || (repeatMask == 6)) )
|
|
||||||
)
|
|
||||||
{
|
|
||||||
if(c < 2)
|
if(c < 2)
|
||||||
{
|
{
|
||||||
_upcomingEvents[upcomingPointerPlus1].pixelCounterResetMask &= ~(1 << c);
|
// update the pixel
|
||||||
|
now[c].broad_pixel = oneClockAgo[c].broad_pixel + 1;
|
||||||
|
switch(repeatMask)
|
||||||
|
{
|
||||||
|
default: now[c].pixel = oneClockAgo[c].pixel + 1; break;
|
||||||
|
case 5: now[c].pixel = oneClockAgo[c].pixel + (now[c].broad_pixel&1); break;
|
||||||
|
case 7: now[c].pixel = oneClockAgo[c].pixel + (((now[c].broad_pixel | (now[c].broad_pixel >> 1))^1)&1); break;
|
||||||
|
}
|
||||||
|
|
||||||
|
// check for a rollover six clocks ago or equality five clocks ago
|
||||||
|
rollover = sixClocksAgo;
|
||||||
|
equality = fiveClocksAgo;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
_objectCounter[c].pixel = 0;
|
// update the pixel
|
||||||
}
|
now[c].pixel = oneClockAgo[c].pixel + 1;
|
||||||
}
|
|
||||||
}
|
// check for a rollover five clocks ago or equality four clocks ago
|
||||||
}
|
rollover = fiveClocksAgo;
|
||||||
|
equality = fourClocksAgo;
|
||||||
}
|
}
|
||||||
|
|
||||||
// update the pixel counters
|
if(
|
||||||
for(int c = 0; c < 2; c++)
|
(rollover[c].count == 159) ||
|
||||||
|
(_hasSecondCopy[c&1] && equality[c].count == 16) ||
|
||||||
|
(_hasThirdCopy[c&1] && equality[c].count == 32) ||
|
||||||
|
(_hasFourthCopy[c&1] && equality[c].count == 64)
|
||||||
|
)
|
||||||
{
|
{
|
||||||
_upcomingEvents[upcomingPointerPlus4].pixelCounters[c] = _objectCounter[c].pixel;
|
now[c].pixel = 0;
|
||||||
if(mask&(1 << c))
|
now[c].broad_pixel = 0;
|
||||||
{
|
|
||||||
_objectCounter[c].broad_pixel++;
|
|
||||||
|
|
||||||
uint8_t repeatMask = _playerAndMissileSize[c] & 7;
|
|
||||||
switch(repeatMask)
|
|
||||||
{
|
|
||||||
default: _objectCounter[c].pixel ++; break;
|
|
||||||
case 5: _objectCounter[c].pixel += _objectCounter[c].broad_pixel&1; break;
|
|
||||||
case 7: _objectCounter[c].pixel += ((_objectCounter[c].broad_pixel | (_objectCounter[c].broad_pixel >> 1))^1)&1; break;
|
|
||||||
}
|
|
||||||
_objectCounter[c].count = (_objectCounter[c].count + 1)%160;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else
|
||||||
for(int c = 2; c < 5; c++)
|
|
||||||
{
|
{
|
||||||
_upcomingEvents[upcomingPointerPlus4].pixelCounters[c] = _objectCounter[c].pixel;
|
now[c] = oneClockAgo[c];
|
||||||
if(mask&(1 << c))
|
|
||||||
{
|
|
||||||
_objectCounter[c].count = (_objectCounter[c].count + 1)%160;
|
|
||||||
_objectCounter[c].pixel ++;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
uint8_t Machine::get_output_pixel()
|
uint8_t Machine::get_output_pixel()
|
||||||
{
|
{
|
||||||
unsigned int offset = _horizontalTimer - (horizontalTimerPeriod - 160);
|
ObjectCounter *now = _objectCounter[_objectCounterPointer];
|
||||||
|
|
||||||
// get the playfield pixel and hence a proposed colour
|
// get the playfield pixel
|
||||||
|
unsigned int offset = _horizontalTimer - (horizontalTimerPeriod - 160);
|
||||||
uint8_t playfieldColour = ((_playfieldControl&6) == 2) ? _playerColour[offset / 80] : _playfieldColour;
|
uint8_t playfieldColour = ((_playfieldControl&6) == 2) ? _playerColour[offset / 80] : _playfieldColour;
|
||||||
|
|
||||||
|
// ball pixel
|
||||||
uint8_t ballPixel = 0;
|
uint8_t ballPixel = 0;
|
||||||
if(_upcomingEvents[_upcomingEventsPointer].pixelCounters[4] < _ballSize) {
|
if(now[4].pixel < _ballSize) {
|
||||||
ballPixel = _ballGraphicsEnable[_ballGraphicsSelector];
|
ballPixel = _ballGraphicsEnable[_ballGraphicsSelector];
|
||||||
}
|
}
|
||||||
|
|
||||||
// determine the pixel masks
|
// determine the player and missile pixels
|
||||||
uint8_t playerPixels[2] = { 0, 0 };
|
uint8_t playerPixels[2] = { 0, 0 };
|
||||||
uint8_t missilePixels[2] = { 0, 0 };
|
uint8_t missilePixels[2] = { 0, 0 };
|
||||||
for(int c = 0; c < 2; c++)
|
for(int c = 0; c < 2; c++)
|
||||||
{
|
{
|
||||||
if(_playerGraphics[c] && _upcomingEvents[_upcomingEventsPointer].pixelCounters[c] < 8) {
|
if(_playerGraphics[c] && now[c].pixel < 8) {
|
||||||
playerPixels[c] = (_playerGraphics[_playerGraphicsSelector[c]][c] >> (_upcomingEvents[_upcomingEventsPointer].pixelCounters[c] ^ _playerReflectionMask[c])) & 1;
|
playerPixels[c] = (_playerGraphics[_playerGraphicsSelector[c]][c] >> (now[c].pixel ^ _playerReflectionMask[c])) & 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(_upcomingEvents[_upcomingEventsPointer].pixelCounters[c+2] < _missileSize[c] && !_missileGraphicsReset[c]) {
|
if(!_missileGraphicsReset[c] && now[c+2].pixel < _missileSize[c]) {
|
||||||
missilePixels[c] = _missileGraphicsEnable[c];
|
missilePixels[c] = _missileGraphicsEnable[c];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -217,7 +221,7 @@ uint8_t Machine::get_output_pixel()
|
|||||||
|
|
||||||
void Machine::setup_reported_collisions()
|
void Machine::setup_reported_collisions()
|
||||||
{
|
{
|
||||||
for(int c = 0; c < 32; c++)
|
for(int c = 0; c < 64; c++)
|
||||||
{
|
{
|
||||||
memset(_reportedCollisions[c], 0, 8);
|
memset(_reportedCollisions[c], 0, 8);
|
||||||
|
|
||||||
@ -248,11 +252,6 @@ void Machine::setup_reported_collisions()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// in imputing the knowledge that all we're dealing with is the rollover from 159 to 0,
|
|
||||||
// this is faster than the straightforward +1)%160 per profiling
|
|
||||||
//#define increment_object_counter(c) _objectCounter[c] = (_objectCounter[c]+1)&~((158-_objectCounter[c]) >> 8)
|
|
||||||
|
|
||||||
void Machine::output_pixels(unsigned int count)
|
void Machine::output_pixels(unsigned int count)
|
||||||
{
|
{
|
||||||
while(count--)
|
while(count--)
|
||||||
@ -310,7 +309,7 @@ void Machine::output_pixels(unsigned int count)
|
|||||||
{
|
{
|
||||||
for(int c = 0; c < 5; c++)
|
for(int c = 0; c < 5; c++)
|
||||||
{
|
{
|
||||||
if(((_objectCounter[c].motion >> 4)^_hMoveCounter) == 7)
|
if(((_objectMotion[c] >> 4)^_hMoveCounter) == 7)
|
||||||
{
|
{
|
||||||
_hMoveFlags &= ~(1 << c);
|
_hMoveFlags &= ~(1 << c);
|
||||||
}
|
}
|
||||||
@ -328,19 +327,6 @@ void Machine::output_pixels(unsigned int count)
|
|||||||
update_timers(_hMoveFlags);
|
update_timers(_hMoveFlags);
|
||||||
}
|
}
|
||||||
|
|
||||||
// if(_upcomingEvents[_upcomingEventsPointer].updates & Event::Action::ClockPixels)
|
|
||||||
// {
|
|
||||||
// }
|
|
||||||
|
|
||||||
// apply any resets
|
|
||||||
_objectCounter[0].pixel *= (_upcomingEvents[_upcomingEventsPointer].pixelCounterResetMask >> 0) & 1;
|
|
||||||
_objectCounter[0].broad_pixel *= (_upcomingEvents[_upcomingEventsPointer].pixelCounterResetMask >> 0) & 1;
|
|
||||||
_objectCounter[1].pixel *= (_upcomingEvents[_upcomingEventsPointer].pixelCounterResetMask >> 1) & 1;
|
|
||||||
_objectCounter[1].broad_pixel *= (_upcomingEvents[_upcomingEventsPointer].pixelCounterResetMask >> 1) & 1;
|
|
||||||
_objectCounter[2].pixel *= (_upcomingEvents[_upcomingEventsPointer].pixelCounterResetMask >> 2) & 1;
|
|
||||||
_objectCounter[3].pixel *= (_upcomingEvents[_upcomingEventsPointer].pixelCounterResetMask >> 3) & 1;
|
|
||||||
_objectCounter[4].pixel *= (_upcomingEvents[_upcomingEventsPointer].pixelCounterResetMask >> 4) & 1;
|
|
||||||
|
|
||||||
// reload the playfield pixel if appropriate
|
// reload the playfield pixel if appropriate
|
||||||
if(_upcomingEvents[_upcomingEventsPointer].updates & Event::Action::Playfield)
|
if(_upcomingEvents[_upcomingEventsPointer].updates & Event::Action::Playfield)
|
||||||
{
|
{
|
||||||
@ -388,7 +374,6 @@ void Machine::output_pixels(unsigned int count)
|
|||||||
|
|
||||||
// advance
|
// advance
|
||||||
_upcomingEvents[_upcomingEventsPointer].updates = 0;
|
_upcomingEvents[_upcomingEventsPointer].updates = 0;
|
||||||
_upcomingEvents[_upcomingEventsPointer].pixelCounterResetMask = ~0;
|
|
||||||
_upcomingEventsPointer = (_upcomingEventsPointer + 1)%number_of_upcoming_events;
|
_upcomingEventsPointer = (_upcomingEventsPointer + 1)%number_of_upcoming_events;
|
||||||
|
|
||||||
// advance horizontal timer, perform reset actions if requested
|
// advance horizontal timer, perform reset actions if requested
|
||||||
@ -505,10 +490,16 @@ unsigned int Machine::perform_bus_operation(CPU6502::BusOperation operation, uin
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case 0x04:
|
case 0x04:
|
||||||
case 0x05:
|
case 0x05: {
|
||||||
_playerAndMissileSize[decodedAddress - 0x04] = *value;
|
int entry = decodedAddress - 0x04;
|
||||||
_missileSize[decodedAddress - 0x04] = 1 << ((*value >> 4)&3);
|
_playerAndMissileSize[entry] = *value;
|
||||||
break;
|
_missileSize[entry] = 1 << ((*value >> 4)&3);
|
||||||
|
|
||||||
|
uint8_t repeatMask = (*value)&7;
|
||||||
|
_hasSecondCopy[entry] = (repeatMask == 1) || (repeatMask == 3);
|
||||||
|
_hasThirdCopy[entry] = (repeatMask == 2) || (repeatMask == 3) || (repeatMask == 6);
|
||||||
|
_hasFourthCopy[entry] = (repeatMask == 4) || (repeatMask == 6);
|
||||||
|
} break;
|
||||||
|
|
||||||
case 0x06:
|
case 0x06:
|
||||||
case 0x07: _playerColour[decodedAddress - 0x06] = *value; break;
|
case 0x07: _playerColour[decodedAddress - 0x06] = *value; break;
|
||||||
@ -579,7 +570,7 @@ unsigned int Machine::perform_bus_operation(CPU6502::BusOperation operation, uin
|
|||||||
|
|
||||||
case 0x10: case 0x11: case 0x12: case 0x13:
|
case 0x10: case 0x11: case 0x12: case 0x13:
|
||||||
case 0x14:
|
case 0x14:
|
||||||
_objectCounter[decodedAddress - 0x10].count = 0;
|
_objectCounter[_objectCounterPointer][decodedAddress - 0x10].count = 0;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 0x1c:
|
case 0x1c:
|
||||||
@ -600,7 +591,7 @@ unsigned int Machine::perform_bus_operation(CPU6502::BusOperation operation, uin
|
|||||||
case 0x22:
|
case 0x22:
|
||||||
case 0x23:
|
case 0x23:
|
||||||
case 0x24:
|
case 0x24:
|
||||||
_objectCounter[decodedAddress - 0x20].motion = *value;
|
_objectMotion[decodedAddress - 0x20] = *value;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 0x25: _playerGraphicsSelector[0] = (*value)&1; break;
|
case 0x25: _playerGraphicsSelector[0] = (*value)&1; break;
|
||||||
@ -613,7 +604,7 @@ unsigned int Machine::perform_bus_operation(CPU6502::BusOperation operation, uin
|
|||||||
int index = decodedAddress - 0x28;
|
int index = decodedAddress - 0x28;
|
||||||
if(!(*value&0x02) && _missileGraphicsReset[index])
|
if(!(*value&0x02) && _missileGraphicsReset[index])
|
||||||
{
|
{
|
||||||
_objectCounter[index + 2].count = _objectCounter[index].count;
|
_objectCounter[_objectCounterPointer][index + 2].count = _objectCounter[_objectCounterPointer][index].count;
|
||||||
|
|
||||||
uint8_t repeatMask = _playerAndMissileSize[index] & 7;
|
uint8_t repeatMask = _playerAndMissileSize[index] & 7;
|
||||||
int extra_offset;
|
int extra_offset;
|
||||||
@ -624,7 +615,7 @@ unsigned int Machine::perform_bus_operation(CPU6502::BusOperation operation, uin
|
|||||||
case 7: extra_offset = 10; break;
|
case 7: extra_offset = 10; break;
|
||||||
}
|
}
|
||||||
|
|
||||||
_objectCounter[index + 2].count = (_objectCounter[index + 2].count + extra_offset)%160;
|
_objectCounter[_objectCounterPointer][index + 2].count = (_objectCounter[_objectCounterPointer][index + 2].count + extra_offset)%160;
|
||||||
}
|
}
|
||||||
_missileGraphicsReset[index] = !!((*value) & 0x02);
|
_missileGraphicsReset[index] = !!((*value) & 0x02);
|
||||||
}
|
}
|
||||||
@ -637,11 +628,11 @@ unsigned int Machine::perform_bus_operation(CPU6502::BusOperation operation, uin
|
|||||||
_upcomingEvents[(_upcomingEventsPointer + 5)%number_of_upcoming_events].updates |= Event::Action::HMoveSetup;
|
_upcomingEvents[(_upcomingEventsPointer + 5)%number_of_upcoming_events].updates |= Event::Action::HMoveSetup;
|
||||||
break;
|
break;
|
||||||
case 0x2b:
|
case 0x2b:
|
||||||
_objectCounter[0].motion =
|
_objectMotion[0] =
|
||||||
_objectCounter[1].motion =
|
_objectMotion[1] =
|
||||||
_objectCounter[2].motion =
|
_objectMotion[2] =
|
||||||
_objectCounter[3].motion =
|
_objectMotion[3] =
|
||||||
_objectCounter[4].motion = 0;
|
_objectMotion[4] = 0;
|
||||||
break;
|
break;
|
||||||
case 0x2c:
|
case 0x2c:
|
||||||
_collisions[0] = _collisions[1] = _collisions[2] =
|
_collisions[0] = _collisions[1] = _collisions[2] =
|
||||||
|
@ -17,6 +17,7 @@
|
|||||||
namespace Atari2600 {
|
namespace Atari2600 {
|
||||||
|
|
||||||
const unsigned int number_of_upcoming_events = 6;
|
const unsigned int number_of_upcoming_events = 6;
|
||||||
|
const unsigned int number_of_recorded_counters = 7;
|
||||||
|
|
||||||
class Machine: public CPU6502::Processor<Machine> {
|
class Machine: public CPU6502::Processor<Machine> {
|
||||||
|
|
||||||
@ -64,24 +65,31 @@ class Machine: public CPU6502::Processor<Machine> {
|
|||||||
struct Event {
|
struct Event {
|
||||||
enum Action {
|
enum Action {
|
||||||
Playfield = 1 << 0,
|
Playfield = 1 << 0,
|
||||||
ClockPixels = 1 << 1,
|
|
||||||
|
|
||||||
HMoveSetup = 1 << 2,
|
HMoveSetup = 1 << 1,
|
||||||
HMoveCompare = 1 << 3,
|
HMoveCompare = 1 << 2,
|
||||||
HMoveDecrement = 1 << 4,
|
HMoveDecrement = 1 << 3,
|
||||||
};
|
};
|
||||||
int updates;
|
int updates;
|
||||||
|
|
||||||
OutputState state;
|
OutputState state;
|
||||||
int pixelCounterResetMask;
|
|
||||||
uint8_t playfieldPixel;
|
uint8_t playfieldPixel;
|
||||||
|
|
||||||
int pixelCounters[5];
|
Event() : updates(0), playfieldPixel(0) {}
|
||||||
|
|
||||||
Event() : updates(0), pixelCounterResetMask(~0), playfieldPixel(0) {}
|
|
||||||
} _upcomingEvents[number_of_upcoming_events];
|
} _upcomingEvents[number_of_upcoming_events];
|
||||||
unsigned int _upcomingEventsPointer;
|
unsigned int _upcomingEventsPointer;
|
||||||
|
|
||||||
|
// object counters
|
||||||
|
struct ObjectCounter {
|
||||||
|
int count; // the counter value, multiplied by four, counting phase
|
||||||
|
int pixel; // for non-sprite objects, a count of cycles since the last counter reset; for sprite objects a count of pixels so far elapsed
|
||||||
|
int broad_pixel; // for sprite objects, a count of cycles since the last counter reset; otherwise unused
|
||||||
|
|
||||||
|
ObjectCounter() : count(0), pixel(0), broad_pixel(0) {}
|
||||||
|
} _objectCounter[number_of_recorded_counters][5];
|
||||||
|
unsigned int _objectCounterPointer;
|
||||||
|
|
||||||
|
// the latched playfield output
|
||||||
uint8_t _playfieldOutput;
|
uint8_t _playfieldOutput;
|
||||||
|
|
||||||
// player registers
|
// player registers
|
||||||
@ -91,6 +99,12 @@ class Machine: public CPU6502::Processor<Machine> {
|
|||||||
uint8_t _playerGraphicsSelector[2];
|
uint8_t _playerGraphicsSelector[2];
|
||||||
bool _playerStart[2];
|
bool _playerStart[2];
|
||||||
|
|
||||||
|
// object flags
|
||||||
|
bool _hasSecondCopy[2];
|
||||||
|
bool _hasThirdCopy[2];
|
||||||
|
bool _hasFourthCopy[2];
|
||||||
|
uint8_t _objectMotion[5]; // the value stored to this counter's motion register
|
||||||
|
|
||||||
// player + missile registers
|
// player + missile registers
|
||||||
uint8_t _playerAndMissileSize[2];
|
uint8_t _playerAndMissileSize[2];
|
||||||
|
|
||||||
@ -111,14 +125,6 @@ class Machine: public CPU6502::Processor<Machine> {
|
|||||||
uint8_t _hMoveCounter;
|
uint8_t _hMoveCounter;
|
||||||
uint8_t _hMoveFlags;
|
uint8_t _hMoveFlags;
|
||||||
|
|
||||||
// object counters
|
|
||||||
struct {
|
|
||||||
int count; // the counter value, multiplied by four, counting phase
|
|
||||||
int pixel; // for non-sprite objects, a count of cycles since the last counter reset; for sprite objects a count of pixels so far elapsed
|
|
||||||
int broad_pixel; // for sprite objects, a count of cycles since the last counter reset; otherwise unused
|
|
||||||
uint8_t motion; // the value stored to this counter's motion register
|
|
||||||
} _objectCounter[5];
|
|
||||||
|
|
||||||
// joystick state
|
// joystick state
|
||||||
uint8_t _piaDataDirection[2];
|
uint8_t _piaDataDirection[2];
|
||||||
uint8_t _piaDataValue[2];
|
uint8_t _piaDataValue[2];
|
||||||
@ -138,7 +144,7 @@ class Machine: public CPU6502::Processor<Machine> {
|
|||||||
uint8_t *_outputBuffer;
|
uint8_t *_outputBuffer;
|
||||||
|
|
||||||
// lookup table for collision reporting
|
// lookup table for collision reporting
|
||||||
uint8_t _reportedCollisions[32][8];
|
uint8_t _reportedCollisions[64][8];
|
||||||
void setup_reported_collisions();
|
void setup_reported_collisions();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user