2020-03-15 14:59:54 -04:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "Iop_Module.h"
|
2020-07-13 20:16:53 +02:00
|
|
|
#include "Iop_Dmac.h"
|
2020-03-15 14:59:54 -04:00
|
|
|
|
|
|
|
class CIopBios;
|
|
|
|
|
|
|
|
namespace Iop
|
|
|
|
{
|
|
|
|
class CDmacman : public CModule
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
CDmacman() = default;
|
|
|
|
virtual ~CDmacman() = default;
|
|
|
|
|
|
|
|
std::string GetId() const override;
|
|
|
|
std::string GetFunctionName(unsigned int) const override;
|
|
|
|
void Invoke(CMIPS&, unsigned int) override;
|
|
|
|
|
|
|
|
private:
|
2021-05-17 18:05:54 +02:00
|
|
|
void DmacSetDpcr(CMIPS&, uint32);
|
|
|
|
uint32 DmacGetDpcr(CMIPS&);
|
|
|
|
void DmacSetDpcr2(CMIPS&, uint32);
|
|
|
|
uint32 DmacGetDpcr2(CMIPS&);
|
|
|
|
void DmacSetDpcr3(CMIPS&, uint32);
|
|
|
|
uint32 DmacGetDpcr3(CMIPS&);
|
2020-03-15 14:59:54 -04:00
|
|
|
uint32 DmacRequest(CMIPS&, uint32, uint32, uint32, uint32, uint32);
|
|
|
|
void DmacTransfer(CMIPS&, uint32);
|
2020-07-13 20:16:53 +02:00
|
|
|
void DmacChSetDpcr(CMIPS&, uint32, uint32);
|
|
|
|
void DmacEnable(CMIPS&, uint32);
|
|
|
|
void DmacDisable(CMIPS&, uint32);
|
|
|
|
uint32 GetDPCRAddr(uint32 channel);
|
2020-03-15 14:59:54 -04:00
|
|
|
};
|
|
|
|
}
|