[LLVMdev] compiler-rt: Infinite loop/stack overflow in __modsi3()
    Matt Johnson 
    johnso87 at crhc.illinois.edu
       
    Thu Mar 10 11:31:31 PST 2011
    
    
  
Hi All,
     The default implementation of __modsi3() (signed integer modulus) 
in compiler-rt/lib/modsi3.c is defined recursively.  Thankfully, LLVM is 
smart enough to do tail call elimination on the recursion, so I got an 
infinite loop rather than a stack overflow :)
     Here's the patch, patterned after the correct implementation in 
umodsi3.c:
diff --git a/lib/compiler-rt/lib/modsi3.c b/lib/compiler-rt/lib/modsi3.c
index 388418a..3759ce0 100644
--- a/lib/compiler-rt/lib/modsi3.c
+++ b/lib/compiler-rt/lib/modsi3.c
@@ -16,8 +16,10 @@
  /* Returns: a % b */
+su_int __divsi3(si_int a, si_int b);
+
  si_int
  __modsi3(si_int a, si_int b)
  {
-    return a - (a / b) * b;
+    return a - __divsi3(a, b) * b;
  }
Best,
Matt
    
    
More information about the llvm-dev
mailing list