Logo

dev-resources.site

for different kinds of informations.

The Power of Memory Map

Published at
11/2/2024
Categories
bsp
memory
hardware
soc
Author
lsahn
Categories
4 categories in total
bsp
open
memory
open
hardware
open
soc
open
Author
5 person written this
lsahn
open
The Power of Memory Map

Since early this year, I’ve been working on a BSP project. The biggest challenge was understanding physical memory layout, specifically why certain addresses are defined in the DTS and don’t fall within other expected ranges.

To tackle this, I created a complete memory map of the chip1, which helped me gain a clear understanding, and use the resources of the reference board2 to explain.


Fortunately, NXP has made the kernel source and reference manuals for the S32G3 chipset publicly available. This allows us to practice designing memory map diagrams freely using these resources—big thanks to NXP!

The image below shows the complete memory map, including kernel-reserved memory regions.

s32g3-memory-map-diagram

The S32G3 chip includes five categories of memory ranges:

  • Extended Address Map
  • External DRAM
  • Peripherals
  • RAM
  • QSPI Memory

Extended Address Map

A 4GB DRAM can be mapped within a 32-bit address space. However, since the lower half of this range is allocated to peripherals, only up to 2GB is available for DRAM.

To overcome this limitation, the system can extend the address space to 40-bit mode. This allows more than 2GB of DRAM to be mapped and provides additional address space for other devices, including the PCIe endpoint as shown in the diagram.

External DRAM

This is the basic range where DRAM is mapped. It serves as the main memory used by the kernel, where tasks like loading the kernel image during boot, memory management like the page allocation.

Peripherals

This range is where most peripherals are mapped to specific areas of the SoC, allowing access to their controllers.

RAM

It’s integrated into SoC chips because key components like PCIe, CPU, and GPU need ultra-high-speed communication. Its size is quite limited compared to DRAM, typically ranging from KB to MB, due to the high cost of larger capacities. This type of memory is commonly used for cache and CPU registers, where ultra-high speed is essential.

QSPI Flash Memory

A QSPI-interfaced flash memory is used to store resources such as pre/boot loaders, kernel images, and additional binaries. This area is used by the M7 cores to store their firmware.

However, the actual accessible address size on the board is limited to 0x03FF_FFFF (64MB), even though the total address space extends up to 0x1FFF_FFFF (512MB), because the NOR flash3 is designed as a 64MB storage.


Conclusion

We have been exploring the memory map of the chip. This can be challenging for BSP newcomers, but it’s essential knowledge. For instance, U-Boot, a bootloader uses environment variables such as loadaddr and fdtaddr to load binaries into DRAM. In such cases, understanding the accessible memory range is crucial.

I hope you found this post helpful and insightful!

hardware Article's
30 articles in total
Favicon
AI in Your Hands: Nvidia’s $3,000 Supercomputer Changes Everything
Favicon
Exploring Embedded System Development: How to Choose and Optimize Single Board Computers and Development Boards
Favicon
Why Is My Printer Offline? Easy Steps to Fix It
Favicon
Rust on a $2 dev board
Favicon
Curso De Fundamentos Do Hardware Gratuito Com Certificado Da Cisco
Favicon
Hardware and PCB design considerations for ESP8266 based programmable controller.
Favicon
The Power of Memory Map
Favicon
Extending NUC with External U.2 SSD
Favicon
I'm building robots
Favicon
ARM vs x86, Which works best for you!
Favicon
Which Operating System Offers Better Hardware Compatibility: Windows or Linux?
Favicon
Curso De Suporte De TI Online E Gratuito Da JA Brasil
Favicon
Tinkerforge Weather Station, part 3 - Continuing the project after a decade
Favicon
The Evolution of Hardware vs. Software Speed: Analyzing the Growing Gap Over Time
Favicon
USB HID Down the rabbit hole: Logitech G435 dongle
Favicon
What are ASIC cooling systems?
Favicon
Software OR Hardware Raid: What's Better In 2024?
Favicon
Round Two: Enhancing the Ollama Cluster
Favicon
Should I buy a new PC?
Favicon
Building the Brains of the Machine: A Guide to Becoming a Computer Hardware Engineer
Favicon
4090 - ECC ON vs ECC OFF
Favicon
freerouting kicad
Favicon
Troubleshooting External Hard Drives on Linux
Favicon
Using TensorFlow 2.8 on an Apple Silicon arm64 chip
Favicon
Nvidia's 1000x Performance Boost Claim Verified
Favicon
Ocean Supply Your Premier Destination for High-Quality Marine Gear
Favicon
Replacing the Battery in my Sennheiser PXC 550 Headphones
Favicon
USB HID Down the rabbit hole: Reverse engineering the Logitech CU0019 USB receiver
Favicon
Instruction Set Architecture, a linguagem das máquinas
Favicon
LLM Fine-tunig on RTX 4090: 90% Performance at 55% Power

Featured ones: