From 4edf2f53a2cc52ec820f0e48454e82e53b6e3446 Mon Sep 17 00:00:00 2001 From: Guo Ren Date: Thu, 29 Aug 2024 06:05:19 -0400 Subject: [PATCH] EF_RISCV_N32: Limit the address space to lower 2GiB Limiting the address space to lower 2GiB does not pose any issues with sign extending addresses into the upper 32 bits of a 64-bit register. Signed-off-by: Guo Ren Signed-off-by: Liao Shihua --- riscv-elf.adoc | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/riscv-elf.adoc b/riscv-elf.adoc index 8abb18bf..21b19e8a 100644 --- a/riscv-elf.adoc +++ b/riscv-elf.adoc @@ -26,6 +26,11 @@ address space or the lower 2 GiB and highest 2 GiB of the RV64 address space By using the `lui` and load / store instructions, when referring to an object, or `addi`, when calculating an address literal, for example, a 32-bit address literal can be produced. +For the ILP32 ABI on RV64* ISA, the medlow allows the code to address lower 2GiB +of the RV64 address space (`0x0` ~ `0x000000007FFFFFFF`). + +NOTE: Limiting the address space to lower 2GiB does not pose any issues with sign +extending addresses into the upper 32 bits of a 64-bit register. The following instructions show how to load a value, store a value, or calculate an address in the `medlow` code model.