mirror of
https://git.suyu.dev/suyu/suyu
synced 2025-01-09 16:03:21 +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
5 changed files with 28 additions and 16 deletions
|
@ -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 a new issue