[llvm-commits] [compiler-rt] r158996 - in /compiler-rt/trunk/lib: divsi3.c udivsi3.c
Stephen Canon
scanon at apple.com
Fri Jun 22 07:44:13 PDT 2012
Author: scanon
Date: Fri Jun 22 09:44:13 2012
New Revision: 158996
URL: http://llvm.org/viewvc/llvm-project?rev=158996&view=rev
Log:
Allow divsi3 to take advantage of a hardware unsigned divide when it is available, by replacing an explicit call to udivsi3 with the divide operator. Patch by Sébastien Bourdeauducq.
Modified:
compiler-rt/trunk/lib/divsi3.c
compiler-rt/trunk/lib/udivsi3.c
Modified: compiler-rt/trunk/lib/divsi3.c
URL: http://llvm.org/viewvc/llvm-project/compiler-rt/trunk/lib/divsi3.c?rev=158996&r1=158995&r2=158996&view=diff
==============================================================================
--- compiler-rt/trunk/lib/divsi3.c (original)
+++ compiler-rt/trunk/lib/divsi3.c Fri Jun 22 09:44:13 2012
@@ -29,5 +29,11 @@
a = (a ^ s_a) - s_a; /* negate if s_a == -1 */
b = (b ^ s_b) - s_b; /* negate if s_b == -1 */
s_a ^= s_b; /* sign of quotient */
- return (__udivsi3(a, b) ^ s_a) - s_a; /* negate if s_a == -1 */
+ /*
+ * On CPUs without unsigned hardware division support,
+ * this calls __udivsi3 (notice the cast to su_int).
+ * On CPUs with unsigned hardware division support,
+ * this uses the unsigned division instruction.
+ */
+ return ((su_int)a/(su_int)b ^ s_a) - s_a; /* negate if s_a == -1 */
}
Modified: compiler-rt/trunk/lib/udivsi3.c
URL: http://llvm.org/viewvc/llvm-project/compiler-rt/trunk/lib/udivsi3.c?rev=158996&r1=158995&r2=158996&view=diff
==============================================================================
--- compiler-rt/trunk/lib/udivsi3.c (original)
+++ compiler-rt/trunk/lib/udivsi3.c Fri Jun 22 09:44:13 2012
@@ -20,6 +20,7 @@
ARM_EABI_FNALIAS(uidiv, udivsi3);
+/* This function should not call __divsi3! */
COMPILER_RT_ABI su_int
__udivsi3(su_int n, su_int d)
{
More information about the llvm-commits
mailing list