2018-09-07 15:00:13 +00:00
|
|
|
/*
|
2020-01-24 10:10:40 +00:00
|
|
|
* Copyright (c) 2018-2020 Atmosphère-NX
|
2018-09-07 15:00:13 +00:00
|
|
|
*
|
|
|
|
* 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-21 18:57:51 +00:00
|
|
|
#ifndef EXOSPHERE_BOOTCONFIG_H
|
|
|
|
#define EXOSPHERE_BOOTCONFIG_H
|
|
|
|
|
2018-02-24 20:46:57 +00:00
|
|
|
#include <stdbool.h>
|
2018-02-21 18:57:51 +00:00
|
|
|
#include <stdint.h>
|
2018-03-01 10:06:55 +00:00
|
|
|
#include "memory_map.h"
|
2018-02-21 18:57:51 +00:00
|
|
|
|
2019-04-11 06:30:19 +00:00
|
|
|
/* This is kind of ConfigItem, but it's stored in BootConfig, so... */
|
|
|
|
typedef enum {
|
|
|
|
KERNELCONFIGFLAG_INITIALIZE_MEMORY_TO_PATTERN = (1 << 0),
|
|
|
|
KERNELCONFIGFLAG_ENABLE_USER_EXCEPTION_HANDLERS = (1 << 1),
|
|
|
|
KERNELCONFIGFLAG_ENABLE_USER_PMU_ACCESS = (1 << 2),
|
|
|
|
KERNELCONFIGFLAG_CALL_SMC_PANIC_ON_KERNEL_ERROR = (1 << 8),
|
|
|
|
} KernelConfigFlag;
|
|
|
|
|
2018-02-21 18:57:51 +00:00
|
|
|
/* This provides management for Switch BootConfig. */
|
|
|
|
|
2018-03-01 10:06:55 +00:00
|
|
|
#define LOADED_BOOTCONFIG (get_loaded_bootconfig())
|
|
|
|
|
2018-02-21 18:57:51 +00:00
|
|
|
typedef struct {
|
2018-02-28 04:28:34 +00:00
|
|
|
uint8_t data[0x200];
|
|
|
|
} bootconfig_unsigned_config_t;
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
uint8_t _0x0[8];
|
|
|
|
uint8_t package2_config;
|
|
|
|
uint8_t _0x9[7];
|
|
|
|
uint8_t hardware_info[0x10];
|
|
|
|
uint8_t disable_program_verification;
|
|
|
|
uint8_t _0x21[0xDF];
|
|
|
|
} bootconfig_signed_config_t;
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
bootconfig_unsigned_config_t unsigned_config;
|
2018-02-21 18:57:51 +00:00
|
|
|
uint8_t signature[0x100];
|
2018-02-28 04:28:34 +00:00
|
|
|
bootconfig_signed_config_t signed_config;
|
2018-02-21 18:57:51 +00:00
|
|
|
} bootconfig_t;
|
|
|
|
|
2018-03-01 10:06:55 +00:00
|
|
|
static inline bootconfig_t *get_loaded_bootconfig(void) {
|
|
|
|
/* this is also get_exception_entry_stack_address(2) */
|
|
|
|
return (bootconfig_t *)(TZRAM_GET_SEGMENT_ADDRESS(TZRAM_SEGEMENT_ID_SECMON_EVT) + 0x180);
|
|
|
|
}
|
|
|
|
|
2018-03-08 09:48:57 +00:00
|
|
|
typedef struct {
|
2018-08-29 17:28:21 +00:00
|
|
|
uint32_t bootloader_version;
|
|
|
|
uint32_t bootloader_start_block;
|
|
|
|
uint32_t bootloader_start_page;
|
|
|
|
uint32_t bootloader_attribute;
|
|
|
|
uint32_t boot_reason_value;
|
|
|
|
uint32_t boot_reason_state;
|
2018-03-08 09:48:57 +00:00
|
|
|
} boot_reason_t;
|
|
|
|
|
2018-02-21 19:52:39 +00:00
|
|
|
void bootconfig_load_and_verify(const bootconfig_t *bootconfig);
|
2018-02-21 18:57:51 +00:00
|
|
|
void bootconfig_clear(void);
|
|
|
|
|
2018-03-08 09:48:57 +00:00
|
|
|
void bootconfig_load_boot_reason(volatile boot_reason_t *boot_reason);
|
|
|
|
|
2018-03-25 21:05:08 +00:00
|
|
|
void bootconfig_set_package2_hash_for_recovery(const void *package2, size_t package2_size);
|
|
|
|
void bootconfig_get_package2_hash_for_recovery(uint64_t *out_hash);
|
|
|
|
|
2018-02-21 19:52:39 +00:00
|
|
|
/* Actual configuration getters. */
|
2018-02-23 03:58:39 +00:00
|
|
|
bool bootconfig_is_package2_plaintext(void);
|
|
|
|
bool bootconfig_is_package2_unsigned(void);
|
2018-04-12 03:56:30 +00:00
|
|
|
void bootconfig_set_package2_plaintext_and_unsigned(void);
|
2018-02-24 15:25:38 +00:00
|
|
|
bool bootconfig_disable_program_verification(void);
|
2018-02-25 09:21:52 +00:00
|
|
|
bool bootconfig_is_debug_mode(void);
|
|
|
|
|
2018-03-03 18:31:22 +00:00
|
|
|
bool bootconfig_take_extabt_serror_to_el3(void);
|
2018-03-02 23:04:16 +00:00
|
|
|
|
2018-06-02 04:20:04 +00:00
|
|
|
uint64_t bootconfig_get_value_for_sysctr0(void);
|
|
|
|
|
2018-02-25 09:21:52 +00:00
|
|
|
uint64_t bootconfig_get_memory_arrangement(void);
|
2019-04-11 06:30:19 +00:00
|
|
|
uint64_t bootconfig_get_kernel_configuration(void);
|
2018-02-21 19:52:39 +00:00
|
|
|
|
2018-03-08 09:48:57 +00:00
|
|
|
bool bootconfig_is_recovery_boot(void);
|
|
|
|
uint64_t bootconfig_get_boot_reason(void);
|
|
|
|
|
2018-03-01 10:06:55 +00:00
|
|
|
#endif
|