DEN0001C Principles of Arm Memory Maps
DEN0001C Principles of Arm Memory Maps
White Paper
Document number: ARM DEN 0001C Copyright ARM Limited 2012
Release information
The Change history table lists the changes made to this document.
19 October 2012
Non-Confidential
Proprietary Notice Words and logos marked with or are registered trademarks or trademarks of ARM in the EU and other countries, except as otherwise stated below in this proprietary notice. Other brands and names mentioned herein may be the trademarks of their respective owners. Neither the whole nor any part of the information contained in, or the product described in, this document may be adapted or reproduced in any material form except with the prior written permission of the copyright holder. The product described in this document is subject to continuous developments and improvements. All particulars of the product and its use contained in this document are given by ARM in good faith. However, all warranties implied or expressed, including but not limited to implied warranties of merchantability, or fitness for purpose, are excluded. This document is intended only to assist the reader in the use of the product. ARM shall not be liable for any loss or damage arising from the use of any information in this document, or any error or omission in such information, or any incorrect use of the product. Where the term ARM is used it means ARM or any of its subsidiaries as appropriate. Confidentiality Status This document is Non-Confidential. The right to use, copy and disclose this document may be subject to license restrictions in accordance with the terms of the agreement entered into by ARM and the party that ARM delivered this document to. Web Address http://www.arm.com
Table of Contents
Table of Contents
1 Introduction ................................................................................................................ 4 1.1 Scope.................................................................................................................. 4 1.2 Additional reading ............................................................................................... 4 1.3 Conventions ........................................................................................................ 4 Overview ..................................................................................................................... 5 2.1 CPUs and hardware ........................................................................................... 6 2.2 Software Portability ............................................................................................. 7 2.3 Address Map overview ....................................................................................... 9 Address map principles .......................................................................................... 10 32-bit, 36-bit and 40-bit ARM Address Maps......................................................... 14 4.1 32-bit Memory Map ........................................................................................... 15 4.2 36-bit Memory Map ........................................................................................... 16 4.3 40-bit Memory Map ........................................................................................... 17 Proposed 44-bit and 48bit Address Maps ............................................................. 19 5.1 44-bit Memory Map ........................................................................................... 20 5.2 48-bit Memory Map ........................................................................................... 21 Glossary.................................................................................................................... 22 Appendix A: Memory map example, ARM Versatile Express ............................. 23
3 4
6 7
Introduction
Introduction
This document describes the address maps used by ARM for A-class systems, from models and emulators to development boards and complex SoCs. It explains the choice of address partitioning for memories, peripherals, and expansion spaces. It describes the issues and constraints when 32bit platform operating systems use a 36-bit or 40-bit address space, and the restrictions imposed by 32-bit bus masters and peripherals. It extends the memory maps to 48-bits of address space for future 64-bit ARM systems,
1.1
Scope
This document is applicable to ARM systems containing: 32-bit ARMv7 A-profile CPUs with Large Physical Address Extension (LPAE). 64-bit ARMv8 A-profile CPUs
This document replaces the deprecated DEN001 Principles of ARM Memory Maps PDD.
1.2
Additional reading
This section lists publications by ARM and by third parties. The following documents contain information relevant to this document: ARM Architecture Reference Manual ARMv7-A and ARMv7-R edition (ARM DDI 0406) ARMv8 documentation has limited availability at this time. Please see ARM info center for latest updates . Appendix A: TC2 and Versatile Expressand o Motherboard Express ATX (V2M-P1) o v2p ca15 a7 reference manual (DDI0503B)
1.3
Conventions
This paper uses the terms memory map and address map interchangeably.
Overview
Overview
ARM creates a variety of development systems to support A-class cortex CPUs, ranging from cycle accurate RTL models, to fast software models, onto FPGAs and full custom SoCs. ARM has been harmonizing the memory maps in these systems to provide internal consistency and software portability, and to address the constraints that come with mixing 32-bit components within larger address spaces. The introduction of Large Physical Address Extension (LPAE) to ARMv7 class CPUs has grown the physical address spaces to 36-bit and 40-bits, providing 64GB or 1024GB (1TB) memory space. Likewise the 64-bit ARMv8 architecture can address 48-bits, providing 256TB. This paper describes ARM address maps for 32, 36 and 40-bit systems, and proposes extensions for 44 and 48-bit systems. Each larger address map is a superset of the smaller space, to enable the system to boot and interwork between address spaces. It does define and explain the gross partitioning of the address space for memories, peripherals, and expansion space. It does not specify or require the addresses of individual peripherals. The principles expressed in this paper help drive some of the design decisions ARM makes when defining system IP such as interconnects and memory controllers.
Overview
2.1
2.1.1
2.1.2
32-bit ARMv7 with LPAE The introduction of LPAE enabled access to a 40-bit address space, as found on the ARM Cortex-A15 and Cortex-A7. A 32bit ARM processor requires an Extended VMSAv7 MMU to access the extended memory addresses. This multistage MMU provides the translations from a 32-bit virtual address (VA) to a 40-bit intermediate physical address (IPA), and then to a 40-bit physical address (PA). The processors Memory Model Feature Register, ID_MMFR3, provides the size of the actual physical memory supported of 32, 36, or 40 bits. The ARMv7 MMU with LPAE controls memory access down to a 4Kbyte granule.
2.1.3
64-bit ARMv8 64-bit ARMv8 CPUs can naturally access up to 48bits of physical address space, with a two stage MMU performing VA->IPA->PA translations. The ID_A64MMFR0 register describes the size of the actual physical address space, 32, 36,40,42,44 or 48bits. NOTE: A 42bit address space is not described by this paper.
The ARMv8 MMU translation contexts can be configured to control memory access down to a 4Kbyte or 64Kbyte granule.
2.1.4
SMMU and Bus Masters Bus mastering peripherals have direct access to the physical memory map and have similar addressing requirements as operating systems. For example a legacy 32-bit mastering peripheral will be limited to the lowest address space. And will require working data buffers to be within the first 4GB. A System MMU (SMMU) can be placed between a mastering peripheral and the system bus to provide translation and protection services for the peripheral. In this case the SMMU can be programmed to map 32-bit device virtual addresses into 40-bit physical addresses.
Overview
2.2
2.2.1
Software Portability
Operating Systems and Hypervisors In this context hypervisors can be viewed as just another operating system that runs guest operating systems in place of applications.
Operating systems provide applications portability, through defined services which have abstracted the underlying hardware. The portability of the operating system in turn depends upon boot time configuration information, device drivers and system specific adaptation code. ACPI tables and FDTs are ways of providing platform descriptions at boot time to an operating system. The entire address map can be described using these methods, and fixed addresses are not needed. Operating systems do have expectations on the address map, such as: DRAM comes in large contiguous blocks Peripherals can be mapped by MMU page granularity Contiguous I/O space is available for dynamically mapped I/O
Pure 32-bit or 64-bit operating systems with flat address mappings have very few constraints on their address maps. Whereas mixed systems of 32-bit software and bus masters in large address spaces need constraints to ensure they can interwork, such as: Significant 32-bit addressable DRAM 32-bit addressable register mapped I/O Backwards compatibility through address map super sets
Note: Experience has shown that general purpose 32-bit operating systems struggle to manage excessive quantities of DRAM gracefully. 32GB of DRAM is often a practical upper limit, for a 32-bit OS kernel.
2.2.2
Firmware and Test Software Firmware and test software tends to be system specific and less portable than operating systems. Therefore it is advantageous to maintain a strong degree of address space compatibility between iterations and generations of hardware. Non-operating system software will often execute without using the MMU, and therefore peripherals must exist within its natural address space. For many systems this software may remain as 32-bit code far longer than the 64-bit operating system in final use.
2.2.3
Trusted OS The ARM security extensions, known as TrustZone, provide an orthogonal CPU execution state with its own address map that is intended to provide secure services. The execute states are referred to as Secure and Non-Secure.
Overview
The ARMv7 Virtualization Extensions are not provided to a CPU in trusted state. A Trusted OS will manage a single stage of VA to PA mappings, and it does not use or see IPAs.
LPAE when present is available to the trusted state, however It is quite possible that a 32bit Trusted OS will not use LPAE capabilities of the MMU.
Within 64-bit ARM system the Trusted OS can remain as 32-bit software, in which case: A 32-bit Trusted OS will natively use the 32-bit address map. An updated 32-bit LPAE Trusted OS may access up to the 40-bit address map.
A 32bit trusted OS increases the utilization pressure on the lower 2GB of physical DRAM.
Overview
2.3
DRAM. Mapped I/O. Reserved space. Previous memory map, that is, without the additional 4 address bits.
For example the 36-bit address map contains the entire 32-bit address map in the lowest 4GB of address space.
The address maps are partitioned into four types or regions: Static I/O and Static Memories, for register mapped on-chip peripherals, boot ROMs, and scratch RAMs. Mapped I/O, for dynamically configured, memory mapped buses, such as PCIe. DRAM, for main system dynamic memory. Reserved space, for future use.
3.1.1
Uniformity A uniform SoC address map provides consistent physical addresses to all shared resources. Uniform addressing removes the need for additional inter-component translations and can simplify system integration. P1. The global SoC address map for application processors and bus mastering peripherals should be consistent with uniform addresses for all shared accesses. P2. Aliased addresses should not exist for shared resources. Large address maps remove the need to reuse addresses. P3. Private local address maps may exist per CPU/Cluster/Device, to provide private peripherals and memories. For example local GIC interface per CPU. P4. Private local address maps should not clash with globally visible addresses, for the same master.
Some on-SoC micro-controllers have locally fixed address maps. Address remapping from local-CPU relative maps, into the ARM centric address map may be required, in HW and by SW.
3.1.2
Interworking Super Sets P5. Each large memory map must contain the complete smaller memory maps within the lower address ranges. Maintaining smaller sub-set address maps allows for interworking and the forward compatibility of hardware and software designed smaller address spaces.
3.1.3
DRAM The primary need for extending the SoC address space beyond 32-bits is to provide room for more DRAM. However the interworking of hardware and software in mixed address space environment will always happen within the lowest common denominator address space. This leads to memory pressure on the DRAM at lower addresses. DRAM requirements: P6. DRAM must not be aliased, shadowed or decoded to additional physical addresses. P7. Unpopulated DRAM partitions must not alias any other addresses, accesses should return bus errors. Coherent systems rely on unique physical addresses to maintain memory consistency, throughout the caches, buses and memories. By forbidding the presence of aliased memories whole classes of errors and bugs can be avoided.
10
If aliasing can occur explicit software management, in the form or preventative cache flushing, may be required to ensure memory consistency. This flushing will negate the benefits of a coherent system. Additionally aliased DRAM can have negative security implications. P8. DRAM holes (when present) must not alias any other address, including DRAM, and accesses should return a bus error. DRAM holes are optional, see below. P9. Recommended that DRAM should be populated in large contiguous regions. Operating systems and hypervisors vary in their ability to manage fragmented physical memory regions. Having fewer memory regions containing contiguous RAM can help increase software compatibility and efficient implementation. Regions of contiguous physical RAM are often required when handing control over between software environments, such as; boot loaders, hypervisors and operating systems. P10. Recommend that DRAM is populated into the lowest addresses memory regions first. Since there is memory pressure on lower addressed regions to provide interworking space.
3.1.4
DRAM holes (optional) P11. DRAM holes provide a way to partition large DRAM device into multiple address ranges. Optional DRAM holes are proposed at the start of the higher DRAM address boundaries. These enable a simplified decoding scheme when partitioning a large capacity DRAM device across the lower physically addressed regions. P12. Aliased DRAM holes must not be used for address space interworking. The issues with aliasing are described above.
For example a 64GB DRAM part will be sub-divided into three regions. With the address offsets performed by a simple subtraction in the high order address bits.
Physical Addresses in SoC 2 GBytes ( 32-bit map ) 30 GBytes ( 36-bit map ) 32 GBytes ( 40-bit map ) 0x00 8000 0000 0x00 FFFF FFFF 0x08 8000 0000 0x0F FFFF FFFF 0x88 0000 0000 0x8F FFFF FFFF
Offset
Internal DRAM address 0x00 0000 0000 0x00 7FFF FFFF 0x00 8000 0000 0x07 FFFF FFFF 0x08 0000 0000 0x0F FFFF FFFF
11
In practical systems, with no aliasing, the holes do not waste DRAM address space since memories come sized in 2^n quantities. A fully loaded 40bit system, with holes would contain exactly 512GBytes of DRAM. Removal of the holes would only provide an additional 34GBytes of address space.
3.1.5
Empty Regions Empty inaccessible regions will exist in the global address map. P13. Empty address space should not alias other addresses. P14. Any access to an empty address map region should either: 1. Be ignored 2. Result in a recoverable bus error. The trapping of incorrectly accessed accesses can aid debugging and development.
3.1.6
32bit Systems Constraints P15. Boot ROMs (where present) must be in the 32-bit address space The reset vector for a 32-bit ARM CPU is architected to be address 0x00000000 or 0xFFFF0000 when HiVECs is enabled. P16. Boot memories, SRAM or DRAM must be in the 32-bit address space Working RAM within the 32bit address map is required before the MMU can be enabled. P17. Static Peripheral Registers must be in the 32-bit address space Static peripheral registers need to be visible to non-MMU software such as boot and test code, and to legacy non-LPAE operating systems. P18. Significant DRAM must be present in the 32-bit address space This is required for all non-LPAE software, and interworking with 32-bit bus mastering peripherals. P19. The 32-bit DRAM region address space should be fully populated, before DRAM regions in higher address spaces. The pure 32-bit DRAM will be under utilization pressure for interworking between 32-bit peripherals, and use by all non-LPAE software. P20. Dynamic I/O regions (if present) should exist in the 32-bit address space. 32-bit only operating systems will require access to dynamic I/O, such as PCIe.
3.1.7
36-bit and 40-bit Systems P21. 36-bit address space must be presented To support 36-bit x86 PAE compatible operating systems, such as Linux.
3.1.8
Secure and Non-secure address maps The ARM ARM defines the security extensions and how they interact with system addresses and peripherals. Some address map constraints are:
12
P22. Normal cacheable memory must be mapped uniquely into the Secure or Nonsecure address maps. Normal memory should not be aliased, or dual mapped, since this will impact the security architecture, and complicate the software view of cache coherency. Dual mapping is allowed for a limited number of Secure OS use cases, such as limiting access to DRMd media buffers. Additional care has to be taken to ensure cache coherency is maintained inside and outside of these use cases. P23. Non-cached Device addresses can be dual mapped as Secure and Non-secure. Allowing for devices to be claimed by Secure or Non-secure transactions. Policing of the NS bit is dependent upon the SoC interconnect fabric and device interface. P24. NS access to a Secure register in a dual mapped peripheral should be WI/RAZ, this should not generate a bus error. A dual mapped peripheral must enforce security at a register level. 3.1.9 I/O partitions P25. Static I/O region should be subdivided into 64KB large pages. In preparation for 64-bit systems with 64Kbyte pages.. 3.1.10 Boot ROM ARMv7 32bit CPUs are architected to boot from address 0x00000000 or 0xFFFF0000. The boot address of ARMv8 64bit CPUs is implementation defined. P26. A secure SoC using TrustZone technology must boot from on-chip ROM. The secure root of trust starts with the CPU booting from immutable trusted code. P27. Boot ROM must not be aliased or dynamically switchable for RAM. To ensure security boot ROMs must not be remapped to RAM after boot. Note: This is a change from earlier ARM development systems, where boot ROMs and RAMs where overlaid. P28. The boot ROM area must consume at least 164KB of address space. The boot ROM is not required to populate the entire 64KB of address space. Within the boot ROM address region, repeated aliases of the boot ROM are acceptable. 3.1.11 SoC peripherals P29. Each unique peripheral should occupy one or more 64KB pages. To enable page granularity access controls by ARMv8 MMUs when using 64KB pages. 3.1.12 On-chip RAM P30. Regions of on-chip RAM should be contained within 64KB pages. The on-chip RAM is not required to populate the entire 64KB region. P31. On chip RAM should not be aliased. Unpopulated space should return a recoverable bus error.
13
- 32-bit - 36-bit - 40-bit 1024GB + + +--------------+ | | DRAM | ~ ~ ~ ~ | | | | | | | | | | | | 544GB + + +--------------+ | | Hole or DRAM | | | | 512GB + + +--------------+ | | Mapped | | | I/O | ~ ~ ~ ~ | | | 256GB + + +--------------+ | | Reserved | ~ ~ ~ ~ | | | 64GB + +--------------+--------------+ | | DRAM | ~ ~ ~ ~ | | | | | | 34GB + +--------------+--------------+ | | Hole or DRAM | 32GB + +--------------+--------------+ | | Mapped I/O | ~ ~ ~ ~ | | | 16GB + +--------------+--------------+ | | Reserved | ~ ~ ~ ~ 4GB +--------------+--------------+--------------+ | 2GB of DRAM | | | 2GB +--------------+--------------+--------------+ | Mapped I/O | 1GB +--------------+--------------+--------------+ | ROM & RAM & I/O | 0GB +--------------+--------------+--------------+ - 32-bit - 36-bit - 40-bit Figure 1 32-bit, 36-bit and 40-bit Address Map
<- 40-bit
<- 36-bit
<- 32-bit
14
4.1
4GB +-----------------+ | DRAM | | | 2GB +-----------------+ | Mapped I/O | 1GB +-----------------+ | ROM & RAM & I/O | 0GB +-----------------+
Figure 2 32-bit memory map
<- 32-bit
The 32-bit address map provides the working space for existing non-LPAE 32-bit OSes and 32-bit peripherals. DRAM and I/O must exist in the 32-bit address space to enable test code and system booting, before enabling the MMU. Greater than 32-bit bus masters must access the 32-bit DRAM to interwork with 32-bit systems.
4.1.1
4.1.2
4.1.3
0x4000 0000 0x7FFF FFFF. Mapped I/O and additional SoC I/O
This I/O address region is primarily intended for mapped I/O such as PCIe. Also used as overflow space for SoC register mapped peripherals. Notionally divided into 64KB pages to align with ARMv8 MMUs.
4.1.4
15
4.2
<- 36-bit
<- 32-bit
4.2.1
4.2.2
4.2.3
4.2.4
16
4.3
<- 40-bit
<- 36-bit
4.3.1
4.3.2
4.3.3
4.3.4
17
18
- 32 bit - 36 bit - 40 bit - 44 bit - 48 bit 256TB + + + + +--------------+ | | DRAM | ~ ~ ~ ~ ~ ~ | | | 136TB + + + + +--------------+ | | Hole or DRAM | 128TB + + + + +--------------+ | | Mapped | | | I/O | ~ ~ ~ ~ ~ ~ 64TB + + + + +--------------+ | | Reserved | ~ ~ ~ ~ ~ ~ | | | 16TB + + +--------------+--------------+ | | DRAM | ~ ~ ~ ~ ~ ~ | | | 8604GB + + + +--------------+--------------+ | | Hole or DRAM | 8TB + + + +--------------+--------------+ | | Mapped | | | I/O | ~ ~ ~ ~ ~ ~ 4TB + + + +--------------+--------------+ | | Reserved | ~ ~ ~ ~ ~ ~ | | | 1TB + +--------------+--------------+--------------+ | | DRAM | ~ ~ ~ ~ ~ ~ | | | 544GB + + +--------------+--------------+--------------+ | | Hole or DRAM | 512GB + + +--------------+--------------+--------------+ | | Mapped | | | I/O | ~ ~ ~ ~ ~ ~ 256GB + + +--------------+--------------+--------------+ | | Reserved | ~ ~ ~ ~ ~ ~ | | | 64GB + +--------------+--------------+--------------+--------------+ | | DRAM | ~ ~ ~ ~ ~ ~ | | | 34GB + +--------------+--------------+--------------+--------------+ | | Hole or DRAM | 32GB + +--------------+--------------+--------------+--------------+ | | Mapped I/O | ~ ~ ~ ~ ~ ~ 16GB + +--------------+--------------+--------------+--------------+ | | Reserved | ~ ~ ~ ~ ~ ~ 4GB +--------------+--------------+--------------+--------------+--------------+ | 2GB DRAM | | | 2GB +--------------+--------------+--------------+--------------+--------------+ | Mapped I/O | 1GB +--------------+--------------+--------------+--------------+--------------+ | ROM & RAM & I/O | 0GB +--------------+--------------+--------------+--------------+--------------+ - 32 bit - 36 bit - 40 bit - 44 bit - 48 bit -
< 48 bit
< 44 Bit
< 40 Bit
< 36 Bit
< 32 Bit
19
5.1
<- 44-bit
<- 40-bit
5.1.1
5.1.2
5.1.3
5.1.4
20
5.2
<- 48-bit
<- 44-bit
5.2.1
5.2.2
5.2.3
5.2.4
21
Glossary
6 Glossary
Table 2 describes some of the terms used in this document. Table 2 Glossary terms
Term Large Physical Address Extension (LPAE) Memory Management Unit (MMU) Description Optional extension to VMSAv7 that provides an address translation system supporting physical addresses of up to 40 bits at a 4KB granularity of translation. Address translation unit that can transform addresses and check access permissions. In one stage from a VA to a PA, or in two stages from a VA to IPA to PA. Translation descriptions are provided by translation tables held in memory. In an implementation of virtualization, the address to which a Guest OS maps a physical address. Identifies a memory location within the hardware system. System MMU controls peripheral access into the system through address translation, access permissions, and memory attribute determination. The security technology from ARM that enables the construction of a Normal world and a Secure world. Is an address used by the CPU and software when the MMU enabled. A memory system architecture that supports virtual addresses.
Intermediate Physical Address (IPA) Physical Address (PA) System Memory Management Unit (SMMU) TrustZone Virtual Address (VA) Virtual Memory System Architecture (VMSA)
22
StartAddr Start
0x0000_0000 0x0400_0000 0x0800_0000 0x0C00_0000 0x1000_0000 0x1400_0000 0x1800_0000 0x1A00_0000 0x1B00_0000 0x1C00_0000 0x1C01_0000 0x1C02_0000 0x1C03_0000 0x1C04_0000 0x1C05_0000 0x1C06_0000 0x1C07_0000 0x1C08_0000 0x1C09_0000 0x1C0A_0000 0x1C0B_0000 0x1C0C_0000 0x1C0D_0000 0x1C0F_0000 0x1C10_0000 0x1C11_0000 0x1C12_0000 0x1C13_0000 0x1C16_0000 0x1C17_0000 0x1C18_0000 0x1C1A_0000
EndAddr End
0x03FF_FFFF 0x07FF_FFFF 0x0BFF_FFFF 0x0FFF_FFFF 0x13FF_FFFF 0x17FF_FFFF 0x19FF_FFFF 0x1AFF_FFFF 0x1BFF_0000 0x1C00_FFFF 0x1C01_FFFF 0x1C02_FFFF 0x1C03_FFFF 0x1C04_FFFF 0x1C05_FFFF 0x1C06_FFFF 0x1C07_FFFF 0x1C08_FFFF 0x1C09_FFFF 0x1C0A_FFFF 0x1C0B_FFFF 0x1C0C_FFFF 0x1C0E_FFFF 0x1C0F_FFFF 0x1C10_FFFF 0x1C11_FFFF 0x1C12_FFFF 0x1C15_FFFF 0x1C16_FFFF 0x1C17_FFFF 0x1C19_FFFF 0x1C1A_FFFF
V2P-CA15 (TC2)
VE Motherboard RS1/2
Peripheral SMCCS0(NOR)Aliased SMCCS0(NOR) SMCCS4(NOR) SMCCS5(Reserved) SMCCS1(PSRAM) VideoRAM Ethernet USB LocalDAPROM SystemRegisters SP810(Sysctrl) 2Wire(PCIe) PL041(Aaci) PL180(Mci/Mmci) KMI0(PL050) KMI1 Reserved Uart0(PL011) Uart1 Uart2 Uart3
Reserved
SMC CS 3 (Periphs)
0x1C1B_0000 0x1C1C_0000 0x1C1F_0000 0x1C20_0000 0x2000_0000 0x2000_1000 0x2000_2000 0x2000_3000 0x2000_4000 0x2000_5000 0x2000_6000 0x2000_7000 0x2001_0000 0x2002_0000 0x2002_1000 0x2003_0000 0x2003_1000 0x2003_2000 0x2003_3000 0x2003_4000 0x2003_5000 0x2003_6000 0x2003_7000 0x2003_8000 0x2003_9000 0x2003_A000 0x2003_B000 0x2003_C000 0x2003_D000 0x2003_E000 0x2003_F000 0x2004_0000 0x2A00_0000 0x2A10_0000 0x2A42_0000 0x2A43_0000 0x2A44_0000 0x2B00_0000 0x2B01_0000 0x2B02_0000 0x2B03_0000 0x2B06_0000 0x2B07_0000 0x2B08_0000 24
0x1C1B_FFFF 0x1C1E_FFFF 0x1C1F_FFFF 0x1FFF_FFFF 0x2000_0FFF 0x2000_1FFF 0x2000_2FFF 0x2000_3FFF 0x2000_4FFF 0x2000_5FFF 0x2000_6FFF 0x2000_FFFF 0x2001_FFFF 0x2002_0FFF 0x2002_FFFF 0x2003_0FFF 0x2003_1FFF 0x2003_2FFF 0x2003_3FFF 0x2003_4FFF 0x2003_5FFF 0x2003_6FFF 0x2003_7FFF 0x2003_8FFF 0x2003_9FFF 0x2003_AFFF 0x2003_BFFF 0x2003_CFFF 0x2003_DFFF 0x2003_EFFF 0x2003_FFFF 0x29FF_FFFF 0x2A0F_FFFF 0x2A41_FFFF 0x2A42_FFFF 0x2A43_FFFF 0x2AFF_FFFF 0x2B00_FFFF 0x2B01_FFFF 0x2B02_FFFF 0x2B05_FFFF 0x2B06_FFFF 0x2B07_FFFF 0x2B09_FFFF
CoreSight Space
DAPROM
ETB CTI TPIU Funnel ITM SWO
System Peripheral Space
Reserved A15 ROM Table Reserved CPU0 DBG CPU0 PMU CPU1 DBG CPU1 PMU CPU2 DBG CPU2 PMU CPU3 DBG CPU3 PMU CPU0 CTI CPU1 CTI CPU2 CTI CPU3 CTI CPU0 PTM CPU1 PTM CPU2 PTM CPU3 PTM Reserved NIC301 GPV SCC (Alias) Gcounter
HDLCD
UART(0)cfg
System Watchdog
BLMCntrl
0x2B0A_0000 0x2B0B_0000 0x2C00_0000 0x2C01_0000 0x2C09_0000 0x2C0A_0000 0x2C0C_0000 0x2C0C_0100 0x2D00_0000 0x2D01_0000 0x2E00_0000 0x2F00_0000 0x3000_0000 0x4000_0000 0x6000_0000 0x7FEF_0000 0x7FF0_0000 0x7FF2_0000 0x7FFD_0000 0x7FFE_0000 0x7FFF_0000 0x8000_0000 0x01_0000_0000 0x04_0000_0000 0x08_0000_0000 0x08_8000_0000 0x10_0000_0000 0x40_0000_0000 0x80_8000_0000 0x88_0000_0000
0x2B0A_FFFF 0x2BFF_FFFF 0x2C00_7FFF 0x2C08_FFFF 0x2C09_FFFF 0x2C0B_FFFF 0x2C0C_00FF 0x2CFF_FFFF 0x2D00_FFFF 0x2DFF_FFFF 0x2EFF_FFFF 0x2FFF_FFFF 0x3FFF_FFFF 0x5FFF_FFFF 0x7FEE_FFFF 0x7FEF_FFFF 0x7FF1_FFFF 0x7FFC_FFFF 0x7FFD_FFFF 0x7FFE_FFFF 0x7FFF_FFFF 0xFFFF_FFFF 0x03_FFFF_FFFF 0x07_FFFF_FFFF 0x08_7FFF_FFFF 0x0F_FFFF_FFFF 0x3F_FFFF_FFFF 0x7F_FFFF_FFFF 0x87_FFFF_FFFF 0xFF_FFFF_FFFF
CPU Space
DMC cfg
GIC-400 CCI
Graphics Space
Reserved Reserved
EmbeddedRAM
128-bit User expansion
Internal SRAM 64kB External AXI A15 ACP External AXI Reserved DMC phy cfg DMA Reserved PL354 cfg Reserved SCC
64-bit User expansion
DRAM Reserved 128-bit User expansion Reserved DRAM Reserved 128-bit User expansion Reserved DRAM
DRAM
Aliased DRAM
Aliased DRAM
25