forked from eden-emu/eden
		
	common/bit_util: Replace CLZ/CTZ operations with standardized ones
Makes for less code that we need to maintain.
This commit is contained in:
		
							parent
							
								
									6c998e7370
								
							
						
					
					
						commit
						d5bff783bd
					
				
					 10 changed files with 17 additions and 113 deletions
				
			
		|  | @ -8,11 +8,11 @@ | |||
| #pragma once | ||||
| 
 | ||||
| #include <array> | ||||
| #include <bit> | ||||
| #include <concepts> | ||||
| 
 | ||||
| #include "common/assert.h" | ||||
| #include "common/bit_set.h" | ||||
| #include "common/bit_util.h" | ||||
| #include "common/common_types.h" | ||||
| #include "common/concepts.h" | ||||
| 
 | ||||
|  | @ -268,7 +268,7 @@ private: | |||
|     } | ||||
| 
 | ||||
|     constexpr s32 GetNextCore(u64& affinity) { | ||||
|         const s32 core = Common::CountTrailingZeroes64(affinity); | ||||
|         const s32 core = std::countr_zero(affinity); | ||||
|         ClearAffinityBit(affinity, core); | ||||
|         return core; | ||||
|     } | ||||
|  |  | |||
|  | @ -5,6 +5,8 @@ | |||
| // This file references various implementation details from Atmosphere, an open-source firmware for
 | ||||
| // the Nintendo Switch. Copyright 2018-2020 Atmosphere-NX.
 | ||||
| 
 | ||||
| #include <bit> | ||||
| 
 | ||||
| #include "common/assert.h" | ||||
| #include "common/bit_util.h" | ||||
| #include "common/fiber.h" | ||||
|  | @ -31,12 +33,12 @@ static void IncrementScheduledCount(Kernel::Thread* thread) { | |||
| 
 | ||||
| void KScheduler::RescheduleCores(KernelCore& kernel, u64 cores_pending_reschedule, | ||||
|                                  Core::EmuThreadHandle global_thread) { | ||||
|     u32 current_core = global_thread.host_handle; | ||||
|     const u32 current_core = global_thread.host_handle; | ||||
|     bool must_context_switch = global_thread.guest_handle != InvalidHandle && | ||||
|                                (current_core < Core::Hardware::NUM_CPU_CORES); | ||||
| 
 | ||||
|     while (cores_pending_reschedule != 0) { | ||||
|         u32 core = Common::CountTrailingZeroes64(cores_pending_reschedule); | ||||
|         const auto core = static_cast<u32>(std::countr_zero(cores_pending_reschedule)); | ||||
|         ASSERT(core < Core::Hardware::NUM_CPU_CORES); | ||||
|         if (!must_context_switch || core != current_core) { | ||||
|             auto& phys_core = kernel.PhysicalCore(core); | ||||
|  | @ -109,7 +111,7 @@ u64 KScheduler::UpdateHighestPriorityThreadsImpl(KernelCore& kernel) { | |||
| 
 | ||||
|     // Idle cores are bad. We're going to try to migrate threads to each idle core in turn.
 | ||||
|     while (idle_cores != 0) { | ||||
|         u32 core_id = Common::CountTrailingZeroes64(idle_cores); | ||||
|         const auto core_id = static_cast<u32>(std::countr_zero(idle_cores)); | ||||
|         if (Thread* suggested = priority_queue.GetSuggestedFront(core_id); suggested != nullptr) { | ||||
|             s32 migration_candidates[Core::Hardware::NUM_CPU_CORES]; | ||||
|             size_t num_candidates = 0; | ||||
|  |  | |||
|  | @ -8,11 +8,11 @@ | |||
| #pragma once | ||||
| 
 | ||||
| #include <array> | ||||
| #include <bit> | ||||
| #include <vector> | ||||
| 
 | ||||
| #include "common/alignment.h" | ||||
| #include "common/assert.h" | ||||
| #include "common/bit_util.h" | ||||
| #include "common/common_funcs.h" | ||||
| #include "common/common_types.h" | ||||
| #include "core/hle/kernel/memory/memory_types.h" | ||||
|  | @ -105,7 +105,7 @@ private: | |||
|                         ASSERT(depth == 0); | ||||
|                         return -1; | ||||
|                     } | ||||
|                     offset = offset * 64 + Common::CountTrailingZeroes64(v); | ||||
|                     offset = offset * 64 + static_cast<u32>(std::countr_zero(v)); | ||||
|                     ++depth; | ||||
|                 } while (depth < static_cast<s32>(used_depths)); | ||||
| 
 | ||||
|  |  | |||
|  | @ -2,6 +2,8 @@ | |||
| // Licensed under GPLv2 or any later version
 | ||||
| // Refer to the license.txt file included.
 | ||||
| 
 | ||||
| #include <bit> | ||||
| 
 | ||||
| #include "common/bit_util.h" | ||||
| #include "common/logging/log.h" | ||||
| #include "core/hle/kernel/errors.h" | ||||
|  | @ -60,7 +62,7 @@ constexpr CapabilityType GetCapabilityType(u32 value) { | |||
| 
 | ||||
| u32 GetFlagBitOffset(CapabilityType type) { | ||||
|     const auto value = static_cast<u32>(type); | ||||
|     return static_cast<u32>(Common::BitSize<u32>() - Common::CountLeadingZeroes32(value)); | ||||
|     return static_cast<u32>(Common::BitSize<u32>() - static_cast<u32>(std::countl_zero(value))); | ||||
| } | ||||
| 
 | ||||
| } // Anonymous namespace
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Lioncash
						Lioncash