mirror of
https://github.com/Atmosphere-NX/Atmosphere
synced 2024-12-22 20:31:14 +00:00
exosphere: Add support for rebooting to a payload in IRAM.
This commit is contained in:
parent
d349bdb1f8
commit
a52e601f2e
2 changed files with 25 additions and 8 deletions
|
@ -35,13 +35,26 @@ uint32_t configitem_set(bool privileged, ConfigItem item, uint64_t value) {
|
||||||
case CONFIGITEM_BATTERYPROFILE:
|
case CONFIGITEM_BATTERYPROFILE:
|
||||||
g_battery_profile = (value != 0);
|
g_battery_profile = (value != 0);
|
||||||
break;
|
break;
|
||||||
case CONFIGITEM_NEEDS_REBOOT_TO_RCM:
|
case CONFIGITEM_NEEDS_REBOOT:
|
||||||
/* Force a reboot to RCM, if requested. */
|
/* Force a reboot to RCM, if requested. */
|
||||||
if (value != 0) {
|
switch (value) {
|
||||||
MAKE_REG32(MMIO_GET_DEVICE_ADDRESS(MMIO_DEVID_RTC_PMC) + 0x450ull) = 0x2;
|
case REBOOT_KIND_NO_REBOOT:
|
||||||
MAKE_REG32(MMIO_GET_DEVICE_ADDRESS(MMIO_DEVID_RTC_PMC) + 0x400ull) = 0x10;
|
return 0;
|
||||||
while (1) { }
|
case REBOOT_KIND_TO_RCM:
|
||||||
|
/* Set reboot kind = rcm. */
|
||||||
|
MAKE_REG32(MMIO_GET_DEVICE_ADDRESS(MMIO_DEVID_RTC_PMC) + 0x450ull) = 0x2;
|
||||||
|
break;
|
||||||
|
case REBOOT_KIND_TO_WB_PAYLOAD:
|
||||||
|
/* Set reboot kind = warmboot. */
|
||||||
|
MAKE_REG32(MMIO_GET_DEVICE_ADDRESS(MMIO_DEVID_RTC_PMC) + 0x450ull) = 0x1;
|
||||||
|
/* Patch bootrom to jump to payload. */
|
||||||
|
MAKE_REG32(MMIO_GET_DEVICE_ADDRESS(MMIO_DEVID_RTC_PMC) + 0x118) = 0x40010000; /* Return to start of payload. */
|
||||||
|
MAKE_REG32(MMIO_GET_DEVICE_ADDRESS(MMIO_DEVID_RTC_PMC) + 0x11C) = 0x4000FFA4; /* Overwrite bootrom return address on stack. */
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return 2;
|
||||||
}
|
}
|
||||||
|
MAKE_REG32(MMIO_GET_DEVICE_ADDRESS(MMIO_DEVID_RTC_PMC) + 0x400ull) = 0x10;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
return 2;
|
return 2;
|
||||||
|
@ -187,8 +200,8 @@ uint32_t configitem_get(bool privileged, ConfigItem item, uint64_t *p_outvalue)
|
||||||
((uint64_t)(exosphere_get_target_firmware() & 0xFF) << 8ull) |
|
((uint64_t)(exosphere_get_target_firmware() & 0xFF) << 8ull) |
|
||||||
((uint64_t)(mkey_get_revision() & 0xFF) << 0ull);
|
((uint64_t)(mkey_get_revision() & 0xFF) << 0ull);
|
||||||
break;
|
break;
|
||||||
case CONFIGITEM_NEEDS_REBOOT_TO_RCM:
|
case CONFIGITEM_NEEDS_REBOOT:
|
||||||
/* UNOFFICIAL: The fact that we are executing means we aren't in the process of rebooting to rcm. */
|
/* UNOFFICIAL: The fact that we are executing means we aren't in the process of rebooting. */
|
||||||
*p_outvalue = 0;
|
*p_outvalue = 0;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
|
|
@ -41,9 +41,13 @@ typedef enum {
|
||||||
|
|
||||||
/* These are unofficial, for usage by Exosphere. */
|
/* These are unofficial, for usage by Exosphere. */
|
||||||
CONFIGITEM_EXOSPHERE_VERSION = 65000,
|
CONFIGITEM_EXOSPHERE_VERSION = 65000,
|
||||||
CONFIGITEM_NEEDS_REBOOT_TO_RCM = 65001,
|
CONFIGITEM_NEEDS_REBOOT = 65001,
|
||||||
} ConfigItem;
|
} ConfigItem;
|
||||||
|
|
||||||
|
#define REBOOT_KIND_NO_REBOOT 0
|
||||||
|
#define REBOOT_KIND_TO_RCM 1
|
||||||
|
#define REBOOT_KIND_TO_WB_PAYLOAD 2
|
||||||
|
|
||||||
uint32_t configitem_set(bool privileged, ConfigItem item, uint64_t value);
|
uint32_t configitem_set(bool privileged, ConfigItem item, uint64_t value);
|
||||||
uint32_t configitem_get(bool privileged, ConfigItem item, uint64_t *p_outvalue);
|
uint32_t configitem_get(bool privileged, ConfigItem item, uint64_t *p_outvalue);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue