[compiler-rt] [compiler-rt] Add big endian support to __aeabi_(idivmod|uidivmod|uldivmod) (PR #126277)
Victor Campos via llvm-commits
llvm-commits at lists.llvm.org
Fri Feb 7 09:55:44 PST 2025
https://github.com/vhscampos updated https://github.com/llvm/llvm-project/pull/126277
>From dd99a15df4556e310dde0966ccdcdbfce5b0ae9e Mon Sep 17 00:00:00 2001
From: Victor Campos <victor.campos at arm.com>
Date: Fri, 7 Feb 2025 17:35:59 +0000
Subject: [PATCH 1/2] [compiler-rt] Add big endian support to
__aeabi_(idivmod|uidivmod|uldivmod)
This patch makes these functions work in big endian mode:
- `__aeabi_idivmod`.
- `__aeabi_uidivmod`.
The `__aeabi_uldivmod` function was already compatible with big endian,
but its test was not. So in this case, only the test needed fixing.
---
compiler-rt/lib/builtins/arm/aeabi_idivmod.S | 5 +++++
compiler-rt/lib/builtins/arm/aeabi_uidivmod.S | 5 +++++
.../test/builtins/Unit/arm/aeabi_uldivmod_test.c | 14 ++++++++++++++
3 files changed, 24 insertions(+)
diff --git a/compiler-rt/lib/builtins/arm/aeabi_idivmod.S b/compiler-rt/lib/builtins/arm/aeabi_idivmod.S
index bb80e4b96fc1aaa..b08f773e86483ab 100644
--- a/compiler-rt/lib/builtins/arm/aeabi_idivmod.S
+++ b/compiler-rt/lib/builtins/arm/aeabi_idivmod.S
@@ -40,7 +40,12 @@ DEFINE_COMPILERRT_FUNCTION(__aeabi_idivmod)
mov r1, r3
#endif
bl SYMBOL_NAME(__divmodsi4)
+#if _YUGA_BIG_ENDIAN
+ mov r1, r0
+ ldr r0, [sp]
+#else
ldr r1, [sp]
+#endif
add sp, sp, #4
pop { pc }
#endif // defined(USE_THUMB_1)
diff --git a/compiler-rt/lib/builtins/arm/aeabi_uidivmod.S b/compiler-rt/lib/builtins/arm/aeabi_uidivmod.S
index df030769fd40bde..dc3cf90496c5979 100644
--- a/compiler-rt/lib/builtins/arm/aeabi_uidivmod.S
+++ b/compiler-rt/lib/builtins/arm/aeabi_uidivmod.S
@@ -47,7 +47,12 @@ LOCAL_LABEL(case_denom_larger):
mov r1, r3
#endif
bl SYMBOL_NAME(__udivmodsi4)
+#if _YUGA_BIG_ENDIAN
+ mov r1, r0
+ ldr r0, [sp]
+#else
ldr r1, [sp]
+#endif
add sp, sp, #4
pop { pc }
#endif
diff --git a/compiler-rt/test/builtins/Unit/arm/aeabi_uldivmod_test.c b/compiler-rt/test/builtins/Unit/arm/aeabi_uldivmod_test.c
index 2ff65a8b9ec3fa8..32b08d60484c755 100644
--- a/compiler-rt/test/builtins/Unit/arm/aeabi_uldivmod_test.c
+++ b/compiler-rt/test/builtins/Unit/arm/aeabi_uldivmod_test.c
@@ -13,15 +13,29 @@ int test_aeabi_uldivmod(du_int a, du_int b, du_int expected_q, du_int expected_r
{
du_int q, r;
__asm__(
+#if _YUGA_BIG_ENDIAN
+ "movs r1, %Q[a] \n"
+ "movs r0, %R[a] \n"
+ "movs r3, %Q[b] \n"
+ "movs r2, %R[b] \n"
+#else
"movs r0, %Q[a] \n"
"movs r1, %R[a] \n"
"movs r2, %Q[b] \n"
"movs r3, %R[b] \n"
+#endif
"bl __aeabi_uldivmod \n"
+#if _YUGA_BIG_ENDIAN
+ "movs %Q[q], r1\n"
+ "movs %R[q], r0\n"
+ "movs %Q[r], r3\n"
+ "movs %R[r], r2\n"
+#else
"movs %Q[q], r0\n"
"movs %R[q], r1\n"
"movs %Q[r], r2\n"
"movs %R[r], r3\n"
+#endif
: [q] "=r" (q), [r] "=r"(r)
: [a] "r"(a), [b] "r"(b)
: "lr", "r0", "r1", "r2", "r3"
>From aa280c91cf741f83a15f2c9ebd0ba8a1aa672ff9 Mon Sep 17 00:00:00 2001
From: Victor Campos <victor.campos at arm.com>
Date: Fri, 7 Feb 2025 17:53:43 +0000
Subject: [PATCH 2/2] Fix clang-format
---
.../builtins/Unit/arm/aeabi_uldivmod_test.c | 17 ++++++++---------
1 file changed, 8 insertions(+), 9 deletions(-)
diff --git a/compiler-rt/test/builtins/Unit/arm/aeabi_uldivmod_test.c b/compiler-rt/test/builtins/Unit/arm/aeabi_uldivmod_test.c
index 32b08d60484c755..695f50fe2586b73 100644
--- a/compiler-rt/test/builtins/Unit/arm/aeabi_uldivmod_test.c
+++ b/compiler-rt/test/builtins/Unit/arm/aeabi_uldivmod_test.c
@@ -13,33 +13,32 @@ int test_aeabi_uldivmod(du_int a, du_int b, du_int expected_q, du_int expected_r
{
du_int q, r;
__asm__(
-#if _YUGA_BIG_ENDIAN
+# if _YUGA_BIG_ENDIAN
"movs r1, %Q[a] \n"
"movs r0, %R[a] \n"
"movs r3, %Q[b] \n"
"movs r2, %R[b] \n"
-#else
+# else
"movs r0, %Q[a] \n"
"movs r1, %R[a] \n"
"movs r2, %Q[b] \n"
"movs r3, %R[b] \n"
-#endif
+# endif
"bl __aeabi_uldivmod \n"
-#if _YUGA_BIG_ENDIAN
+# if _YUGA_BIG_ENDIAN
"movs %Q[q], r1\n"
"movs %R[q], r0\n"
"movs %Q[r], r3\n"
"movs %R[r], r2\n"
-#else
+# else
"movs %Q[q], r0\n"
"movs %R[q], r1\n"
"movs %Q[r], r2\n"
"movs %R[r], r3\n"
-#endif
- : [q] "=r" (q), [r] "=r"(r)
+# endif
+ : [q] "=r"(q), [r] "=r"(r)
: [a] "r"(a), [b] "r"(b)
- : "lr", "r0", "r1", "r2", "r3"
- );
+ : "lr", "r0", "r1", "r2", "r3");
if (q != expected_q || r != expected_r)
printf("error in aeabi_uldivmod: %llX / %llX = %llX, R = %llX, expected %llX, %llX\n",
a, b, q, r, expected_q, expected_r);
More information about the llvm-commits
mailing list