blob: 5043f4b59341cf5323a272b691b7ae77df46489e [file] [log] [blame]
Masahiro Yamada574388c2016-09-03 11:37:40 +09001/*
Masahiro Yamadae30ec7f2020-01-17 13:46:38 +09002 * Copyright (c) 2017-2020, ARM Limited and Contributors. All rights reserved.
Masahiro Yamada574388c2016-09-03 11:37:40 +09003 *
4 * SPDX-License-Identifier: BSD-3-Clause
5 */
6
Masahiro Yamada1a741d92020-02-03 19:46:15 +09007#include <assert.h>
8
Masahiro Yamada574388c2016-09-03 11:37:40 +09009#include <platform_def.h>
Antonio Nino Diaze0f90632018-12-14 00:18:21 +000010
11#include <common/debug.h>
12#include <lib/xlat_tables/xlat_tables_v2.h>
Masahiro Yamada9c3da382020-03-26 13:18:48 +090013#include <plat/common/platform.h>
Masahiro Yamada574388c2016-09-03 11:37:40 +090014
Masahiro Yamada1a741d92020-02-03 19:46:15 +090015#include "uniphier.h"
16
17struct uniphier_reg_region {
18 uintptr_t base;
19 size_t size;
20};
Masahiro Yamada574388c2016-09-03 11:37:40 +090021
Masahiro Yamada1a741d92020-02-03 19:46:15 +090022static const struct uniphier_reg_region uniphier_reg_region[] = {
23 [UNIPHIER_SOC_LD11] = {
24 .base = 0x50000000UL,
25 .size = 0x20000000UL,
26 },
27 [UNIPHIER_SOC_LD20] = {
28 .base = 0x50000000UL,
29 .size = 0x20000000UL,
30 },
31 [UNIPHIER_SOC_PXS3] = {
32 .base = 0x50000000UL,
33 .size = 0x20000000UL,
34 },
35};
36
37void uniphier_mmap_setup(unsigned int soc)
Masahiro Yamada574388c2016-09-03 11:37:40 +090038{
39 VERBOSE("Trusted RAM seen by this BL image: %p - %p\n",
Masahiro Yamadae30ec7f2020-01-17 13:46:38 +090040 (void *)BL_CODE_BASE, (void *)BL_END);
41 mmap_add_region(BL_CODE_BASE, BL_CODE_BASE,
42 round_up(BL_END, PAGE_SIZE) - BL_CODE_BASE,
Masahiro Yamada574388c2016-09-03 11:37:40 +090043 MT_MEMORY | MT_RW | MT_SECURE);
44
45 /* remap the code section */
46 VERBOSE("Code region: %p - %p\n",
47 (void *)BL_CODE_BASE, (void *)BL_CODE_END);
48 mmap_add_region(BL_CODE_BASE, BL_CODE_BASE,
49 round_up(BL_CODE_END, PAGE_SIZE) - BL_CODE_BASE,
50 MT_CODE | MT_SECURE);
51
52 /* remap the coherent memory region */
53 VERBOSE("Coherent region: %p - %p\n",
54 (void *)BL_COHERENT_RAM_BASE, (void *)BL_COHERENT_RAM_END);
55 mmap_add_region(BL_COHERENT_RAM_BASE, BL_COHERENT_RAM_BASE,
56 BL_COHERENT_RAM_END - BL_COHERENT_RAM_BASE,
57 MT_DEVICE | MT_RW | MT_SECURE);
58
Masahiro Yamada574388c2016-09-03 11:37:40 +090059 /* register region */
Masahiro Yamada1a741d92020-02-03 19:46:15 +090060 assert(soc < ARRAY_SIZE(uniphier_reg_region));
61 mmap_add_region(uniphier_reg_region[soc].base,
62 uniphier_reg_region[soc].base,
63 uniphier_reg_region[soc].size,
Masahiro Yamada574388c2016-09-03 11:37:40 +090064 MT_DEVICE | MT_RW | MT_SECURE);
65
Masahiro Yamada574388c2016-09-03 11:37:40 +090066 init_xlat_tables();
Masahiro Yamadac80bb432020-03-26 13:18:48 +090067
68 enable_mmu(0);
Masahiro Yamada9c3da382020-03-26 13:18:48 +090069
70#if PLAT_RO_XLAT_TABLES
71 {
72 int ret;
73
74 ret = xlat_make_tables_readonly();
75 if (ret) {
76 ERROR("Failed to make translation tables read-only.");
77 plat_error_handler(ret);
78 }
79 }
80#endif
Masahiro Yamada574388c2016-09-03 11:37:40 +090081}