Mesen-SX/Core/DmaController.h

79 lines
1.6 KiB
C
Raw Normal View History

2019-02-15 00:08:50 -05:00
#pragma once
#include "stdafx.h"
#include "CpuTypes.h"
2019-03-12 09:15:57 -04:00
#include "../Utilities/ISerializable.h"
2019-02-15 00:08:50 -05:00
class MemoryManager;
struct DmaChannelConfig
{
bool InvertDirection;
bool Decrement;
bool FixedTransfer;
bool HdmaIndirectAddressing;
2019-02-15 00:08:50 -05:00
uint8_t TransferMode;
uint16_t SrcAddress;
2019-02-21 07:55:53 -05:00
uint8_t SrcBank;
2019-02-15 00:08:50 -05:00
uint16_t TransferSize;
uint8_t DestAddress;
uint16_t HdmaTableAddress;
uint8_t HdmaBank;
uint8_t HdmaLineCounterAndRepeat;
bool DoTransfer;
bool HdmaFinished;
2019-02-21 07:55:53 -05:00
bool InterruptedByHdma;
2019-02-21 07:55:53 -05:00
bool UnusedFlag;
2019-02-15 00:08:50 -05:00
};
class DmaController final : public ISerializable
2019-02-15 00:08:50 -05:00
{
private:
bool _hdmaPending = false;
bool _hdmaInitPending = false;
bool _inDma = false;
uint8_t _hdmaChannels = 0;
uint8_t _nmiIrqDelayCounter = 0;
uint8_t _requestedDmaChannels = 0;
uint64_t _dmaStartClock = 0;
uint8_t _activeChannel = 0; //Used by debugger's event viewer
2019-02-15 00:08:50 -05:00
DmaChannelConfig _channel[8] = {};
2019-02-16 01:16:57 -05:00
MemoryManager *_memoryManager;
void CopyDmaByte(uint32_t addressBusA, uint16_t addressBusB, bool fromBtoA);
void RunSingleTransfer(DmaChannelConfig &channel);
void RunDma(DmaChannelConfig &channel);
void RunHdmaTransfer(DmaChannelConfig &channel);
void ProcessHdmaChannels(bool applyOverhead);
void InitHdmaChannels();
void SyncStartDma();
void SyncEndDma();
2019-02-15 00:08:50 -05:00
public:
2019-02-16 01:16:57 -05:00
DmaController(MemoryManager *memoryManager);
void Reset();
bool HasNmiIrqDelay();
void BeginHdmaTransfer();
void BeginHdmaInit();
void ProcessPendingTransfers();
2019-02-15 00:08:50 -05:00
void Write(uint16_t addr, uint8_t value);
2019-02-21 07:55:53 -05:00
uint8_t Read(uint16_t addr);
2019-03-12 09:15:57 -04:00
uint8_t GetActiveChannel();
DmaChannelConfig GetChannelConfig(uint8_t channel);
2019-03-12 09:15:57 -04:00
void Serialize(Serializer &s) override;
2019-02-15 00:08:50 -05:00
};