[llvm-commits] CVS: llvm/test/Transforms/InstCombine/2007-04-04-BadFoldBitcastIntoMalloc.ll

Jeff Cohen jeffc at jolt-lang.org
Wed Apr 4 09:11:40 PDT 2007



Changes in directory llvm/test/Transforms/InstCombine:

2007-04-04-BadFoldBitcastIntoMalloc.ll added (r1.1)
---
Log message:

Add new test.

---
Diffs of the changes:  (+19 -0)

 2007-04-04-BadFoldBitcastIntoMalloc.ll |   19 +++++++++++++++++++
 1 files changed, 19 insertions(+)


Index: llvm/test/Transforms/InstCombine/2007-04-04-BadFoldBitcastIntoMalloc.ll
diff -c /dev/null llvm/test/Transforms/InstCombine/2007-04-04-BadFoldBitcastIntoMalloc.ll:1.1
*** /dev/null	Wed Apr  4 11:11:33 2007
--- llvm/test/Transforms/InstCombine/2007-04-04-BadFoldBitcastIntoMalloc.ll	Wed Apr  4 11:11:23 2007
***************
*** 0 ****
--- 1,19 ----
+ ; In the presence of a negative offset (the -8 below), a fold of a bitcast into
+ ; a malloc messes up the element count, causing an extra 4GB to be allocated on
+ ; 64-bit targets.
+ ;
+ ; RUN: llvm-as < %s | opt -instcombine | llvm-dis | grep -v '= add i32'
+ 
+ target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:64-f32:32:32-f64:32:64-v64:64:64-v128:128:128-a0:0:64"
+ target triple = "x86_64-unknown-freebsd6.2"
+ 
+ define i1 @test(i32 %tmp141, double** %tmp145)
+ {
+   %tmp133 = add i32 %tmp141, 1
+   %tmp134 = shl i32 %tmp133, 3
+   %tmp135 = add i32 %tmp134, -8
+   %tmp136 = malloc i8, i32 %tmp135
+   %tmp137 = bitcast i8* %tmp136 to double*
+   store double* %tmp137, double** %tmp145
+   ret i1 false
+ }






More information about the llvm-commits mailing list