2018-05-03 08:58:11 +00:00
|
|
|
#include <switch.h>
|
|
|
|
#include "pm_boot_mode.hpp"
|
2018-05-06 08:23:47 +00:00
|
|
|
#include "pm_debug.hpp"
|
2018-05-03 08:58:11 +00:00
|
|
|
|
|
|
|
static bool g_is_maintenance_boot = false;
|
|
|
|
|
|
|
|
Result BootModeService::dispatch(IpcParsedCommand &r, IpcCommand &out_c, u64 cmd_id, u8 *pointer_buffer, size_t pointer_buffer_size) {
|
|
|
|
Result rc = 0xF601;
|
2018-05-06 08:23:47 +00:00
|
|
|
LogForService("BOOTMODE\x00", 8);
|
|
|
|
LogForService(&cmd_id, 8);
|
|
|
|
LogForService(armGetTls(), 0x100);
|
2018-05-03 08:58:11 +00:00
|
|
|
switch ((BootModeCmd)cmd_id) {
|
|
|
|
case BootMode_Cmd_GetBootMode:
|
|
|
|
rc = WrapIpcCommandImpl<&BootModeService::get_boot_mode>(this, r, out_c, pointer_buffer, pointer_buffer_size);
|
|
|
|
break;
|
|
|
|
case BootMode_Cmd_SetMaintenanceBoot:
|
|
|
|
rc = WrapIpcCommandImpl<&BootModeService::set_maintenance_boot>(this, r, out_c, pointer_buffer, pointer_buffer_size);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
2018-05-06 08:23:47 +00:00
|
|
|
LogForService(armGetTls(), 0x100);
|
|
|
|
if (R_FAILED(rc)) {
|
|
|
|
Reboot();
|
|
|
|
}
|
2018-05-03 08:58:11 +00:00
|
|
|
return rc;
|
|
|
|
}
|
|
|
|
|
|
|
|
Result BootModeService::handle_deferred() {
|
|
|
|
/* This service is never deferrable. */
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
std::tuple<Result, bool> BootModeService::get_boot_mode() {
|
2018-05-05 18:41:39 +00:00
|
|
|
return {0, g_is_maintenance_boot};
|
2018-05-03 08:58:11 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
std::tuple<Result> BootModeService::set_maintenance_boot() {
|
|
|
|
g_is_maintenance_boot = true;
|
2018-05-05 18:41:39 +00:00
|
|
|
return {0};
|
|
|
|
}
|