2015-05-12 20:25:15 +00:00
|
|
|
// Copyright 2015 Citra Emulator Project
|
|
|
|
// Licensed under GPLv2 or any later version
|
|
|
|
// Refer to the license.txt file included.
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
2018-11-19 17:54:06 +00:00
|
|
|
#include <array>
|
2015-05-12 20:25:15 +00:00
|
|
|
#include "common/common_types.h"
|
2018-08-02 02:40:00 +00:00
|
|
|
#include "core/hle/kernel/object.h"
|
2015-05-12 20:25:15 +00:00
|
|
|
|
2018-11-19 17:54:06 +00:00
|
|
|
union ResultCode;
|
|
|
|
|
2015-05-12 20:25:15 +00:00
|
|
|
namespace Kernel {
|
|
|
|
|
2018-08-28 16:30:33 +00:00
|
|
|
class KernelCore;
|
|
|
|
|
2018-11-26 23:48:07 +00:00
|
|
|
enum class ResourceType : u32 {
|
2018-11-19 17:54:06 +00:00
|
|
|
PhysicalMemory,
|
|
|
|
Threads,
|
|
|
|
Events,
|
|
|
|
TransferMemory,
|
|
|
|
Sessions,
|
|
|
|
|
|
|
|
// Used as a count, not an actual type.
|
|
|
|
ResourceTypeCount
|
2015-05-12 20:25:15 +00:00
|
|
|
};
|
|
|
|
|
2018-11-26 23:48:07 +00:00
|
|
|
constexpr bool IsValidResourceType(ResourceType type) {
|
|
|
|
return type < ResourceType::ResourceTypeCount;
|
|
|
|
}
|
|
|
|
|
2015-05-12 20:25:15 +00:00
|
|
|
class ResourceLimit final : public Object {
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* Creates a resource limit object.
|
|
|
|
*/
|
2018-08-28 16:30:33 +00:00
|
|
|
static SharedPtr<ResourceLimit> Create(KernelCore& kernel, std::string name = "Unknown");
|
2015-05-12 20:25:15 +00:00
|
|
|
|
2016-09-18 00:38:01 +00:00
|
|
|
std::string GetTypeName() const override {
|
|
|
|
return "ResourceLimit";
|
|
|
|
}
|
|
|
|
std::string GetName() const override {
|
|
|
|
return name;
|
|
|
|
}
|
2015-05-12 20:25:15 +00:00
|
|
|
|
|
|
|
static const HandleType HANDLE_TYPE = HandleType::ResourceLimit;
|
2016-09-18 00:38:01 +00:00
|
|
|
HandleType GetHandleType() const override {
|
|
|
|
return HANDLE_TYPE;
|
|
|
|
}
|
2015-05-12 20:25:15 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the current value for the specified resource.
|
|
|
|
* @param resource Requested resource type
|
|
|
|
* @returns The current value of the resource type
|
|
|
|
*/
|
2018-11-19 17:54:06 +00:00
|
|
|
s64 GetCurrentResourceValue(ResourceType resource) const;
|
2015-05-12 20:25:15 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the max value for the specified resource.
|
|
|
|
* @param resource Requested resource type
|
|
|
|
* @returns The max value of the resource type
|
|
|
|
*/
|
2018-11-19 17:54:06 +00:00
|
|
|
s64 GetMaxResourceValue(ResourceType resource) const;
|
2015-05-12 20:25:15 +00:00
|
|
|
|
2018-11-19 17:54:06 +00:00
|
|
|
/**
|
|
|
|
* Sets the limit value for a given resource type.
|
|
|
|
*
|
|
|
|
* @param resource The resource type to apply the limit to.
|
|
|
|
* @param value The limit to apply to the given resource type.
|
|
|
|
*
|
|
|
|
* @return A result code indicating if setting the limit value
|
|
|
|
* was successful or not.
|
|
|
|
*
|
|
|
|
* @note The supplied limit value *must* be greater than or equal to
|
|
|
|
* the current resource value for the given resource type,
|
|
|
|
* otherwise ERR_INVALID_STATE will be returned.
|
|
|
|
*/
|
|
|
|
ResultCode SetLimitValue(ResourceType resource, s64 value);
|
2015-05-25 18:34:09 +00:00
|
|
|
|
2018-11-19 17:54:06 +00:00
|
|
|
private:
|
|
|
|
explicit ResourceLimit(KernelCore& kernel);
|
|
|
|
~ResourceLimit() override;
|
2015-05-12 20:25:15 +00:00
|
|
|
|
2018-11-19 17:54:06 +00:00
|
|
|
// TODO(Subv): Increment resource limit current values in their respective Kernel::T::Create
|
|
|
|
// functions
|
|
|
|
//
|
2015-05-25 18:34:09 +00:00
|
|
|
// Currently we have no way of distinguishing if a Create was called by the running application,
|
2016-09-18 00:38:01 +00:00
|
|
|
// or by a service module. Approach this once we have separated the service modules into their
|
|
|
|
// own processes
|
2015-05-12 20:25:15 +00:00
|
|
|
|
2018-11-19 17:54:06 +00:00
|
|
|
using ResourceArray =
|
|
|
|
std::array<s64, static_cast<std::size_t>(ResourceType::ResourceTypeCount)>;
|
2015-05-12 20:25:15 +00:00
|
|
|
|
2018-11-19 17:54:06 +00:00
|
|
|
/// Maximum values a resource type may reach.
|
|
|
|
ResourceArray limits{};
|
|
|
|
/// Current resource limit values.
|
|
|
|
ResourceArray values{};
|
2015-05-12 20:25:15 +00:00
|
|
|
|
2018-11-19 17:54:06 +00:00
|
|
|
/// Name of resource limit object.
|
|
|
|
std::string name;
|
2015-05-12 20:25:15 +00:00
|
|
|
};
|
|
|
|
|
2018-01-20 07:48:02 +00:00
|
|
|
} // namespace Kernel
|