mirror of
https://github.com/yuzu-emu/yuzu-mainline.git
synced 2024-12-27 03:15:34 +00:00
svc: Implement svcGetResourceLimitLimitValue()
This kernel service function retrieves the maximum allowable value for a provided resource category for a given resource limit instance. Given we already have the functionality added to the resource limit instance itself, it's sufficient to just hook it up. The error scenarios for this are: 1. If an invalid resource category type is provided, then ERR_INVALID_ENUM is returned. 2. If an invalid handle is provided, then ERR_INVALID_HANDLE is returned (bad thing goes in, bad thing goes out, as one would expect). If neither of the above error cases occur, then the out parameter is provided with the maximum limit value for the given category and success is returned.
This commit is contained in:
parent
4ef2af8c98
commit
1d6399c222
|
@ -14,7 +14,7 @@ namespace Kernel {
|
||||||
|
|
||||||
class KernelCore;
|
class KernelCore;
|
||||||
|
|
||||||
enum class ResourceType {
|
enum class ResourceType : u32 {
|
||||||
PhysicalMemory,
|
PhysicalMemory,
|
||||||
Threads,
|
Threads,
|
||||||
Events,
|
Events,
|
||||||
|
@ -25,6 +25,10 @@ enum class ResourceType {
|
||||||
ResourceTypeCount
|
ResourceTypeCount
|
||||||
};
|
};
|
||||||
|
|
||||||
|
constexpr bool IsValidResourceType(ResourceType type) {
|
||||||
|
return type < ResourceType::ResourceTypeCount;
|
||||||
|
}
|
||||||
|
|
||||||
class ResourceLimit final : public Object {
|
class ResourceLimit final : public Object {
|
||||||
public:
|
public:
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -1364,6 +1364,33 @@ static ResultCode CreateResourceLimit(Handle* out_handle) {
|
||||||
return RESULT_SUCCESS;
|
return RESULT_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static ResultCode GetResourceLimitLimitValue(u64* out_value, Handle resource_limit,
|
||||||
|
u32 resource_type) {
|
||||||
|
LOG_DEBUG(Kernel_SVC, "called. Handle={:08X}, Resource type={}", resource_limit, resource_type);
|
||||||
|
|
||||||
|
const auto type = static_cast<ResourceType>(resource_type);
|
||||||
|
if (!IsValidResourceType(type)) {
|
||||||
|
LOG_ERROR(Kernel_SVC, "Invalid resource limit type: '{}'.", resource_type);
|
||||||
|
return ERR_INVALID_ENUM_VALUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
const auto& kernel = Core::System::GetInstance().Kernel();
|
||||||
|
const auto* const current_process = kernel.CurrentProcess();
|
||||||
|
ASSERT(current_process != nullptr);
|
||||||
|
|
||||||
|
const auto resource_limit_object =
|
||||||
|
current_process->GetHandleTable().Get<ResourceLimit>(resource_limit);
|
||||||
|
if (!resource_limit_object) {
|
||||||
|
LOG_ERROR(Kernel_SVC, "Handle to non-existent resource limit instance used. Handle={:08X}",
|
||||||
|
resource_limit);
|
||||||
|
return ERR_INVALID_HANDLE;
|
||||||
|
}
|
||||||
|
|
||||||
|
const s64 limit_value = resource_limit_object->GetMaxResourceValue(type);
|
||||||
|
*out_value = static_cast<u64>(limit_value);
|
||||||
|
return RESULT_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
struct FunctionDef {
|
struct FunctionDef {
|
||||||
using Func = void();
|
using Func = void();
|
||||||
|
@ -1423,7 +1450,7 @@ static const FunctionDef SVC_Table[] = {
|
||||||
{0x2D, nullptr, "UnmapPhysicalMemory"},
|
{0x2D, nullptr, "UnmapPhysicalMemory"},
|
||||||
{0x2E, nullptr, "GetFutureThreadInfo"},
|
{0x2E, nullptr, "GetFutureThreadInfo"},
|
||||||
{0x2F, nullptr, "GetLastThreadInfo"},
|
{0x2F, nullptr, "GetLastThreadInfo"},
|
||||||
{0x30, nullptr, "GetResourceLimitLimitValue"},
|
{0x30, SvcWrap<GetResourceLimitLimitValue>, "GetResourceLimitLimitValue"},
|
||||||
{0x31, nullptr, "GetResourceLimitCurrentValue"},
|
{0x31, nullptr, "GetResourceLimitCurrentValue"},
|
||||||
{0x32, SvcWrap<SetThreadActivity>, "SetThreadActivity"},
|
{0x32, SvcWrap<SetThreadActivity>, "SetThreadActivity"},
|
||||||
{0x33, SvcWrap<GetThreadContext>, "GetThreadContext"},
|
{0x33, SvcWrap<GetThreadContext>, "GetThreadContext"},
|
||||||
|
|
Loading…
Reference in a new issue