Sandrine Bailleux | 798140d | 2014-07-17 16:06:39 +0100 | [diff] [blame] | 1 | /* |
Manish V Badarkhe | 01e9dd2 | 2020-08-04 17:13:14 +0100 | [diff] [blame] | 2 | * Copyright (c) 2014-2020, ARM Limited and Contributors. All rights reserved. |
Sandrine Bailleux | 798140d | 2014-07-17 16:06:39 +0100 | [diff] [blame] | 3 | * |
dp-arm | fa3cf0b | 2017-05-03 09:38:09 +0100 | [diff] [blame] | 4 | * SPDX-License-Identifier: BSD-3-Clause |
Sandrine Bailleux | 798140d | 2014-07-17 16:06:39 +0100 | [diff] [blame] | 5 | */ |
| 6 | |
Antonio Nino Diaz | 6f3ccc5 | 2018-07-20 09:17:26 +0100 | [diff] [blame] | 7 | #ifndef JUNO_DEF_H |
| 8 | #define JUNO_DEF_H |
Sandrine Bailleux | 798140d | 2014-07-17 16:06:39 +0100 | [diff] [blame] | 9 | |
Antonio Nino Diaz | e0f9063 | 2018-12-14 00:18:21 +0000 | [diff] [blame] | 10 | #include <lib/utils_def.h> |
Sandrine Bailleux | 798140d | 2014-07-17 16:06:39 +0100 | [diff] [blame] | 11 | |
Manish V Badarkhe | 01e9dd2 | 2020-08-04 17:13:14 +0100 | [diff] [blame] | 12 | /****************************************************************************** |
| 13 | * Definition of platform soc id |
| 14 | *****************************************************************************/ |
| 15 | #define JUNO_SOC_ID 1 |
| 16 | |
Sandrine Bailleux | 798140d | 2014-07-17 16:06:39 +0100 | [diff] [blame] | 17 | /******************************************************************************* |
| 18 | * Juno memory map related constants |
| 19 | ******************************************************************************/ |
Sandrine Bailleux | fd8f898 | 2015-02-04 14:06:10 +0000 | [diff] [blame] | 20 | |
| 21 | /* Board revisions */ |
Antonio Nino Diaz | ab5d2b1 | 2018-10-30 16:12:32 +0000 | [diff] [blame] | 22 | #define REV_JUNO_R0 U(0x1) /* Rev B */ |
| 23 | #define REV_JUNO_R1 U(0x2) /* Rev C */ |
| 24 | #define REV_JUNO_R2 U(0x3) /* Rev D */ |
Sandrine Bailleux | 798140d | 2014-07-17 16:06:39 +0100 | [diff] [blame] | 25 | |
Dan Handley | 7bef800 | 2015-03-19 19:22:44 +0000 | [diff] [blame] | 26 | /* Bypass offset from start of NOR flash */ |
Antonio Nino Diaz | ab5d2b1 | 2018-10-30 16:12:32 +0000 | [diff] [blame] | 27 | #define BL1_ROM_BYPASS_OFFSET UL(0x03EC0000) |
Sandrine Bailleux | 798140d | 2014-07-17 16:06:39 +0100 | [diff] [blame] | 28 | |
Antonio Nino Diaz | ab5d2b1 | 2018-10-30 16:12:32 +0000 | [diff] [blame] | 29 | #define EMMC_BASE UL(0x0c000000) |
| 30 | #define EMMC_SIZE UL(0x04000000) |
Sandrine Bailleux | 798140d | 2014-07-17 16:06:39 +0100 | [diff] [blame] | 31 | |
Antonio Nino Diaz | ab5d2b1 | 2018-10-30 16:12:32 +0000 | [diff] [blame] | 32 | #define PSRAM_BASE UL(0x14000000) |
| 33 | #define PSRAM_SIZE UL(0x02000000) |
Sandrine Bailleux | 798140d | 2014-07-17 16:06:39 +0100 | [diff] [blame] | 34 | |
Antonio Nino Diaz | ab5d2b1 | 2018-10-30 16:12:32 +0000 | [diff] [blame] | 35 | #define JUNO_SSC_VER_PART_NUM U(0x030) |
Sandrine Bailleux | 798140d | 2014-07-17 16:06:39 +0100 | [diff] [blame] | 36 | |
| 37 | /******************************************************************************* |
Soby Mathew | 47e43f2 | 2016-02-01 14:04:34 +0000 | [diff] [blame] | 38 | * Juno topology related constants |
| 39 | ******************************************************************************/ |
Deepika Bhavnani | 4287c0c | 2019-12-13 10:23:18 -0600 | [diff] [blame] | 40 | #define JUNO_CLUSTER_COUNT U(2) |
| 41 | #define JUNO_CLUSTER0_CORE_COUNT U(2) |
| 42 | #define JUNO_CLUSTER1_CORE_COUNT U(4) |
Soby Mathew | 47e43f2 | 2016-02-01 14:04:34 +0000 | [diff] [blame] | 43 | |
| 44 | /******************************************************************************* |
Sandrine Bailleux | 798140d | 2014-07-17 16:06:39 +0100 | [diff] [blame] | 45 | * TZC-400 related constants |
| 46 | ******************************************************************************/ |
Dan Handley | 7bef800 | 2015-03-19 19:22:44 +0000 | [diff] [blame] | 47 | #define TZC400_NSAID_CCI400 0 /* Note: Same as default NSAID!! */ |
| 48 | #define TZC400_NSAID_PCIE 1 |
| 49 | #define TZC400_NSAID_HDLCD0 2 |
| 50 | #define TZC400_NSAID_HDLCD1 3 |
| 51 | #define TZC400_NSAID_USB 4 |
| 52 | #define TZC400_NSAID_DMA330 5 |
| 53 | #define TZC400_NSAID_THINLINKS 6 |
| 54 | #define TZC400_NSAID_AP 9 |
| 55 | #define TZC400_NSAID_GPU 10 |
| 56 | #define TZC400_NSAID_SCP 11 |
| 57 | #define TZC400_NSAID_CORESIGHT 12 |
Sandrine Bailleux | 798140d | 2014-07-17 16:06:39 +0100 | [diff] [blame] | 58 | |
Juan Castillo | 21b0419 | 2014-08-12 17:24:30 +0100 | [diff] [blame] | 59 | /******************************************************************************* |
dp-arm | 8f59e15 | 2017-02-27 12:21:43 +0000 | [diff] [blame] | 60 | * TRNG related constants |
| 61 | ******************************************************************************/ |
Antonio Nino Diaz | ab5d2b1 | 2018-10-30 16:12:32 +0000 | [diff] [blame] | 62 | #define TRNG_BASE UL(0x7FE60000) |
dp-arm | 8f59e15 | 2017-02-27 12:21:43 +0000 | [diff] [blame] | 63 | #define TRNG_NOUTPUTS 4 |
Antonio Nino Diaz | ab5d2b1 | 2018-10-30 16:12:32 +0000 | [diff] [blame] | 64 | #define TRNG_STATUS UL(0x10) |
| 65 | #define TRNG_INTMASK UL(0x14) |
| 66 | #define TRNG_CONFIG UL(0x18) |
| 67 | #define TRNG_CONTROL UL(0x1C) |
dp-arm | b3263b3 | 2017-02-28 14:43:15 +0000 | [diff] [blame] | 68 | #define TRNG_NBYTES 16 /* Number of bytes generated per round. */ |
dp-arm | 8f59e15 | 2017-02-27 12:21:43 +0000 | [diff] [blame] | 69 | |
| 70 | /******************************************************************************* |
Robin Murphy | 0f1d666 | 2015-01-09 14:30:58 +0000 | [diff] [blame] | 71 | * MMU-401 related constants |
| 72 | ******************************************************************************/ |
Antonio Nino Diaz | ab5d2b1 | 2018-10-30 16:12:32 +0000 | [diff] [blame] | 73 | #define MMU401_SSD_OFFSET UL(0x4000) |
| 74 | #define MMU401_DMA330_BASE UL(0x7fb00000) |
Dan Handley | 7bef800 | 2015-03-19 19:22:44 +0000 | [diff] [blame] | 75 | |
Vikram Kanigiri | f3bcea2 | 2015-06-24 17:51:09 +0100 | [diff] [blame] | 76 | /******************************************************************************* |
| 77 | * Interrupt handling constants |
| 78 | ******************************************************************************/ |
| 79 | #define JUNO_IRQ_DMA_SMMU 126 |
| 80 | #define JUNO_IRQ_HDLCD0_SMMU 128 |
| 81 | #define JUNO_IRQ_HDLCD1_SMMU 130 |
| 82 | #define JUNO_IRQ_USB_SMMU 132 |
| 83 | #define JUNO_IRQ_THIN_LINKS_SMMU 134 |
| 84 | #define JUNO_IRQ_SEC_I2C 137 |
| 85 | #define JUNO_IRQ_GPU_SMMU_1 73 |
| 86 | #define JUNO_IRQ_ETR_SMMU 75 |
Robin Murphy | 0f1d666 | 2015-01-09 14:30:58 +0000 | [diff] [blame] | 87 | |
Roberto Vargas | bcca6c6 | 2018-06-11 16:15:35 +0100 | [diff] [blame] | 88 | /******************************************************************************* |
| 89 | * Memprotect definitions |
| 90 | ******************************************************************************/ |
| 91 | /* PSCI memory protect definitions: |
| 92 | * This variable is stored in a non-secure flash because some ARM reference |
| 93 | * platforms do not have secure NVRAM. Real systems that provided MEM_PROTECT |
| 94 | * support must use a secure NVRAM to store the PSCI MEM_PROTECT definitions. |
| 95 | */ |
| 96 | #define PLAT_ARM_MEM_PROT_ADDR (V2M_FLASH0_BASE + \ |
| 97 | V2M_FLASH0_SIZE - V2M_FLASH_BLOCK_SIZE) |
| 98 | |
Antonio Nino Diaz | 6f3ccc5 | 2018-07-20 09:17:26 +0100 | [diff] [blame] | 99 | #endif /* JUNO_DEF_H */ |