Merge pull request #1714 from lioncash/kern-err
kernel/errors: Clean up error codes
This commit is contained in:
commit
224fcabe46
|
@ -8,58 +8,28 @@
|
||||||
|
|
||||||
namespace Kernel {
|
namespace Kernel {
|
||||||
|
|
||||||
namespace ErrCodes {
|
// Confirmed Switch kernel error codes
|
||||||
enum {
|
|
||||||
// Confirmed Switch OS error codes
|
|
||||||
MaxConnectionsReached = 7,
|
|
||||||
InvalidSize = 101,
|
|
||||||
InvalidAddress = 102,
|
|
||||||
HandleTableFull = 105,
|
|
||||||
InvalidMemoryState = 106,
|
|
||||||
InvalidMemoryPermissions = 108,
|
|
||||||
InvalidMemoryRange = 110,
|
|
||||||
InvalidThreadPriority = 112,
|
|
||||||
InvalidProcessorId = 113,
|
|
||||||
InvalidHandle = 114,
|
|
||||||
InvalidPointer = 115,
|
|
||||||
InvalidCombination = 116,
|
|
||||||
Timeout = 117,
|
|
||||||
SynchronizationCanceled = 118,
|
|
||||||
TooLarge = 119,
|
|
||||||
InvalidEnumValue = 120,
|
|
||||||
NoSuchEntry = 121,
|
|
||||||
AlreadyRegistered = 122,
|
|
||||||
SessionClosed = 123,
|
|
||||||
InvalidState = 125,
|
|
||||||
ResourceLimitExceeded = 132,
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
// WARNING: The kernel is quite inconsistent in it's usage of errors code. Make sure to always
|
constexpr ResultCode ERR_MAX_CONNECTIONS_REACHED{ErrorModule::Kernel, 7};
|
||||||
// double check that the code matches before re-using the constant.
|
constexpr ResultCode ERR_INVALID_SIZE{ErrorModule::Kernel, 101};
|
||||||
|
constexpr ResultCode ERR_INVALID_ADDRESS{ErrorModule::Kernel, 102};
|
||||||
constexpr ResultCode ERR_HANDLE_TABLE_FULL(ErrorModule::Kernel, ErrCodes::HandleTableFull);
|
constexpr ResultCode ERR_HANDLE_TABLE_FULL{ErrorModule::Kernel, 105};
|
||||||
constexpr ResultCode ERR_SESSION_CLOSED_BY_REMOTE(ErrorModule::Kernel, ErrCodes::SessionClosed);
|
constexpr ResultCode ERR_INVALID_ADDRESS_STATE{ErrorModule::Kernel, 106};
|
||||||
constexpr ResultCode ERR_PORT_NAME_TOO_LONG(ErrorModule::Kernel, ErrCodes::TooLarge);
|
constexpr ResultCode ERR_INVALID_MEMORY_PERMISSIONS{ErrorModule::Kernel, 108};
|
||||||
constexpr ResultCode ERR_MAX_CONNECTIONS_REACHED(ErrorModule::Kernel,
|
constexpr ResultCode ERR_INVALID_MEMORY_RANGE{ErrorModule::Kernel, 110};
|
||||||
ErrCodes::MaxConnectionsReached);
|
constexpr ResultCode ERR_INVALID_PROCESSOR_ID{ErrorModule::Kernel, 113};
|
||||||
constexpr ResultCode ERR_INVALID_ENUM_VALUE(ErrorModule::Kernel, ErrCodes::InvalidEnumValue);
|
constexpr ResultCode ERR_INVALID_THREAD_PRIORITY{ErrorModule::Kernel, 112};
|
||||||
constexpr ResultCode ERR_INVALID_COMBINATION_KERNEL(ErrorModule::Kernel,
|
constexpr ResultCode ERR_INVALID_HANDLE{ErrorModule::Kernel, 114};
|
||||||
ErrCodes::InvalidCombination);
|
constexpr ResultCode ERR_INVALID_POINTER{ErrorModule::Kernel, 115};
|
||||||
constexpr ResultCode ERR_INVALID_ADDRESS(ErrorModule::Kernel, ErrCodes::InvalidAddress);
|
constexpr ResultCode ERR_INVALID_COMBINATION{ErrorModule::Kernel, 116};
|
||||||
constexpr ResultCode ERR_INVALID_ADDRESS_STATE(ErrorModule::Kernel, ErrCodes::InvalidMemoryState);
|
constexpr ResultCode RESULT_TIMEOUT{ErrorModule::Kernel, 117};
|
||||||
constexpr ResultCode ERR_INVALID_MEMORY_PERMISSIONS(ErrorModule::Kernel,
|
constexpr ResultCode ERR_SYNCHRONIZATION_CANCELED{ErrorModule::Kernel, 118};
|
||||||
ErrCodes::InvalidMemoryPermissions);
|
constexpr ResultCode ERR_OUT_OF_RANGE{ErrorModule::Kernel, 119};
|
||||||
constexpr ResultCode ERR_INVALID_MEMORY_RANGE(ErrorModule::Kernel, ErrCodes::InvalidMemoryRange);
|
constexpr ResultCode ERR_INVALID_ENUM_VALUE{ErrorModule::Kernel, 120};
|
||||||
constexpr ResultCode ERR_INVALID_HANDLE(ErrorModule::Kernel, ErrCodes::InvalidHandle);
|
constexpr ResultCode ERR_NOT_FOUND{ErrorModule::Kernel, 121};
|
||||||
constexpr ResultCode ERR_INVALID_PROCESSOR_ID(ErrorModule::Kernel, ErrCodes::InvalidProcessorId);
|
constexpr ResultCode ERR_ALREADY_REGISTERED{ErrorModule::Kernel, 122};
|
||||||
constexpr ResultCode ERR_INVALID_SIZE(ErrorModule::Kernel, ErrCodes::InvalidSize);
|
constexpr ResultCode ERR_SESSION_CLOSED_BY_REMOTE{ErrorModule::Kernel, 123};
|
||||||
constexpr ResultCode ERR_ALREADY_REGISTERED(ErrorModule::Kernel, ErrCodes::AlreadyRegistered);
|
constexpr ResultCode ERR_INVALID_STATE{ErrorModule::Kernel, 125};
|
||||||
constexpr ResultCode ERR_INVALID_STATE(ErrorModule::Kernel, ErrCodes::InvalidState);
|
constexpr ResultCode ERR_RESOURCE_LIMIT_EXCEEDED{ErrorModule::Kernel, 132};
|
||||||
constexpr ResultCode ERR_INVALID_THREAD_PRIORITY(ErrorModule::Kernel,
|
|
||||||
ErrCodes::InvalidThreadPriority);
|
|
||||||
constexpr ResultCode ERR_INVALID_POINTER(ErrorModule::Kernel, ErrCodes::InvalidPointer);
|
|
||||||
constexpr ResultCode ERR_NOT_FOUND(ErrorModule::Kernel, ErrCodes::NoSuchEntry);
|
|
||||||
constexpr ResultCode RESULT_TIMEOUT(ErrorModule::Kernel, ErrCodes::Timeout);
|
|
||||||
|
|
||||||
} // namespace Kernel
|
} // namespace Kernel
|
||||||
|
|
|
@ -214,7 +214,7 @@ static ResultCode ConnectToNamedPort(Handle* out_handle, VAddr port_name_address
|
||||||
// Read 1 char beyond the max allowed port name to detect names that are too long.
|
// Read 1 char beyond the max allowed port name to detect names that are too long.
|
||||||
std::string port_name = Memory::ReadCString(port_name_address, PortNameMaxLength + 1);
|
std::string port_name = Memory::ReadCString(port_name_address, PortNameMaxLength + 1);
|
||||||
if (port_name.size() > PortNameMaxLength) {
|
if (port_name.size() > PortNameMaxLength) {
|
||||||
return ERR_PORT_NAME_TOO_LONG;
|
return ERR_OUT_OF_RANGE;
|
||||||
}
|
}
|
||||||
|
|
||||||
LOG_TRACE(Kernel_SVC, "called port_name={}", port_name);
|
LOG_TRACE(Kernel_SVC, "called port_name={}", port_name);
|
||||||
|
@ -310,8 +310,9 @@ static ResultCode WaitSynchronization(Handle* index, VAddr handles_address, u64
|
||||||
|
|
||||||
static constexpr u64 MaxHandles = 0x40;
|
static constexpr u64 MaxHandles = 0x40;
|
||||||
|
|
||||||
if (handle_count > MaxHandles)
|
if (handle_count > MaxHandles) {
|
||||||
return ResultCode(ErrorModule::Kernel, ErrCodes::TooLarge);
|
return ERR_OUT_OF_RANGE;
|
||||||
|
}
|
||||||
|
|
||||||
auto* const thread = GetCurrentThread();
|
auto* const thread = GetCurrentThread();
|
||||||
|
|
||||||
|
@ -376,8 +377,7 @@ static ResultCode CancelSynchronization(Handle thread_handle) {
|
||||||
}
|
}
|
||||||
|
|
||||||
ASSERT(thread->GetStatus() == ThreadStatus::WaitSynchAny);
|
ASSERT(thread->GetStatus() == ThreadStatus::WaitSynchAny);
|
||||||
thread->SetWaitSynchronizationResult(
|
thread->SetWaitSynchronizationResult(ERR_SYNCHRONIZATION_CANCELED);
|
||||||
ResultCode(ErrorModule::Kernel, ErrCodes::SynchronizationCanceled));
|
|
||||||
thread->ResumeFromWait();
|
thread->ResumeFromWait();
|
||||||
return RESULT_SUCCESS;
|
return RESULT_SUCCESS;
|
||||||
}
|
}
|
||||||
|
@ -606,7 +606,7 @@ static ResultCode GetInfo(u64* result, u64 info_id, u64 handle, u64 info_sub_id)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (info_sub_id >= Process::RANDOM_ENTROPY_SIZE) {
|
if (info_sub_id >= Process::RANDOM_ENTROPY_SIZE) {
|
||||||
return ERR_INVALID_COMBINATION_KERNEL;
|
return ERR_INVALID_COMBINATION;
|
||||||
}
|
}
|
||||||
|
|
||||||
*result = current_process->GetRandomEntropy(info_sub_id);
|
*result = current_process->GetRandomEntropy(info_sub_id);
|
||||||
|
@ -643,7 +643,7 @@ static ResultCode GetInfo(u64* result, u64 info_id, u64 handle, u64 info_sub_id)
|
||||||
case GetInfoType::ThreadTickCount: {
|
case GetInfoType::ThreadTickCount: {
|
||||||
constexpr u64 num_cpus = 4;
|
constexpr u64 num_cpus = 4;
|
||||||
if (info_sub_id != 0xFFFFFFFFFFFFFFFF && info_sub_id >= num_cpus) {
|
if (info_sub_id != 0xFFFFFFFFFFFFFFFF && info_sub_id >= num_cpus) {
|
||||||
return ERR_INVALID_COMBINATION_KERNEL;
|
return ERR_INVALID_COMBINATION;
|
||||||
}
|
}
|
||||||
|
|
||||||
const auto thread =
|
const auto thread =
|
||||||
|
@ -1236,7 +1236,7 @@ static ResultCode SetThreadCoreMask(Handle thread_handle, u32 core, u64 mask) {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (mask == 0) {
|
if (mask == 0) {
|
||||||
return ResultCode(ErrorModule::Kernel, ErrCodes::InvalidCombination);
|
return ERR_INVALID_COMBINATION;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// This value is used to only change the affinity mask without changing the current ideal core.
|
/// This value is used to only change the affinity mask without changing the current ideal core.
|
||||||
|
@ -1245,12 +1245,12 @@ static ResultCode SetThreadCoreMask(Handle thread_handle, u32 core, u64 mask) {
|
||||||
if (core == OnlyChangeMask) {
|
if (core == OnlyChangeMask) {
|
||||||
core = thread->GetIdealCore();
|
core = thread->GetIdealCore();
|
||||||
} else if (core >= Core::NUM_CPU_CORES && core != static_cast<u32>(-1)) {
|
} else if (core >= Core::NUM_CPU_CORES && core != static_cast<u32>(-1)) {
|
||||||
return ResultCode(ErrorModule::Kernel, ErrCodes::InvalidProcessorId);
|
return ERR_INVALID_PROCESSOR_ID;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Error out if the input core isn't enabled in the input mask.
|
// Error out if the input core isn't enabled in the input mask.
|
||||||
if (core < Core::NUM_CPU_CORES && (mask & (1ull << core)) == 0) {
|
if (core < Core::NUM_CPU_CORES && (mask & (1ull << core)) == 0) {
|
||||||
return ResultCode(ErrorModule::Kernel, ErrCodes::InvalidCombination);
|
return ERR_INVALID_COMBINATION;
|
||||||
}
|
}
|
||||||
|
|
||||||
thread->ChangeCore(core, mask);
|
thread->ChangeCore(core, mask);
|
||||||
|
|
Reference in New Issue