blob: 3e81616cb7465aecd296a9e81d5a216c5925dc6e [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001// SPDX-License-Identifier: GPL-2.0+
Andrew F. Davis6a2b2672017-07-10 14:45:52 -05002/*
3 * Copyright 2017 Texas Instruments, Inc.
Andrew F. Davis6a2b2672017-07-10 14:45:52 -05004 */
5
Simon Glassf11478f2019-12-28 10:45:07 -07006#include <hang.h>
Masahiro Yamada75f82d02018-03-05 01:20:11 +09007#include <linux/libfdt.h>
Andrew F. Davis6a2b2672017-07-10 14:45:52 -05008#include <fdt_support.h>
9#include <malloc.h>
10
11#include <asm/omap_common.h>
12#include <asm/arch-am33xx/sys_proto.h>
13
14#ifdef CONFIG_TI_SECURE_DEVICE
15
Masahiro Yamadaf7ed78b2020-06-26 15:13:33 +090016static void ft_hs_fixups(void *fdt, struct bd_info *bd)
Andrew F. Davis6a2b2672017-07-10 14:45:52 -050017{
18 /* Check we are running on an HS/EMU device type */
19 if (GP_DEVICE != get_device_type()) {
20 if ((ft_hs_disable_rng(fdt, bd) == 0) &&
21 (ft_hs_fixup_dram(fdt, bd) == 0) &&
22 (ft_hs_add_tee(fdt, bd) == 0))
23 return;
24 } else {
25 printf("ERROR: Incorrect device type (GP) detected!");
26 }
27 /* Fixup failed or wrong device type */
28 hang();
29}
30#else
Masahiro Yamadaf7ed78b2020-06-26 15:13:33 +090031static void ft_hs_fixups(void *fdt, struct bd_info *bd) { }
Andrew F. Davis6a2b2672017-07-10 14:45:52 -050032#endif /* #ifdef CONFIG_TI_SECURE_DEVICE */
33
34/*
35 * Place for general cpu/SoC FDT fixups. Board specific
36 * fixups should remain in the board files which is where
37 * this function should be called from.
38 */
Masahiro Yamadaf7ed78b2020-06-26 15:13:33 +090039void ft_cpu_setup(void *fdt, struct bd_info *bd)
Andrew F. Davis6a2b2672017-07-10 14:45:52 -050040{
41 ft_hs_fixups(fdt, bd);
42}