Fix trailing whitespace
This commit is contained in:
		| @@ -128,7 +128,7 @@ static const cfg_op_t _display_config_2[94] = { | |||||||
| }; | }; | ||||||
|  |  | ||||||
| //DSI Init config. | //DSI Init config. | ||||||
| static const cfg_op_t _display_config_3[61] = {  | static const cfg_op_t _display_config_3[61] = { | ||||||
| 	{DSI_WR_DATA, 0}, | 	{DSI_WR_DATA, 0}, | ||||||
| 	{DSI_INT_ENABLE, 0}, | 	{DSI_INT_ENABLE, 0}, | ||||||
| 	{DSI_INT_STATUS, 0}, | 	{DSI_INT_STATUS, 0}, | ||||||
|   | |||||||
| @@ -263,7 +263,6 @@ void gfx_putc(char c) | |||||||
| 		} | 		} | ||||||
| 		break; | 		break; | ||||||
| 	} | 	} | ||||||
| 	 |  | ||||||
| } | } | ||||||
|  |  | ||||||
| void gfx_puts(const char *s) | void gfx_puts(const char *s) | ||||||
|   | |||||||
| @@ -83,7 +83,7 @@ void tui_pbar(int x, int y, u32 val, u32 fgcol, u32 bgcol) | |||||||
| 	gfx_printf("%k[%3d%%]%k", fgcol, val, 0xFFCCCCCC); | 	gfx_printf("%k[%3d%%]%k", fgcol, val, 0xFFCCCCCC); | ||||||
|  |  | ||||||
| 	x += 7 * gfx_con.fntsz; | 	x += 7 * gfx_con.fntsz; | ||||||
| 	 |  | ||||||
| 	for (int i = 0; i < (gfx_con.fntsz >> 3) * 6; i++) | 	for (int i = 0; i < (gfx_con.fntsz >> 3) * 6; i++) | ||||||
| 	{ | 	{ | ||||||
| 		gfx_line(x, y + i + 1, x + 3 * val, y + i + 1, fgcol); | 		gfx_line(x, y + i + 1, x + 3 * val, y + i + 1, fgcol); | ||||||
|   | |||||||
| @@ -1,48 +1,48 @@ | |||||||
| /* | /* | ||||||
|  * Copyright (c) 2018 naehrwert |  * Copyright (c) 2018 naehrwert | ||||||
|  * Copyright (c) 2018 st4rk |  * Copyright (c) 2018 st4rk | ||||||
|  * Copyright (c) 2018-2019 CTCaer |  * Copyright (c) 2018-2019 CTCaer | ||||||
|  * Copyright (c) 2018 balika011 |  * Copyright (c) 2018 balika011 | ||||||
|  * |  * | ||||||
|  * This program is free software; you can redistribute it and/or modify it |  * This program is free software; you can redistribute it and/or modify it | ||||||
|  * under the terms and conditions of the GNU General Public License, |  * under the terms and conditions of the GNU General Public License, | ||||||
|  * version 2, as published by the Free Software Foundation. |  * version 2, as published by the Free Software Foundation. | ||||||
|  * |  * | ||||||
|  * This program is distributed in the hope it will be useful, but WITHOUT |  * This program is distributed in the hope it will be useful, but WITHOUT | ||||||
|  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | ||||||
|  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for |  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for | ||||||
|  * more details. |  * more details. | ||||||
|  * |  * | ||||||
|  * You should have received a copy of the GNU General Public License |  * You should have received a copy of the GNU General Public License | ||||||
|  * along with this program.  If not, see <http://www.gnu.org/licenses/>. |  * along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| #include <string.h> | #include <string.h> | ||||||
|  |  | ||||||
| #include "pkg1.h" | #include "pkg1.h" | ||||||
| #include "../sec/se.h" | #include "../sec/se.h" | ||||||
|  |  | ||||||
| static const pkg1_id_t _pkg1_ids[] = { | static const pkg1_id_t _pkg1_ids[] = { | ||||||
| 	{ "20161121183008", 0 }, //1.0.0 | 	{ "20161121183008", 0 }, //1.0.0 | ||||||
| 	{ "20170210155124", 0 }, //2.0.0 - 2.3.0 | 	{ "20170210155124", 0 }, //2.0.0 - 2.3.0 | ||||||
| 	{ "20170519101410", 1 }, //3.0.0 | 	{ "20170519101410", 1 }, //3.0.0 | ||||||
| 	{ "20170710161758", 2 }, //3.0.1 - 3.0.2 | 	{ "20170710161758", 2 }, //3.0.1 - 3.0.2 | ||||||
| 	{ "20170921172629", 3 }, //4.0.0 - 4.1.0 | 	{ "20170921172629", 3 }, //4.0.0 - 4.1.0 | ||||||
| 	{ "20180220163747", 4 }, //5.0.0 - 5.1.0 | 	{ "20180220163747", 4 }, //5.0.0 - 5.1.0 | ||||||
| 	{ "20180802162753", 5 }, //6.0.0 - 6.1.0 | 	{ "20180802162753", 5 }, //6.0.0 - 6.1.0 | ||||||
| 	{ "20181107105733", 6 }, //6.2.0 | 	{ "20181107105733", 6 }, //6.2.0 | ||||||
| 	{ "20181218175730", 7 }, //7.0.0 | 	{ "20181218175730", 7 }, //7.0.0 | ||||||
| 	{ "20190208150037", 7 }, //7.0.1 | 	{ "20190208150037", 7 }, //7.0.1 | ||||||
| 	{ "20190314172056", 7 }, //8.0.0 | 	{ "20190314172056", 7 }, //8.0.0 | ||||||
| 	{ "20190531152432", 8 }, //8.1.0 | 	{ "20190531152432", 8 }, //8.1.0 | ||||||
| 	{ "20190809135709", 9 }, //9.0.0 | 	{ "20190809135709", 9 }, //9.0.0 | ||||||
| 	{ NULL } //End. | 	{ NULL } //End. | ||||||
| }; | }; | ||||||
|  |  | ||||||
| const pkg1_id_t *pkg1_identify(u8 *pkg1) | const pkg1_id_t *pkg1_identify(u8 *pkg1) | ||||||
| { | { | ||||||
| 	for (u32 i = 0; _pkg1_ids[i].id; i++) | 	for (u32 i = 0; _pkg1_ids[i].id; i++) | ||||||
| 		if (!memcmp(pkg1 + 0x10, _pkg1_ids[i].id, 12)) | 		if (!memcmp(pkg1 + 0x10, _pkg1_ids[i].id, 12)) | ||||||
| 			return &_pkg1_ids[i]; | 			return &_pkg1_ids[i]; | ||||||
| 	return NULL; | 	return NULL; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -85,19 +85,19 @@ int pkg2_decompress_kip(pkg2_kip1_info_t* ki, u32 sectsToDecomp) | |||||||
|  |  | ||||||
| 	pkg2_kip1_t hdr; | 	pkg2_kip1_t hdr; | ||||||
| 	memcpy(&hdr, ki->kip1, sizeof(hdr)); | 	memcpy(&hdr, ki->kip1, sizeof(hdr)); | ||||||
| 	 |  | ||||||
| 	unsigned int newKipSize = sizeof(hdr); | 	unsigned int newKipSize = sizeof(hdr); | ||||||
| 	for (u32 sectIdx = 0; sectIdx < KIP1_NUM_SECTIONS; sectIdx++) | 	for (u32 sectIdx = 0; sectIdx < KIP1_NUM_SECTIONS; sectIdx++) | ||||||
| 	{ | 	{ | ||||||
| 		u32 sectCompBit = 1u << sectIdx; | 		u32 sectCompBit = 1u << sectIdx; | ||||||
| 		// For compressed, cant get actual decompressed size without doing it, so use safe "output size". | 		// For compressed, cant get actual decompressed size without doing it, so use safe "output size". | ||||||
| 		if (sectIdx < 3 && (sectsToDecomp & sectCompBit) && (hdr.flags & sectCompBit))  | 		if (sectIdx < 3 && (sectsToDecomp & sectCompBit) && (hdr.flags & sectCompBit)) | ||||||
| 			newKipSize += hdr.sections[sectIdx].size_decomp; | 			newKipSize += hdr.sections[sectIdx].size_decomp; | ||||||
| 		else | 		else | ||||||
| 			newKipSize += hdr.sections[sectIdx].size_comp; | 			newKipSize += hdr.sections[sectIdx].size_comp; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	pkg2_kip1_t* newKip = malloc(newKipSize);	 | 	pkg2_kip1_t* newKip = malloc(newKipSize); | ||||||
| 	unsigned char* dstDataPtr = newKip->data; | 	unsigned char* dstDataPtr = newKip->data; | ||||||
| 	const unsigned char* srcDataPtr = ki->kip1->data; | 	const unsigned char* srcDataPtr = ki->kip1->data; | ||||||
| 	for (u32 sectIdx = 0; sectIdx < KIP1_NUM_SECTIONS; sectIdx++) | 	for (u32 sectIdx = 0; sectIdx < KIP1_NUM_SECTIONS; sectIdx++) | ||||||
| @@ -121,7 +121,7 @@ int pkg2_decompress_kip(pkg2_kip1_info_t* ki, u32 sectsToDecomp) | |||||||
| 		//gfx_printf("Decomping %s KIP1 sect %d of size %d...\n", (const char*)hdr.name, sectIdx, compSize); | 		//gfx_printf("Decomping %s KIP1 sect %d of size %d...\n", (const char*)hdr.name, sectIdx, compSize); | ||||||
| 		if (blz_uncompress_srcdest(srcDataPtr, compSize, dstDataPtr, outputSize) == 0) | 		if (blz_uncompress_srcdest(srcDataPtr, compSize, dstDataPtr, outputSize) == 0) | ||||||
| 		{ | 		{ | ||||||
| 			gfx_printf("%kERROR decomping sect %d of %s KIP!%k\n", 0xFFFF0000, sectIdx, (char*)hdr.name, 0xFFCCCCCC);			 | 			gfx_printf("%kERROR decomping sect %d of %s KIP!%k\n", 0xFFFF0000, sectIdx, (char*)hdr.name, 0xFFCCCCCC); | ||||||
| 			free(newKip); | 			free(newKip); | ||||||
|  |  | ||||||
| 			return 1; | 			return 1; | ||||||
| @@ -149,7 +149,7 @@ int pkg2_decompress_kip(pkg2_kip1_info_t* ki, u32 sectsToDecomp) | |||||||
| pkg2_hdr_t *pkg2_decrypt(void *data) | pkg2_hdr_t *pkg2_decrypt(void *data) | ||||||
| { | { | ||||||
| 	u8 *pdata = (u8 *)data; | 	u8 *pdata = (u8 *)data; | ||||||
| 	 |  | ||||||
| 	// Skip signature. | 	// Skip signature. | ||||||
| 	pdata += 0x100; | 	pdata += 0x100; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,145 +1,145 @@ | |||||||
| /* | /* | ||||||
|  * Copyright (c) 2019 CTCaer |  * Copyright (c) 2019 CTCaer | ||||||
|  * |  * | ||||||
|  * This program is free software; you can redistribute it and/or modify it |  * This program is free software; you can redistribute it and/or modify it | ||||||
|  * under the terms and conditions of the GNU General Public License, |  * under the terms and conditions of the GNU General Public License, | ||||||
|  * version 2, as published by the Free Software Foundation. |  * version 2, as published by the Free Software Foundation. | ||||||
|  * |  * | ||||||
|  * This program is distributed in the hope it will be useful, but WITHOUT |  * This program is distributed in the hope it will be useful, but WITHOUT | ||||||
|  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | ||||||
|  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for |  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for | ||||||
|  * more details. |  * more details. | ||||||
|  * |  * | ||||||
|  * You should have received a copy of the GNU General Public License |  * You should have received a copy of the GNU General Public License | ||||||
|  * along with this program.  If not, see <http://www.gnu.org/licenses/>. |  * along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| #include <string.h> | #include <string.h> | ||||||
|  |  | ||||||
| #include "sept.h" | #include "sept.h" | ||||||
| #include "../gfx/di.h" | #include "../gfx/di.h" | ||||||
| #include "../libs/fatfs/ff.h" | #include "../libs/fatfs/ff.h" | ||||||
| #include "../mem/heap.h" | #include "../mem/heap.h" | ||||||
| #include "../soc/hw_init.h" | #include "../soc/hw_init.h" | ||||||
| #include "../soc/pmc.h" | #include "../soc/pmc.h" | ||||||
| #include "../soc/t210.h" | #include "../soc/t210.h" | ||||||
| #include "../storage/nx_emmc.h" | #include "../storage/nx_emmc.h" | ||||||
| #include "../storage/sdmmc.h" | #include "../storage/sdmmc.h" | ||||||
| #include "../utils/btn.h" | #include "../utils/btn.h" | ||||||
| #include "../utils/types.h" | #include "../utils/types.h" | ||||||
|  |  | ||||||
| #include "../gfx/gfx.h" | #include "../gfx/gfx.h" | ||||||
|  |  | ||||||
| #define PATCHED_RELOC_SZ 0x94 | #define PATCHED_RELOC_SZ 0x94 | ||||||
|  |  | ||||||
| #define WB_RST_ADDR 0x40010ED0 | #define WB_RST_ADDR 0x40010ED0 | ||||||
| #define WB_RST_SIZE 0x30 | #define WB_RST_SIZE 0x30 | ||||||
|  |  | ||||||
| u8 warmboot_reboot[] = { | u8 warmboot_reboot[] = { | ||||||
| 	0x14, 0x00, 0x9F, 0xE5, // LDR R0, =0x7000E450 | 	0x14, 0x00, 0x9F, 0xE5, // LDR R0, =0x7000E450 | ||||||
| 	0x01, 0x10, 0xB0, 0xE3, // MOVS R1, #1 | 	0x01, 0x10, 0xB0, 0xE3, // MOVS R1, #1 | ||||||
| 	0x00, 0x10, 0x80, 0xE5, // STR R1, [R0] | 	0x00, 0x10, 0x80, 0xE5, // STR R1, [R0] | ||||||
| 	0x0C, 0x00, 0x9F, 0xE5, // LDR R0, =0x7000E400  | 	0x0C, 0x00, 0x9F, 0xE5, // LDR R0, =0x7000E400 | ||||||
| 	0x10, 0x10, 0xB0, 0xE3, // MOVS R1, #0x10 | 	0x10, 0x10, 0xB0, 0xE3, // MOVS R1, #0x10 | ||||||
| 	0x00, 0x10, 0x80, 0xE5, // STR R1, [R0] | 	0x00, 0x10, 0x80, 0xE5, // STR R1, [R0] | ||||||
| 	0xFE, 0xFF, 0xFF, 0xEA, // LOOP | 	0xFE, 0xFF, 0xFF, 0xEA, // LOOP | ||||||
| 	0x50, 0xE4, 0x00, 0x70, // #0x7000E450 | 	0x50, 0xE4, 0x00, 0x70, // #0x7000E450 | ||||||
| 	0x00, 0xE4, 0x00, 0x70  // #0x7000E400 | 	0x00, 0xE4, 0x00, 0x70  // #0x7000E400 | ||||||
| }; | }; | ||||||
|  |  | ||||||
| #define SEPT_PRI_ADDR   0x4003F000 | #define SEPT_PRI_ADDR   0x4003F000 | ||||||
|  |  | ||||||
| #define SEPT_PK1T_ADDR  0xC0400000 | #define SEPT_PK1T_ADDR  0xC0400000 | ||||||
| #define SEPT_PK1T_STACK 0x40008000 | #define SEPT_PK1T_STACK 0x40008000 | ||||||
| #define SEPT_TCSZ_ADDR  (SEPT_PK1T_ADDR - 0x4) | #define SEPT_TCSZ_ADDR  (SEPT_PK1T_ADDR - 0x4) | ||||||
| #define SEPT_STG1_ADDR  (SEPT_PK1T_ADDR + 0x2E100) | #define SEPT_STG1_ADDR  (SEPT_PK1T_ADDR + 0x2E100) | ||||||
| #define SEPT_STG2_ADDR  (SEPT_PK1T_ADDR + 0x60E0) | #define SEPT_STG2_ADDR  (SEPT_PK1T_ADDR + 0x60E0) | ||||||
| #define SEPT_PKG_SZ     (0x2F100 + WB_RST_SIZE) | #define SEPT_PKG_SZ     (0x2F100 + WB_RST_SIZE) | ||||||
|  |  | ||||||
| extern boot_cfg_t b_cfg; | extern boot_cfg_t b_cfg; | ||||||
| extern void sd_unmount(); | extern void sd_unmount(); | ||||||
| extern void reloc_patcher(u32 payload_dst, u32 payload_src, u32 payload_size); | extern void reloc_patcher(u32 payload_dst, u32 payload_src, u32 payload_size); | ||||||
|  |  | ||||||
| int reboot_to_sept(const u8 *tsec_fw, const u32 tsec_size, const u32 kb) | int reboot_to_sept(const u8 *tsec_fw, const u32 tsec_size, const u32 kb) | ||||||
| { | { | ||||||
| 	FIL fp; | 	FIL fp; | ||||||
|  |  | ||||||
| 	// Copy warmboot reboot code and TSEC fw. | 	// Copy warmboot reboot code and TSEC fw. | ||||||
| 	memcpy((u8 *)(SEPT_PK1T_ADDR - WB_RST_SIZE), (u8 *)warmboot_reboot, sizeof(warmboot_reboot)); | 	memcpy((u8 *)(SEPT_PK1T_ADDR - WB_RST_SIZE), (u8 *)warmboot_reboot, sizeof(warmboot_reboot)); | ||||||
| 	memcpy((void *)SEPT_PK1T_ADDR, tsec_fw, tsec_size); | 	memcpy((void *)SEPT_PK1T_ADDR, tsec_fw, tsec_size); | ||||||
| 	*(vu32 *)SEPT_TCSZ_ADDR = tsec_size; | 	*(vu32 *)SEPT_TCSZ_ADDR = tsec_size; | ||||||
|  |  | ||||||
| 	// Copy sept-primary. | 	// Copy sept-primary. | ||||||
| 	if (f_open(&fp, "sd:/sept/sept-primary.bin", FA_READ)) | 	if (f_open(&fp, "sd:/sept/sept-primary.bin", FA_READ)) | ||||||
| 		goto error; | 		goto error; | ||||||
|  |  | ||||||
| 	if (f_read(&fp, (u8 *)SEPT_STG1_ADDR, f_size(&fp), NULL)) | 	if (f_read(&fp, (u8 *)SEPT_STG1_ADDR, f_size(&fp), NULL)) | ||||||
| 	{ | 	{ | ||||||
| 		f_close(&fp); | 		f_close(&fp); | ||||||
| 		goto error; | 		goto error; | ||||||
| 	} | 	} | ||||||
| 	f_close(&fp); | 	f_close(&fp); | ||||||
|  |  | ||||||
| 	// Copy sept-secondary. | 	// Copy sept-secondary. | ||||||
| 	if (kb < KB_FIRMWARE_VERSION_810) | 	if (kb < KB_FIRMWARE_VERSION_810) | ||||||
| 	{ | 	{ | ||||||
| 		if (f_open(&fp, "sd:/sept/sept-secondary_00.enc", FA_READ)) | 		if (f_open(&fp, "sd:/sept/sept-secondary_00.enc", FA_READ)) | ||||||
| 			if (f_open(&fp, "sd:/sept/sept-secondary.enc", FA_READ)) // Try the deprecated version. | 			if (f_open(&fp, "sd:/sept/sept-secondary.enc", FA_READ)) // Try the deprecated version. | ||||||
| 				goto error; | 				goto error; | ||||||
| 	} | 	} | ||||||
| 	else | 	else | ||||||
| 	{ | 	{ | ||||||
| 		if (f_open(&fp, "sd:/sept/sept-secondary_01.enc", FA_READ)) | 		if (f_open(&fp, "sd:/sept/sept-secondary_01.enc", FA_READ)) | ||||||
| 			goto error; | 			goto error; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	if (f_read(&fp, (u8 *)SEPT_STG2_ADDR, f_size(&fp), NULL)) | 	if (f_read(&fp, (u8 *)SEPT_STG2_ADDR, f_size(&fp), NULL)) | ||||||
| 	{ | 	{ | ||||||
| 		f_close(&fp); | 		f_close(&fp); | ||||||
| 		goto error; | 		goto error; | ||||||
| 	} | 	} | ||||||
| 	f_close(&fp); | 	f_close(&fp); | ||||||
|  |  | ||||||
| 	// Save auto boot config to sept payload, if any. | 	// Save auto boot config to sept payload, if any. | ||||||
| 	boot_cfg_t *tmp_cfg = malloc(sizeof(boot_cfg_t)); | 	boot_cfg_t *tmp_cfg = malloc(sizeof(boot_cfg_t)); | ||||||
| 	memcpy(tmp_cfg, &b_cfg, sizeof(boot_cfg_t)); | 	memcpy(tmp_cfg, &b_cfg, sizeof(boot_cfg_t)); | ||||||
|  |  | ||||||
| 	tmp_cfg->boot_cfg |= BOOT_CFG_SEPT_RUN; | 	tmp_cfg->boot_cfg |= BOOT_CFG_SEPT_RUN; | ||||||
|  |  | ||||||
| 	if (f_open(&fp, "sd:/sept/payload.bin", FA_READ | FA_WRITE)) | 	if (f_open(&fp, "sd:/sept/payload.bin", FA_READ | FA_WRITE)) | ||||||
| 		goto error; | 		goto error; | ||||||
|  |  | ||||||
| 	f_lseek(&fp, PATCHED_RELOC_SZ); | 	f_lseek(&fp, PATCHED_RELOC_SZ); | ||||||
| 	f_write(&fp, tmp_cfg, sizeof(boot_cfg_t), NULL); | 	f_write(&fp, tmp_cfg, sizeof(boot_cfg_t), NULL); | ||||||
|  |  | ||||||
| 	f_close(&fp); | 	f_close(&fp); | ||||||
|  |  | ||||||
| 	sd_unmount(); | 	sd_unmount(); | ||||||
| 	gfx_printf("\n%kPress Power or Vol +/-\n%k   to Reboot to Sept...", COLOR_BLUE, COLOR_VIOLET); | 	gfx_printf("\n%kPress Power or Vol +/-\n%k   to Reboot to Sept...", COLOR_BLUE, COLOR_VIOLET); | ||||||
| 	btn_wait(); | 	btn_wait(); | ||||||
|  |  | ||||||
| 	u32 pk1t_sept = SEPT_PK1T_ADDR - (ALIGN(PATCHED_RELOC_SZ, 0x10) + WB_RST_SIZE); | 	u32 pk1t_sept = SEPT_PK1T_ADDR - (ALIGN(PATCHED_RELOC_SZ, 0x10) + WB_RST_SIZE); | ||||||
|  |  | ||||||
| 	void (*sept)() = (void *)pk1t_sept; | 	void (*sept)() = (void *)pk1t_sept; | ||||||
|  |  | ||||||
| 	reloc_patcher(WB_RST_ADDR, pk1t_sept, SEPT_PKG_SZ); | 	reloc_patcher(WB_RST_ADDR, pk1t_sept, SEPT_PKG_SZ); | ||||||
|  |  | ||||||
| 	// Patch SDRAM init to perform an SVC immediately after second write. | 	// Patch SDRAM init to perform an SVC immediately after second write. | ||||||
| 	PMC(APBDEV_PMC_SCRATCH45) = 0x2E38DFFF; | 	PMC(APBDEV_PMC_SCRATCH45) = 0x2E38DFFF; | ||||||
| 	PMC(APBDEV_PMC_SCRATCH46) = 0x6001DC28; | 	PMC(APBDEV_PMC_SCRATCH46) = 0x6001DC28; | ||||||
| 	// Set SVC handler to jump to sept-primary in IRAM. | 	// Set SVC handler to jump to sept-primary in IRAM. | ||||||
| 	PMC(APBDEV_PMC_SCRATCH33) = SEPT_PRI_ADDR; | 	PMC(APBDEV_PMC_SCRATCH33) = SEPT_PRI_ADDR; | ||||||
| 	PMC(APBDEV_PMC_SCRATCH40) = 0x6000F208; | 	PMC(APBDEV_PMC_SCRATCH40) = 0x6000F208; | ||||||
|  |  | ||||||
| 	reconfig_hw_workaround(false, 0); | 	reconfig_hw_workaround(false, 0); | ||||||
|  |  | ||||||
| 	(*sept)(); | 	(*sept)(); | ||||||
|  |  | ||||||
| error: | error: | ||||||
| 	EPRINTF("\nSept files not found in sd:/sept!\nPlace appropriate files and try again."); | 	EPRINTF("\nSept files not found in sd:/sept!\nPlace appropriate files and try again."); | ||||||
| 	display_backlight_brightness(100, 1000); | 	display_backlight_brightness(100, 1000); | ||||||
|  |  | ||||||
| 	btn_wait(); | 	btn_wait(); | ||||||
|  |  | ||||||
| 	return 0; | 	return 0; | ||||||
| } | } | ||||||
| @@ -1,165 +1,165 @@ | |||||||
| /* | /* | ||||||
|  * Copyright (c) 2019 shchmue |  * Copyright (c) 2019 shchmue | ||||||
|  * |  * | ||||||
|  * This program is free software; you can redistribute it and/or modify it |  * This program is free software; you can redistribute it and/or modify it | ||||||
|  * under the terms and conditions of the GNU General Public License, |  * under the terms and conditions of the GNU General Public License, | ||||||
|  * version 2, as published by the Free Software Foundation. |  * version 2, as published by the Free Software Foundation. | ||||||
|  * |  * | ||||||
|  * This program is distributed in the hope it will be useful, but WITHOUT |  * This program is distributed in the hope it will be useful, but WITHOUT | ||||||
|  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | ||||||
|  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for |  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for | ||||||
|  * more details. |  * more details. | ||||||
|  * |  * | ||||||
|  * You should have received a copy of the GNU General Public License |  * You should have received a copy of the GNU General Public License | ||||||
|  * along with this program.  If not, see <http://www.gnu.org/licenses/>. |  * along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| static const u8 zeros[0x10] = {0}; | static const u8 zeros[0x10] = {0}; | ||||||
|  |  | ||||||
| static const u8 keyblob_key_source[][0x10] = { | static const u8 keyblob_key_source[][0x10] = { | ||||||
|     {0xDF, 0x20, 0x6F, 0x59, 0x44, 0x54, 0xEF, 0xDC, 0x70, 0x74, 0x48, 0x3B, 0x0D, 0xED, 0x9F, 0xD3}, //1.0.0 |     {0xDF, 0x20, 0x6F, 0x59, 0x44, 0x54, 0xEF, 0xDC, 0x70, 0x74, 0x48, 0x3B, 0x0D, 0xED, 0x9F, 0xD3}, //1.0.0 | ||||||
|     {0x0C, 0x25, 0x61, 0x5D, 0x68, 0x4C, 0xEB, 0x42, 0x1C, 0x23, 0x79, 0xEA, 0x82, 0x25, 0x12, 0xAC}, //3.0.0 |     {0x0C, 0x25, 0x61, 0x5D, 0x68, 0x4C, 0xEB, 0x42, 0x1C, 0x23, 0x79, 0xEA, 0x82, 0x25, 0x12, 0xAC}, //3.0.0 | ||||||
|     {0x33, 0x76, 0x85, 0xEE, 0x88, 0x4A, 0xAE, 0x0A, 0xC2, 0x8A, 0xFD, 0x7D, 0x63, 0xC0, 0x43, 0x3B}, //3.0.1 |     {0x33, 0x76, 0x85, 0xEE, 0x88, 0x4A, 0xAE, 0x0A, 0xC2, 0x8A, 0xFD, 0x7D, 0x63, 0xC0, 0x43, 0x3B}, //3.0.1 | ||||||
|     {0x2D, 0x1F, 0x48, 0x80, 0xED, 0xEC, 0xED, 0x3E, 0x3C, 0xF2, 0x48, 0xB5, 0x65, 0x7D, 0xF7, 0xBE}, //4.0.0 |     {0x2D, 0x1F, 0x48, 0x80, 0xED, 0xEC, 0xED, 0x3E, 0x3C, 0xF2, 0x48, 0xB5, 0x65, 0x7D, 0xF7, 0xBE}, //4.0.0 | ||||||
|     {0xBB, 0x5A, 0x01, 0xF9, 0x88, 0xAF, 0xF5, 0xFC, 0x6C, 0xFF, 0x07, 0x9E, 0x13, 0x3C, 0x39, 0x80}, //5.0.0 |     {0xBB, 0x5A, 0x01, 0xF9, 0x88, 0xAF, 0xF5, 0xFC, 0x6C, 0xFF, 0x07, 0x9E, 0x13, 0x3C, 0x39, 0x80}, //5.0.0 | ||||||
|     {0xD8, 0xCC, 0xE1, 0x26, 0x6A, 0x35, 0x3F, 0xCC, 0x20, 0xF3, 0x2D, 0x3B, 0x51, 0x7D, 0xE9, 0xC0}  //6.0.0 |     {0xD8, 0xCC, 0xE1, 0x26, 0x6A, 0x35, 0x3F, 0xCC, 0x20, 0xF3, 0x2D, 0x3B, 0x51, 0x7D, 0xE9, 0xC0}  //6.0.0 | ||||||
| }; | }; | ||||||
|  |  | ||||||
| static const u8 master_kek_sources[KB_FIRMWARE_VERSION_MAX - KB_FIRMWARE_VERSION_600][0x10] = { | static const u8 master_kek_sources[KB_FIRMWARE_VERSION_MAX - KB_FIRMWARE_VERSION_600][0x10] = { | ||||||
|     {0x37, 0x4B, 0x77, 0x29, 0x59, 0xB4, 0x04, 0x30, 0x81, 0xF6, 0xE5, 0x8C, 0x6D, 0x36, 0x17, 0x9A}, //6.2.0 |     {0x37, 0x4B, 0x77, 0x29, 0x59, 0xB4, 0x04, 0x30, 0x81, 0xF6, 0xE5, 0x8C, 0x6D, 0x36, 0x17, 0x9A}, //6.2.0 | ||||||
|     {0x9A, 0x3E, 0xA9, 0xAB, 0xFD, 0x56, 0x46, 0x1C, 0x9B, 0xF6, 0x48, 0x7F, 0x5C, 0xFA, 0x09, 0x5C}, //7.0.0 |     {0x9A, 0x3E, 0xA9, 0xAB, 0xFD, 0x56, 0x46, 0x1C, 0x9B, 0xF6, 0x48, 0x7F, 0x5C, 0xFA, 0x09, 0x5C}, //7.0.0 | ||||||
|     {0xDE, 0xDC, 0xE3, 0x39, 0x30, 0x88, 0x16, 0xF8, 0xAE, 0x97, 0xAD, 0xEC, 0x64, 0x2D, 0x41, 0x41}, //8.1.0 |     {0xDE, 0xDC, 0xE3, 0x39, 0x30, 0x88, 0x16, 0xF8, 0xAE, 0x97, 0xAD, 0xEC, 0x64, 0x2D, 0x41, 0x41}, //8.1.0 | ||||||
|     {0x1A, 0xEC, 0x11, 0x82, 0x2B, 0x32, 0x38, 0x7A, 0x2B, 0xED, 0xBA, 0x01, 0x47, 0x7E, 0x3B, 0x67}, //9.0.0 |     {0x1A, 0xEC, 0x11, 0x82, 0x2B, 0x32, 0x38, 0x7A, 0x2B, 0xED, 0xBA, 0x01, 0x47, 0x7E, 0x3B, 0x67}, //9.0.0 | ||||||
| }; | }; | ||||||
|  |  | ||||||
| static const u8 mkey_vectors[KB_FIRMWARE_VERSION_MAX+1][0x10] = | static const u8 mkey_vectors[KB_FIRMWARE_VERSION_MAX+1][0x10] = | ||||||
| { | { | ||||||
|     {0x0C, 0xF0, 0x59, 0xAC, 0x85, 0xF6, 0x26, 0x65, 0xE1, 0xE9, 0x19, 0x55, 0xE6, 0xF2, 0x67, 0x3D}, /* Zeroes encrypted with Master Key 00. */ |     {0x0C, 0xF0, 0x59, 0xAC, 0x85, 0xF6, 0x26, 0x65, 0xE1, 0xE9, 0x19, 0x55, 0xE6, 0xF2, 0x67, 0x3D}, /* Zeroes encrypted with Master Key 00. */ | ||||||
|     {0x29, 0x4C, 0x04, 0xC8, 0xEB, 0x10, 0xED, 0x9D, 0x51, 0x64, 0x97, 0xFB, 0xF3, 0x4D, 0x50, 0xDD}, /* Master key 00 encrypted with Master key 01. */ |     {0x29, 0x4C, 0x04, 0xC8, 0xEB, 0x10, 0xED, 0x9D, 0x51, 0x64, 0x97, 0xFB, 0xF3, 0x4D, 0x50, 0xDD}, /* Master key 00 encrypted with Master key 01. */ | ||||||
|     {0xDE, 0xCF, 0xEB, 0xEB, 0x10, 0xAE, 0x74, 0xD8, 0xAD, 0x7C, 0xF4, 0x9E, 0x62, 0xE0, 0xE8, 0x72}, /* Master key 01 encrypted with Master key 02. */ |     {0xDE, 0xCF, 0xEB, 0xEB, 0x10, 0xAE, 0x74, 0xD8, 0xAD, 0x7C, 0xF4, 0x9E, 0x62, 0xE0, 0xE8, 0x72}, /* Master key 01 encrypted with Master key 02. */ | ||||||
|     {0x0A, 0x0D, 0xDF, 0x34, 0x22, 0x06, 0x6C, 0xA4, 0xE6, 0xB1, 0xEC, 0x71, 0x85, 0xCA, 0x4E, 0x07}, /* Master key 02 encrypted with Master key 03. */ |     {0x0A, 0x0D, 0xDF, 0x34, 0x22, 0x06, 0x6C, 0xA4, 0xE6, 0xB1, 0xEC, 0x71, 0x85, 0xCA, 0x4E, 0x07}, /* Master key 02 encrypted with Master key 03. */ | ||||||
|     {0x6E, 0x7D, 0x2D, 0xC3, 0x0F, 0x59, 0xC8, 0xFA, 0x87, 0xA8, 0x2E, 0xD5, 0x89, 0x5E, 0xF3, 0xE9}, /* Master key 03 encrypted with Master key 04. */ |     {0x6E, 0x7D, 0x2D, 0xC3, 0x0F, 0x59, 0xC8, 0xFA, 0x87, 0xA8, 0x2E, 0xD5, 0x89, 0x5E, 0xF3, 0xE9}, /* Master key 03 encrypted with Master key 04. */ | ||||||
|     {0xEB, 0xF5, 0x6F, 0x83, 0x61, 0x9E, 0xF8, 0xFA, 0xE0, 0x87, 0xD7, 0xA1, 0x4E, 0x25, 0x36, 0xEE}, /* Master key 04 encrypted with Master key 05. */ |     {0xEB, 0xF5, 0x6F, 0x83, 0x61, 0x9E, 0xF8, 0xFA, 0xE0, 0x87, 0xD7, 0xA1, 0x4E, 0x25, 0x36, 0xEE}, /* Master key 04 encrypted with Master key 05. */ | ||||||
|     {0x1E, 0x1E, 0x22, 0xC0, 0x5A, 0x33, 0x3C, 0xB9, 0x0B, 0xA9, 0x03, 0x04, 0xBA, 0xDB, 0x07, 0x57}, /* Master key 05 encrypted with Master key 06. */ |     {0x1E, 0x1E, 0x22, 0xC0, 0x5A, 0x33, 0x3C, 0xB9, 0x0B, 0xA9, 0x03, 0x04, 0xBA, 0xDB, 0x07, 0x57}, /* Master key 05 encrypted with Master key 06. */ | ||||||
|     {0xA4, 0xD4, 0x52, 0x6F, 0xD1, 0xE4, 0x36, 0xAA, 0x9F, 0xCB, 0x61, 0x27, 0x1C, 0x67, 0x65, 0x1F}, /* Master key 06 encrypted with Master key 07. */ |     {0xA4, 0xD4, 0x52, 0x6F, 0xD1, 0xE4, 0x36, 0xAA, 0x9F, 0xCB, 0x61, 0x27, 0x1C, 0x67, 0x65, 0x1F}, /* Master key 06 encrypted with Master key 07. */ | ||||||
|     {0xEA, 0x60, 0xB3, 0xEA, 0xCE, 0x8F, 0x24, 0x46, 0x7D, 0x33, 0x9C, 0xD1, 0xBC, 0x24, 0x98, 0x29}, /* Master key 07 encrypted with Master key 08. */ |     {0xEA, 0x60, 0xB3, 0xEA, 0xCE, 0x8F, 0x24, 0x46, 0x7D, 0x33, 0x9C, 0xD1, 0xBC, 0x24, 0x98, 0x29}, /* Master key 07 encrypted with Master key 08. */ | ||||||
|     {0x4D, 0xD9, 0x98, 0x42, 0x45, 0x0D, 0xB1, 0x3C, 0x52, 0x0C, 0x9A, 0x44, 0xBB, 0xAD, 0xAF, 0x80}, /* Master key 08 encrypted with Master key 09. */ |     {0x4D, 0xD9, 0x98, 0x42, 0x45, 0x0D, 0xB1, 0x3C, 0x52, 0x0C, 0x9A, 0x44, 0xBB, 0xAD, 0xAF, 0x80}, /* Master key 08 encrypted with Master key 09. */ | ||||||
| }; | }; | ||||||
|  |  | ||||||
| //======================================Keys======================================// | //======================================Keys======================================// | ||||||
| // from Package1 -> Secure_Monitor | // from Package1 -> Secure_Monitor | ||||||
| static const u8 aes_kek_generation_source[0x10] = { | static const u8 aes_kek_generation_source[0x10] = { | ||||||
|     0x4D, 0x87, 0x09, 0x86, 0xC4, 0x5D, 0x20, 0x72, 0x2F, 0xBA, 0x10, 0x53, 0xDA, 0x92, 0xE8, 0xA9}; |     0x4D, 0x87, 0x09, 0x86, 0xC4, 0x5D, 0x20, 0x72, 0x2F, 0xBA, 0x10, 0x53, 0xDA, 0x92, 0xE8, 0xA9}; | ||||||
| static const u8 aes_kek_seed_01[0x10] = { | static const u8 aes_kek_seed_01[0x10] = { | ||||||
|     0xA2, 0xAB, 0xBF, 0x9C, 0x92, 0x2F, 0xBB, 0xE3, 0x78, 0x79, 0x9B, 0xC0, 0xCC, 0xEA, 0xA5, 0x74}; |     0xA2, 0xAB, 0xBF, 0x9C, 0x92, 0x2F, 0xBB, 0xE3, 0x78, 0x79, 0x9B, 0xC0, 0xCC, 0xEA, 0xA5, 0x74}; | ||||||
| static const u8 aes_kek_seed_03[0x10] = { | static const u8 aes_kek_seed_03[0x10] = { | ||||||
|     0xE5, 0x4D, 0x9A, 0x02, 0xF0, 0x4F, 0x5F, 0xA8, 0xAD, 0x76, 0x0A, 0xF6, 0x32, 0x95, 0x59, 0xBB}; |     0xE5, 0x4D, 0x9A, 0x02, 0xF0, 0x4F, 0x5F, 0xA8, 0xAD, 0x76, 0x0A, 0xF6, 0x32, 0x95, 0x59, 0xBB}; | ||||||
| static const u8 package2_key_source[0x10] = { | static const u8 package2_key_source[0x10] = { | ||||||
|     0xFB, 0x8B, 0x6A, 0x9C, 0x79, 0x00, 0xC8, 0x49, 0xEF, 0xD2, 0x4D, 0x85, 0x4D, 0x30, 0xA0, 0xC7}; |     0xFB, 0x8B, 0x6A, 0x9C, 0x79, 0x00, 0xC8, 0x49, 0xEF, 0xD2, 0x4D, 0x85, 0x4D, 0x30, 0xA0, 0xC7}; | ||||||
| static const u8 titlekek_source[0x10] = { | static const u8 titlekek_source[0x10] = { | ||||||
|     0x1E, 0xDC, 0x7B, 0x3B, 0x60, 0xE6, 0xB4, 0xD8, 0x78, 0xB8, 0x17, 0x15, 0x98, 0x5E, 0x62, 0x9B}; |     0x1E, 0xDC, 0x7B, 0x3B, 0x60, 0xE6, 0xB4, 0xD8, 0x78, 0xB8, 0x17, 0x15, 0x98, 0x5E, 0x62, 0x9B}; | ||||||
| static const u8 retail_specific_aes_key_source[0x10] = { | static const u8 retail_specific_aes_key_source[0x10] = { | ||||||
|     0xE2, 0xD6, 0xB8, 0x7A, 0x11, 0x9C, 0xB8, 0x80, 0xE8, 0x22, 0x88, 0x8A, 0x46, 0xFB, 0xA1, 0x95}; |     0xE2, 0xD6, 0xB8, 0x7A, 0x11, 0x9C, 0xB8, 0x80, 0xE8, 0x22, 0x88, 0x8A, 0x46, 0xFB, 0xA1, 0x95}; | ||||||
|  |  | ||||||
| // from Package1ldr (or Secure_Monitor on 6.2.0) | // from Package1ldr (or Secure_Monitor on 6.2.0) | ||||||
| static const u8 keyblob_mac_key_source[0x10] = { | static const u8 keyblob_mac_key_source[0x10] = { | ||||||
|     0x59, 0xC7, 0xFB, 0x6F, 0xBE, 0x9B, 0xBE, 0x87, 0x65, 0x6B, 0x15, 0xC0, 0x53, 0x73, 0x36, 0xA5}; |     0x59, 0xC7, 0xFB, 0x6F, 0xBE, 0x9B, 0xBE, 0x87, 0x65, 0x6B, 0x15, 0xC0, 0x53, 0x73, 0x36, 0xA5}; | ||||||
| static const u8 master_key_source[0x10] = { | static const u8 master_key_source[0x10] = { | ||||||
|     0xD8, 0xA2, 0x41, 0x0A, 0xC6, 0xC5, 0x90, 0x01, 0xC6, 0x1D, 0x6A, 0x26, 0x7C, 0x51, 0x3F, 0x3C}; |     0xD8, 0xA2, 0x41, 0x0A, 0xC6, 0xC5, 0x90, 0x01, 0xC6, 0x1D, 0x6A, 0x26, 0x7C, 0x51, 0x3F, 0x3C}; | ||||||
| static const u8 per_console_key_source[0x10] = { | static const u8 per_console_key_source[0x10] = { | ||||||
|     0x4F, 0x02, 0x5F, 0x0E, 0xB6, 0x6D, 0x11, 0x0E, 0xDC, 0x32, 0x7D, 0x41, 0x86, 0xC2, 0xF4, 0x78}; |     0x4F, 0x02, 0x5F, 0x0E, 0xB6, 0x6D, 0x11, 0x0E, 0xDC, 0x32, 0x7D, 0x41, 0x86, 0xC2, 0xF4, 0x78}; | ||||||
| static const u8 per_console_key_source_4x[0x10] = { | static const u8 per_console_key_source_4x[0x10] = { | ||||||
|     0x0C, 0x91, 0x09, 0xDB, 0x93, 0x93, 0x07, 0x81, 0x07, 0x3C, 0xC4, 0x16, 0x22, 0x7C, 0x6C, 0x28}; |     0x0C, 0x91, 0x09, 0xDB, 0x93, 0x93, 0x07, 0x81, 0x07, 0x3C, 0xC4, 0x16, 0x22, 0x7C, 0x6C, 0x28}; | ||||||
|  |  | ||||||
| static const u8 new_device_key_sources[KB_FIRMWARE_VERSION_MAX - KB_FIRMWARE_VERSION_400 + 1][0x10] = { | static const u8 new_device_key_sources[KB_FIRMWARE_VERSION_MAX - KB_FIRMWARE_VERSION_400 + 1][0x10] = { | ||||||
|     {0x8B, 0x4E, 0x1C, 0x22, 0x42, 0x07, 0xC8, 0x73, 0x56, 0x94, 0x08, 0x8B, 0xCC, 0x47, 0x0F, 0x5D}, /* 4.x   New Device Key Source. */ |     {0x8B, 0x4E, 0x1C, 0x22, 0x42, 0x07, 0xC8, 0x73, 0x56, 0x94, 0x08, 0x8B, 0xCC, 0x47, 0x0F, 0x5D}, /* 4.x   New Device Key Source. */ | ||||||
|     {0x6C, 0xEF, 0xC6, 0x27, 0x8B, 0xEC, 0x8A, 0x91, 0x99, 0xAB, 0x24, 0xAC, 0x4F, 0x1C, 0x8F, 0x1C}, /* 5.x   New Device Key Source. */ |     {0x6C, 0xEF, 0xC6, 0x27, 0x8B, 0xEC, 0x8A, 0x91, 0x99, 0xAB, 0x24, 0xAC, 0x4F, 0x1C, 0x8F, 0x1C}, /* 5.x   New Device Key Source. */ | ||||||
|     {0x70, 0x08, 0x1B, 0x97, 0x44, 0x64, 0xF8, 0x91, 0x54, 0x9D, 0xC6, 0x84, 0x8F, 0x1A, 0xB2, 0xE4}, /* 6.x   New Device Key Source. */ |     {0x70, 0x08, 0x1B, 0x97, 0x44, 0x64, 0xF8, 0x91, 0x54, 0x9D, 0xC6, 0x84, 0x8F, 0x1A, 0xB2, 0xE4}, /* 6.x   New Device Key Source. */ | ||||||
|     {0x8E, 0x09, 0x1F, 0x7A, 0xBB, 0xCA, 0x6A, 0xFB, 0xB8, 0x9B, 0xD5, 0xC1, 0x25, 0x9C, 0xA9, 0x17}, /* 6.2.0 New Device Key Source. */ |     {0x8E, 0x09, 0x1F, 0x7A, 0xBB, 0xCA, 0x6A, 0xFB, 0xB8, 0x9B, 0xD5, 0xC1, 0x25, 0x9C, 0xA9, 0x17}, /* 6.2.0 New Device Key Source. */ | ||||||
|     {0x8F, 0x77, 0x5A, 0x96, 0xB0, 0x94, 0xFD, 0x8D, 0x28, 0xE4, 0x19, 0xC8, 0x16, 0x1C, 0xDB, 0x3D}, /* 7.0.0 New Device Key Source. */ |     {0x8F, 0x77, 0x5A, 0x96, 0xB0, 0x94, 0xFD, 0x8D, 0x28, 0xE4, 0x19, 0xC8, 0x16, 0x1C, 0xDB, 0x3D}, /* 7.0.0 New Device Key Source. */ | ||||||
|     {0x67, 0x62, 0xD4, 0x8E, 0x55, 0xCF, 0xFF, 0x41, 0x31, 0x15, 0x3B, 0x24, 0x0C, 0x7C, 0x07, 0xAE}, /* 8.1.0 New Device Key Source. */ |     {0x67, 0x62, 0xD4, 0x8E, 0x55, 0xCF, 0xFF, 0x41, 0x31, 0x15, 0x3B, 0x24, 0x0C, 0x7C, 0x07, 0xAE}, /* 8.1.0 New Device Key Source. */ | ||||||
|     {0x4A, 0xC3, 0x4E, 0x14, 0x8B, 0x96, 0x4A, 0xD5, 0xD4, 0x99, 0x73, 0xC4, 0x45, 0xAB, 0x8B, 0x49}, /* 9.0.0 New Device Key Source. */ |     {0x4A, 0xC3, 0x4E, 0x14, 0x8B, 0x96, 0x4A, 0xD5, 0xD4, 0x99, 0x73, 0xC4, 0x45, 0xAB, 0x8B, 0x49}, /* 9.0.0 New Device Key Source. */ | ||||||
| }; | }; | ||||||
|  |  | ||||||
| static const u8 new_device_keygen_sources[KB_FIRMWARE_VERSION_MAX - KB_FIRMWARE_VERSION_400 + 1][0x10] = { | static const u8 new_device_keygen_sources[KB_FIRMWARE_VERSION_MAX - KB_FIRMWARE_VERSION_400 + 1][0x10] = { | ||||||
|     {0x88, 0x62, 0x34, 0x6E, 0xFA, 0xF7, 0xD8, 0x3F, 0xE1, 0x30, 0x39, 0x50, 0xF0, 0xB7, 0x5D, 0x5D}, /* 4.x   New Device Keygen Source. */ |     {0x88, 0x62, 0x34, 0x6E, 0xFA, 0xF7, 0xD8, 0x3F, 0xE1, 0x30, 0x39, 0x50, 0xF0, 0xB7, 0x5D, 0x5D}, /* 4.x   New Device Keygen Source. */ | ||||||
|     {0x06, 0x1E, 0x7B, 0xE9, 0x6D, 0x47, 0x8C, 0x77, 0xC5, 0xC8, 0xE7, 0x94, 0x9A, 0xA8, 0x5F, 0x2E}, /* 5.x   New Device Keygen Source. */ |     {0x06, 0x1E, 0x7B, 0xE9, 0x6D, 0x47, 0x8C, 0x77, 0xC5, 0xC8, 0xE7, 0x94, 0x9A, 0xA8, 0x5F, 0x2E}, /* 5.x   New Device Keygen Source. */ | ||||||
|     {0x99, 0xFA, 0x98, 0xBD, 0x15, 0x1C, 0x72, 0xFD, 0x7D, 0x9A, 0xD5, 0x41, 0x00, 0xFD, 0xB2, 0xEF}, /* 6.x   New Device Keygen Source. */ |     {0x99, 0xFA, 0x98, 0xBD, 0x15, 0x1C, 0x72, 0xFD, 0x7D, 0x9A, 0xD5, 0x41, 0x00, 0xFD, 0xB2, 0xEF}, /* 6.x   New Device Keygen Source. */ | ||||||
|     {0x81, 0x3C, 0x6C, 0xBF, 0x5D, 0x21, 0xDE, 0x77, 0x20, 0xD9, 0x6C, 0xE3, 0x22, 0x06, 0xAE, 0xBB}, /* 6.2.0 New Device Keygen Source. */ |     {0x81, 0x3C, 0x6C, 0xBF, 0x5D, 0x21, 0xDE, 0x77, 0x20, 0xD9, 0x6C, 0xE3, 0x22, 0x06, 0xAE, 0xBB}, /* 6.2.0 New Device Keygen Source. */ | ||||||
|     {0x86, 0x61, 0xB0, 0x16, 0xFA, 0x7A, 0x9A, 0xEA, 0xF6, 0xF5, 0xBE, 0x1A, 0x13, 0x5B, 0x6D, 0x9E}, /* 7.0.0 New Device Keygen Source. */ |     {0x86, 0x61, 0xB0, 0x16, 0xFA, 0x7A, 0x9A, 0xEA, 0xF6, 0xF5, 0xBE, 0x1A, 0x13, 0x5B, 0x6D, 0x9E}, /* 7.0.0 New Device Keygen Source. */ | ||||||
|     {0xA6, 0x81, 0x71, 0xE7, 0xB5, 0x23, 0x74, 0xB0, 0x39, 0x8C, 0xB7, 0xFF, 0xA0, 0x62, 0x9F, 0x8D}, /* 8.1.0 New Device Keygen Source. */ |     {0xA6, 0x81, 0x71, 0xE7, 0xB5, 0x23, 0x74, 0xB0, 0x39, 0x8C, 0xB7, 0xFF, 0xA0, 0x62, 0x9F, 0x8D}, /* 8.1.0 New Device Keygen Source. */ | ||||||
|     {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /* TODO: 9.0.0 New Device Keygen Source to be added on next change-of-keys. */ |     {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}, /* TODO: 9.0.0 New Device Keygen Source to be added on next change-of-keys. */ | ||||||
| }; | }; | ||||||
|  |  | ||||||
| // from SPL | // from SPL | ||||||
| static const u8 aes_key_generation_source[0x10] = { | static const u8 aes_key_generation_source[0x10] = { | ||||||
|     0x89, 0x61, 0x5E, 0xE0, 0x5C, 0x31, 0xB6, 0x80, 0x5F, 0xE5, 0x8F, 0x3D, 0xA2, 0x4F, 0x7A, 0xA8}; |     0x89, 0x61, 0x5E, 0xE0, 0x5C, 0x31, 0xB6, 0x80, 0x5F, 0xE5, 0x8F, 0x3D, 0xA2, 0x4F, 0x7A, 0xA8}; | ||||||
|  |  | ||||||
| // from FS | // from FS | ||||||
| static const u8 bis_kek_source[0x10] = { | static const u8 bis_kek_source[0x10] = { | ||||||
|     0x34, 0xC1, 0xA0, 0xC4, 0x82, 0x58, 0xF8, 0xB4, 0xFA, 0x9E, 0x5E, 0x6A, 0xDA, 0xFC, 0x7E, 0x4F}; |     0x34, 0xC1, 0xA0, 0xC4, 0x82, 0x58, 0xF8, 0xB4, 0xFA, 0x9E, 0x5E, 0x6A, 0xDA, 0xFC, 0x7E, 0x4F}; | ||||||
| static const u8 bis_key_source[3][0x20] = { | static const u8 bis_key_source[3][0x20] = { | ||||||
|     { |     { | ||||||
|         0xF8, 0x3F, 0x38, 0x6E, 0x2C, 0xD2, 0xCA, 0x32, 0xA8, 0x9A, 0xB9, 0xAA, 0x29, 0xBF, 0xC7, 0x48, |         0xF8, 0x3F, 0x38, 0x6E, 0x2C, 0xD2, 0xCA, 0x32, 0xA8, 0x9A, 0xB9, 0xAA, 0x29, 0xBF, 0xC7, 0x48, | ||||||
|         0x7D, 0x92, 0xB0, 0x3A, 0xA8, 0xBF, 0xDE, 0xE1, 0xA7, 0x4C, 0x3B, 0x6E, 0x35, 0xCB, 0x71, 0x06}, |         0x7D, 0x92, 0xB0, 0x3A, 0xA8, 0xBF, 0xDE, 0xE1, 0xA7, 0x4C, 0x3B, 0x6E, 0x35, 0xCB, 0x71, 0x06}, | ||||||
|     { |     { | ||||||
|         0x41, 0x00, 0x30, 0x49, 0xDD, 0xCC, 0xC0, 0x65, 0x64, 0x7A, 0x7E, 0xB4, 0x1E, 0xED, 0x9C, 0x5F, |         0x41, 0x00, 0x30, 0x49, 0xDD, 0xCC, 0xC0, 0x65, 0x64, 0x7A, 0x7E, 0xB4, 0x1E, 0xED, 0x9C, 0x5F, | ||||||
|         0x44, 0x42, 0x4E, 0xDA, 0xB4, 0x9D, 0xFC, 0xD9, 0x87, 0x77, 0x24, 0x9A, 0xDC, 0x9F, 0x7C, 0xA4}, |         0x44, 0x42, 0x4E, 0xDA, 0xB4, 0x9D, 0xFC, 0xD9, 0x87, 0x77, 0x24, 0x9A, 0xDC, 0x9F, 0x7C, 0xA4}, | ||||||
|     { |     { | ||||||
|         0x52, 0xC2, 0xE9, 0xEB, 0x09, 0xE3, 0xEE, 0x29, 0x32, 0xA1, 0x0C, 0x1F, 0xB6, 0xA0, 0x92, 0x6C, |         0x52, 0xC2, 0xE9, 0xEB, 0x09, 0xE3, 0xEE, 0x29, 0x32, 0xA1, 0x0C, 0x1F, 0xB6, 0xA0, 0x92, 0x6C, | ||||||
|         0x4D, 0x12, 0xE1, 0x4B, 0x2A, 0x47, 0x4C, 0x1C, 0x09, 0xCB, 0x03, 0x59, 0xF0, 0x15, 0xF4, 0xE4} |         0x4D, 0x12, 0xE1, 0x4B, 0x2A, 0x47, 0x4C, 0x1C, 0x09, 0xCB, 0x03, 0x59, 0xF0, 0x15, 0xF4, 0xE4} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| static const u8 fs_hashes_sha256[10][0x20] = { | static const u8 fs_hashes_sha256[10][0x20] = { | ||||||
|     { // header_kek_source |     { // header_kek_source | ||||||
|         0x18, 0x88, 0xca, 0xed, 0x55, 0x51, 0xb3, 0xed, 0xe0, 0x14, 0x99, 0xe8, 0x7c, 0xe0, 0xd8, 0x68, |         0x18, 0x88, 0xca, 0xed, 0x55, 0x51, 0xb3, 0xed, 0xe0, 0x14, 0x99, 0xe8, 0x7c, 0xe0, 0xd8, 0x68, | ||||||
|         0x27, 0xf8, 0x08, 0x20, 0xef, 0xb2, 0x75, 0x92, 0x10, 0x55, 0xaa, 0x4e, 0x2a, 0xbd, 0xff, 0xc2}, |         0x27, 0xf8, 0x08, 0x20, 0xef, 0xb2, 0x75, 0x92, 0x10, 0x55, 0xaa, 0x4e, 0x2a, 0xbd, 0xff, 0xc2}, | ||||||
|     { // header_key_source |     { // header_key_source | ||||||
|         0x8f, 0x78, 0x3e, 0x46, 0x85, 0x2d, 0xf6, 0xbe, 0x0b, 0xa4, 0xe1, 0x92, 0x73, 0xc4, 0xad, 0xba, |         0x8f, 0x78, 0x3e, 0x46, 0x85, 0x2d, 0xf6, 0xbe, 0x0b, 0xa4, 0xe1, 0x92, 0x73, 0xc4, 0xad, 0xba, | ||||||
|         0xee, 0x16, 0x38, 0x00, 0x43, 0xe1, 0xb8, 0xc4, 0x18, 0xc4, 0x08, 0x9a, 0x8b, 0xd6, 0x4a, 0xa6}, |         0xee, 0x16, 0x38, 0x00, 0x43, 0xe1, 0xb8, 0xc4, 0x18, 0xc4, 0x08, 0x9a, 0x8b, 0xd6, 0x4a, 0xa6}, | ||||||
|     { // key_area_key_application_source |     { // key_area_key_application_source | ||||||
|         0x04, 0xad, 0x66, 0x14, 0x3c, 0x72, 0x6b, 0x2a, 0x13, 0x9f, 0xb6, 0xb2, 0x11, 0x28, 0xb4, 0x6f, |         0x04, 0xad, 0x66, 0x14, 0x3c, 0x72, 0x6b, 0x2a, 0x13, 0x9f, 0xb6, 0xb2, 0x11, 0x28, 0xb4, 0x6f, | ||||||
|         0x56, 0xc5, 0x53, 0xb2, 0xb3, 0x88, 0x71, 0x10, 0x30, 0x42, 0x98, 0xd8, 0xd0, 0x09, 0x2d, 0x9e}, |         0x56, 0xc5, 0x53, 0xb2, 0xb3, 0x88, 0x71, 0x10, 0x30, 0x42, 0x98, 0xd8, 0xd0, 0x09, 0x2d, 0x9e}, | ||||||
|     { // key_area_key_ocean_source |     { // key_area_key_ocean_source | ||||||
|         0xfd, 0x43, 0x40, 0x00, 0xc8, 0xff, 0x2b, 0x26, 0xf8, 0xe9, 0xa9, 0xd2, 0xd2, 0xc1, 0x2f, 0x6b, |         0xfd, 0x43, 0x40, 0x00, 0xc8, 0xff, 0x2b, 0x26, 0xf8, 0xe9, 0xa9, 0xd2, 0xd2, 0xc1, 0x2f, 0x6b, | ||||||
|         0xe5, 0x77, 0x3c, 0xbb, 0x9d, 0xc8, 0x63, 0x00, 0xe1, 0xbd, 0x99, 0xf8, 0xea, 0x33, 0xa4, 0x17}, |         0xe5, 0x77, 0x3c, 0xbb, 0x9d, 0xc8, 0x63, 0x00, 0xe1, 0xbd, 0x99, 0xf8, 0xea, 0x33, 0xa4, 0x17}, | ||||||
|     { // key_area_key_system_source |     { // key_area_key_system_source | ||||||
|         0x1f, 0x17, 0xb1, 0xfd, 0x51, 0xad, 0x1c, 0x23, 0x79, 0xb5, 0x8f, 0x15, 0x2c, 0xa4, 0x91, 0x2e, |         0x1f, 0x17, 0xb1, 0xfd, 0x51, 0xad, 0x1c, 0x23, 0x79, 0xb5, 0x8f, 0x15, 0x2c, 0xa4, 0x91, 0x2e, | ||||||
|         0xc2, 0x10, 0x64, 0x41, 0xe5, 0x17, 0x22, 0xf3, 0x87, 0x00, 0xd5, 0x93, 0x7a, 0x11, 0x62, 0xf7}, |         0xc2, 0x10, 0x64, 0x41, 0xe5, 0x17, 0x22, 0xf3, 0x87, 0x00, 0xd5, 0x93, 0x7a, 0x11, 0x62, 0xf7}, | ||||||
|     { // save_mac_kek_source |     { // save_mac_kek_source | ||||||
|         0x3D, 0xCB, 0xA1, 0x00, 0xAD, 0x4D, 0xF1, 0x54, 0x7F, 0xE3, 0xC4, 0x79, 0x5C, 0x4B, 0x22, 0x8A, |         0x3D, 0xCB, 0xA1, 0x00, 0xAD, 0x4D, 0xF1, 0x54, 0x7F, 0xE3, 0xC4, 0x79, 0x5C, 0x4B, 0x22, 0x8A, | ||||||
|         0xA9, 0x80, 0x38, 0xF0, 0x7A, 0x36, 0xF1, 0xBC, 0x14, 0x8E, 0xEA, 0xF3, 0xDC, 0xD7, 0x50, 0xF4}, |         0xA9, 0x80, 0x38, 0xF0, 0x7A, 0x36, 0xF1, 0xBC, 0x14, 0x8E, 0xEA, 0xF3, 0xDC, 0xD7, 0x50, 0xF4}, | ||||||
|     { // save_mac_key_source |     { // save_mac_key_source | ||||||
|         0xB4, 0x7B, 0x60, 0x0B, 0x1A, 0xD3, 0x14, 0xF9, 0x41, 0x14, 0x7D, 0x8B, 0x39, 0x1D, 0x4B, 0x19, |         0xB4, 0x7B, 0x60, 0x0B, 0x1A, 0xD3, 0x14, 0xF9, 0x41, 0x14, 0x7D, 0x8B, 0x39, 0x1D, 0x4B, 0x19, | ||||||
|         0x87, 0xCC, 0x8C, 0x88, 0x4A, 0xC8, 0x9F, 0xFC, 0x91, 0xCA, 0xE2, 0x21, 0xC5, 0x24, 0x51, 0xF7}, |         0x87, 0xCC, 0x8C, 0x88, 0x4A, 0xC8, 0x9F, 0xFC, 0x91, 0xCA, 0xE2, 0x21, 0xC5, 0x24, 0x51, 0xF7}, | ||||||
|     { // sd_card_kek_source |     { // sd_card_kek_source | ||||||
|         0x6B, 0x2E, 0xD8, 0x77, 0xC2, 0xC5, 0x23, 0x34, 0xAC, 0x51, 0xE5, 0x9A, 0xBF, 0xA7, 0xEC, 0x45, |         0x6B, 0x2E, 0xD8, 0x77, 0xC2, 0xC5, 0x23, 0x34, 0xAC, 0x51, 0xE5, 0x9A, 0xBF, 0xA7, 0xEC, 0x45, | ||||||
|         0x7F, 0x4A, 0x7D, 0x01, 0xE4, 0x62, 0x91, 0xE9, 0xF2, 0xEA, 0xA4, 0x5F, 0x01, 0x1D, 0x24, 0xB7}, |         0x7F, 0x4A, 0x7D, 0x01, 0xE4, 0x62, 0x91, 0xE9, 0xF2, 0xEA, 0xA4, 0x5F, 0x01, 0x1D, 0x24, 0xB7}, | ||||||
|     { // sd_card_nca_key_source |     { // sd_card_nca_key_source | ||||||
|         0x2E, 0x75, 0x1C, 0xEC, 0xF7, 0xD9, 0x3A, 0x2B, 0x95, 0x7B, 0xD5, 0xFF, 0xCB, 0x08, 0x2F, 0xD0, |         0x2E, 0x75, 0x1C, 0xEC, 0xF7, 0xD9, 0x3A, 0x2B, 0x95, 0x7B, 0xD5, 0xFF, 0xCB, 0x08, 0x2F, 0xD0, | ||||||
|         0x38, 0xCC, 0x28, 0x53, 0x21, 0x9D, 0xD3, 0x09, 0x2C, 0x6D, 0xAB, 0x98, 0x38, 0xF5, 0xA7, 0xCC}, |         0x38, 0xCC, 0x28, 0x53, 0x21, 0x9D, 0xD3, 0x09, 0x2C, 0x6D, 0xAB, 0x98, 0x38, 0xF5, 0xA7, 0xCC}, | ||||||
|     { // sd_card_save_key_source |     { // sd_card_save_key_source | ||||||
|         0xD4, 0x82, 0x74, 0x35, 0x63, 0xD3, 0xEA, 0x5D, 0xCD, 0xC3, 0xB7, 0x4E, 0x97, 0xC9, 0xAC, 0x8A, |         0xD4, 0x82, 0x74, 0x35, 0x63, 0xD3, 0xEA, 0x5D, 0xCD, 0xC3, 0xB7, 0x4E, 0x97, 0xC9, 0xAC, 0x8A, | ||||||
|         0x34, 0x21, 0x64, 0xFA, 0x04, 0x1A, 0x1D, 0xC8, 0x0F, 0x17, 0xF6, 0xD3, 0x1E, 0x4B, 0xC0, 0x1C} |         0x34, 0x21, 0x64, 0xFA, 0x04, 0x1A, 0x1D, 0xC8, 0x0F, 0x17, 0xF6, 0xD3, 0x1E, 0x4B, 0xC0, 0x1C} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| static const u8 es_hashes_sha256[3][0x20] = { | static const u8 es_hashes_sha256[3][0x20] = { | ||||||
|     { // eticket_rsa_kek |     { // eticket_rsa_kek | ||||||
|         0xB7, 0x1D, 0xB2, 0x71, 0xDC, 0x33, 0x8D, 0xF3, 0x80, 0xAA, 0x2C, 0x43, 0x35, 0xEF, 0x88, 0x73, |         0xB7, 0x1D, 0xB2, 0x71, 0xDC, 0x33, 0x8D, 0xF3, 0x80, 0xAA, 0x2C, 0x43, 0x35, 0xEF, 0x88, 0x73, | ||||||
|         0xB1, 0xAF, 0xD4, 0x08, 0xE8, 0x0B, 0x35, 0x82, 0xD8, 0x71, 0x9F, 0xC8, 0x1C, 0x5E, 0x51, 0x1C}, |         0xB1, 0xAF, 0xD4, 0x08, 0xE8, 0x0B, 0x35, 0x82, 0xD8, 0x71, 0x9F, 0xC8, 0x1C, 0x5E, 0x51, 0x1C}, | ||||||
|     { // eticket_rsa_kekek |     { // eticket_rsa_kekek | ||||||
|         0xE8, 0x96, 0x5A, 0x18, 0x7D, 0x30, 0xE5, 0x78, 0x69, 0xF5, 0x62, 0xD0, 0x43, 0x83, 0xC9, 0x96, |         0xE8, 0x96, 0x5A, 0x18, 0x7D, 0x30, 0xE5, 0x78, 0x69, 0xF5, 0x62, 0xD0, 0x43, 0x83, 0xC9, 0x96, | ||||||
|         0xDE, 0x48, 0x7B, 0xBA, 0x57, 0x61, 0x36, 0x3D, 0x2D, 0x4D, 0x32, 0x39, 0x18, 0x66, 0xA8, 0x5C}, |         0xDE, 0x48, 0x7B, 0xBA, 0x57, 0x61, 0x36, 0x3D, 0x2D, 0x4D, 0x32, 0x39, 0x18, 0x66, 0xA8, 0x5C}, | ||||||
|     { // ssl_rsa_kek_source_x |     { // ssl_rsa_kek_source_x | ||||||
|         0x69, 0xA0, 0x8E, 0x62, 0xE0, 0xAE, 0x50, 0x7B, 0xB5, 0xDA, 0x0E, 0x65, 0x17, 0x9A, 0xE3, 0xBE, |         0x69, 0xA0, 0x8E, 0x62, 0xE0, 0xAE, 0x50, 0x7B, 0xB5, 0xDA, 0x0E, 0x65, 0x17, 0x9A, 0xE3, 0xBE, | ||||||
|         0x05, 0x1F, 0xED, 0x3C, 0x49, 0x94, 0x1D, 0xF4, 0xEF, 0x29, 0x56, 0xD3, 0x6D, 0x30, 0x11, 0x0C} |         0x05, 0x1F, 0xED, 0x3C, 0x49, 0x94, 0x1D, 0xF4, 0xEF, 0x29, 0x56, 0xD3, 0x6D, 0x30, 0x11, 0x0C} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| static const u8 ssl_hashes_sha256[2][0x20] = { | static const u8 ssl_hashes_sha256[2][0x20] = { | ||||||
|     { // ssl_rsa_kek_source_x |     { // ssl_rsa_kek_source_x | ||||||
|         0x69, 0xA0, 0x8E, 0x62, 0xE0, 0xAE, 0x50, 0x7B, 0xB5, 0xDA, 0x0E, 0x65, 0x17, 0x9A, 0xE3, 0xBE, |         0x69, 0xA0, 0x8E, 0x62, 0xE0, 0xAE, 0x50, 0x7B, 0xB5, 0xDA, 0x0E, 0x65, 0x17, 0x9A, 0xE3, 0xBE, | ||||||
|         0x05, 0x1F, 0xED, 0x3C, 0x49, 0x94, 0x1D, 0xF4, 0xEF, 0x29, 0x56, 0xD3, 0x6D, 0x30, 0x11, 0x0C}, |         0x05, 0x1F, 0xED, 0x3C, 0x49, 0x94, 0x1D, 0xF4, 0xEF, 0x29, 0x56, 0xD3, 0x6D, 0x30, 0x11, 0x0C}, | ||||||
|     { // ssl_rsa_kek_source_y |     { // ssl_rsa_kek_source_y | ||||||
|         0x1C, 0x86, 0xF3, 0x63, 0x26, 0x54, 0x17, 0xD4, 0x99, 0x22, 0x9E, 0xB1, 0xC4, 0xAD, 0xC7, 0x47, |         0x1C, 0x86, 0xF3, 0x63, 0x26, 0x54, 0x17, 0xD4, 0x99, 0x22, 0x9E, 0xB1, 0xC4, 0xAD, 0xC7, 0x47, | ||||||
|         0x9B, 0x2A, 0x15, 0xF9, 0x31, 0x26, 0x1F, 0x31, 0xEE, 0x67, 0x76, 0xAE, 0xB4, 0xC7, 0x65, 0x42} |         0x9B, 0x2A, 0x15, 0xF9, 0x31, 0x26, 0x1F, 0x31, 0xEE, 0x67, 0x76, 0xAE, 0xB4, 0xC7, 0x65, 0x42} | ||||||
| }; | }; | ||||||
| @@ -342,7 +342,7 @@ get_tsec: ; | |||||||
|     // Parse eMMC GPT. |     // Parse eMMC GPT. | ||||||
|     LIST_INIT(gpt); |     LIST_INIT(gpt); | ||||||
|     nx_emmc_gpt_parse(&gpt, &storage); |     nx_emmc_gpt_parse(&gpt, &storage); | ||||||
|      |  | ||||||
|     // Find package2 partition. |     // Find package2 partition. | ||||||
|     emmc_part_t *pkg2_part = nx_emmc_part_find(&gpt, "BCPKG2-1-Normal-Main"); |     emmc_part_t *pkg2_part = nx_emmc_part_find(&gpt, "BCPKG2-1-Normal-Main"); | ||||||
|     if (!pkg2_part) { |     if (!pkg2_part) { | ||||||
|   | |||||||
| @@ -32,24 +32,24 @@ const blz_footer *blz_get_footer(const unsigned char *compData, unsigned int com | |||||||
| } | } | ||||||
|  |  | ||||||
| // From https://github.com/SciresM/hactool/blob/master/kip.c which is exactly how kernel does it, thanks SciresM! | // From https://github.com/SciresM/hactool/blob/master/kip.c which is exactly how kernel does it, thanks SciresM! | ||||||
| int blz_uncompress_inplace(unsigned char *dataBuf, unsigned int compSize, const blz_footer *footer)  | int blz_uncompress_inplace(unsigned char *dataBuf, unsigned int compSize, const blz_footer *footer) | ||||||
| { | { | ||||||
| 	u32 addl_size = footer->addl_size; | 	u32 addl_size = footer->addl_size; | ||||||
| 	u32 header_size = footer->header_size; | 	u32 header_size = footer->header_size; | ||||||
| 	u32 cmp_and_hdr_size = footer->cmp_and_hdr_size; | 	u32 cmp_and_hdr_size = footer->cmp_and_hdr_size; | ||||||
| 	 |  | ||||||
| 	unsigned char* cmp_start = &dataBuf[compSize] - cmp_and_hdr_size; | 	unsigned char* cmp_start = &dataBuf[compSize] - cmp_and_hdr_size; | ||||||
| 	u32 cmp_ofs = cmp_and_hdr_size - header_size; | 	u32 cmp_ofs = cmp_and_hdr_size - header_size; | ||||||
| 	u32 out_ofs = cmp_and_hdr_size + addl_size; | 	u32 out_ofs = cmp_and_hdr_size + addl_size; | ||||||
| 	 |  | ||||||
| 	while (out_ofs)  | 	while (out_ofs) | ||||||
| 	{ | 	{ | ||||||
| 		unsigned char control = cmp_start[--cmp_ofs]; | 		unsigned char control = cmp_start[--cmp_ofs]; | ||||||
| 		for (unsigned int i=0; i<8; i++)  | 		for (unsigned int i=0; i<8; i++) | ||||||
| 		{ | 		{ | ||||||
| 			if (control & 0x80)  | 			if (control & 0x80) | ||||||
| 			{ | 			{ | ||||||
| 				if (cmp_ofs < 2)  | 				if (cmp_ofs < 2) | ||||||
| 					return 0; // Out of bounds. | 					return 0; // Out of bounds. | ||||||
|  |  | ||||||
| 				cmp_ofs -= 2; | 				cmp_ofs -= 2; | ||||||
| @@ -64,17 +64,17 @@ int blz_uncompress_inplace(unsigned char *dataBuf, unsigned int compSize, const | |||||||
| 				for (unsigned int j = 0; j < seg_size; j++) | 				for (unsigned int j = 0; j < seg_size; j++) | ||||||
| 					cmp_start[out_ofs + j] = cmp_start[out_ofs + j + seg_ofs]; | 					cmp_start[out_ofs + j] = cmp_start[out_ofs + j + seg_ofs]; | ||||||
| 			} | 			} | ||||||
| 			else  | 			else | ||||||
| 			{ | 			{ | ||||||
| 				// Copy directly. | 				// Copy directly. | ||||||
| 				if (cmp_ofs < 1)  | 				if (cmp_ofs < 1) | ||||||
| 					return 0; //out of bounds | 					return 0; //out of bounds | ||||||
|  |  | ||||||
| 				cmp_start[--out_ofs] = cmp_start[--cmp_ofs]; | 				cmp_start[--out_ofs] = cmp_start[--cmp_ofs]; | ||||||
| 			} | 			} | ||||||
| 			control <<= 1; | 			control <<= 1; | ||||||
| 			if (out_ofs == 0) // Blz works backwards, so if it reaches byte 0, it's done. | 			if (out_ofs == 0) // Blz works backwards, so if it reaches byte 0, it's done. | ||||||
| 				return 1;  | 				return 1; | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
|   | |||||||
| @@ -262,7 +262,7 @@ int max17050_fix_configuration() | |||||||
| 	/* Init complete, Clear the POR bit */ | 	/* Init complete, Clear the POR bit */ | ||||||
| 	//_max17050_set_por_bit(0); // Should we? Or let the switch to reconfigure POR? | 	//_max17050_set_por_bit(0); // Should we? Or let the switch to reconfigure POR? | ||||||
|  |  | ||||||
| 	// Sets POR, BI, BR.  | 	// Sets POR, BI, BR. | ||||||
| 	_max17050_set_por_bit(0x8801); | 	_max17050_set_por_bit(0x8801); | ||||||
|  |  | ||||||
| 	return 0; | 	return 0; | ||||||
|   | |||||||
| @@ -36,7 +36,7 @@ void max77620_rtc_get_time(rtc_time_t *time) | |||||||
| 	time->min  = i2c_recv_byte(I2C_5, MAX77620_RTC_I2C_ADDR, MAX77620_RTC_MIN_REG) & 0x7F; | 	time->min  = i2c_recv_byte(I2C_5, MAX77620_RTC_I2C_ADDR, MAX77620_RTC_MIN_REG) & 0x7F; | ||||||
|  |  | ||||||
| 	time->hour = i2c_recv_byte(I2C_5, MAX77620_RTC_I2C_ADDR, MAX77620_RTC_HOUR_REG) & 0x1F; | 	time->hour = i2c_recv_byte(I2C_5, MAX77620_RTC_I2C_ADDR, MAX77620_RTC_HOUR_REG) & 0x1F; | ||||||
| 	 |  | ||||||
| 	if (!(val & MAX77620_RTC_24H) && time->hour & MAX77620_RTC_HOUR_PM_MASK) | 	if (!(val & MAX77620_RTC_24H) && time->hour & MAX77620_RTC_HOUR_PM_MASK) | ||||||
| 		time->hour = (time->hour & 0xF) + 12; | 		time->hour = (time->hour & 0xF) + 12; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -138,7 +138,7 @@ static int _se_execute_one_block(u32 op, void *dst, u32 dst_size, const void *sr | |||||||
| 	memcpy(block, src, src_size); | 	memcpy(block, src, src_size); | ||||||
| 	int res = _se_execute(op, block, 0x10, block, 0x10); | 	int res = _se_execute(op, block, 0x10, block, 0x10); | ||||||
| 	memcpy(dst, block, dst_size); | 	memcpy(dst, block, dst_size); | ||||||
| 	 |  | ||||||
| 	free(block); | 	free(block); | ||||||
| 	return res; | 	return res; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -154,7 +154,7 @@ int tsec_query(u8 *tsec_keys, u8 kb, tsec_ctxt_t *tsec_ctxt) | |||||||
| 		se = page_alloc(1); | 		se = page_alloc(1); | ||||||
| 		memcpy(se, (void *)SE_BASE, 0x1000); | 		memcpy(se, (void *)SE_BASE, 0x1000); | ||||||
| 		smmu_map(pdir, SE_BASE, (u32)se, 1, _READABLE | _WRITABLE | _NONSECURE); | 		smmu_map(pdir, SE_BASE, (u32)se, 1, _READABLE | _WRITABLE | _NONSECURE); | ||||||
| 		 |  | ||||||
| 		// Memory controller. | 		// Memory controller. | ||||||
| 		mc = page_alloc(1); | 		mc = page_alloc(1); | ||||||
| 		memcpy(mc, (void *)MC_BASE, 0x1000); | 		memcpy(mc, (void *)MC_BASE, 0x1000); | ||||||
| @@ -216,7 +216,7 @@ int tsec_query(u8 *tsec_keys, u8 kb, tsec_ctxt_t *tsec_ctxt) | |||||||
|  |  | ||||||
| 		memcpy(tsec_keys, &key, 0x20); | 		memcpy(tsec_keys, &key, 0x20); | ||||||
| 		memcpy(tsec_ctxt->pkg1, iram, 0x30000); | 		memcpy(tsec_ctxt->pkg1, iram, 0x30000); | ||||||
| 		 |  | ||||||
| 		smmu_deinit_for_tsec(); | 		smmu_deinit_for_tsec(); | ||||||
|  |  | ||||||
| 		// for (int i = 0; i < kidx; i++) | 		// for (int i = 0; i < kidx; i++) | ||||||
|   | |||||||
| @@ -53,9 +53,9 @@ void _config_oscillators() | |||||||
| 	CLOCK(CLK_RST_CONTROLLER_SPARE_REG0) = (CLOCK(CLK_RST_CONTROLLER_SPARE_REG0) & 0xFFFFFFF3) | 4; // Set CLK_M_DIVISOR to 2. | 	CLOCK(CLK_RST_CONTROLLER_SPARE_REG0) = (CLOCK(CLK_RST_CONTROLLER_SPARE_REG0) & 0xFFFFFFF3) | 4; // Set CLK_M_DIVISOR to 2. | ||||||
| 	SYSCTR0(SYSCTR0_CNTFID0) = 19200000;             // Set counter frequency. | 	SYSCTR0(SYSCTR0_CNTFID0) = 19200000;             // Set counter frequency. | ||||||
| 	TMR(TIMERUS_USEC_CFG) = 0x45F;                   // For 19.2MHz clk_m. | 	TMR(TIMERUS_USEC_CFG) = 0x45F;                   // For 19.2MHz clk_m. | ||||||
| 	CLOCK(CLK_RST_CONTROLLER_OSC_CTRL) = 0x50000071; // Set OSC to 38.4MHz and drive strength.  | 	CLOCK(CLK_RST_CONTROLLER_OSC_CTRL) = 0x50000071; // Set OSC to 38.4MHz and drive strength. | ||||||
|  |  | ||||||
| 	PMC(APBDEV_PMC_OSC_EDPD_OVER) = (PMC(APBDEV_PMC_OSC_EDPD_OVER) & 0xFFFFFF81) | 0xE; // Set LP0 OSC drive strength.  | 	PMC(APBDEV_PMC_OSC_EDPD_OVER) = (PMC(APBDEV_PMC_OSC_EDPD_OVER) & 0xFFFFFF81) | 0xE; // Set LP0 OSC drive strength. | ||||||
| 	PMC(APBDEV_PMC_OSC_EDPD_OVER) = (PMC(APBDEV_PMC_OSC_EDPD_OVER) & 0xFFBFFFFF) | PMC_OSC_EDPD_OVER_OSC_CTRL_OVER; | 	PMC(APBDEV_PMC_OSC_EDPD_OVER) = (PMC(APBDEV_PMC_OSC_EDPD_OVER) & 0xFFBFFFFF) | PMC_OSC_EDPD_OVER_OSC_CTRL_OVER; | ||||||
| 	PMC(APBDEV_PMC_CNTRL2) = (PMC(APBDEV_PMC_CNTRL2) & 0xFFFFEFFF) | PMC_CNTRL2_HOLD_CKE_LOW_EN; | 	PMC(APBDEV_PMC_CNTRL2) = (PMC(APBDEV_PMC_CNTRL2) & 0xFFFFEFFF) | PMC_CNTRL2_HOLD_CKE_LOW_EN; | ||||||
| 	PMC(APBDEV_PMC_SCRATCH188) = (PMC(APBDEV_PMC_SCRATCH188) & 0xFCFFFFFF) | (4 << 23); // LP0 EMC2TMC_CFG_XM2COMP_PU_VREF_SEL_RANGE. | 	PMC(APBDEV_PMC_SCRATCH188) = (PMC(APBDEV_PMC_SCRATCH188) & 0xFCFFFFFF) | (4 << 23); // LP0 EMC2TMC_CFG_XM2COMP_PU_VREF_SEL_RANGE. | ||||||
| @@ -187,7 +187,7 @@ void _config_se_brom() | |||||||
| 	if (!(b_cfg.boot_cfg & BOOT_CFG_SEPT_RUN)) | 	if (!(b_cfg.boot_cfg & BOOT_CFG_SEPT_RUN)) | ||||||
| 	{ | 	{ | ||||||
| 		// Bootrom part we skipped. | 		// Bootrom part we skipped. | ||||||
| 		u32 sbk[4] = {  | 		u32 sbk[4] = { | ||||||
| 			FUSE(FUSE_PRIVATE_KEY0), | 			FUSE(FUSE_PRIVATE_KEY0), | ||||||
| 			FUSE(FUSE_PRIVATE_KEY1), | 			FUSE(FUSE_PRIVATE_KEY1), | ||||||
| 			FUSE(FUSE_PRIVATE_KEY2), | 			FUSE(FUSE_PRIVATE_KEY2), | ||||||
|   | |||||||
| @@ -97,7 +97,7 @@ | |||||||
| #define PINMUX_OPEN_DRAIN   (1 << 11) | #define PINMUX_OPEN_DRAIN   (1 << 11) | ||||||
| #define PINMUX_SCHMT        (1 << 12) | #define PINMUX_SCHMT        (1 << 12) | ||||||
|  |  | ||||||
| #define PINMUX_DRIVE_1X     (0 << 13)  | #define PINMUX_DRIVE_1X     (0 << 13) | ||||||
| #define PINMUX_DRIVE_2X     (1 << 13) | #define PINMUX_DRIVE_2X     (1 << 13) | ||||||
| #define PINMUX_DRIVE_3X     (2 << 13) | #define PINMUX_DRIVE_3X     (2 << 13) | ||||||
| #define PINMUX_DRIVE_4X     (3 << 13) | #define PINMUX_DRIVE_4X     (3 << 13) | ||||||
|   | |||||||
| @@ -156,7 +156,7 @@ | |||||||
| #define SYSCTR0_COUNTERID7  0xFDC | #define SYSCTR0_COUNTERID7  0xFDC | ||||||
| #define SYSCTR0_COUNTERID8  0xFF0 | #define SYSCTR0_COUNTERID8  0xFF0 | ||||||
| #define SYSCTR0_COUNTERID9  0xFF4 | #define SYSCTR0_COUNTERID9  0xFF4 | ||||||
| #define SYSCTR0_COUNTERID10 0xFF8  | #define SYSCTR0_COUNTERID10 0xFF8 | ||||||
| #define SYSCTR0_COUNTERID11 0xFFC | #define SYSCTR0_COUNTERID11 0xFFC | ||||||
|  |  | ||||||
| /*! TMR registers. */ | /*! TMR registers. */ | ||||||
|   | |||||||
| @@ -182,7 +182,7 @@ int emummc_storage_read(sdmmc_storage_t *storage, u32 sector, u32 num_sectors, v | |||||||
| 			f_close(&fp); | 			f_close(&fp); | ||||||
| 			return 0; | 			return 0; | ||||||
| 		} | 		} | ||||||
| 		 |  | ||||||
| 		f_close(&fp); | 		f_close(&fp); | ||||||
| 		return 1; | 		return 1; | ||||||
| 	} | 	} | ||||||
| @@ -227,7 +227,7 @@ int emummc_storage_write(sdmmc_storage_t *storage, u32 sector, u32 num_sectors, | |||||||
| 			f_close(&fp); | 			f_close(&fp); | ||||||
| 			return 0; | 			return 0; | ||||||
| 		} | 		} | ||||||
| 		 |  | ||||||
| 		f_close(&fp); | 		f_close(&fp); | ||||||
| 		return 1; | 		return 1; | ||||||
| 	} | 	} | ||||||
|   | |||||||
| @@ -1064,7 +1064,7 @@ void sdmmc_storage_init_wait_sd() | |||||||
| int sdmmc_storage_init_sd(sdmmc_storage_t *storage, sdmmc_t *sdmmc, u32 id, u32 bus_width, u32 type) | int sdmmc_storage_init_sd(sdmmc_storage_t *storage, sdmmc_t *sdmmc, u32 id, u32 bus_width, u32 type) | ||||||
| { | { | ||||||
| 	int is_version_1 = 0; | 	int is_version_1 = 0; | ||||||
| 	 |  | ||||||
| 	// Some cards (Sandisk U1), do not like a fast power cycle. Wait min 100ms. | 	// Some cards (Sandisk U1), do not like a fast power cycle. Wait min 100ms. | ||||||
| 	sdmmc_storage_init_wait_sd(); | 	sdmmc_storage_init_wait_sd(); | ||||||
|  |  | ||||||
| @@ -1144,7 +1144,7 @@ DPRINTF("[SD] cleared card detect\n"); | |||||||
| 		free(buf); | 		free(buf); | ||||||
| 		return 0; | 		return 0; | ||||||
| 	} | 	} | ||||||
| 		 |  | ||||||
| 	//gfx_hexdump(0, storage->raw_scr, 8); | 	//gfx_hexdump(0, storage->raw_scr, 8); | ||||||
| DPRINTF("[SD] got scr\n"); | DPRINTF("[SD] got scr\n"); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -77,7 +77,7 @@ static int _sdmmc_set_voltage(sdmmc_t *sdmmc, u32 power) | |||||||
| 	{ | 	{ | ||||||
| 		pwr |= TEGRA_MMC_PWRCTL_SD_BUS_POWER; | 		pwr |= TEGRA_MMC_PWRCTL_SD_BUS_POWER; | ||||||
| 		sdmmc->regs->pwrcon = pwr; | 		sdmmc->regs->pwrcon = pwr; | ||||||
| 	}	 | 	} | ||||||
|  |  | ||||||
| 	return 1; | 	return 1; | ||||||
| } | } | ||||||
| @@ -385,7 +385,7 @@ int sdmmc_get_rsp(sdmmc_t *sdmmc, u32 *rsp, u32 size, u32 type) | |||||||
|  |  | ||||||
| static void _sdmmc_reset(sdmmc_t *sdmmc) | static void _sdmmc_reset(sdmmc_t *sdmmc) | ||||||
| { | { | ||||||
| 	sdmmc->regs->swrst |=  | 	sdmmc->regs->swrst |= | ||||||
| 		TEGRA_MMC_SWRST_SW_RESET_FOR_CMD_LINE | TEGRA_MMC_SWRST_SW_RESET_FOR_DAT_LINE; | 		TEGRA_MMC_SWRST_SW_RESET_FOR_CMD_LINE | TEGRA_MMC_SWRST_SW_RESET_FOR_DAT_LINE; | ||||||
| 	_sdmmc_get_clkcon(sdmmc); | 	_sdmmc_get_clkcon(sdmmc); | ||||||
| 	u32 timeout = get_tmr_ms() + 2000; | 	u32 timeout = get_tmr_ms() + 2000; | ||||||
| @@ -456,7 +456,7 @@ static int _sdmmc_setup_read_small_block(sdmmc_t *sdmmc) | |||||||
| static int _sdmmc_parse_cmdbuf(sdmmc_t *sdmmc, sdmmc_cmd_t *cmd, bool is_data_present) | static int _sdmmc_parse_cmdbuf(sdmmc_t *sdmmc, sdmmc_cmd_t *cmd, bool is_data_present) | ||||||
| { | { | ||||||
| 	u16 cmdflags = 0; | 	u16 cmdflags = 0; | ||||||
| 	 |  | ||||||
| 	switch (cmd->rsp_type) | 	switch (cmd->rsp_type) | ||||||
| 	{ | 	{ | ||||||
| 	case SDMMC_RSP_TYPE_0: | 	case SDMMC_RSP_TYPE_0: | ||||||
| @@ -722,7 +722,7 @@ static int _sdmmc_check_mask_interrupt(sdmmc_t *sdmmc, u16 *pout, u16 mask) | |||||||
| 		sdmmc->regs->norintsts = norintsts & mask; | 		sdmmc->regs->norintsts = norintsts & mask; | ||||||
| 		return SDMMC_MASKINT_MASKED; | 		return SDMMC_MASKINT_MASKED; | ||||||
| 	} | 	} | ||||||
| 	 |  | ||||||
| 	return SDMMC_MASKINT_NOERROR; | 	return SDMMC_MASKINT_NOERROR; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -767,7 +767,7 @@ static int _sdmmc_stop_transmission_inner(sdmmc_t *sdmmc, u32 *rsp) | |||||||
|  |  | ||||||
| 	if (!res) | 	if (!res) | ||||||
| 		return 0; | 		return 0; | ||||||
| 	 |  | ||||||
| 	_sdmmc_cache_rsp(sdmmc, rsp, 4, SDMMC_RSP_TYPE_1); | 	_sdmmc_cache_rsp(sdmmc, rsp, 4, SDMMC_RSP_TYPE_1); | ||||||
|  |  | ||||||
| 	return _sdmmc_wait_prnsts_type1(sdmmc); | 	return _sdmmc_wait_prnsts_type1(sdmmc); | ||||||
| @@ -901,7 +901,7 @@ static int _sdmmc_execute_cmd_inner(sdmmc_t *sdmmc, sdmmc_cmd_t *cmd, sdmmc_req_ | |||||||
| 	_sdmmc_parse_cmdbuf(sdmmc, cmd, is_data_present); | 	_sdmmc_parse_cmdbuf(sdmmc, cmd, is_data_present); | ||||||
|  |  | ||||||
| 	int res = _sdmmc_wait_request(sdmmc); | 	int res = _sdmmc_wait_request(sdmmc); | ||||||
| 	DPRINTF("rsp(%d): %08X, %08X, %08X, %08X\n", res,  | 	DPRINTF("rsp(%d): %08X, %08X, %08X, %08X\n", res, | ||||||
| 		sdmmc->regs->rspreg0, sdmmc->regs->rspreg1, sdmmc->regs->rspreg2, sdmmc->regs->rspreg3); | 		sdmmc->regs->rspreg0, sdmmc->regs->rspreg1, sdmmc->regs->rspreg2, sdmmc->regs->rspreg3); | ||||||
| 	if (res) | 	if (res) | ||||||
| 	{ | 	{ | ||||||
| @@ -943,7 +943,7 @@ static int _sdmmc_config_sdmmc1() | |||||||
| 	gpio_output_enable(GPIO_PORT_Z, GPIO_PIN_1, GPIO_OUTPUT_DISABLE); | 	gpio_output_enable(GPIO_PORT_Z, GPIO_PIN_1, GPIO_OUTPUT_DISABLE); | ||||||
| 	usleep(100); | 	usleep(100); | ||||||
|  |  | ||||||
| 	// Check if SD card is inserted.  | 	// Check if SD card is inserted. | ||||||
| 	if(!!gpio_read(GPIO_PORT_Z, GPIO_PIN_1)) | 	if(!!gpio_read(GPIO_PORT_Z, GPIO_PIN_1)) | ||||||
| 		return 0; | 		return 0; | ||||||
|  |  | ||||||
| @@ -1055,7 +1055,7 @@ void sdmmc_end(sdmmc_t *sdmmc) | |||||||
| 	if (!sdmmc->clock_stopped) | 	if (!sdmmc->clock_stopped) | ||||||
| 	{ | 	{ | ||||||
| 		_sdmmc_sd_clock_disable(sdmmc); | 		_sdmmc_sd_clock_disable(sdmmc); | ||||||
| 		// Disable SDMMC power.  | 		// Disable SDMMC power. | ||||||
| 		_sdmmc_set_voltage(sdmmc, SDMMC_POWER_OFF); | 		_sdmmc_set_voltage(sdmmc, SDMMC_POWER_OFF); | ||||||
|  |  | ||||||
| 		// Disable SD card power. | 		// Disable SD card power. | ||||||
| @@ -1134,7 +1134,7 @@ int sdmmc_enable_low_voltage(sdmmc_t *sdmmc) | |||||||
| 	_sdmmc_set_voltage(sdmmc, SDMMC_POWER_1_8); | 	_sdmmc_set_voltage(sdmmc, SDMMC_POWER_1_8); | ||||||
| 	_sdmmc_get_clkcon(sdmmc); | 	_sdmmc_get_clkcon(sdmmc); | ||||||
| 	msleep(5); | 	msleep(5); | ||||||
| 	 |  | ||||||
| 	if (sdmmc->regs->hostctl2 & SDHCI_CTRL_VDD_180) | 	if (sdmmc->regs->hostctl2 & SDHCI_CTRL_VDD_180) | ||||||
| 	{ | 	{ | ||||||
| 		sdmmc->regs->clkcon |= TEGRA_MMC_CLKCON_SD_CLOCK_ENABLE; | 		sdmmc->regs->clkcon |= TEGRA_MMC_CLKCON_SD_CLOCK_ENABLE; | ||||||
|   | |||||||
| @@ -29,7 +29,7 @@ char *dirlist(const char *directory, const char *pattern, bool includeHiddenFile | |||||||
| 	u32 i = 0, j = 0, k = 0; | 	u32 i = 0, j = 0, k = 0; | ||||||
| 	DIR dir; | 	DIR dir; | ||||||
| 	FILINFO fno; | 	FILINFO fno; | ||||||
| 	 |  | ||||||
| 	char *dir_entries = (char *)calloc(max_entries, 256); | 	char *dir_entries = (char *)calloc(max_entries, 256); | ||||||
| 	char *temp = (char *)calloc(1, 256); | 	char *temp = (char *)calloc(1, 256); | ||||||
|  |  | ||||||
| @@ -79,7 +79,7 @@ char *dirlist(const char *directory, const char *pattern, bool includeHiddenFile | |||||||
| 	{ | 	{ | ||||||
| 		for (j = i + 1; j < k; j++) | 		for (j = i + 1; j < k; j++) | ||||||
| 		{ | 		{ | ||||||
| 			if (strcmp(&dir_entries[i * 256], &dir_entries[j * 256]) > 0)  | 			if (strcmp(&dir_entries[i * 256], &dir_entries[j * 256]) > 0) | ||||||
| 			{ | 			{ | ||||||
| 				memcpy(temp, &dir_entries[i * 256], strlen(&dir_entries[i * 256]) + 1); | 				memcpy(temp, &dir_entries[i * 256], strlen(&dir_entries[i * 256]) + 1); | ||||||
| 				memcpy(&dir_entries[i * 256], &dir_entries[j * 256], strlen(&dir_entries[j * 256]) + 1); | 				memcpy(&dir_entries[i * 256], &dir_entries[j * 256], strlen(&dir_entries[j * 256]) + 1); | ||||||
|   | |||||||
| @@ -1,123 +1,123 @@ | |||||||
| /* | /* | ||||||
|  * Copyright (c) 2019 shchmue |  * Copyright (c) 2019 shchmue | ||||||
|  * |  * | ||||||
|  * This program is free software; you can redistribute it and/or modify it |  * This program is free software; you can redistribute it and/or modify it | ||||||
|  * under the terms and conditions of the GNU General Public License, |  * under the terms and conditions of the GNU General Public License, | ||||||
|  * version 2, as published by the Free Software Foundation. |  * version 2, as published by the Free Software Foundation. | ||||||
|  * |  * | ||||||
|  * This program is distributed in the hope it will be useful, but WITHOUT |  * This program is distributed in the hope it will be useful, but WITHOUT | ||||||
|  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | ||||||
|  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for |  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for | ||||||
|  * more details. |  * more details. | ||||||
|  * |  * | ||||||
|  * You should have received a copy of the GNU General Public License |  * You should have received a copy of the GNU General Public License | ||||||
|  * along with this program.  If not, see <http://www.gnu.org/licenses/>. |  * along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| #include "sprintf.h" | #include "sprintf.h" | ||||||
|  |  | ||||||
| #include <stdarg.h> | #include <stdarg.h> | ||||||
|  |  | ||||||
| static void _putc(char *buffer, const char c) { | static void _putc(char *buffer, const char c) { | ||||||
|     *buffer = c; |     *buffer = c; | ||||||
| } | } | ||||||
|  |  | ||||||
| static u32 _puts(char *buffer, const char *s) { | static u32 _puts(char *buffer, const char *s) { | ||||||
|     u32 count = 0; |     u32 count = 0; | ||||||
|     for (; *s; s++, count++) |     for (; *s; s++, count++) | ||||||
|         _putc(buffer + count, *s); |         _putc(buffer + count, *s); | ||||||
|     return count; |     return count; | ||||||
| } | } | ||||||
|  |  | ||||||
| static u32 _putn(char *buffer, u32 v, int base, char fill, int fcnt) { | static u32 _putn(char *buffer, u32 v, int base, char fill, int fcnt) { | ||||||
|     char buf[0x121]; |     char buf[0x121]; | ||||||
|     static const char digits[] = "0123456789abcdefghijklmnopqrstuvwxyz"; |     static const char digits[] = "0123456789abcdefghijklmnopqrstuvwxyz"; | ||||||
|     char *p; |     char *p; | ||||||
|     int c = fcnt; |     int c = fcnt; | ||||||
|  |  | ||||||
|     if (base > 36) |     if (base > 36) | ||||||
|         return 0; |         return 0; | ||||||
|  |  | ||||||
|     p = buf + 0x120; |     p = buf + 0x120; | ||||||
|     *p = 0; |     *p = 0; | ||||||
|     do { |     do { | ||||||
|         c--; |         c--; | ||||||
|         *--p = digits[v % base]; |         *--p = digits[v % base]; | ||||||
|         v /= base; |         v /= base; | ||||||
|     } while (v); |     } while (v); | ||||||
|  |  | ||||||
|     if (fill != 0) { |     if (fill != 0) { | ||||||
|         while (c > 0) { |         while (c > 0) { | ||||||
|             *--p = fill; |             *--p = fill; | ||||||
|             c--; |             c--; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     return _puts(buffer, p); |     return _puts(buffer, p); | ||||||
| } | } | ||||||
|  |  | ||||||
| u32 sprintf(char *buffer, const char *fmt, ...) { | u32 sprintf(char *buffer, const char *fmt, ...) { | ||||||
|     va_list ap; |     va_list ap; | ||||||
|     int fill, fcnt; |     int fill, fcnt; | ||||||
|     u32 count = 0; |     u32 count = 0; | ||||||
|  |  | ||||||
|     va_start(ap, fmt); |     va_start(ap, fmt); | ||||||
|     while(*fmt) { |     while(*fmt) { | ||||||
|         if (*fmt == '%') { |         if (*fmt == '%') { | ||||||
|             fmt++; |             fmt++; | ||||||
|             fill = 0; |             fill = 0; | ||||||
|             fcnt = 0; |             fcnt = 0; | ||||||
|             if ((*fmt >= '0' && *fmt <= '9') || *fmt == ' ') { |             if ((*fmt >= '0' && *fmt <= '9') || *fmt == ' ') { | ||||||
|                 fcnt = *fmt; |                 fcnt = *fmt; | ||||||
|                 fmt++; |                 fmt++; | ||||||
|                 if (*fmt >= '0' && *fmt <= '9') { |                 if (*fmt >= '0' && *fmt <= '9') { | ||||||
|                     fill = fcnt; |                     fill = fcnt; | ||||||
|                     fcnt = *fmt - '0'; |                     fcnt = *fmt - '0'; | ||||||
|                     fmt++; |                     fmt++; | ||||||
|                 } else { |                 } else { | ||||||
|                     fill = ' '; |                     fill = ' '; | ||||||
|                     fcnt -= '0'; |                     fcnt -= '0'; | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             switch (*fmt) { |             switch (*fmt) { | ||||||
|             case 'c': |             case 'c': | ||||||
|                 _putc(buffer + count, va_arg(ap, u32)); |                 _putc(buffer + count, va_arg(ap, u32)); | ||||||
|                 count++; |                 count++; | ||||||
|                 break; |                 break; | ||||||
|             case 's': |             case 's': | ||||||
|                 count += _puts(buffer + count, va_arg(ap, char *)); |                 count += _puts(buffer + count, va_arg(ap, char *)); | ||||||
|                 break; |                 break; | ||||||
|             case 'd': |             case 'd': | ||||||
|                 count += _putn(buffer + count, va_arg(ap, u32), 10, fill, fcnt); |                 count += _putn(buffer + count, va_arg(ap, u32), 10, fill, fcnt); | ||||||
|                 break; |                 break; | ||||||
|             case 'p': |             case 'p': | ||||||
|             case 'P': |             case 'P': | ||||||
|             case 'x': |             case 'x': | ||||||
|             case 'X': |             case 'X': | ||||||
|                 count += _putn(buffer + count, va_arg(ap, u32), 16, fill, fcnt); |                 count += _putn(buffer + count, va_arg(ap, u32), 16, fill, fcnt); | ||||||
|                 break; |                 break; | ||||||
|             case '%': |             case '%': | ||||||
|                 _putc(buffer + count, '%'); |                 _putc(buffer + count, '%'); | ||||||
|                 count++; |                 count++; | ||||||
|                 break; |                 break; | ||||||
|             case '\0': |             case '\0': | ||||||
|                 goto out; |                 goto out; | ||||||
|             default: |             default: | ||||||
|                 _putc(buffer + count, '%'); |                 _putc(buffer + count, '%'); | ||||||
|                 count++; |                 count++; | ||||||
|                 _putc(buffer + count, *fmt); |                 _putc(buffer + count, *fmt); | ||||||
|                 count++; |                 count++; | ||||||
|                 break; |                 break; | ||||||
|             } |             } | ||||||
|         } else { |         } else { | ||||||
|             _putc(buffer + count, *fmt); |             _putc(buffer + count, *fmt); | ||||||
|             count++; |             count++; | ||||||
|         } |         } | ||||||
|         fmt++; |         fmt++; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     out: |     out: | ||||||
|     buffer[count] = 0; |     buffer[count] = 0; | ||||||
|     va_end(ap); |     va_end(ap); | ||||||
|     return count; |     return count; | ||||||
| } | } | ||||||
| @@ -1,24 +1,24 @@ | |||||||
| /* | /* | ||||||
|  * Copyright (c) 2019 shchmue |  * Copyright (c) 2019 shchmue | ||||||
|  * |  * | ||||||
|  * This program is free software; you can redistribute it and/or modify it |  * This program is free software; you can redistribute it and/or modify it | ||||||
|  * under the terms and conditions of the GNU General Public License, |  * under the terms and conditions of the GNU General Public License, | ||||||
|  * version 2, as published by the Free Software Foundation. |  * version 2, as published by the Free Software Foundation. | ||||||
|  * |  * | ||||||
|  * This program is distributed in the hope it will be useful, but WITHOUT |  * This program is distributed in the hope it will be useful, but WITHOUT | ||||||
|  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | ||||||
|  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for |  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for | ||||||
|  * more details. |  * more details. | ||||||
|  * |  * | ||||||
|  * You should have received a copy of the GNU General Public License |  * You should have received a copy of the GNU General Public License | ||||||
|  * along with this program.  If not, see <http://www.gnu.org/licenses/>. |  * along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| #ifndef _SPRINTF_H_ | #ifndef _SPRINTF_H_ | ||||||
| #define _SPRINTF_H_ | #define _SPRINTF_H_ | ||||||
|  |  | ||||||
| #include "types.h" | #include "types.h" | ||||||
|  |  | ||||||
| u32 sprintf(char *buffer, const char *fmt, ...); | u32 sprintf(char *buffer, const char *fmt, ...); | ||||||
|  |  | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -88,7 +88,7 @@ void panic(u32 val) | |||||||
| 	TMR(TIMER_TMR9_TMR_PTV) = TIMER_EN | TIMER_PER_EN; | 	TMR(TIMER_TMR9_TMR_PTV) = TIMER_EN | TIMER_PER_EN; | ||||||
| 	TMR(TIMER_WDT4_CONFIG)  = TIMER_SRC(9) | TIMER_PER(1) | TIMER_PMCRESET_EN; | 	TMR(TIMER_WDT4_CONFIG)  = TIMER_SRC(9) | TIMER_PER(1) | TIMER_PMCRESET_EN; | ||||||
| 	TMR(TIMER_WDT4_COMMAND) = TIMER_START_CNT; | 	TMR(TIMER_WDT4_COMMAND) = TIMER_START_CNT; | ||||||
| 	 |  | ||||||
| 	while (true) | 	while (true) | ||||||
| 		usleep(1); | 		usleep(1); | ||||||
| } | } | ||||||
| @@ -126,7 +126,7 @@ void power_off() | |||||||
| 	max77620_rtc_stop_alarm(); | 	max77620_rtc_stop_alarm(); | ||||||
|  |  | ||||||
| 	i2c_send_byte(I2C_5, MAX77620_I2C_ADDR, MAX77620_REG_ONOFFCNFG1, MAX77620_ONOFFCNFG1_PWR_OFF); | 	i2c_send_byte(I2C_5, MAX77620_I2C_ADDR, MAX77620_REG_ONOFFCNFG1, MAX77620_ONOFFCNFG1_PWR_OFF); | ||||||
| 	 |  | ||||||
| 	while (true) | 	while (true) | ||||||
| 		bpmp_halt(); | 		bpmp_halt(); | ||||||
| } | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user