| ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py |
| ; This test ensures that alloca instructions in the entry block for an inlined |
| ; function are moved to the top of the function they are inlined into. |
| ; |
| ; RUN: opt -S -inline < %s | FileCheck %s |
| ; RUN: opt -S -passes='cgscc(inline)' < %s | FileCheck %s |
| |
| define i32 @func(i32 %i) { |
| %X = alloca i32 |
| store i32 %i, i32* %X |
| ret i32 %i |
| } |
| |
| declare void @bar() |
| |
| define i32 @main(i32 %argc) { |
| ; CHECK-LABEL: @main( |
| ; CHECK-NEXT: Entry: |
| ; CHECK-NEXT: [[X_I:%.*]] = alloca i32 |
| ; |
| Entry: |
| call void @bar( ) |
| %X = call i32 @func( i32 7 ) |
| %Y = add i32 %X, %argc |
| ret i32 %Y |
| } |
| |
| ; https://llvm.org/bugs/show_bug.cgi?id=27277 |
| ; Don't assume that the size is a ConstantInt (an undef value is also a constant). |
| |
| define void @PR27277(i32 %p1) { |
| ; CHECK-LABEL: @PR27277( |
| ; CHECK-NEXT: [[VLA:%.*]] = alloca double, i32 %p1 |
| ; CHECK-NEXT: call void @PR27277(i32 undef) |
| ; CHECK-NEXT: ret void |
| ; |
| %vla = alloca double, i32 %p1 |
| call void @PR27277(i32 undef) |
| ret void |
| } |
| |
| ; Don't assume that the size is a ConstantInt (a ConstExpr is also a constant). |
| |
| @GV = common global i32* null |
| |
| define void @PR27277_part2(i32 %p1) { |
| ; CHECK-LABEL: @PR27277_part2( |
| ; CHECK-NEXT: [[VLA:%.*]] = alloca double, i32 %p1 |
| ; CHECK-NEXT: call void @PR27277_part2(i32 ptrtoint (i32** @GV to i32)) |
| ; CHECK-NEXT: ret void |
| ; |
| %vla = alloca double, i32 %p1 |
| call void @PR27277_part2(i32 ptrtoint (i32** @GV to i32)) |
| ret void |
| } |
| |