[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