blob: 3145fea2b1665bb8d548a20c3d616af2ea66088a [file] [log] [blame]
Samuel Hollandb8566642017-08-12 04:07:39 -05001/*
Samuel Hollandd00eaa22019-10-27 14:07:52 -05002 * Copyright (c) 2017-2019, ARM Limited and Contributors. All rights reserved.
Samuel Hollandb8566642017-08-12 04:07:39 -05003 *
4 * SPDX-License-Identifier: BSD-3-Clause
5 */
6
Antonio Nino Diaz6f3ccc52018-07-20 09:17:26 +01007#ifndef PLATFORM_DEF_H
8#define PLATFORM_DEF_H
Samuel Hollandb8566642017-08-12 04:07:39 -05009
Antonio Nino Diaze0f90632018-12-14 00:18:21 +000010#include <common/tbbr/tbbr_img_def.h>
11#include <lib/utils_def.h>
12#include <plat/common/common_def.h>
13
Samuel Hollandb8566642017-08-12 04:07:39 -050014#include <sunxi_mmap.h>
Samuel Hollandb8566642017-08-12 04:07:39 -050015
Andre Przywaracd1c67e2020-11-28 01:38:15 +000016/* The SCP firmware is allocated the last 16KiB of SRAM A2. */
17#define SUNXI_SCP_SIZE 0x4000
18
19#ifdef SUNXI_BL31_IN_DRAM
20#else /* !SUNXI_BL31_IN_DRAM */
21
Samuel Holland38d98de2019-02-17 15:10:36 -060022#define BL31_BASE (SUNXI_SRAM_A2_BASE + 0x4000)
Samuel Hollandd002f3b2019-12-29 12:22:55 -060023#define BL31_LIMIT (SUNXI_SRAM_A2_BASE + \
24 SUNXI_SRAM_A2_SIZE - SUNXI_SCP_SIZE)
Samuel Hollandd002f3b2019-12-29 12:22:55 -060025#define SUNXI_SCP_BASE BL31_LIMIT
Samuel Hollandb8566642017-08-12 04:07:39 -050026
Samuel Hollandd00eaa22019-10-27 14:07:52 -050027/* Overwrite U-Boot SPL, but reserve the first page for the SPL header. */
28#define BL31_NOBITS_BASE (SUNXI_SRAM_A1_BASE + 0x1000)
29#define BL31_NOBITS_LIMIT (SUNXI_SRAM_A1_BASE + SUNXI_SRAM_A1_SIZE)
30
Andre Przywaracd1c67e2020-11-28 01:38:15 +000031#define MAX_XLAT_TABLES 1
32#define PLAT_VIRT_ADDR_SPACE_SIZE (1ULL << 28)
33#define SUNXI_BL33_VIRT_BASE (SUNXI_DRAM_VIRT_BASE + SUNXI_DRAM_SEC_SIZE)
34
35#endif /* SUNXI_BL31_IN_DRAM */
36
Andre Przywarab3fddff2018-09-20 21:13:55 +010037/* How much memory to reserve as secure for BL32, if configured */
38#define SUNXI_DRAM_SEC_SIZE (32U << 20)
39
Andre Przywaraea5fa472018-09-16 02:08:06 +010040/* How much DRAM to map (to map BL33, for fetching the DTB from U-Boot) */
Andre Przywarab3fddff2018-09-20 21:13:55 +010041#define SUNXI_DRAM_MAP_SIZE (64U << 20)
42
Samuel Hollandb8566642017-08-12 04:07:39 -050043#define CACHE_WRITEBACK_SHIFT 6
44#define CACHE_WRITEBACK_GRANULE (1 << CACHE_WRITEBACK_SHIFT)
45
Samuel Hollanda4fbdfa2019-10-27 17:30:15 -050046#define MAX_MMAP_REGIONS (3 + PLATFORM_MMAP_REGIONS)
Samuel Hollandb8566642017-08-12 04:07:39 -050047
Samuel Holland103ee9b2018-10-21 12:41:03 -050048#define PLAT_CSS_SCP_COM_SHARED_MEM_BASE \
49 (SUNXI_SRAM_A2_BASE + SUNXI_SRAM_A2_SIZE - 0x200)
50
Antonio Nino Diaz6f3ccc52018-07-20 09:17:26 +010051#define PLAT_MAX_PWR_LVL_STATES U(2)
52#define PLAT_MAX_RET_STATE U(1)
53#define PLAT_MAX_OFF_STATE U(2)
Samuel Hollandb8566642017-08-12 04:07:39 -050054
Antonio Nino Diaz6f3ccc52018-07-20 09:17:26 +010055#define PLAT_MAX_PWR_LVL U(2)
Deepika Bhavnanifa4e1d02019-12-13 10:48:27 -060056#define PLAT_NUM_PWR_DOMAINS (U(1) + \
Samuel Hollandb8566642017-08-12 04:07:39 -050057 PLATFORM_CLUSTER_COUNT + \
58 PLATFORM_CORE_COUNT)
59
60#define PLAT_PHY_ADDR_SPACE_SIZE (1ULL << 32)
Samuel Hollandb8566642017-08-12 04:07:39 -050061
Deepika Bhavnanifa4e1d02019-12-13 10:48:27 -060062#define PLATFORM_CLUSTER_COUNT U(1)
Samuel Hollandb8566642017-08-12 04:07:39 -050063#define PLATFORM_CORE_COUNT (PLATFORM_CLUSTER_COUNT * \
64 PLATFORM_MAX_CPUS_PER_CLUSTER)
Deepika Bhavnanifa4e1d02019-12-13 10:48:27 -060065#define PLATFORM_MAX_CPUS_PER_CLUSTER U(4)
Samuel Hollandd002f3b2019-12-29 12:22:55 -060066#define PLATFORM_MMAP_REGIONS 5
Samuel Hollandb8566642017-08-12 04:07:39 -050067#define PLATFORM_STACK_SIZE (0x1000 / PLATFORM_CORE_COUNT)
68
Amit Singh Tomar2f372242018-06-20 00:44:50 +053069#ifndef SPD_none
70#ifndef BL32_BASE
71#define BL32_BASE SUNXI_DRAM_BASE
72#endif
73#endif
74
Antonio Nino Diaz6f3ccc52018-07-20 09:17:26 +010075#endif /* PLATFORM_DEF_H */