xref: /optee_os/core/arch/arm/plat-rzn1/main.c (revision 55ab8f06a831946a49717446cd2e4495a2b5d659)
1f1cf4b79SSumit Garg // SPDX-License-Identifier: BSD-2-Clause
2f1cf4b79SSumit Garg /*
3f1cf4b79SSumit Garg  * Copyright (c) 2017, Schneider Electric
4f1cf4b79SSumit Garg  * Copyright (c) 2020, Linaro Limited
5f1cf4b79SSumit Garg  */
6f1cf4b79SSumit Garg 
7f1cf4b79SSumit Garg #include <arm.h>
8f1cf4b79SSumit Garg #include <console.h>
9f1cf4b79SSumit Garg #include <drivers/gic.h>
10f1cf4b79SSumit Garg #include <drivers/ns16550.h>
11f1cf4b79SSumit Garg #include <kernel/boot.h>
12a7b6b979SRalph Siemsen #include <kernel/delay.h>
13f1cf4b79SSumit Garg #include <kernel/panic.h>
14f1cf4b79SSumit Garg #include <mm/core_memprot.h>
15f1cf4b79SSumit Garg #include <mm/core_mmu.h>
16f1cf4b79SSumit Garg #include <platform_config.h>
17f1cf4b79SSumit Garg #include <rzn1_tz.h>
18f1cf4b79SSumit Garg 
19a7b6b979SRalph Siemsen #define SYSCTRL_PWRCTRL_CM3	(SYSCTRL_BASE + 0x174)
20a7b6b979SRalph Siemsen #define SYSCTRL_PWRSTAT_CM3	(SYSCTRL_BASE + 0x178)
21a7b6b979SRalph Siemsen 
22a7b6b979SRalph Siemsen #define SYSCTRL_PWRCTRL_CM3_CLKEN_A	BIT(0)
23a7b6b979SRalph Siemsen #define SYSCTRL_PWRCTRL_CM3_RSTN_A	BIT(1)
24a7b6b979SRalph Siemsen #define SYSCTRL_PWRCTRL_CM3_MIREQ_A	BIT(2)
25a7b6b979SRalph Siemsen 
26a7b6b979SRalph Siemsen #define SYSCTRL_PWRSTAT_CM3_MIRACK_A	BIT(0)
27a7b6b979SRalph Siemsen 
28a7b6b979SRalph Siemsen /* Timeout waiting for Master Idle Request Acknowledge */
29a7b6b979SRalph Siemsen #define IDLE_ACK_TIMEOUT_US		1000
30a7b6b979SRalph Siemsen 
31f1cf4b79SSumit Garg static struct ns16550_data console_data;
32f1cf4b79SSumit Garg 
33f1cf4b79SSumit Garg register_phys_mem(MEM_AREA_IO_SEC, GIC_BASE, CORE_MMU_PGDIR_SIZE);
34f1cf4b79SSumit Garg register_phys_mem(MEM_AREA_IO_SEC, PERIPH_REG_BASE, CORE_MMU_PGDIR_SIZE);
35f1cf4b79SSumit Garg register_ddr(DRAM_BASE, DRAM_SIZE);
36f1cf4b79SSumit Garg 
plat_console_init(void)37*55ab8f06SAlvin Chang void plat_console_init(void)
38f1cf4b79SSumit Garg {
39f1cf4b79SSumit Garg 	ns16550_init(&console_data, CONSOLE_UART_BASE, IO_WIDTH_U32, 2);
40f1cf4b79SSumit Garg 	register_serial_console(&console_data.chip);
41f1cf4b79SSumit Garg }
42f1cf4b79SSumit Garg 
boot_primary_init_intc(void)43df913c6dSAlvin Chang void boot_primary_init_intc(void)
44f1cf4b79SSumit Garg {
4567e55c51SEtienne Carriere 	gic_init(GICC_BASE, GICD_BASE);
46f1cf4b79SSumit Garg }
47f1cf4b79SSumit Garg 
boot_secondary_init_intc(void)488aae4669SAlvin Chang void boot_secondary_init_intc(void)
49f1cf4b79SSumit Garg {
50998b6203SJens Wiklander 	gic_init_per_cpu();
51f1cf4b79SSumit Garg }
52f1cf4b79SSumit Garg 
rzn1_tz_init(void)53f1cf4b79SSumit Garg static TEE_Result rzn1_tz_init(void)
54f1cf4b79SSumit Garg {
55f1cf4b79SSumit Garg 	vaddr_t tza_init_reg = 0;
56f1cf4b79SSumit Garg 	vaddr_t tza_targ_reg = 0;
57f1cf4b79SSumit Garg 
58c2e4eb43SAnton Rybakov 	tza_init_reg = core_mmu_get_va(FW_STATIC_TZA_INIT, MEM_AREA_IO_SEC,
59c2e4eb43SAnton Rybakov 				       sizeof(uint32_t));
60c2e4eb43SAnton Rybakov 	tza_targ_reg = core_mmu_get_va(FW_STATIC_TZA_TARG, MEM_AREA_IO_SEC,
61c2e4eb43SAnton Rybakov 				       sizeof(uint32_t));
62f1cf4b79SSumit Garg 
63f1cf4b79SSumit Garg 	/* TZ initiator ports */
64f1cf4b79SSumit Garg 	io_write32(tza_init_reg, TZ_INIT_CSA_SEC | TZ_INIT_YS_SEC |
65f1cf4b79SSumit Garg 				 TZ_INIT_YC_SEC | TZ_INIT_YD_SEC);
66f1cf4b79SSumit Garg 
67f1cf4b79SSumit Garg 	/* TZ target ports */
68f1cf4b79SSumit Garg 	io_write32(tza_targ_reg, TZ_TARG_PC_SEC | TZ_TARG_QB_SEC |
69f1cf4b79SSumit Garg 				 TZ_TARG_QA_SEC | TZ_TARG_UB_SEC |
70f1cf4b79SSumit Garg 				 TZ_TARG_UA_SEC);
71f1cf4b79SSumit Garg 
72f1cf4b79SSumit Garg 	return TEE_SUCCESS;
73f1cf4b79SSumit Garg }
74f1cf4b79SSumit Garg 
75f1cf4b79SSumit Garg service_init(rzn1_tz_init);
76a7b6b979SRalph Siemsen 
77a7b6b979SRalph Siemsen #ifdef CFG_BOOT_CM3
rzn1_cm3_start(void)78a7b6b979SRalph Siemsen static TEE_Result rzn1_cm3_start(void)
79a7b6b979SRalph Siemsen {
80a7b6b979SRalph Siemsen 	vaddr_t cm3_pwrctrl_reg = 0;
81a7b6b979SRalph Siemsen 	vaddr_t cm3_pwrstat_reg = 0;
82a7b6b979SRalph Siemsen 	uint64_t timeout_ack = timeout_init_us(IDLE_ACK_TIMEOUT_US);
83a7b6b979SRalph Siemsen 
84a7b6b979SRalph Siemsen 	cm3_pwrctrl_reg = core_mmu_get_va(SYSCTRL_PWRCTRL_CM3, MEM_AREA_IO_SEC,
85a7b6b979SRalph Siemsen 					  sizeof(uint32_t));
86a7b6b979SRalph Siemsen 	cm3_pwrstat_reg = core_mmu_get_va(SYSCTRL_PWRSTAT_CM3, MEM_AREA_IO_SEC,
87a7b6b979SRalph Siemsen 					  sizeof(uint32_t));
88a7b6b979SRalph Siemsen 
89a7b6b979SRalph Siemsen 	/* Master Idle Request to the interconnect for CM3 */
90a7b6b979SRalph Siemsen 	io_clrbits32(cm3_pwrctrl_reg, SYSCTRL_PWRCTRL_CM3_MIREQ_A);
91a7b6b979SRalph Siemsen 
92a7b6b979SRalph Siemsen 	/* Wait for Master Idle Request Acknowledge for CM3 */
93a7b6b979SRalph Siemsen 	while (!timeout_elapsed(timeout_ack))
94a7b6b979SRalph Siemsen 		if (!(io_read32(cm3_pwrstat_reg) &
95a7b6b979SRalph Siemsen 				SYSCTRL_PWRSTAT_CM3_MIRACK_A))
96a7b6b979SRalph Siemsen 			break;
97a7b6b979SRalph Siemsen 
98a7b6b979SRalph Siemsen 	if (io_read32(cm3_pwrstat_reg) & SYSCTRL_PWRSTAT_CM3_MIRACK_A)
99a7b6b979SRalph Siemsen 		panic();
100a7b6b979SRalph Siemsen 
101a7b6b979SRalph Siemsen 	/* Clock Enable for CM3_HCLK & Active low Reset to CM3 */
102a7b6b979SRalph Siemsen 	io_setbits32(cm3_pwrctrl_reg, SYSCTRL_PWRCTRL_CM3_CLKEN_A);
103a7b6b979SRalph Siemsen 	io_setbits32(cm3_pwrctrl_reg, SYSCTRL_PWRCTRL_CM3_RSTN_A);
104a7b6b979SRalph Siemsen 
105a7b6b979SRalph Siemsen 	return TEE_SUCCESS;
106a7b6b979SRalph Siemsen }
107a7b6b979SRalph Siemsen 
108a7b6b979SRalph Siemsen service_init(rzn1_cm3_start);
109a7b6b979SRalph Siemsen #endif
110