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;
|
2019-02-19 21:09:12 -05:00
|
|
|
bool HdmaIndirectAddressing;
|
2019-02-15 00:08:50 -05:00
|
|
|
uint8_t TransferMode;
|
|
|
|
|
2019-02-19 21:09:12 -05:00
|
|
|
uint16_t SrcAddress;
|
2019-02-21 07:55:53 -05:00
|
|
|
uint8_t SrcBank;
|
2019-02-19 21:09:12 -05:00
|
|
|
|
2019-02-15 00:08:50 -05:00
|
|
|
uint8_t DestAddress;
|
|
|
|
uint16_t TransferSize;
|
2019-02-19 21:09:12 -05:00
|
|
|
|
|
|
|
uint8_t HdmaBank;
|
|
|
|
uint16_t HdmaTableAddress;
|
|
|
|
uint8_t HdmaLineCounterAndRepeat;
|
|
|
|
bool DoTransfer;
|
|
|
|
bool HdmaFinished;
|
2019-02-21 07:55:53 -05:00
|
|
|
|
2019-03-09 12:01:36 -05:00
|
|
|
bool InterruptedByHdma;
|
2019-02-21 07:55:53 -05:00
|
|
|
bool UnusedFlag;
|
2019-02-15 00:08:50 -05:00
|
|
|
};
|
|
|
|
|
2019-03-31 14:50:12 -04:00
|
|
|
class DmaController final : public ISerializable
|
2019-02-15 00:08:50 -05:00
|
|
|
{
|
|
|
|
private:
|
2019-02-19 21:09:12 -05:00
|
|
|
bool _hdmaPending = false;
|
|
|
|
uint8_t _hdmaChannels = 0;
|
2019-04-04 17:49:47 -04:00
|
|
|
uint8_t _nmiIrqDelayCounter = 0;
|
2019-02-19 21:09:12 -05:00
|
|
|
|
2019-02-15 00:08:50 -05:00
|
|
|
DmaChannelConfig _channel[8] = {};
|
2019-02-16 01:16:57 -05:00
|
|
|
MemoryManager *_memoryManager;
|
2019-02-16 00:47:02 -05:00
|
|
|
|
2019-03-09 14:27:32 -05:00
|
|
|
void CopyDmaByte(uint32_t addressBusA, uint16_t addressBusB, bool fromBtoA);
|
|
|
|
|
2019-02-19 21:09:12 -05:00
|
|
|
void RunSingleTransfer(DmaChannelConfig &channel);
|
2019-02-16 00:47:02 -05:00
|
|
|
void RunDma(DmaChannelConfig &channel);
|
2019-02-19 21:09:12 -05:00
|
|
|
void RunHdmaTransfer(DmaChannelConfig &channel);
|
|
|
|
|
2019-02-15 00:08:50 -05:00
|
|
|
public:
|
2019-02-16 01:16:57 -05:00
|
|
|
DmaController(MemoryManager *memoryManager);
|
2019-03-09 14:27:32 -05:00
|
|
|
|
2019-03-16 12:20:18 -04:00
|
|
|
void Reset();
|
2019-04-04 17:49:47 -04:00
|
|
|
|
|
|
|
bool HasNmiIrqDelay();
|
2019-03-16 12:20:18 -04:00
|
|
|
|
2019-02-19 21:09:12 -05:00
|
|
|
void InitHdmaChannels();
|
|
|
|
void ProcessHdmaChannels();
|
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
|
|
|
|
|
|
|
void Serialize(Serializer &s) override;
|
2019-02-15 00:08:50 -05:00
|
|
|
};
|