[compiler-rt] [compiler-rt] Add support for big endian for Arm's __negdf2vfp (PR #127096)

Victor Campos via llvm-commits llvm-commits at lists.llvm.org
Thu Feb 13 09:06:45 PST 2025


https://github.com/vhscampos created https://github.com/llvm/llvm-project/pull/127096

In soft floating-point ABI, this function takes the double argument as a pair of registers r0 and r1.

The ordering of these two registers follow the endianness rules, therefore the register on which the bit flipping must happen depends on the endianness.

>From a4f2f191bd4a161e35223002afda733b87116716 Mon Sep 17 00:00:00 2001
From: Victor Campos <victor.campos at arm.com>
Date: Thu, 13 Feb 2025 17:00:15 +0000
Subject: [PATCH] [compiler-rt] Add support for big endian for Arm's
 __negdf2vfp

In soft floating-point ABI, this function takes the double argument as a
pair of registers r0 and r1.

The ordering of these two registers follow the endianness rules,
therefore the register on which the bit flipping must happen depends on
the endianness.
---
 compiler-rt/lib/builtins/arm/negdf2vfp.S | 6 +++++-
 1 file changed, 5 insertions(+), 1 deletion(-)

diff --git a/compiler-rt/lib/builtins/arm/negdf2vfp.S b/compiler-rt/lib/builtins/arm/negdf2vfp.S
index b7cf91877e38c..329c6de757f68 100644
--- a/compiler-rt/lib/builtins/arm/negdf2vfp.S
+++ b/compiler-rt/lib/builtins/arm/negdf2vfp.S
@@ -20,7 +20,11 @@ DEFINE_COMPILERRT_FUNCTION(__negdf2vfp)
 #if defined(COMPILER_RT_ARMHF_TARGET)
 	vneg.f64 d0, d0
 #else
-	eor	r1, r1, #-2147483648	// flip sign bit on double in r0/r1 pair
+#if _YUGA_BIG_ENDIAN
+	eor	r0, r0, #0x80000000	// flip sign bit on double in r0/r1 pair
+#else
+	eor	r1, r1, #0x80000000	// flip sign bit on double in r0/r1 pair
+#endif
 #endif
 	bx	lr
 END_COMPILERRT_FUNCTION(__negdf2vfp)



More information about the llvm-commits mailing list