mirror of https://github.com/stella-emu/stella.git
Bus stuffing.
This commit is contained in:
parent
5e8e31b2d8
commit
4bcc8056b9
|
@ -92,6 +92,13 @@ BusTransactionQueue& BusTransactionQueue::injectROM(uInt8 value, uInt16 address)
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
BusTransactionQueue& BusTransactionQueue::stuffByte(uInt8 value, uInt16 address)
|
||||||
|
{
|
||||||
|
push(Transaction::transactionDrive(address, value));
|
||||||
|
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
BusTransactionQueue& BusTransactionQueue::yield(uInt16 address)
|
BusTransactionQueue& BusTransactionQueue::yield(uInt16 address)
|
||||||
{
|
{
|
||||||
|
|
|
@ -43,12 +43,17 @@ class BusTransactionQueue {
|
||||||
|
|
||||||
BusTransactionQueue& injectROM(uInt8 value);
|
BusTransactionQueue& injectROM(uInt8 value);
|
||||||
BusTransactionQueue& injectROM(uInt8 value, uInt16 address);
|
BusTransactionQueue& injectROM(uInt8 value, uInt16 address);
|
||||||
|
BusTransactionQueue& stuffByte(uInt8 value, uInt16 address);
|
||||||
|
|
||||||
BusTransactionQueue& yield(uInt16 address);
|
BusTransactionQueue& yield(uInt16 address);
|
||||||
|
|
||||||
bool hasPendingTransaction() const;
|
bool hasPendingTransaction() const;
|
||||||
Transaction* getNextTransaction(uInt16 address);
|
Transaction* getNextTransaction(uInt16 address);
|
||||||
|
|
||||||
|
inline size_t size() const {
|
||||||
|
return myQueueSize;
|
||||||
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void push(const Transaction& transaction);
|
void push(const Transaction& transaction);
|
||||||
|
|
||||||
|
|
|
@ -146,7 +146,14 @@ CortexM0::err_t VcsLib::fetch16(uInt32 address, uInt16& value, uInt8& op, Cortex
|
||||||
return returnFromStub(value, op);
|
return returnFromStub(value, op);
|
||||||
|
|
||||||
case ADDR_VCS_WRITE3:
|
case ADDR_VCS_WRITE3:
|
||||||
FatalEmulationError::raise("unimplemented: vcsWrite3");
|
arg = cortex.getRegister(0);
|
||||||
|
|
||||||
|
myTransactionQueue
|
||||||
|
.injectROM(0x85)
|
||||||
|
.injectROM(arg)
|
||||||
|
.stuffByte(arg, cortex.getRegister(1));
|
||||||
|
|
||||||
|
return returnFromStub(value, op);
|
||||||
|
|
||||||
case ADDR_VCS_JMP3:
|
case ADDR_VCS_JMP3:
|
||||||
myTransactionQueue
|
myTransactionQueue
|
||||||
|
|
Loading…
Reference in New Issue