2018-09-07 15:00:13 +00:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2018 Atmosphère-NX
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify it
|
|
|
|
* under the terms and conditions of the GNU General Public License,
|
|
|
|
* version 2, as published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope it will be useful, but WITHOUT
|
|
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
|
|
|
* more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
2018-02-19 08:41:19 +00:00
|
|
|
#include <stdint.h>
|
|
|
|
|
2018-02-24 15:25:38 +00:00
|
|
|
#include "bootconfig.h"
|
2018-02-19 08:41:19 +00:00
|
|
|
#include "configitem.h"
|
2018-02-24 20:46:57 +00:00
|
|
|
#include "interrupt.h"
|
|
|
|
#include "package2.h"
|
|
|
|
#include "se.h"
|
2018-02-25 19:00:50 +00:00
|
|
|
#include "fuse.h"
|
2018-02-24 20:46:57 +00:00
|
|
|
#include "utils.h"
|
2018-03-09 10:54:36 +00:00
|
|
|
#include "masterkey.h"
|
2018-03-25 21:05:08 +00:00
|
|
|
#include "exocfg.h"
|
2018-05-09 12:29:56 +00:00
|
|
|
#include "version.h"
|
2018-02-19 08:41:19 +00:00
|
|
|
|
2018-02-26 10:00:02 +00:00
|
|
|
static bool g_battery_profile = false;
|
2018-02-19 08:41:19 +00:00
|
|
|
|
2018-03-05 22:59:46 +00:00
|
|
|
uint32_t configitem_set(ConfigItem item, uint64_t value) {
|
2018-02-19 08:41:19 +00:00
|
|
|
if (item != CONFIGITEM_BATTERYPROFILE) {
|
|
|
|
return 2;
|
|
|
|
}
|
|
|
|
|
2018-02-26 10:00:02 +00:00
|
|
|
g_battery_profile = (value != 0);
|
|
|
|
return 0;
|
2018-02-19 08:41:19 +00:00
|
|
|
}
|
|
|
|
|
2018-02-23 03:58:39 +00:00
|
|
|
bool configitem_is_recovery_boot(void) {
|
2018-02-20 09:02:01 +00:00
|
|
|
uint64_t is_recovery_boot;
|
|
|
|
if (configitem_get(CONFIGITEM_ISRECOVERYBOOT, &is_recovery_boot) != 0) {
|
2018-02-24 14:20:45 +00:00
|
|
|
generic_panic();
|
2018-02-20 09:02:01 +00:00
|
|
|
}
|
2018-02-23 03:58:39 +00:00
|
|
|
|
|
|
|
return is_recovery_boot != 0;
|
2018-02-20 09:02:01 +00:00
|
|
|
}
|
|
|
|
|
2018-02-25 09:21:52 +00:00
|
|
|
bool configitem_is_retail(void) {
|
|
|
|
uint64_t is_retail;
|
|
|
|
if (configitem_get(CONFIGITEM_ISRETAIL, &is_retail) != 0) {
|
|
|
|
generic_panic();
|
|
|
|
}
|
|
|
|
|
|
|
|
return is_retail != 0;
|
|
|
|
}
|
|
|
|
|
2018-02-26 10:00:02 +00:00
|
|
|
bool configitem_should_profile_battery(void) {
|
|
|
|
return g_battery_profile;
|
|
|
|
}
|
|
|
|
|
2018-03-02 20:16:30 +00:00
|
|
|
uint64_t configitem_get_hardware_type(void) {
|
|
|
|
uint64_t hardware_type;
|
|
|
|
if (configitem_get(CONFIGITEM_HARDWARETYPE, &hardware_type) != 0) {
|
|
|
|
generic_panic();
|
|
|
|
}
|
|
|
|
return hardware_type;
|
|
|
|
}
|
|
|
|
|
2018-03-05 22:59:46 +00:00
|
|
|
uint32_t configitem_get(ConfigItem item, uint64_t *p_outvalue) {
|
2018-02-19 08:41:19 +00:00
|
|
|
uint32_t result = 0;
|
|
|
|
switch (item) {
|
|
|
|
case CONFIGITEM_DISABLEPROGRAMVERIFICATION:
|
2018-02-24 15:25:38 +00:00
|
|
|
*p_outvalue = (int)(bootconfig_disable_program_verification());
|
2018-02-19 08:41:19 +00:00
|
|
|
break;
|
2018-02-25 09:21:52 +00:00
|
|
|
case CONFIGITEM_DRAMID:
|
|
|
|
*p_outvalue = fuse_get_dram_id();
|
2018-02-19 08:41:19 +00:00
|
|
|
break;
|
|
|
|
case CONFIGITEM_SECURITYENGINEIRQ:
|
2018-02-24 15:25:38 +00:00
|
|
|
/* SE is interrupt #0x2C. */
|
|
|
|
*p_outvalue = INTERRUPT_ID_USER_SECURITY_ENGINE;
|
2018-02-19 08:41:19 +00:00
|
|
|
break;
|
2018-02-24 20:46:57 +00:00
|
|
|
case CONFIGITEM_VERSION:
|
2018-02-24 15:25:38 +00:00
|
|
|
/* Always returns maxver - 1 on hardware. */
|
2018-04-23 18:07:49 +00:00
|
|
|
*p_outvalue = PACKAGE2_MAXVER_400_410 - 1;
|
2018-02-19 08:41:19 +00:00
|
|
|
break;
|
|
|
|
case CONFIGITEM_HARDWARETYPE:
|
2018-02-25 09:21:52 +00:00
|
|
|
*p_outvalue = fuse_get_hardware_type();
|
2018-02-19 08:41:19 +00:00
|
|
|
break;
|
|
|
|
case CONFIGITEM_ISRETAIL:
|
2018-02-25 09:21:52 +00:00
|
|
|
*p_outvalue = fuse_get_retail_type();
|
2018-02-19 08:41:19 +00:00
|
|
|
break;
|
|
|
|
case CONFIGITEM_ISRECOVERYBOOT:
|
2018-03-08 09:48:57 +00:00
|
|
|
*p_outvalue = (int)(bootconfig_is_recovery_boot());
|
2018-02-19 08:41:19 +00:00
|
|
|
break;
|
|
|
|
case CONFIGITEM_DEVICEID:
|
2018-02-25 09:21:52 +00:00
|
|
|
*p_outvalue = fuse_get_device_id();
|
2018-02-19 08:41:19 +00:00
|
|
|
break;
|
|
|
|
case CONFIGITEM_BOOTREASON:
|
2018-03-09 10:54:36 +00:00
|
|
|
/* For some reason, Nintendo removed it on 4.0 */
|
2018-03-25 21:05:08 +00:00
|
|
|
if (exosphere_get_target_firmware() < EXOSPHERE_TARGET_FIRMWARE_400) {
|
2018-03-09 10:54:36 +00:00
|
|
|
*p_outvalue = bootconfig_get_boot_reason();
|
|
|
|
} else {
|
|
|
|
result = 2;
|
|
|
|
}
|
2018-02-19 08:41:19 +00:00
|
|
|
break;
|
|
|
|
case CONFIGITEM_MEMORYARRANGE:
|
2018-02-25 09:21:52 +00:00
|
|
|
*p_outvalue = bootconfig_get_memory_arrangement();
|
2018-02-19 08:41:19 +00:00
|
|
|
break;
|
|
|
|
case CONFIGITEM_ISDEBUGMODE:
|
2018-02-25 09:21:52 +00:00
|
|
|
*p_outvalue = (int)(bootconfig_is_debug_mode());
|
2018-02-19 08:41:19 +00:00
|
|
|
break;
|
|
|
|
case CONFIGITEM_KERNELMEMORYCONFIGURATION:
|
2018-02-25 09:21:52 +00:00
|
|
|
*p_outvalue = bootconfig_get_kernel_memory_configuration();
|
2018-02-19 08:41:19 +00:00
|
|
|
break;
|
|
|
|
case CONFIGITEM_BATTERYPROFILE:
|
2018-02-26 10:00:02 +00:00
|
|
|
*p_outvalue = (int)g_battery_profile;
|
2018-02-19 08:41:19 +00:00
|
|
|
break;
|
2018-03-09 10:54:36 +00:00
|
|
|
case CONFIGITEM_ODM4BIT10_4X:
|
|
|
|
/* Added on 4.x ... where is it being used? */
|
2018-03-25 21:05:08 +00:00
|
|
|
if (exosphere_get_target_firmware() >= EXOSPHERE_TARGET_FIRMWARE_400) {
|
2018-03-09 10:54:36 +00:00
|
|
|
*p_outvalue = (fuse_get_reserved_odm(4) >> 10) & 1;
|
|
|
|
} else {
|
|
|
|
result = 2;
|
|
|
|
}
|
|
|
|
break;
|
2018-03-25 21:05:08 +00:00
|
|
|
case CONFIGITEM_NEWHARDWARETYPE_5X:
|
|
|
|
/* Added in 5.x, currently hardcoded to 0. */
|
|
|
|
if (exosphere_get_target_firmware() >= EXOSPHERE_TARGET_FIRMWARE_500) {
|
|
|
|
*p_outvalue = 0;
|
|
|
|
} else {
|
|
|
|
result = 2;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case CONFIGITEM_NEWKEYGENERATION_5X:
|
|
|
|
/* Added in 5.x. */
|
|
|
|
if (exosphere_get_target_firmware() >= EXOSPHERE_TARGET_FIRMWARE_500) {
|
|
|
|
*p_outvalue = fuse_get_5x_key_generation();
|
|
|
|
} else {
|
|
|
|
result = 2;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case CONFIGITEM_PACKAGE2HASH_5X:
|
|
|
|
/* Added in 5.x. */
|
|
|
|
if (exosphere_get_target_firmware() >= EXOSPHERE_TARGET_FIRMWARE_500 && bootconfig_is_recovery_boot()) {
|
|
|
|
bootconfig_get_package2_hash_for_recovery(p_outvalue);
|
|
|
|
} else {
|
|
|
|
result = 2;
|
|
|
|
}
|
|
|
|
break;
|
2018-05-09 12:29:56 +00:00
|
|
|
case CONFIGITEM_EXOSPHERE_VERSION:
|
|
|
|
/* UNOFFICIAL: Gets information about the current exosphere version. */
|
|
|
|
*p_outvalue = (EXOSPHERE_RELEASE_VERSION_MAJOR << 24) | (EXOSPHERE_RELEASE_VERSION_MINOR << 16) | (exosphere_get_target_firmware() << 8) | (mkey_get_revision() << 0);
|
|
|
|
break;
|
2018-02-19 08:41:19 +00:00
|
|
|
default:
|
|
|
|
result = 2;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
}
|