added NDMA hardware interface
This commit is contained in:
		| @@ -55,7 +55,7 @@ enum LOG_TYPE { | ||||
|     WII_IPC_HID, | ||||
|     WII_IPC_HLE, | ||||
|     WII_IPC_NET, | ||||
|     WII_IPC_WC24, | ||||
|     NDMA, | ||||
|     HLE, | ||||
|     RENDER, | ||||
|     LCD, | ||||
|   | ||||
| @@ -67,7 +67,7 @@ LogManager::LogManager() | ||||
|     m_Log[LogTypes::RENDER]             = new LogContainer("RENDER",            "RENDER"); | ||||
|     m_Log[LogTypes::LCD]                = new LogContainer("LCD",               "LCD"); | ||||
|     m_Log[LogTypes::WII_IPC_NET]        = new LogContainer("WII_IPC_NET",       "WII IPC NET"); | ||||
|     m_Log[LogTypes::WII_IPC_WC24]       = new LogContainer("WII_IPC_WC24",      "WII IPC WC24"); | ||||
|     m_Log[LogTypes::NDMA]               = new LogContainer("NDMA",              "NDMA"); | ||||
|     m_Log[LogTypes::HLE]                = new LogContainer("HLE",               "High Level Emulation"); | ||||
|     m_Log[LogTypes::HW]                 = new LogContainer("HW",                "Hardware"); | ||||
|     m_Log[LogTypes::ACTIONREPLAY]       = new LogContainer("ActionReplay",      "ActionReplay"); | ||||
|   | ||||
| @@ -161,6 +161,7 @@ | ||||
|     <ClCompile Include="hle\syscall.cpp" /> | ||||
|     <ClCompile Include="hw\hw.cpp" /> | ||||
|     <ClCompile Include="hw\hw_lcd.cpp" /> | ||||
|     <ClCompile Include="hw\ndma.cpp" /> | ||||
|     <ClCompile Include="loader.cpp" /> | ||||
|     <ClCompile Include="mem_map.cpp" /> | ||||
|     <ClCompile Include="mem_map_funcs.cpp" /> | ||||
| @@ -199,6 +200,7 @@ | ||||
|     <ClInclude Include="hle\syscall.h" /> | ||||
|     <ClInclude Include="hw\hw.h" /> | ||||
|     <ClInclude Include="hw\hw_lcd.h" /> | ||||
|     <ClInclude Include="hw\ndma.h" /> | ||||
|     <ClInclude Include="loader.h" /> | ||||
|     <ClInclude Include="mem_map.h" /> | ||||
|     <ClInclude Include="system.h" /> | ||||
|   | ||||
| @@ -102,6 +102,9 @@ | ||||
|     <ClCompile Include="hle\service\hid.cpp"> | ||||
|       <Filter>hle\service</Filter> | ||||
|     </ClCompile> | ||||
|     <ClCompile Include="hw\ndma.cpp"> | ||||
|       <Filter>hw</Filter> | ||||
|     </ClCompile> | ||||
|   </ItemGroup> | ||||
|   <ItemGroup> | ||||
|     <ClInclude Include="arm\disassembler\arm_disasm.h"> | ||||
| @@ -199,6 +202,9 @@ | ||||
|     <ClInclude Include="hle\service\hid.h"> | ||||
|       <Filter>hle\service</Filter> | ||||
|     </ClInclude> | ||||
|     <ClInclude Include="hw\ndma.h"> | ||||
|       <Filter>hw</Filter> | ||||
|     </ClInclude> | ||||
|   </ItemGroup> | ||||
|   <ItemGroup> | ||||
|     <Text Include="CMakeLists.txt" /> | ||||
|   | ||||
| @@ -7,17 +7,72 @@ | ||||
|  | ||||
| #include "core/hw/hw.h" | ||||
| #include "core/hw/hw_lcd.h" | ||||
| #include "core/hw/ndma.h" | ||||
|  | ||||
| namespace HW { | ||||
|  | ||||
| enum { | ||||
|     ADDRESS_CONFIG      = 0x10000000, | ||||
|     ADDRESS_IRQ         = 0x10001000, | ||||
|     ADDRESS_NDMA        = 0x10002000, | ||||
|     ADDRESS_TIMER       = 0x10003000, | ||||
|     ADDRESS_CTRCARD     = 0x10004000, | ||||
|     ADDRESS_CTRCARD_2   = 0x10005000, | ||||
|     ADDRESS_SDMC_NAND   = 0x10006000, | ||||
|     ADDRESS_SDMC_NAND_2 = 0x10007000,   // Apparently not used on retail | ||||
|     ADDRESS_PXI         = 0x10008000, | ||||
|     ADDRESS_AES         = 0x10009000, | ||||
|     ADDRESS_SHA         = 0x1000A000, | ||||
|     ADDRESS_RSA         = 0x1000B000, | ||||
|     ADDRESS_XDMA        = 0x1000C000, | ||||
|     ADDRESS_SPICARD     = 0x1000D800, | ||||
|     ADDRESS_CONFIG_2    = 0x10010000, | ||||
|     ADDRESS_HASH        = 0x10101000, | ||||
|     ADDRESS_CSND        = 0x10103000, | ||||
|     ADDRESS_DSP         = 0x10140000, | ||||
|     ADDRESS_PDN         = 0x10141000, | ||||
|     ADDRESS_CODEC       = 0x10141000, | ||||
|     ADDRESS_SPI         = 0x10142000, | ||||
|     ADDRESS_SPI_2       = 0x10143000, | ||||
|     ADDRESS_I2C         = 0x10144000, | ||||
|     ADDRESS_CODEC_2     = 0x10145000, | ||||
|     ADDRESS_HID         = 0x10146000, | ||||
|     ADDRESS_PAD         = 0x10146000, | ||||
|     ADDRESS_PTM         = 0x10146000, | ||||
|     ADDRESS_I2C_2       = 0x10148000, | ||||
|     ADDRESS_SPI_3       = 0x10160000, | ||||
|     ADDRESS_I2C_3       = 0x10161000, | ||||
|     ADDRESS_MIC         = 0x10162000, | ||||
|     ADDRESS_PXI_2       = 0x10163000, | ||||
|     ADDRESS_NTRCARD     = 0x10164000, | ||||
|     ADDRESS_DSP_2       = 0x10203000, | ||||
|     ADDRESS_HASH_2      = 0x10301000, | ||||
| }; | ||||
|  | ||||
| template <typename T> | ||||
| inline void Read(T &var, const u32 addr) { | ||||
|     NOTICE_LOG(HW, "read from address %08X", addr); | ||||
|     switch (addr & 0xFFFFF000) { | ||||
|      | ||||
|     case ADDRESS_NDMA: | ||||
|         NDMA::Read(var, addr); | ||||
|         break; | ||||
|  | ||||
|     default: | ||||
|         ERROR_LOG(HW, "unknown Read%d @ 0x%08X", sizeof(var) * 8, addr); | ||||
|     } | ||||
| } | ||||
|  | ||||
| template <typename T> | ||||
| inline void Write(u32 addr, const T data) { | ||||
|     NOTICE_LOG(HW, "write to address %08X", addr); | ||||
|     switch (addr & 0xFFFFF000) { | ||||
|      | ||||
|     case ADDRESS_NDMA: | ||||
|         NDMA::Write(addr, data); | ||||
|         break; | ||||
|  | ||||
|     default: | ||||
|         ERROR_LOG(HW, "unknown Write%d 0x%08X @ 0x%08X", sizeof(data) * 8, data, addr); | ||||
|     } | ||||
| } | ||||
|  | ||||
| // Explicitly instantiate template functions because we aren't defining this in the header: | ||||
| @@ -35,11 +90,13 @@ template void Write<u8>(u32 addr, const u8 data); | ||||
| /// Update hardware | ||||
| void Update() { | ||||
|     LCD::Update(); | ||||
|     NDMA::Update(); | ||||
| } | ||||
|  | ||||
| /// Initialize hardware | ||||
| void Init() { | ||||
|     LCD::Init(); | ||||
|     NDMA::Init(); | ||||
|     NOTICE_LOG(HW, "initialized OK"); | ||||
| } | ||||
|  | ||||
|   | ||||
							
								
								
									
										48
									
								
								src/core/hw/ndma.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										48
									
								
								src/core/hw/ndma.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,48 @@ | ||||
| // Copyright 2014 Citra Emulator Project | ||||
| // Licensed under GPLv2 | ||||
| // Refer to the license.txt file included. | ||||
|  | ||||
| #include "common/common_types.h" | ||||
| #include "common/log.h" | ||||
|  | ||||
| #include "core/hw/ndma.h" | ||||
|  | ||||
| namespace NDMA { | ||||
|  | ||||
| template <typename T> | ||||
| inline void Read(T &var, const u32 addr) { | ||||
|     ERROR_LOG(NDMA, "unknown Read%d @ 0x%08X", sizeof(var) * 8, addr); | ||||
| } | ||||
|  | ||||
| template <typename T> | ||||
| inline void Write(u32 addr, const T data) { | ||||
|     ERROR_LOG(NDMA, "unknown Write%d 0x%08X @ 0x%08X", sizeof(data) * 8, data, addr); | ||||
| } | ||||
|  | ||||
| // Explicitly instantiate template functions because we aren't defining this in the header: | ||||
|  | ||||
| template void Read<u64>(u64 &var, const u32 addr); | ||||
| template void Read<u32>(u32 &var, const u32 addr); | ||||
| template void Read<u16>(u16 &var, const u32 addr); | ||||
| template void Read<u8>(u8 &var, const u32 addr); | ||||
|  | ||||
| template void Write<u64>(u32 addr, const u64 data); | ||||
| template void Write<u32>(u32 addr, const u32 data); | ||||
| template void Write<u16>(u32 addr, const u16 data); | ||||
| template void Write<u8>(u32 addr, const u8 data); | ||||
|  | ||||
| /// Update hardware | ||||
| void Update() { | ||||
| } | ||||
|  | ||||
| /// Initialize hardware | ||||
| void Init() { | ||||
|     NOTICE_LOG(LCD, "initialized OK"); | ||||
| } | ||||
|  | ||||
| /// Shutdown hardware | ||||
| void Shutdown() { | ||||
|     NOTICE_LOG(LCD, "shutdown OK"); | ||||
| } | ||||
|  | ||||
| } // namespace | ||||
							
								
								
									
										26
									
								
								src/core/hw/ndma.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								src/core/hw/ndma.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,26 @@ | ||||
| // Copyright 2014 Citra Emulator Project | ||||
| // Licensed under GPLv2 | ||||
| // Refer to the license.txt file included. | ||||
|  | ||||
| #pragma once | ||||
|  | ||||
| #include "common/common_types.h" | ||||
|  | ||||
| namespace NDMA { | ||||
|  | ||||
| template <typename T> | ||||
| inline void Read(T &var, const u32 addr); | ||||
|  | ||||
| template <typename T> | ||||
| inline void Write(u32 addr, const T data); | ||||
|  | ||||
| /// Update hardware | ||||
| void Update(); | ||||
|  | ||||
| /// Initialize hardware | ||||
| void Init(); | ||||
|  | ||||
| /// Shutdown hardware | ||||
| void Shutdown(); | ||||
|  | ||||
| } // namespace | ||||
		Reference in New Issue
	
	Block a user
	 bunnei
					bunnei