mirror of
				https://git.zaroz.cloud/nintendo-back-up/yuzu/yuzu.git
				synced 2025-05-12 00:45:25 +00:00 
			
		
		
		
	Threads: Added enum values for the Switch's 4 cpu cores and implemented svcGetInfo(AllowedCpuIdBitmask)
This commit is contained in:
		
							parent
							
								
									188feba457
								
							
						
					
					
						commit
						7ad20154fc
					
				| @ -205,14 +205,11 @@ std::vector<std::unique_ptr<WaitTreeItem>> WaitTreeThread::GetChildren() const { | |||||||
|     case ThreadProcessorId::THREADPROCESSORID_DEFAULT: |     case ThreadProcessorId::THREADPROCESSORID_DEFAULT: | ||||||
|         processor = tr("default"); |         processor = tr("default"); | ||||||
|         break; |         break; | ||||||
|     case ThreadProcessorId::THREADPROCESSORID_ALL: |  | ||||||
|         processor = tr("all"); |  | ||||||
|         break; |  | ||||||
|     case ThreadProcessorId::THREADPROCESSORID_0: |     case ThreadProcessorId::THREADPROCESSORID_0: | ||||||
|         processor = tr("AppCore"); |  | ||||||
|         break; |  | ||||||
|     case ThreadProcessorId::THREADPROCESSORID_1: |     case ThreadProcessorId::THREADPROCESSORID_1: | ||||||
|         processor = tr("SysCore"); |     case ThreadProcessorId::THREADPROCESSORID_2: | ||||||
|  |     case ThreadProcessorId::THREADPROCESSORID_3: | ||||||
|  |         processor = tr("core %1").arg(thread.processor_id); | ||||||
|         break; |         break; | ||||||
|     default: |     default: | ||||||
|         processor = tr("Unknown processor %1").arg(thread.processor_id); |         processor = tr("Unknown processor %1").arg(thread.processor_id); | ||||||
|  | |||||||
| @ -13,6 +13,7 @@ | |||||||
| #include "common/bit_field.h" | #include "common/bit_field.h" | ||||||
| #include "common/common_types.h" | #include "common/common_types.h" | ||||||
| #include "core/hle/kernel/kernel.h" | #include "core/hle/kernel/kernel.h" | ||||||
|  | #include "core/hle/kernel/thread.h" | ||||||
| #include "core/hle/kernel/vm_manager.h" | #include "core/hle/kernel/vm_manager.h" | ||||||
| 
 | 
 | ||||||
| namespace Kernel { | namespace Kernel { | ||||||
| @ -127,6 +128,9 @@ public: | |||||||
|     u16 kernel_version = 0; |     u16 kernel_version = 0; | ||||||
|     /// The default CPU for this process, threads are scheduled on this cpu by default.
 |     /// The default CPU for this process, threads are scheduled on this cpu by default.
 | ||||||
|     u8 ideal_processor = 0; |     u8 ideal_processor = 0; | ||||||
|  |     /// Bitmask of allowed CPUs that this process' threads can run on. TODO(Subv): Actually parse
 | ||||||
|  |     /// this value from the process header.
 | ||||||
|  |     u32 allowed_processor_mask = THREADPROCESSORID_DEFAULT_MASK; | ||||||
|     /// Current status of the process
 |     /// Current status of the process
 | ||||||
|     ProcessStatus status; |     ProcessStatus status; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -296,8 +296,14 @@ static ResultCode GetInfo(u64* result, u64 info_id, u64 handle, u64 info_sub_id) | |||||||
|     LOG_TRACE(Kernel_SVC, "called info_id=0x%X, info_sub_id=0x%X, handle=0x%08X", info_id, |     LOG_TRACE(Kernel_SVC, "called info_id=0x%X, info_sub_id=0x%X, handle=0x%08X", info_id, | ||||||
|               info_sub_id, handle); |               info_sub_id, handle); | ||||||
| 
 | 
 | ||||||
|  |     ASSERT(handle == 0 || handle == CurrentProcess); | ||||||
|  | 
 | ||||||
|     auto& vm_manager = g_current_process->vm_manager; |     auto& vm_manager = g_current_process->vm_manager; | ||||||
|  | 
 | ||||||
|     switch (static_cast<GetInfoType>(info_id)) { |     switch (static_cast<GetInfoType>(info_id)) { | ||||||
|  |     case GetInfoType::AllowedCpuIdBitmask: | ||||||
|  |         *result = g_current_process->allowed_processor_mask; | ||||||
|  |         break; | ||||||
|     case GetInfoType::TotalMemoryUsage: |     case GetInfoType::TotalMemoryUsage: | ||||||
|         *result = vm_manager.GetTotalMemoryUsage(); |         *result = vm_manager.GetTotalMemoryUsage(); | ||||||
|         break; |         break; | ||||||
| @ -455,16 +461,15 @@ static ResultCode CreateThread(Handle* out_handle, VAddr entry_point, u64 arg, V | |||||||
|     switch (processor_id) { |     switch (processor_id) { | ||||||
|     case THREADPROCESSORID_0: |     case THREADPROCESSORID_0: | ||||||
|         break; |         break; | ||||||
|     case THREADPROCESSORID_ALL: |  | ||||||
|         LOG_INFO(Kernel_SVC, |  | ||||||
|                  "Newly created thread is allowed to be run in any Core, unimplemented."); |  | ||||||
|         break; |  | ||||||
|     case THREADPROCESSORID_1: |     case THREADPROCESSORID_1: | ||||||
|  |     case THREADPROCESSORID_2: | ||||||
|  |     case THREADPROCESSORID_3: | ||||||
|  |         // TODO(bunnei): Implement support for other processor IDs
 | ||||||
|         LOG_ERROR(Kernel_SVC, |         LOG_ERROR(Kernel_SVC, | ||||||
|                   "Newly created thread must run in the SysCore (Core1), unimplemented."); |                   "Newly created thread must run in another thread (%u), unimplemented.", | ||||||
|  |                   processor_id); | ||||||
|         break; |         break; | ||||||
|     default: |     default: | ||||||
|         // TODO(bunnei): Implement support for other processor IDs
 |  | ||||||
|         ASSERT_MSG(false, "Unsupported thread processor ID: %d", processor_id); |         ASSERT_MSG(false, "Unsupported thread processor ID: %d", processor_id); | ||||||
|         break; |         break; | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -23,6 +23,7 @@ struct PageInfo { | |||||||
| /// Values accepted by svcGetInfo
 | /// Values accepted by svcGetInfo
 | ||||||
| enum class GetInfoType : u64 { | enum class GetInfoType : u64 { | ||||||
|     // 1.0.0+
 |     // 1.0.0+
 | ||||||
|  |     AllowedCpuIdBitmask = 0, | ||||||
|     TotalMemoryUsage = 6, |     TotalMemoryUsage = 6, | ||||||
|     TotalHeapUsage = 7, |     TotalHeapUsage = 7, | ||||||
|     RandomEntropy = 11, |     RandomEntropy = 11, | ||||||
|  | |||||||
| @ -24,10 +24,15 @@ enum ThreadPriority : u32 { | |||||||
| 
 | 
 | ||||||
| enum ThreadProcessorId : s32 { | enum ThreadProcessorId : s32 { | ||||||
|     THREADPROCESSORID_DEFAULT = -2, ///< Run thread on default core specified by exheader
 |     THREADPROCESSORID_DEFAULT = -2, ///< Run thread on default core specified by exheader
 | ||||||
|     THREADPROCESSORID_ALL = -1,     ///< Run thread on either core
 |     THREADPROCESSORID_0 = 0,        ///< Run thread on core 0
 | ||||||
|     THREADPROCESSORID_0 = 0,        ///< Run thread on core 0 (AppCore)
 |     THREADPROCESSORID_1 = 1,        ///< Run thread on core 1
 | ||||||
|     THREADPROCESSORID_1 = 1,        ///< Run thread on core 1 (SysCore)
 |     THREADPROCESSORID_2 = 2,        ///< Run thread on core 2
 | ||||||
|     THREADPROCESSORID_MAX = 2,      ///< Processor ID must be less than this
 |     THREADPROCESSORID_3 = 3,        ///< Run thread on core 3
 | ||||||
|  |     THREADPROCESSORID_MAX = 4,      ///< Processor ID must be less than this
 | ||||||
|  | 
 | ||||||
|  |     /// Allowed CPU mask
 | ||||||
|  |     THREADPROCESSORID_DEFAULT_MASK = (1 << THREADPROCESSORID_0) | (1 << THREADPROCESSORID_1) | | ||||||
|  |                                      (1 << THREADPROCESSORID_2) | (1 << THREADPROCESSORID_3) | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| enum ThreadStatus { | enum ThreadStatus { | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Subv
						Subv