mirror of
https://github.com/skyline-emu/skyline.git
synced 2024-11-04 23:55:08 +01:00
Stub ICommonStateGetter::SetCpuBoostMode
This makes Metroid Dread boot
This commit is contained in:
parent
d033ff2478
commit
6e929e6f6a
@ -71,4 +71,19 @@ namespace skyline::service::am {
|
||||
}
|
||||
return {};
|
||||
}
|
||||
|
||||
Result ICommonStateGetter::SetCpuBoostMode(type::KSession &session, ipc::IpcRequest &request, ipc::IpcResponse &response) {
|
||||
cpuBoostMode = request.Pop<CpuBoostMode>();
|
||||
switch (cpuBoostMode) {
|
||||
case CpuBoostMode::Normal:
|
||||
case CpuBoostMode::FastLoad:
|
||||
case CpuBoostMode::PowerSaving:
|
||||
Logger::Info("Set CPU boost mode to {}", ToString(cpuBoostMode));
|
||||
return {};
|
||||
default:
|
||||
Logger::Error("Unknown CPU boost mode value: 0x{:X}", cpuBoostMode);
|
||||
return result::InvalidParameters;
|
||||
}
|
||||
return {};
|
||||
}
|
||||
}
|
||||
|
@ -5,10 +5,12 @@
|
||||
|
||||
#include <kernel/types/KEvent.h>
|
||||
#include <services/serviceman.h>
|
||||
#include <common/macros.h>
|
||||
|
||||
namespace skyline::service::am {
|
||||
namespace result {
|
||||
constexpr Result NoMessages(128, 3);
|
||||
constexpr Result InvalidParameters(128, 506);
|
||||
}
|
||||
|
||||
/**
|
||||
@ -44,6 +46,18 @@ namespace skyline::service::am {
|
||||
Docked = 1, //!< The device is in docked mode
|
||||
} operationMode;
|
||||
|
||||
enum class CpuBoostMode : u32 {
|
||||
Normal = 0, //!< The device runs at stock CPU and CPU clocks
|
||||
FastLoad = 1, //!< The device runs at boosted CPU clocks and minimum GPU clocks
|
||||
PowerSaving = 2 //!< The device runs at stock CPU clocks and minimum GPU clocks
|
||||
} cpuBoostMode;
|
||||
|
||||
ENUM_STRING(CpuBoostMode, {
|
||||
ENUM_CASE_PAIR(Normal, "Normal");
|
||||
ENUM_CASE_PAIR(FastLoad, "Fast Load");
|
||||
ENUM_CASE_PAIR(PowerSaving, "Power Saving");
|
||||
})
|
||||
|
||||
/**
|
||||
* @brief Queues a message for the application to read via ReceiveMessage
|
||||
* @param message The message to queue
|
||||
@ -95,6 +109,12 @@ namespace skyline::service::am {
|
||||
*/
|
||||
Result GetDefaultDisplayResolution(type::KSession &session, ipc::IpcRequest &request, ipc::IpcResponse &response);
|
||||
|
||||
/**
|
||||
* @brief Sets the CPU boost mode to the supplied value
|
||||
* @url https://switchbrew.org/wiki/Applet_Manager_services#SetCpuBoostMode
|
||||
*/
|
||||
Result SetCpuBoostMode(type::KSession &session, ipc::IpcRequest &request, ipc::IpcResponse &response);
|
||||
|
||||
SERVICE_DECL(
|
||||
SFUNC(0x0, ICommonStateGetter, GetEventHandle),
|
||||
SFUNC(0x1, ICommonStateGetter, ReceiveMessage),
|
||||
@ -102,7 +122,8 @@ namespace skyline::service::am {
|
||||
SFUNC(0x6, ICommonStateGetter, GetPerformanceMode),
|
||||
SFUNC(0x9, ICommonStateGetter, GetCurrentFocusState),
|
||||
SFUNC(0x32, ICommonStateGetter, IsVrModeEnabled),
|
||||
SFUNC(0x3C, ICommonStateGetter, GetDefaultDisplayResolution)
|
||||
SFUNC(0x3C, ICommonStateGetter, GetDefaultDisplayResolution),
|
||||
SFUNC(0x42, ICommonStateGetter, SetCpuBoostMode)
|
||||
)
|
||||
};
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user