Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Support ILP32 on RV64 in psABI #381

Merged
merged 3 commits into from
Jan 23, 2025
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 4 additions & 0 deletions introduction.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -50,6 +50,10 @@ This specification uses the following terms and abbreviations:
| LP64F | Ratified
| LP64D | Ratified
| LP64Q | Ratified
| RV64ILP32 | Draft
| RV64ILP32F | Draft
| RV64ILP32D | Draft
| RV64ILP32Q | Draft
|===

NOTE: ABI for big-endian is *NOT* included in this specification, we intend to
Expand Down
41 changes: 35 additions & 6 deletions riscv-cc.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -449,6 +449,15 @@ The ILP32E calling convention is not compatible with ISAs that have registers
that require load and store alignments of more than 32 bits. In particular, this
calling convention must not be used with the D ISA extension.

=== RV64ILP32* Calling Convention

IMPORTANT: RV64ILP32* ABIs are experimental.

The RV64ILP32* calling convention is designed to be usable with the RV64* ISA.
These calling conventions are composed of the integer & floating-point & vector
calling conventions. When passed in registers or on the stack, pointer scalars
(32-bit), narrower than XLEN bits (64-bit), are sign-extended to XLEN bits.

=== Named ABIs

This specification defines the following named ABIs:
Expand Down Expand Up @@ -493,10 +502,30 @@ LP64Q:: LP64 with hardware floating-point calling
convention for ABI_FLEN=128 (i.e. <<ELFCLASS64,ELFCLASS64>> and
<<EF_RISCV_FLOAT_ABI_QUAD,EF_RISCV_FLOAT_ABI_QUAD>>).

The ILP32* ABIs are only compatible with RV32* ISAs, and the LP64* ABIs are
only compatible with RV64* ISAs. A future version of this specification may
define an ILP32 ABI for the RV64 ISA, but currently this is not a supported
operating mode.
[[abi-rv64ilp32]]
RV64ILP32:: Integer calling-convention only, hardware
floating-point calling convention is not used (i.e. <<ELFCLASS32,ELFCLASS32>> and
<<EF_RISCV_FLOAT_ABI_SINGLE,EF_RISCV_FLOAT_ABI_SINGLE>>).

[[abi-rv64ilp32f]]
RV64ILP32F:: RV64ILP32 with hardware floating-point calling
convention for ABI_FLEN=32 (i.e. <<ELFCLASS32,ELFCLASS32>> and
<<EF_RISCV_FLOAT_ABI_SINGLE,EF_RISCV_FLOAT_ABI_SINGLE>>).

[[abi-rv64ilp32d]]
RV64ILP32D:: RV64ILP32 with hardware floating-point calling
convention for ABI_FLEN=64 (i.e. <<ELFCLASS32,ELFCLASS32>> and
<<EF_RISCV_FLOAT_ABI_DOUBLE,EF_RISCV_FLOAT_ABI_DOUBLE>>).

[[abi-rv64ilp32q]]
RV64ILP32Q:: RV64ILP32 with hardware floating-point calling
convention for ABI_FLEN=128 (i.e. <<ELFCLASS32,ELFCLASS32>> and
<<EF_RISCV_FLOAT_ABI_QUAD,EF_RISCV_FLOAT_ABI_QUAD>>).

The LP64* ABIs are only compatible with RV64* ISAs. The ILP32* are compatible
with RV32* and RV64* ISAs.
kito-cheng marked this conversation as resolved.
Show resolved Hide resolved

NOTE: RV64ILP32* ABIs are experimental.

The *F ABIs require the *F ISA extension, the *D ABIs require the *D ISA
extension, and the LP64Q ABI requires the Q ISA extension.
Expand Down Expand Up @@ -535,7 +564,7 @@ There are two conventions for C/{Cpp} type sizes and alignments.
ILP32, ILP32F, ILP32D, and ILP32E:: Use the following type sizes and
alignments (based on the ILP32 convention):
+
.C/{Cpp} type sizes and alignments for RV32
.C/{Cpp} type sizes and alignments for ILP32
[cols="4,>2,>3,4"]
[width=60%]
|===
Expand All @@ -561,7 +590,7 @@ alignments (based on the ILP32 convention):
LP64, LP64F, LP64D, and LP64Q:: Use the following type sizes and
alignments (based on the LP64 convention):
+
.C/{Cpp} type sizes and alignments for RV64
.C/{Cpp} type sizes and alignments for LP64
[cols="4,>2,>3,4"]
[width=60%]
|===
Expand Down
20 changes: 15 additions & 5 deletions riscv-elf.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -101,6 +101,8 @@ NOTE: Although the generated code is technically position independent, it's not
suitable for ELF shared libraries due to differing symbol interposition rules;
for that, please use the medium position independent code model below.

NOTE: The address space of RV64ILP32* ABIs is not continuous in the middle.

=== Medium position independent code model

This model is similar to the medium any code model, but uses the
Expand Down Expand Up @@ -247,8 +249,8 @@ header fields; any fields not listed in this section have no RISC-V-specific
values.

e_ident::
EI_CLASS::: Specifies the base ISA, either RV32 or RV64.
Linking RV32 and RV64 code together is not supported.
EI_CLASS::: Specifies the ABIs, either ILP32*, LP64* or RV64ILP32*.
Linking different ABIs' code together is not supported.
+
--
[horizontal]
Expand Down Expand Up @@ -277,12 +279,12 @@ below.
+
[[e-flags-layout]]
.Layout of e_flags
[cols="1,2,1,1,3,5"]
[cols="1,2,1,1,1,3,5"]
[width=80%]
|===
| Bit 0 | Bits 1 - 2 | Bit 3 | Bit 4 | Bits 5 - 23 | Bits 24 - 31
| Bit 0 | Bits 1 - 2 | Bit 3 | Bit 4 | Bit 5 | Bits 6 - 23 | Bits 24 - 31

| RVC | Float ABI | RVE | TSO | *Reserved* | *Non-standard extensions*
| RVC | Float ABI | RVE | TSO | RV64ILP32 | *Reserved* | *Non-standard extensions*
|===

+
Expand Down Expand Up @@ -320,6 +322,11 @@ below.
EF_RISCV_TSO (0x0010)::: This bit is set when the binary requires the RVTSO
memory consistency model.

EF_RISCV_RV64ILP32 (0x0020)::: This bit is set when the binary requires the
RV64ILP32* ABIs on RV64* ISAs.

NOTE: RV64ILP32* ABIs are experimental.

Until such a time that the *Reserved* bits (0x00ffffe0) are allocated by future
versions of this specification, they shall not be set by standard software.
Non-standard extensions are free to use bits 24-31 for any purpose. This may
Expand Down Expand Up @@ -355,6 +362,9 @@ raise an error.
TSO::: Input files can have different values for the TSO field; the linker
should set this field if any of the input objects have the TSO field set.

RV64ILP32::: Linker should report errors if object files of different value
for RV64ILP32 field.

NOTE: The static linker may ignore the compatibility checks if all fields in the
`e_flags` are zero and all sections in the input file are non-executable
sections.
Expand Down
Loading