2018-02-21 10:57:51 -08:00
|
|
|
#ifndef EXOSPHERE_PACKAGE2_H
|
|
|
|
#define EXOSPHERE_PACKAGE2_H
|
|
|
|
|
|
|
|
/* This is code responsible for validating a package2. Actual file reading is done by bootloader. */
|
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
#include "bootconfig.h"
|
2018-02-24 17:13:42 +01:00
|
|
|
#include "memory_map.h"
|
2018-02-21 10:57:51 -08:00
|
|
|
|
|
|
|
/* Physaddr 0x40002EF8 */
|
2018-02-22 17:08:54 -08:00
|
|
|
#define MAILBOX_NX_BOOTLOADER_BASE (mmio_get_device_address(MMIO_DEVID_NXBOOTLOADER_MAILBOX))
|
|
|
|
|
|
|
|
#define MAILBOX_NX_BOOTLOADER_SETUP_STATE (*((volatile uint32_t *)(MAILBOX_NX_BOOTLOADER_BASE + 0xEF8ULL)))
|
2018-02-21 10:57:51 -08:00
|
|
|
|
|
|
|
#define NX_BOOTLOADER_STATE_INIT 0
|
|
|
|
#define NX_BOOTLOADER_STATE_MOVED_BOOTCONFIG 1
|
|
|
|
#define NX_BOOTLOADER_STATE_LOADED_PACKAGE2 2
|
|
|
|
#define NX_BOOTLOADER_STATE_FINISHED 3
|
|
|
|
|
|
|
|
/* Physaddr 0x40002EFC */
|
2018-02-22 17:08:54 -08:00
|
|
|
#define MAILBOX_NX_BOOTLOADER_IS_SECMON_AWAKE (*((volatile uint32_t *)(MAILBOX_NX_BOOTLOADER_BASE + 0xEFCULL)))
|
2018-02-21 10:57:51 -08:00
|
|
|
|
2018-02-21 11:52:39 -08:00
|
|
|
#define NX_BOOTLOADER_BOOTCONFIG_POINTER ((void *)(0x4003D000ULL))
|
|
|
|
|
|
|
|
#define NX_BOOTLOADER_PACKAGE2_LOAD_ADDRESS ((void *)(0xA9800000ULL))
|
|
|
|
|
2018-02-21 13:38:55 -08:00
|
|
|
#define DRAM_BASE_PHYSICAL (0x80000000ULL)
|
2018-02-21 11:52:39 -08:00
|
|
|
|
|
|
|
#define MAGIC_PK21 (0x31324B50)
|
2018-02-21 13:38:55 -08:00
|
|
|
#define PACKAGE2_SIZE_MAX 0x7FC000
|
|
|
|
#define PACKAGE2_SECTION_MAX 0x3
|
|
|
|
|
|
|
|
#define PACKAGE2_MINVER_THEORETICAL 0x0
|
|
|
|
#define PACKAGE2_MAXVER_100 0x2
|
|
|
|
#define PACKAGE2_MAXVER_200 0x3
|
|
|
|
#define PACKAGE2_MAXVER_300 0x4
|
|
|
|
#define PACKAGE2_MAXVER_302 0x5
|
|
|
|
#define PACKAGE2_MAXVER_400_CURRENT 0x6
|
|
|
|
|
|
|
|
#define PACKAGE2_MINVER_100 0x3
|
|
|
|
#define PACKAGE2_MINVER_200 0x4
|
|
|
|
#define PACKAGE2_MINVER_300 0x5
|
|
|
|
#define PACKAGE2_MINVER_302 0x6
|
|
|
|
#define PACKAGE2_MINVER_400_CURRENT 0x7
|
|
|
|
|
2018-02-21 11:52:39 -08:00
|
|
|
|
|
|
|
#pragma pack(push, 1)
|
|
|
|
typedef struct {
|
|
|
|
union {
|
|
|
|
uint8_t ctr[0x10];
|
|
|
|
uint32_t ctr_dwords[0x4];
|
|
|
|
};
|
|
|
|
uint8_t section_ctrs[4][0x10];
|
|
|
|
uint32_t magic;
|
2018-02-21 13:38:55 -08:00
|
|
|
uint32_t entrypoint;
|
2018-02-21 11:52:39 -08:00
|
|
|
uint32_t _0x58;
|
|
|
|
uint8_t version_max; /* Must be > TZ value. */
|
|
|
|
uint8_t version_min; /* Must be < TZ value. */
|
|
|
|
uint16_t _0x5E;
|
|
|
|
uint32_t section_sizes[4];
|
|
|
|
uint32_t section_offsets[4];
|
|
|
|
uint8_t section_hashes[4][0x20];
|
|
|
|
} package2_meta_t;
|
|
|
|
#pragma pack(pop)
|
|
|
|
|
|
|
|
#pragma pack(push, 1)
|
|
|
|
typedef struct {
|
|
|
|
uint8_t signature[0x100];
|
|
|
|
union {
|
|
|
|
package2_meta_t metadata;
|
|
|
|
uint8_t encrypted_header[0x100];
|
|
|
|
};
|
|
|
|
} package2_header_t;
|
|
|
|
#pragma pack(pop)
|
2018-02-21 10:57:51 -08:00
|
|
|
|
|
|
|
void load_package2(void);
|
|
|
|
|
2018-02-24 17:13:42 +01:00
|
|
|
#endif
|