forked from eden-emu/eden
		
	Added more svcGetInfo pairs
This commit is contained in:
		
							parent
							
								
									c903372111
								
							
						
					
					
						commit
						68143af636
					
				
					 4 changed files with 29 additions and 2 deletions
				
			
		|  | @ -131,6 +131,8 @@ public: | ||||||
|     /// Bitmask of allowed CPUs that this process' threads can run on. TODO(Subv): Actually parse
 |     /// Bitmask of allowed CPUs that this process' threads can run on. TODO(Subv): Actually parse
 | ||||||
|     /// this value from the process header.
 |     /// this value from the process header.
 | ||||||
|     u32 allowed_processor_mask = THREADPROCESSORID_DEFAULT_MASK; |     u32 allowed_processor_mask = THREADPROCESSORID_DEFAULT_MASK; | ||||||
|  |     u32 allowed_thread_priority_mask = 0xFFFFFFFF; | ||||||
|  |     u32 is_virtual_address_memory_enabled = 0; | ||||||
|     /// Current status of the process
 |     /// Current status of the process
 | ||||||
|     ProcessStatus status; |     ProcessStatus status; | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -313,6 +313,15 @@ static ResultCode GetInfo(u64* result, u64 info_id, u64 handle, u64 info_sub_id) | ||||||
|     case GetInfoType::AllowedCpuIdBitmask: |     case GetInfoType::AllowedCpuIdBitmask: | ||||||
|         *result = g_current_process->allowed_processor_mask; |         *result = g_current_process->allowed_processor_mask; | ||||||
|         break; |         break; | ||||||
|  |     case GetInfoType::AllowedThreadPrioBitmask: | ||||||
|  |         *result = g_current_process->allowed_thread_priority_mask; | ||||||
|  |         break; | ||||||
|  |     case GetInfoType::MapRegionBaseAddr: | ||||||
|  |         *result = vm_manager.GetAddressSpaceBaseAddr(); | ||||||
|  |         break; | ||||||
|  |     case GetInfoType::MapRegionSize: | ||||||
|  |         *result = vm_manager.GetAddressSpaceSize(); | ||||||
|  |         break; | ||||||
|     case GetInfoType::TotalMemoryUsage: |     case GetInfoType::TotalMemoryUsage: | ||||||
|         *result = vm_manager.GetTotalMemoryUsage(); |         *result = vm_manager.GetTotalMemoryUsage(); | ||||||
|         break; |         break; | ||||||
|  | @ -334,6 +343,9 @@ static ResultCode GetInfo(u64* result, u64 info_id, u64 handle, u64 info_sub_id) | ||||||
|     case GetInfoType::NewMapRegionSize: |     case GetInfoType::NewMapRegionSize: | ||||||
|         *result = vm_manager.GetNewMapRegionSize(); |         *result = vm_manager.GetNewMapRegionSize(); | ||||||
|         break; |         break; | ||||||
|  |     case GetInfoType::IsVirtualAddressMemoryEnabled: | ||||||
|  |         *result = g_current_process->is_virtual_address_memory_enabled; | ||||||
|  |         break; | ||||||
|     default: |     default: | ||||||
|         UNIMPLEMENTED(); |         UNIMPLEMENTED(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  | @ -24,14 +24,27 @@ struct PageInfo { | ||||||
| enum class GetInfoType : u64 { | enum class GetInfoType : u64 { | ||||||
|     // 1.0.0+
 |     // 1.0.0+
 | ||||||
|     AllowedCpuIdBitmask = 0, |     AllowedCpuIdBitmask = 0, | ||||||
|  |     AllowedThreadPrioBitmask = 1, | ||||||
|  |     MapRegionBaseAddr = 2, | ||||||
|  |     MapRegionSize = 3, | ||||||
|  |     HeapRegionBaseAddr = 4, | ||||||
|  |     HeapRegionSize = 5, | ||||||
|     TotalMemoryUsage = 6, |     TotalMemoryUsage = 6, | ||||||
|     TotalHeapUsage = 7, |     TotalHeapUsage = 7, | ||||||
|  |     IsCurrentProcessBeingDebugged = 8, | ||||||
|  |     ResourceHandleLimit = 9, | ||||||
|  |     IdleTickCount = 10, | ||||||
|     RandomEntropy = 11, |     RandomEntropy = 11, | ||||||
|  |     PerformanceCounter = 0xF0000002, | ||||||
|     // 2.0.0+
 |     // 2.0.0+
 | ||||||
|     AddressSpaceBaseAddr = 12, |     AddressSpaceBaseAddr = 12, | ||||||
|     AddressSpaceSize = 13, |     AddressSpaceSize = 13, | ||||||
|     NewMapRegionBaseAddr = 14, |     NewMapRegionBaseAddr = 14, | ||||||
|     NewMapRegionSize = 15, |     NewMapRegionSize = 15, | ||||||
|  |     // 3.0.0+
 | ||||||
|  |     IsVirtualAddressMemoryEnabled = 16, | ||||||
|  |     TitleId = 18, | ||||||
|  |     PrivilegedProcessId = 19, | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| void CallSVC(u32 immediate); | void CallSVC(u32 immediate); | ||||||
|  |  | ||||||
|  | @ -356,12 +356,12 @@ void VMManager::UpdatePageTableForVMA(const VirtualMemoryArea& vma) { | ||||||
| 
 | 
 | ||||||
| u64 VMManager::GetTotalMemoryUsage() { | u64 VMManager::GetTotalMemoryUsage() { | ||||||
|     LOG_WARNING(Kernel, "(STUBBED) called"); |     LOG_WARNING(Kernel, "(STUBBED) called"); | ||||||
|     return 0x400000; |     return 0xBE000000; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| u64 VMManager::GetTotalHeapUsage() { | u64 VMManager::GetTotalHeapUsage() { | ||||||
|     LOG_WARNING(Kernel, "(STUBBED) called"); |     LOG_WARNING(Kernel, "(STUBBED) called"); | ||||||
|     return 0x10000; |     return 0x0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| VAddr VMManager::GetAddressSpaceBaseAddr() { | VAddr VMManager::GetAddressSpaceBaseAddr() { | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 David Marcec
						David Marcec