Add BPMP overclock, add hekate fixes, fix sprintf
This commit is contained in:
		
							parent
							
								
									34890f0025
								
							
						
					
					
						commit
						82bea6be8f
					
				
					 39 changed files with 1130 additions and 544 deletions
				
			
		|  | @ -21,6 +21,7 @@ | |||
| 
 | ||||
| #include "../sec/se.h" | ||||
| #include "../mem/heap.h" | ||||
| #include "../soc/bpmp.h" | ||||
| #include "../soc/t210.h" | ||||
| #include "../sec/se_t210.h" | ||||
| #include "../utils/util.h" | ||||
|  | @ -108,10 +109,14 @@ static int _se_execute(u32 op, void *dst, u32 dst_size, const void *src, u32 src | |||
| 
 | ||||
| 	SE(SE_ERR_STATUS_0) = SE(SE_ERR_STATUS_0); | ||||
| 	SE(SE_INT_STATUS_REG_OFFSET) = SE(SE_INT_STATUS_REG_OFFSET); | ||||
| 	SE(SE_OPERATION_REG_OFFSET) = SE_OPERATION(op); | ||||
| 
 | ||||
| 	bpmp_mmu_maintenance(BPMP_MMU_MAINT_CLN_INV_WAY); | ||||
| 
 | ||||
| 	SE(SE_OPERATION_REG_OFFSET) = SE_OPERATION(op); | ||||
| 	int res = _se_wait(); | ||||
| 
 | ||||
| 	bpmp_mmu_maintenance(BPMP_MMU_MAINT_CLN_INV_WAY); | ||||
| 
 | ||||
| 	if (src) | ||||
| 		free(ll_src); | ||||
| 	if (dst) | ||||
|  | @ -227,18 +232,7 @@ int se_aes_crypt_ecb(u32 ks, u32 enc, void *dst, u32 dst_size, const void *src, | |||
| 
 | ||||
| int se_aes_crypt_block_ecb(u32 ks, u32 enc, void *dst, const void *src) | ||||
| { | ||||
| 	if (enc) | ||||
| 	{ | ||||
| 		SE(SE_CONFIG_REG_OFFSET) = SE_CONFIG_ENC_ALG(ALG_AES_ENC) | SE_CONFIG_DST(DST_MEMORY); | ||||
| 		SE(SE_CRYPTO_REG_OFFSET) = SE_CRYPTO_KEY_INDEX(ks) | SE_CRYPTO_CORE_SEL(CORE_ENCRYPT); | ||||
| 	} | ||||
| 	else | ||||
| 	{ | ||||
| 		SE(SE_CONFIG_REG_OFFSET) = SE_CONFIG_DEC_ALG(ALG_AES_DEC) | SE_CONFIG_DST(DST_MEMORY); | ||||
| 		SE(SE_CRYPTO_REG_OFFSET) = SE_CRYPTO_KEY_INDEX(ks) | SE_CRYPTO_CORE_SEL(CORE_DECRYPT); | ||||
| 	} | ||||
| 	SE(SE_BLOCK_COUNT_REG_OFFSET) = 0; | ||||
| 	return _se_execute(OP_START, dst, 0x10, src, 0x10); | ||||
| 	return se_aes_crypt_ecb(ks, enc, dst, 0x10, src, 0x10); | ||||
| } | ||||
| 
 | ||||
| int se_aes_crypt_ctr(u32 ks, void *dst, u32 dst_size, const void *src, u32 src_size, void *ctr) | ||||
|  |  | |||
|  | @ -21,6 +21,7 @@ | |||
| #include "../sec/tsec.h" | ||||
| #include "../sec/tsec_t210.h" | ||||
| #include "../sec/se_t210.h" | ||||
| #include "../soc/bpmp.h" | ||||
| #include "../soc/clock.h" | ||||
| #include "../soc/smmu.h" | ||||
| #include "../soc/t210.h" | ||||
|  | @ -64,8 +65,12 @@ int tsec_query(u8 *tsec_keys, u8 kb, tsec_ctxt_t *tsec_ctxt) | |||
| 	u32 *pdir, *car, *fuse, *pmc, *flowctrl, *se, *mc, *iram, *evec; | ||||
| 	u32 *pkg11_magic_off; | ||||
| 
 | ||||
| 	//Enable clocks.
 | ||||
| 	bpmp_mmu_disable(); | ||||
| 	bpmp_clk_rate_set(BPMP_CLK_NORMAL); | ||||
| 
 | ||||
| 	// Enable clocks.
 | ||||
| 	clock_enable_host1x(); | ||||
| 	usleep(2); | ||||
| 	clock_enable_tsec(); | ||||
| 	clock_enable_sor_safe(); | ||||
| 	clock_enable_sor0(); | ||||
|  | @ -170,7 +175,7 @@ int tsec_query(u8 *tsec_keys, u8 kb, tsec_ctxt_t *tsec_ctxt) | |||
| 	} | ||||
| 
 | ||||
| 	//Execute firmware.
 | ||||
| 	HOST1X(0x3300) = 0x34C2E1DA; | ||||
| 	HOST1X(HOST1X_CH0_SYNC_SYNCPT_160) = 0x34C2E1DA; | ||||
| 	TSEC(TSEC_STATUS) = 0; | ||||
| 	TSEC(TSEC_BOOTKEYVER) = 1; // HOS uses key version 1.
 | ||||
| 	TSEC(TSEC_BOOTVEC) = 0; | ||||
|  | @ -247,7 +252,7 @@ int tsec_query(u8 *tsec_keys, u8 kb, tsec_ctxt_t *tsec_ctxt) | |||
| 		} | ||||
| 
 | ||||
| 		//Fetch result.
 | ||||
| 		HOST1X(0x3300) = 0; | ||||
| 		HOST1X(HOST1X_CH0_SYNC_SYNCPT_160) = 0; | ||||
| 		u32 buf[4]; | ||||
| 		buf[0] = SOR1(SOR_NV_PDISP_SOR_DP_HDCP_BKSV_LSB); | ||||
| 		buf[1] = SOR1(SOR_NV_PDISP_SOR_TMDS_HDCP_BKSV_LSB); | ||||
|  | @ -272,7 +277,8 @@ out:; | |||
| 	clock_disable_sor0(); | ||||
| 	clock_disable_sor_safe(); | ||||
| 	clock_disable_tsec(); | ||||
| 	clock_disable_host1x(); | ||||
| 	bpmp_mmu_enable(); | ||||
| 	bpmp_clk_rate_set(BPMP_CLK_SUPER_BOOST); | ||||
| 
 | ||||
| 	return res; | ||||
| } | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue