mirror of
https://github.com/skyline-emu/skyline.git
synced 2024-12-29 00:15:27 +03: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 {};
|
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 <kernel/types/KEvent.h>
|
||||||
#include <services/serviceman.h>
|
#include <services/serviceman.h>
|
||||||
|
#include <common/macros.h>
|
||||||
|
|
||||||
namespace skyline::service::am {
|
namespace skyline::service::am {
|
||||||
namespace result {
|
namespace result {
|
||||||
constexpr Result NoMessages(128, 3);
|
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
|
Docked = 1, //!< The device is in docked mode
|
||||||
} operationMode;
|
} 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
|
* @brief Queues a message for the application to read via ReceiveMessage
|
||||||
* @param message The message to queue
|
* @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);
|
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(
|
SERVICE_DECL(
|
||||||
SFUNC(0x0, ICommonStateGetter, GetEventHandle),
|
SFUNC(0x0, ICommonStateGetter, GetEventHandle),
|
||||||
SFUNC(0x1, ICommonStateGetter, ReceiveMessage),
|
SFUNC(0x1, ICommonStateGetter, ReceiveMessage),
|
||||||
@ -102,7 +122,8 @@ namespace skyline::service::am {
|
|||||||
SFUNC(0x6, ICommonStateGetter, GetPerformanceMode),
|
SFUNC(0x6, ICommonStateGetter, GetPerformanceMode),
|
||||||
SFUNC(0x9, ICommonStateGetter, GetCurrentFocusState),
|
SFUNC(0x9, ICommonStateGetter, GetCurrentFocusState),
|
||||||
SFUNC(0x32, ICommonStateGetter, IsVrModeEnabled),
|
SFUNC(0x32, ICommonStateGetter, IsVrModeEnabled),
|
||||||
SFUNC(0x3C, ICommonStateGetter, GetDefaultDisplayResolution)
|
SFUNC(0x3C, ICommonStateGetter, GetDefaultDisplayResolution),
|
||||||
|
SFUNC(0x42, ICommonStateGetter, SetCpuBoostMode)
|
||||||
)
|
)
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user