/* * Copyright (c) 2018 naehrwert * * 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 . */ #ifndef _HOS_H_ #define _HOS_H_ #include "pkg1.h" #include "pkg2.h" #include "../utils/types.h" #include "../config/ini.h" #include "../sec/tsec.h" #define KB_FIRMWARE_VERSION_100_200 0 #define KB_FIRMWARE_VERSION_300 1 #define KB_FIRMWARE_VERSION_301 2 #define KB_FIRMWARE_VERSION_400 3 #define KB_FIRMWARE_VERSION_500 4 #define KB_FIRMWARE_VERSION_600 5 #define KB_FIRMWARE_VERSION_620 6 #define KB_FIRMWARE_VERSION_MAX KB_FIRMWARE_VERSION_620 #define HOS_PKG11_MAGIC 0x31314B50 typedef struct _launch_ctxt_t { void *keyblob; void *pkg1; const pkg1_id_t *pkg1_id; const pkg2_kernel_id_t *pkg2_kernel_id; void *warmboot; u32 warmboot_size; void *secmon; u32 secmon_size; void *pkg2; u32 pkg2_size; void *kernel; u32 kernel_size; link_t kip1_list; char* kip1_patches; bool svcperm; bool debugmode; bool atmosphere; } launch_ctxt_t; typedef struct _merge_kip_t { void *kip1; link_t link; } merge_kip_t; int hos_launch(ini_sec_t *cfg); int keygen(u8 *keyblob, u32 kb, tsec_ctxt_t *tsec_ctxt); #endif