/* * Copyright (c) 2017-2020, ARM Limited and Contributors. All rights reserved. * * SPDX-License-Identifier: BSD-3-Clause */ #include #include #include #include #include #include #define DMA_SEC_REG 0x20 /* * Setup the peripherals to be accessible by non-secure world. * This will not work for the Secure Peripherals Controller (SPC) unless * a fuse it burnt (seems to be an erratum), but we do it nevertheless, * to allow booting on boards using secure boot. */ void sunxi_security_setup(void) { int i; INFO("Configuring SPC Controller\n"); /* SPC setup: set all devices to non-secure */ for (i = 0; i < SUNXI_SPC_NUM_PORTS; i++) mmio_write_32(SUNXI_SPC_DECPORT_SET_REG(i), 0xffffffff); /* set MBUS clocks, bus clocks (AXI/AHB/APB) and PLLs to non-secure */ mmio_write_32(SUNXI_CCU_SEC_SWITCH_REG, 0x7); /* Set R_PRCM bus clocks to non-secure */ mmio_write_32(SUNXI_R_PRCM_SEC_SWITCH_REG, 0x1); /* Set all DMA channels (16 max.) to non-secure */ mmio_write_32(SUNXI_DMA_BASE + DMA_SEC_REG, 0xffff); }