2018-05-06 21:58:06 +00:00
|
|
|
// SPDX-License-Identifier: GPL-2.0+
|
2015-08-25 02:49:19 +00:00
|
|
|
/*
|
|
|
|
* (C) Copyright 2015 Chen-Yu Tsai <wens@csie.org>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <asm/io.h>
|
|
|
|
#include <asm/arch/cpu.h>
|
|
|
|
#include <asm/arch/tzpc.h>
|
|
|
|
|
|
|
|
/* Configure Trust Zone Protection Controller */
|
|
|
|
void tzpc_init(void)
|
|
|
|
{
|
|
|
|
struct sunxi_tzpc *tzpc = (struct sunxi_tzpc *)SUNXI_TZPC_BASE;
|
|
|
|
|
2016-01-06 07:13:06 +00:00
|
|
|
#ifdef CONFIG_MACH_SUN6I
|
2015-08-25 02:49:19 +00:00
|
|
|
/* Enable non-secure access to the RTC */
|
2016-01-06 07:13:06 +00:00
|
|
|
writel(SUN6I_TZPC_DECPORT0_RTC, &tzpc->decport0_set);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef CONFIG_MACH_SUN8I_H3
|
|
|
|
/* Enable non-secure access to all peripherals */
|
|
|
|
writel(SUN8I_H3_TZPC_DECPORT0_ALL, &tzpc->decport0_set);
|
|
|
|
writel(SUN8I_H3_TZPC_DECPORT1_ALL, &tzpc->decport1_set);
|
|
|
|
writel(SUN8I_H3_TZPC_DECPORT2_ALL, &tzpc->decport2_set);
|
|
|
|
#endif
|
2015-08-25 02:49:19 +00:00
|
|
|
}
|