Memory spaces are not just used for RAM, as RAM is often much smaller than the entire memory space. The layout of memory is detailed by memory maps.
In the memory map of the Cortex shown above, there are some things we should note:
- Hexadecimal memory addresses: Lowest is
0x0
and highest is0xFFFF FFFF
, which corresponds to . - Memory is organized into 512 MB blocks. This is more than the Cortex M4 ever uses for its blocks, but it’s good to have more than you need for future-proofing purposes.
- Reserved portions. This can mean several things:
- Future expansion.
- Common core: Chips may share a common core set of features, so space is reserved for fancier chips to do their extra functions.
- Circuit optimization: Addresses aren’t mapped because it isn’t necessary or practical to create circuits that use them. This is seen in peripherals, where only 2 or 3 bits of an entire 32-bit address are used and the rest are “reserved”. It really just means that it was easier to route wires to those specific bits, given how the rest of the circuit was placed.