blob: fa99dc76d35cb2eb651ca3d7ce5f523b80b9b26a [file] [log] [blame]
Andrew F. Davis6a2b2672017-07-10 14:45:52 -05001/*
2 * Copyright 2017 Texas Instruments, Inc.
3 *
4 * SPDX-License-Identifier: GPL-2.0+
5 */
6
7#include <common.h>
Masahiro Yamada75f82d02018-03-05 01:20:11 +09008#include <linux/libfdt.h>
Andrew F. Davis6a2b2672017-07-10 14:45:52 -05009#include <fdt_support.h>
10#include <malloc.h>
11
12#include <asm/omap_common.h>
13#include <asm/arch-am33xx/sys_proto.h>
14
15#ifdef CONFIG_TI_SECURE_DEVICE
16
17static void ft_hs_fixups(void *fdt, bd_t *bd)
18{
19 /* Check we are running on an HS/EMU device type */
20 if (GP_DEVICE != get_device_type()) {
21 if ((ft_hs_disable_rng(fdt, bd) == 0) &&
22 (ft_hs_fixup_dram(fdt, bd) == 0) &&
23 (ft_hs_add_tee(fdt, bd) == 0))
24 return;
25 } else {
26 printf("ERROR: Incorrect device type (GP) detected!");
27 }
28 /* Fixup failed or wrong device type */
29 hang();
30}
31#else
32static void ft_hs_fixups(void *fdt, bd_t *bd) { }
33#endif /* #ifdef CONFIG_TI_SECURE_DEVICE */
34
35/*
36 * Place for general cpu/SoC FDT fixups. Board specific
37 * fixups should remain in the board files which is where
38 * this function should be called from.
39 */
40void ft_cpu_setup(void *fdt, bd_t *bd)
41{
42 ft_hs_fixups(fdt, bd);
43}