forked from eden-emu/eden
		
	kernel: update KProcess
This commit is contained in:
		
							parent
							
								
									db37e583ff
								
							
						
					
					
						commit
						8c59543ee3
					
				
					 39 changed files with 2004 additions and 1209 deletions
				
			
		|  | @ -86,20 +86,19 @@ Result GetInfo(Core::System& system, u64* result, InfoType info_id_type, Handle | |||
|             R_SUCCEED(); | ||||
| 
 | ||||
|         case InfoType::TotalMemorySize: | ||||
|             *result = process->GetTotalPhysicalMemoryAvailable(); | ||||
|             *result = process->GetTotalUserPhysicalMemorySize(); | ||||
|             R_SUCCEED(); | ||||
| 
 | ||||
|         case InfoType::UsedMemorySize: | ||||
|             *result = process->GetTotalPhysicalMemoryUsed(); | ||||
|             *result = process->GetUsedUserPhysicalMemorySize(); | ||||
|             R_SUCCEED(); | ||||
| 
 | ||||
|         case InfoType::SystemResourceSizeTotal: | ||||
|             *result = process->GetSystemResourceSize(); | ||||
|             *result = process->GetTotalSystemResourceSize(); | ||||
|             R_SUCCEED(); | ||||
| 
 | ||||
|         case InfoType::SystemResourceSizeUsed: | ||||
|             LOG_WARNING(Kernel_SVC, "(STUBBED) Attempted to query system resource usage"); | ||||
|             *result = process->GetSystemResourceUsage(); | ||||
|             *result = process->GetUsedSystemResourceSize(); | ||||
|             R_SUCCEED(); | ||||
| 
 | ||||
|         case InfoType::ProgramId: | ||||
|  | @ -111,20 +110,29 @@ Result GetInfo(Core::System& system, u64* result, InfoType info_id_type, Handle | |||
|             R_SUCCEED(); | ||||
| 
 | ||||
|         case InfoType::TotalNonSystemMemorySize: | ||||
|             *result = process->GetTotalPhysicalMemoryAvailableWithoutSystemResource(); | ||||
|             *result = process->GetTotalNonSystemUserPhysicalMemorySize(); | ||||
|             R_SUCCEED(); | ||||
| 
 | ||||
|         case InfoType::UsedNonSystemMemorySize: | ||||
|             *result = process->GetTotalPhysicalMemoryUsedWithoutSystemResource(); | ||||
|             *result = process->GetUsedNonSystemUserPhysicalMemorySize(); | ||||
|             R_SUCCEED(); | ||||
| 
 | ||||
|         case InfoType::IsApplication: | ||||
|             LOG_WARNING(Kernel_SVC, "(STUBBED) Assuming process is application"); | ||||
|             *result = true; | ||||
|             *result = process->IsApplication(); | ||||
|             R_SUCCEED(); | ||||
| 
 | ||||
|         case InfoType::FreeThreadCount: | ||||
|             *result = process->GetFreeThreadCount(); | ||||
|             if (KResourceLimit* resource_limit = process->GetResourceLimit(); | ||||
|                 resource_limit != nullptr) { | ||||
|                 const auto current_value = | ||||
|                     resource_limit->GetCurrentValue(Svc::LimitableResource::ThreadCountMax); | ||||
|                 const auto limit_value = | ||||
|                     resource_limit->GetLimitValue(Svc::LimitableResource::ThreadCountMax); | ||||
|                 *result = limit_value - current_value; | ||||
|             } else { | ||||
|                 *result = 0; | ||||
|             } | ||||
|             R_SUCCEED(); | ||||
| 
 | ||||
|         default: | ||||
|  | @ -161,7 +169,7 @@ Result GetInfo(Core::System& system, u64* result, InfoType info_id_type, Handle | |||
| 
 | ||||
|     case InfoType::RandomEntropy: | ||||
|         R_UNLESS(handle == 0, ResultInvalidHandle); | ||||
|         R_UNLESS(info_sub_id < KProcess::RANDOM_ENTROPY_SIZE, ResultInvalidCombination); | ||||
|         R_UNLESS(info_sub_id < 4, ResultInvalidCombination); | ||||
| 
 | ||||
|         *result = GetCurrentProcess(system.Kernel()).GetRandomEntropy(info_sub_id); | ||||
|         R_SUCCEED(); | ||||
|  |  | |||
|  | @ -17,7 +17,7 @@ Result ArbitrateLock(Core::System& system, Handle thread_handle, u64 address, u3 | |||
|     R_UNLESS(!IsKernelAddress(address), ResultInvalidCurrentMemory); | ||||
|     R_UNLESS(Common::IsAligned(address, sizeof(u32)), ResultInvalidAddress); | ||||
| 
 | ||||
|     R_RETURN(GetCurrentProcess(system.Kernel()).WaitForAddress(thread_handle, address, tag)); | ||||
|     R_RETURN(KConditionVariable::WaitForAddress(system.Kernel(), thread_handle, address, tag)); | ||||
| } | ||||
| 
 | ||||
| /// Unlock a mutex
 | ||||
|  | @ -28,7 +28,7 @@ Result ArbitrateUnlock(Core::System& system, u64 address) { | |||
|     R_UNLESS(!IsKernelAddress(address), ResultInvalidCurrentMemory); | ||||
|     R_UNLESS(Common::IsAligned(address, sizeof(u32)), ResultInvalidAddress); | ||||
| 
 | ||||
|     R_RETURN(GetCurrentProcess(system.Kernel()).SignalToAddress(address)); | ||||
|     R_RETURN(KConditionVariable::SignalToAddress(system.Kernel(), address)); | ||||
| } | ||||
| 
 | ||||
| Result ArbitrateLock64(Core::System& system, Handle thread_handle, uint64_t address, uint32_t tag) { | ||||
|  |  | |||
|  | @ -46,7 +46,7 @@ Result MapPhysicalMemory(Core::System& system, u64 addr, u64 size) { | |||
|     KProcess* const current_process{GetCurrentProcessPointer(system.Kernel())}; | ||||
|     auto& page_table{current_process->GetPageTable()}; | ||||
| 
 | ||||
|     if (current_process->GetSystemResourceSize() == 0) { | ||||
|     if (current_process->GetTotalSystemResourceSize() == 0) { | ||||
|         LOG_ERROR(Kernel_SVC, "System Resource Size is zero"); | ||||
|         R_THROW(ResultInvalidState); | ||||
|     } | ||||
|  | @ -95,7 +95,7 @@ Result UnmapPhysicalMemory(Core::System& system, u64 addr, u64 size) { | |||
|     KProcess* const current_process{GetCurrentProcessPointer(system.Kernel())}; | ||||
|     auto& page_table{current_process->GetPageTable()}; | ||||
| 
 | ||||
|     if (current_process->GetSystemResourceSize() == 0) { | ||||
|     if (current_process->GetTotalSystemResourceSize() == 0) { | ||||
|         LOG_ERROR(Kernel_SVC, "System Resource Size is zero"); | ||||
|         R_THROW(ResultInvalidState); | ||||
|     } | ||||
|  |  | |||
|  | @ -132,7 +132,7 @@ void SynchronizePreemptionState(Core::System& system) { | |||
|         GetCurrentThread(kernel).ClearInterruptFlag(); | ||||
| 
 | ||||
|         // Unpin the current thread.
 | ||||
|         cur_process->UnpinCurrentThread(core_id); | ||||
|         cur_process->UnpinCurrentThread(); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -85,10 +85,6 @@ Result StartThread(Core::System& system, Handle thread_handle) { | |||
|     // Try to start the thread.
 | ||||
|     R_TRY(thread->Run()); | ||||
| 
 | ||||
|     // If we succeeded, persist a reference to the thread.
 | ||||
|     thread->Open(); | ||||
|     system.Kernel().RegisterInUseObject(thread.GetPointerUnsafe()); | ||||
| 
 | ||||
|     R_SUCCEED(); | ||||
| } | ||||
| 
 | ||||
|  | @ -99,7 +95,6 @@ void ExitThread(Core::System& system) { | |||
|     auto* const current_thread = GetCurrentThreadPointer(system.Kernel()); | ||||
|     system.GlobalSchedulerContext().RemoveThread(current_thread); | ||||
|     current_thread->Exit(); | ||||
|     system.Kernel().UnregisterInUseObject(current_thread); | ||||
| } | ||||
| 
 | ||||
| /// Sleep the current thread
 | ||||
|  | @ -260,7 +255,7 @@ Result GetThreadList(Core::System& system, s32* out_num_threads, u64 out_thread_ | |||
| 
 | ||||
|     auto list_iter = thread_list.cbegin(); | ||||
|     for (std::size_t i = 0; i < copy_amount; ++i, ++list_iter) { | ||||
|         memory.Write64(out_thread_ids, (*list_iter)->GetThreadId()); | ||||
|         memory.Write64(out_thread_ids, list_iter->GetThreadId()); | ||||
|         out_thread_ids += sizeof(u64); | ||||
|     } | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Liam
						Liam