|  | ; 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 | 
|  |  | 
|  | 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 | 
|  | } | 
|  |  |