[llvm-commits] [compiler-rt] r109492 - /compiler-rt/trunk/lib/arm/modsi3.S
Nick Kledzik
kledzik at apple.com
Mon Jul 26 23:24:32 PDT 2010
Author: kledzik
Date: Tue Jul 27 01:24:32 2010
New Revision: 109492
URL: http://llvm.org/viewvc/llvm-project?rev=109492&view=rev
Log:
add assembly implementation of modsi3 so compiler does not have to special case a - (a / b) * b optimization
Added:
compiler-rt/trunk/lib/arm/modsi3.S
Added: compiler-rt/trunk/lib/arm/modsi3.S
URL: http://llvm.org/viewvc/llvm-project/compiler-rt/trunk/lib/arm/modsi3.S?rev=109492&view=auto
==============================================================================
--- compiler-rt/trunk/lib/arm/modsi3.S (added)
+++ compiler-rt/trunk/lib/arm/modsi3.S Tue Jul 27 01:24:32 2010
@@ -0,0 +1,36 @@
+//===-------- modsi3.S - Implement modsi3 ---------------------------------===//
+//
+// The LLVM Compiler Infrastructure
+//
+// This file is distributed under the University of Illinois Open Source
+// License. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+
+#include "../assembly.h"
+
+//
+// extern int32_t __modsi3(int32_t a, int32_t b);
+//
+// Returns the remainder when dividing two 32-bit signed integers.
+// Conceptually, the function is: { return a - (a / b) * b; }
+// But if you write that in C, llvm compiles it to a call to __modsi3...
+//
+ .align 2
+DEFINE_COMPILERRT_FUNCTION(__modsi3)
+ push {r4, r5, r7, lr}
+ add r7, sp, #8 // set stack frame
+ mov r5, r0 // save a
+ mov r4, r1 // save b
+ bl ___divsi3 // compute a/b
+#if __ARM_ARCH_7A__
+ mls r0, r4, r0, r5 // mulitple result * b and subtract from a
+#else
+ // before armv7, does not have "mls" instruction
+ mul r3, r0, r4 // multiple result * b
+ sub r0, r5, r3 // a - result
+#endif
+ pop {r4, r5, r7, pc}
+
+
+
More information about the llvm-commits
mailing list