From 60075223b616fb8ae1955e193d300f8fd2f9ba3f Mon Sep 17 00:00:00 2001 From: Xi Ruoyao Date: Tue, 19 Apr 2022 20:33:32 +0800 Subject: [PATCH] update calling convention to match GCC behavior Fixes #48. --- docs/LoongArch-ELF-ABI-EN.adoc | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/docs/LoongArch-ELF-ABI-EN.adoc b/docs/LoongArch-ELF-ABI-EN.adoc index d006242..aba1a43 100644 --- a/docs/LoongArch-ELF-ABI-EN.adoc +++ b/docs/LoongArch-ELF-ABI-EN.adoc @@ -800,6 +800,20 @@ If only one GAR is available, the low-order bits are in the GAR and the high-ord .. It’s passed by reference and are replaced in the argument list with the address. If there is an available GAR, the reference is passed in the GAR, and passed on the stack if no GAR is available. +. Special Cases + +.. If WOA ≤ 2 × GRLEN, and the structure contains zero-length array (as a GNU extension) members or zero-width bit-field members: + +... Let `f(T)` be the predicate to denote if there is any zero-length array member of which the element type is `T`, or an array, structure, or union containing (directly or indirectly) `T`. + +... If the structure only contains only one `float` member except those zero-length array or zero-width bit-field members, and both `f(double)` and `f(long double)` are not true, the structure is passed in one FAR. + +... If the structure only contains only one `double` member except those zero-length array or zero-width bit-field members, and `f(long double)` is not true, the structure is passed in one FAR. + +... Otherwise, the structure is passed via GAR and/or stack. No FAR shall be used. + +.. If a structure contains (directly or indirectly) an union, and the union occupies non-zero bits of space in the memory layout of this structure, this structure is passed via GAR and/or stack as if the structure itself is an union. No FAR shall be used. + Structure and scalars passed on the stack are aligned to the greater of the type alignment and GRLEN bits, but never more than the stack alignment. ==== Union