mirror of
				https://github.com/PabloMK7/citra.git
				synced 2025-10-30 21:30:04 +00:00 
			
		
		
		
	added hw R/W/ memory functions
This commit is contained in:
		
							parent
							
								
									f24f4ff978
								
							
						
					
					
						commit
						030c836793
					
				
					 5 changed files with 161 additions and 3 deletions
				
			
		|  | @ -138,6 +138,7 @@ | ||||||
|     <ClCompile Include="src\arm\disassembler\arm_disasm.cpp" /> |     <ClCompile Include="src\arm\disassembler\arm_disasm.cpp" /> | ||||||
|     <ClCompile Include="src\core.cpp" /> |     <ClCompile Include="src\core.cpp" /> | ||||||
|     <ClCompile Include="src\mem_map.cpp" /> |     <ClCompile Include="src\mem_map.cpp" /> | ||||||
|  |     <ClCompile Include="src\mem_map_funcs.cpp" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
|   <ItemGroup> |   <ItemGroup> | ||||||
|     <ClInclude Include="src\arm\armcpu.h" /> |     <ClInclude Include="src\arm\armcpu.h" /> | ||||||
|  |  | ||||||
|  | @ -12,6 +12,7 @@ | ||||||
|     <ClCompile Include="src\arm\armemu.cpp"> |     <ClCompile Include="src\arm\armemu.cpp"> | ||||||
|       <Filter>arm</Filter> |       <Filter>arm</Filter> | ||||||
|     </ClCompile> |     </ClCompile> | ||||||
|  |     <ClCompile Include="src\mem_map_funcs.cpp" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
|   <ItemGroup> |   <ItemGroup> | ||||||
|     <Filter Include="arm"> |     <Filter Include="arm"> | ||||||
|  |  | ||||||
|  | @ -101,7 +101,7 @@ void Init() { | ||||||
| 
 | 
 | ||||||
| 	for (size_t i = 0; i < ARRAY_SIZE(g_views); i++) { | 	for (size_t i = 0; i < ARRAY_SIZE(g_views); i++) { | ||||||
| 		if (g_views[i].flags & MV_IS_PRIMARY_RAM) | 		if (g_views[i].flags & MV_IS_PRIMARY_RAM) | ||||||
| 			g_views[i].size = MEMORY_SIZE; | 			g_views[i].size = MEM_FCRAM_SIZE; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	INFO_LOG(MEMMAP, "Memory system initialized. RAM at %p (mirror at 0 @ %p)", g_fcram,  | 	INFO_LOG(MEMMAP, "Memory system initialized. RAM at %p (mirror at 0 @ %p)", g_fcram,  | ||||||
|  |  | ||||||
|  | @ -39,8 +39,7 @@ | ||||||
| #define MEM_AXI_WRAM_SIZE		0x00080000	///< AXI WRAM size
 | #define MEM_AXI_WRAM_SIZE		0x00080000	///< AXI WRAM size
 | ||||||
| #define MEM_FCRAM_SIZE			0x08000000	///< FCRAM size
 | #define MEM_FCRAM_SIZE			0x08000000	///< FCRAM size
 | ||||||
| 
 | 
 | ||||||
| #define MEMORY_SIZE				MEM_FCRAM_SIZE | #define MEM_FCRAM_MASK			(MEM_FCRAM_SIZE - 1)	///< FCRAm mask
 | ||||||
| #define MEMORY_MASK				(MEM_FCRAM_SIZE - 1)	///< Main memory mask
 |  | ||||||
| 
 | 
 | ||||||
| ////////////////////////////////////////////////////////////////////////////////////////////////////
 | ////////////////////////////////////////////////////////////////////////////////////////////////////
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
							
								
								
									
										157
									
								
								src/core/src/mem_map_funcs.cpp
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										157
									
								
								src/core/src/mem_map_funcs.cpp
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,157 @@ | ||||||
|  | /**
 | ||||||
|  |  * Copyright (C) 2013 Citrus Emulator | ||||||
|  |  * | ||||||
|  |  * @file    mem_map_funcs.cpp | ||||||
|  |  * @author  ShizZy <shizzy247@gmail.com> | ||||||
|  |  * @date    2013-09-18 | ||||||
|  |  * @brief   Memory map R/W functions | ||||||
|  |  * | ||||||
|  |  * @section LICENSE | ||||||
|  |  * This program is free software; you can redistribute it and/or | ||||||
|  |  * modify it under the terms of the GNU General Public License as | ||||||
|  |  * published by the Free Software Foundation; either version 2 of | ||||||
|  |  * the License, or (at your option) any later version. | ||||||
|  |  * | ||||||
|  |  * This program is distributed in the hope that it will be useful, but | ||||||
|  |  * WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | ||||||
|  |  * General Public License for more details at | ||||||
|  |  * http://www.gnu.org/copyleft/gpl.html
 | ||||||
|  |  * | ||||||
|  |  * Official project repository can be found at: | ||||||
|  |  * http://code.google.com/p/gekko-gc-emu/
 | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | #include "common.h" | ||||||
|  | 
 | ||||||
|  | #include "mem_map.h" | ||||||
|  | 
 | ||||||
|  | namespace Memory { | ||||||
|  | 
 | ||||||
|  | /*
 | ||||||
|  | u8 *GetPointer(const u32 address) | ||||||
|  | { | ||||||
|  | 	if ((address & 0x3E000000) == 0x08000000) { | ||||||
|  | 		return g_fcram + (address & MEM_FCRAM_MASK); | ||||||
|  | 	} | ||||||
|  | 	else if ((address & 0x3F800000) == 0x04000000) { | ||||||
|  | 		return m_pVRAM + (address & VRAM_MASK); | ||||||
|  | 	} | ||||||
|  | 	else if ((address & 0x3F000000) >= 0x08000000 && (address & 0x3F000000) < 0x08000000 + g_MemorySize) { | ||||||
|  | 		return m_pRAM + (address & g_MemoryMask); | ||||||
|  | 	} | ||||||
|  | 	else { | ||||||
|  | 		ERROR_LOG(MEMMAP, "Unknown GetPointer %08x PC %08x LR %08x", address, currentMIPS->pc, currentMIPS->r[MIPS_REG_RA]); | ||||||
|  | 		static bool reported = false; | ||||||
|  | 		if (!reported) { | ||||||
|  | 			Reporting::ReportMessage("Unknown GetPointer %08x PC %08x LR %08x", address, currentMIPS->pc, currentMIPS->r[MIPS_REG_RA]); | ||||||
|  | 			reported = true; | ||||||
|  | 		} | ||||||
|  | 		if (!g_Config.bIgnoreBadMemAccess) { | ||||||
|  | 			Core_EnableStepping(true); | ||||||
|  | 			host->SetDebugMode(true); | ||||||
|  | 		} | ||||||
|  | 		return 0; | ||||||
|  | 	} | ||||||
|  | }*/ | ||||||
|  | 
 | ||||||
|  | template <typename T> | ||||||
|  | inline void ReadFromHardware(T &var, const u32 address) | ||||||
|  | { | ||||||
|  | 	// TODO: Figure out the fastest order of tests for both read and write (they are probably different).
 | ||||||
|  | 	// TODO: Make sure this represents the mirrors in a correct way.
 | ||||||
|  | 
 | ||||||
|  | 	// Could just do a base-relative read, too.... TODO
 | ||||||
|  | 
 | ||||||
|  | 	if ((address & 0x3E000000) == 0x08000000) { | ||||||
|  | 		var = *((const T*)&g_fcram[address & MEM_FCRAM_MASK]); | ||||||
|  | 	} | ||||||
|  | 	/*else if ((address & 0x3F800000) == 0x04000000) {
 | ||||||
|  | 		var = *((const T*)&m_pVRAM[address & VRAM_MASK]); | ||||||
|  | 	}*/ | ||||||
|  | 	else { | ||||||
|  | 		_assert_msg_(MEMMAP, false, "unknown hardware read"); | ||||||
|  | 		// WARN_LOG(MEMMAP, "ReadFromHardware: Invalid address %08x PC %08x LR %08x", address, currentMIPS->pc, currentMIPS->r[MIPS_REG_RA]);
 | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | template <typename T> | ||||||
|  | inline void WriteToHardware(u32 address, const T data) | ||||||
|  | { | ||||||
|  | 	// Could just do a base-relative write, too.... TODO
 | ||||||
|  | 
 | ||||||
|  | 	if ((address & 0x3E000000) == 0x08000000) { | ||||||
|  | 		*(T*)&g_fcram[address & MEM_FCRAM_MASK] = data; | ||||||
|  | 	} | ||||||
|  | 	/*else if ((address & 0x3F800000) == 0x04000000) {
 | ||||||
|  | 		*(T*)&m_pVRAM[address & VRAM_MASK] = data; | ||||||
|  | 	}*/ | ||||||
|  | 	else { | ||||||
|  | 		_assert_msg_(MEMMAP, false, "unknown hardware write"); | ||||||
|  | 		// WARN_LOG(MEMMAP, "WriteToHardware: Invalid address %08x	PC %08x LR %08x", address, currentMIPS->pc, currentMIPS->r[MIPS_REG_RA]);
 | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | bool IsValidAddress(const u32 address) { | ||||||
|  | 	if ((address & 0x3E000000) == 0x08000000) { | ||||||
|  | 		return true; | ||||||
|  | 	} else if ((address & 0x3F800000) == 0x04000000) { | ||||||
|  | 		return true; | ||||||
|  | 	} else if ((address & 0xBFFF0000) == 0x00010000) { | ||||||
|  | 		return true; | ||||||
|  | 	} else if ((address & 0x3F000000) >= 0x08000000 && (address & 0x3F000000) < 0x08000000 + MEM_FCRAM_MASK) { | ||||||
|  | 		return true; | ||||||
|  | 	} else { | ||||||
|  | 		return false; | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | u8 Read_U8(const u32 _Address) { | ||||||
|  | 	u8 _var = 0; | ||||||
|  | 	ReadFromHardware<u8>(_var, _Address); | ||||||
|  | 	return (u8)_var; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | u16 Read_U16(const u32 _Address) { | ||||||
|  | 	u16_le _var = 0; | ||||||
|  | 	ReadFromHardware<u16_le>(_var, _Address); | ||||||
|  | 	return (u16)_var; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | u32 Read_U32(const u32 _Address) { | ||||||
|  | 	u32_le _var = 0; | ||||||
|  | 	ReadFromHardware<u32_le>(_var, _Address); | ||||||
|  | 	return _var; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | u64 Read_U64(const u32 _Address) { | ||||||
|  | 	u64_le _var = 0; | ||||||
|  | 	ReadFromHardware<u64_le>(_var, _Address); | ||||||
|  | 	return _var; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | u32 Read_U8_ZX(const u32 _Address) { | ||||||
|  | 	return (u32)Read_U8(_Address); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | u32 Read_U16_ZX(const u32 _Address) { | ||||||
|  | 	return (u32)Read_U16(_Address); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void Write_U8(const u8 _Data, const u32 _Address) { | ||||||
|  | 	WriteToHardware<u8>(_Address, _Data); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void Write_U16(const u16 _Data, const u32 _Address) { | ||||||
|  | 	WriteToHardware<u16_le>(_Address, _Data); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void Write_U32(const u32 _Data, const u32 _Address) { | ||||||
|  | 	WriteToHardware<u32_le>(_Address, _Data); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void Write_U64(const u64 _Data, const u32 _Address) { | ||||||
|  | 	WriteToHardware<u64_le>(_Address, _Data); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | } // namespace
 | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue