forked from eden-emu/eden
		
	Core/Common: Address Feedback.
This commit is contained in:
		
							parent
							
								
									e486c66850
								
							
						
					
					
						commit
						2f8947583f
					
				
					 21 changed files with 58 additions and 58 deletions
				
			
		|  | @ -54,9 +54,7 @@ Fiber::Fiber(std::function<void(void*)>&& entry_point_func, void* start_paramete | |||
|     impl->handle = CreateFiber(default_stack_size, &FiberStartFunc, this); | ||||
| } | ||||
| 
 | ||||
| Fiber::Fiber() { | ||||
|     impl = std::make_unique<FiberImpl>(); | ||||
| } | ||||
| Fiber::Fiber() : impl{std::make_unique<FiberImpl>()} {} | ||||
| 
 | ||||
| Fiber::~Fiber() { | ||||
|     if (released) { | ||||
|  | @ -116,8 +114,8 @@ std::shared_ptr<Fiber> Fiber::ThreadToFiber() { | |||
| 
 | ||||
| struct Fiber::FiberImpl { | ||||
|     alignas(64) std::array<u8, default_stack_size> stack; | ||||
|     u8* stack_limit; | ||||
|     alignas(64) std::array<u8, default_stack_size> rewind_stack; | ||||
|     u8* stack_limit; | ||||
|     u8* rewind_stack_limit; | ||||
|     boost::context::detail::fcontext_t context; | ||||
|     boost::context::detail::fcontext_t rewind_context; | ||||
|  | @ -168,9 +166,7 @@ void Fiber::SetRewindPoint(std::function<void(void*)>&& rewind_func, void* start | |||
|     rewind_parameter = start_parameter; | ||||
| } | ||||
| 
 | ||||
| Fiber::Fiber() { | ||||
|     impl = std::make_unique<FiberImpl>(); | ||||
| } | ||||
| Fiber::Fiber() : impl{std::make_unique<FiberImpl>()} {} | ||||
| 
 | ||||
| Fiber::~Fiber() { | ||||
|     if (released) { | ||||
|  |  | |||
|  | @ -20,7 +20,7 @@ | |||
| 
 | ||||
| namespace { | ||||
| 
 | ||||
| void thread_pause() { | ||||
| void ThreadPause() { | ||||
| #if __x86_64__ | ||||
|     _mm_pause(); | ||||
| #elif __aarch64__ && _MSC_VER | ||||
|  | @ -30,13 +30,13 @@ void thread_pause() { | |||
| #endif | ||||
| } | ||||
| 
 | ||||
| } // namespace
 | ||||
| } // Anonymous namespace
 | ||||
| 
 | ||||
| namespace Common { | ||||
| 
 | ||||
| void SpinLock::lock() { | ||||
|     while (lck.test_and_set(std::memory_order_acquire)) { | ||||
|         thread_pause(); | ||||
|         ThreadPause(); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -8,6 +8,11 @@ | |||
| 
 | ||||
| namespace Common { | ||||
| 
 | ||||
| /**
 | ||||
|  * SpinLock class | ||||
|  * a lock similar to mutex that forces a thread to spin wait instead calling the | ||||
|  * supervisor. Should be used on short sequences of code. | ||||
|  */ | ||||
| class SpinLock { | ||||
| public: | ||||
|     void lock(); | ||||
|  |  | |||
|  | @ -3,6 +3,7 @@ | |||
| // Refer to the license.txt file included.
 | ||||
| 
 | ||||
| #include <chrono> | ||||
| #include <mutex> | ||||
| #include <thread> | ||||
| 
 | ||||
| #ifdef _MSC_VER | ||||
|  | @ -52,7 +53,7 @@ NativeClock::NativeClock(u64 emulated_cpu_frequency, u64 emulated_clock_frequenc | |||
| } | ||||
| 
 | ||||
| u64 NativeClock::GetRTSC() { | ||||
|     rtsc_serialize.lock(); | ||||
|     std::scoped_lock scope{rtsc_serialize}; | ||||
|     _mm_mfence(); | ||||
|     const u64 current_measure = __rdtsc(); | ||||
|     u64 diff = current_measure - last_measure; | ||||
|  | @ -61,7 +62,6 @@ u64 NativeClock::GetRTSC() { | |||
|         last_measure = current_measure; | ||||
|     } | ||||
|     accumulated_ticks += diff; | ||||
|     rtsc_serialize.unlock(); | ||||
|     /// The clock cannot be more precise than the guest timer, remove the lower bits
 | ||||
|     return accumulated_ticks & inaccuracy_mask; | ||||
| } | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Fernando Sahmkow
						Fernando Sahmkow