57 lines
1.5 KiB
LLVM
57 lines
1.5 KiB
LLVM
; 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
|
|
}
|
|
|