mirror of
				https://git.suyu.dev/suyu/suyu.git
				synced 2025-10-25 03:46:43 +08:00 
			
		
		
		
	Merge pull request #7616 from bunnei/fix-get-idle-ticks
hle: kernel: svc: GetInfo: Fix error checking with IdleTickCount.
This commit is contained in:
		
						commit
						b85f5b1332
					
				| @ -880,22 +880,17 @@ static ResultCode GetInfo(Core::System& system, u64* result, u64 info_id, Handle | ||||
|         return ResultSuccess; | ||||
|     } | ||||
|     case GetInfoType::IdleTickCount: { | ||||
|         if (handle == 0) { | ||||
|             LOG_ERROR(Kernel_SVC, "Thread handle does not exist, handle=0x{:08X}", | ||||
|                       static_cast<Handle>(handle)); | ||||
|             return ResultInvalidHandle; | ||||
|         } | ||||
|         // Verify the input handle is invalid.
 | ||||
|         R_UNLESS(handle == InvalidHandle, ResultInvalidHandle); | ||||
| 
 | ||||
|         if (info_sub_id != 0xFFFFFFFFFFFFFFFF && | ||||
|             info_sub_id != system.Kernel().CurrentPhysicalCoreIndex()) { | ||||
|             LOG_ERROR(Kernel_SVC, "Core is not the current core, got {}", info_sub_id); | ||||
|             return ResultInvalidCombination; | ||||
|         } | ||||
|         // Verify the requested core is valid.
 | ||||
|         const bool core_valid = | ||||
|             (info_sub_id == static_cast<u64>(-1ULL)) || | ||||
|             (info_sub_id == static_cast<u64>(system.Kernel().CurrentPhysicalCoreIndex())); | ||||
|         R_UNLESS(core_valid, ResultInvalidCombination); | ||||
| 
 | ||||
|         const auto& scheduler = *system.Kernel().CurrentScheduler(); | ||||
|         const auto* const idle_thread = scheduler.GetIdleThread(); | ||||
| 
 | ||||
|         *result = idle_thread->GetCpuTime(); | ||||
|         // Get the idle tick count.
 | ||||
|         *result = system.Kernel().CurrentScheduler()->GetIdleThread()->GetCpuTime(); | ||||
|         return ResultSuccess; | ||||
|     } | ||||
|     default: | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user