blob: a96baae061955bdae9bd5b1c8f9e42b4efebcf60 [file] [log] [blame]
Abdellatif El Khlifiad9b8e52021-04-21 17:20:43 +01001/*
Vishnu Banavath2b651ea2022-01-19 18:43:12 +00002 * Copyright (c) 2021-2022, Arm Limited and Contributors. All rights reserved.
Abdellatif El Khlifiad9b8e52021-04-21 17:20:43 +01003 *
4 * SPDX-License-Identifier: BSD-3-Clause
5 */
6
7#include <assert.h>
8
9#include <common/bl_common.h>
10
Satish Kumaraa4a3af2021-10-27 16:31:04 +010011#include <drivers/generic_delay_timer.h>
12#include <drivers/io/io_storage.h>
Abdellatif El Khlifiad9b8e52021-04-21 17:20:43 +010013#include <plat/common/platform.h>
Satish Kumaraa4a3af2021-10-27 16:31:04 +010014#include <plat/arm/common/arm_fconf_getter.h>
15#include <plat/arm/common/arm_fconf_io_storage.h>
16#include <plat/arm/common/plat_arm.h>
Abdellatif El Khlifiad9b8e52021-04-21 17:20:43 +010017#include <platform_def.h>
18
19/*
20 * Table of regions to map using the MMU.
21 * Replace or extend the below regions as required
22 */
23
24const mmap_region_t plat_arm_mmap[] = {
25 ARM_MAP_SHARED_RAM,
26 ARM_MAP_NS_SHARED_RAM,
27 ARM_MAP_NS_DRAM1,
Vishnu Banavath2b651ea2022-01-19 18:43:12 +000028 CORSTONE1000_MAP_DEVICE,
29 CORSTONE1000_EXTERNAL_FLASH,
Abdellatif El Khlifiad9b8e52021-04-21 17:20:43 +010030 {0}
31};
32
Satish Kumaraa4a3af2021-10-27 16:31:04 +010033static void set_fip_image_source(void)
34{
35 const struct plat_io_policy *policy;
36 /*
37 * metadata for firmware update is written at 0x0000 offset of the flash.
38 * PLAT_ARM_BOOT_BANK_FLAG contains the boot bank that TF-M is booted.
39 * As per firmware update spec, at a given point of time, only one bank is active.
40 * This means, TF-A should boot from the same bank as TF-M.
41 */
42 volatile uint32_t *boot_bank_flag = (uint32_t *)(PLAT_ARM_BOOT_BANK_FLAG);
43 if (*boot_bank_flag > 1) {
44 VERBOSE("Boot_bank is set higher than possible values");
45 }
46
47 VERBOSE("Boot bank flag = %u.\n\r", *boot_bank_flag);
48
49 policy = FCONF_GET_PROPERTY(arm, io_policies, FIP_IMAGE_ID);
50
51 assert(policy != NULL);
52 assert(policy->image_spec != 0UL);
53
54 io_block_spec_t *spec = (io_block_spec_t *)policy->image_spec;
55
56 if ((*boot_bank_flag) == 0) {
57 VERBOSE("Booting from bank 0: fip offset = 0x%lx\n\r",
58 PLAT_ARM_FIP_BASE_BANK0);
59 spec->offset = PLAT_ARM_FIP_BASE_BANK0;
60 } else {
61 VERBOSE("Booting from bank 1: fip offset = 0x%lx\n\r",
62 PLAT_ARM_FIP_BASE_BANK1);
63 spec->offset = PLAT_ARM_FIP_BASE_BANK1;
64 }
65}
66
67void bl2_platform_setup(void)
68{
69 arm_bl2_platform_setup();
70 /*
71 * Identify the start address of the FIP by reading the boot
72 * index flag from the flash.
73 */
74 set_fip_image_source();
75}
76
Vishnu Banavath2b651ea2022-01-19 18:43:12 +000077/* corstone1000 only has one always-on power domain and there
Abdellatif El Khlifiad9b8e52021-04-21 17:20:43 +010078 * is no power control present
79 */
80void __init plat_arm_pwrc_setup(void)
81{
82}
83
84unsigned int plat_get_syscnt_freq2(void)
85{
86 /* Returning the Generic Timer Frequency */
87 return SYS_COUNTER_FREQ_IN_TICKS;
88}
89
90
91/*
92 * Helper function to initialize ARM interconnect driver.
93 */
94void plat_arm_interconnect_init(void)
95{
96}
97
98/*
99 * Helper function to place current master into coherency
100 */
101void plat_arm_interconnect_enter_coherency(void)
102{
103}
104
105/*
106 * Helper function to remove current master from coherency
107 */
108void plat_arm_interconnect_exit_coherency(void)
109{
110}
111
112/*
113 * This function is invoked during Mbed TLS library initialisation to get a heap
114 * The function simply returns the default allocated heap.
115 */
116
117#if TRUSTED_BOARD_BOOT
118int plat_get_mbedtls_heap(void **heap_addr, size_t *heap_size)
119{
120 assert(heap_addr != NULL);
121 assert(heap_size != NULL);
122
123 return arm_get_mbedtls_heap(heap_addr, heap_size);
124}
125#endif