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