| 
									
										
										
										
											2020-04-02 22:00:41 -04:00
										 |  |  | // Copyright 2020 yuzu Emulator Project
 | 
					
						
							|  |  |  | // Licensed under GPLv2 or any later version
 | 
					
						
							|  |  |  | // Refer to the license.txt file included.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "common/assert.h"
 | 
					
						
							|  |  |  | #include "common/common_funcs.h"
 | 
					
						
							| 
									
										
										
										
											2020-04-08 17:39:58 -04:00
										 |  |  | #include "common/virtual_buffer.h"
 | 
					
						
							| 
									
										
										
										
											2020-04-02 22:00:41 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace Core { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class System; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace DramMemoryMap { | 
					
						
							|  |  |  | constexpr u64 Base = 0x80000000ULL; | 
					
						
							|  |  |  | constexpr u64 Size = 0x100000000ULL; | 
					
						
							|  |  |  | constexpr u64 End = Base + Size; | 
					
						
							|  |  |  | constexpr u64 KernelReserveBase = Base + 0x60000; | 
					
						
							|  |  |  | constexpr u64 SlabHeapBase = KernelReserveBase + 0x85000; | 
					
						
							|  |  |  | constexpr u64 SlapHeapSize = 0xa21000; | 
					
						
							|  |  |  | constexpr u64 SlabHeapEnd = SlabHeapBase + SlapHeapSize; | 
					
						
							|  |  |  | }; // namespace DramMemoryMap
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class DeviceMemory : NonCopyable { | 
					
						
							|  |  |  | public: | 
					
						
							| 
									
										
										
										
											2020-04-08 17:39:58 -04:00
										 |  |  |     explicit DeviceMemory(Core::System& system); | 
					
						
							| 
									
										
										
										
											2020-04-02 22:00:41 -04:00
										 |  |  |     ~DeviceMemory(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     template <typename T> | 
					
						
							| 
									
										
										
										
											2020-04-08 23:37:24 -04:00
										 |  |  |     constexpr PAddr GetPhysicalAddr(T* ptr) { | 
					
						
							|  |  |  |         return (reinterpret_cast<uintptr_t>(ptr) - reinterpret_cast<uintptr_t>(buffer.data())) + | 
					
						
							|  |  |  |                DramMemoryMap::Base; | 
					
						
							| 
									
										
										
										
											2020-04-02 22:00:41 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-08 17:39:58 -04:00
										 |  |  |     constexpr u8* GetPointer(PAddr addr) { | 
					
						
							|  |  |  |         return buffer.data() + (addr - DramMemoryMap::Base); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-04-02 22:00:41 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							| 
									
										
										
										
											2020-04-08 17:39:58 -04:00
										 |  |  |     Common::VirtualBuffer<u8> buffer; | 
					
						
							| 
									
										
										
										
											2020-04-02 22:00:41 -04:00
										 |  |  |     Core::System& system; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } // namespace Core
 |