New testcase that functions with dynamic allocas can be inlined, and are

inlined correctly.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@25287 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Chris Lattner 2006-01-13 19:35:05 +00:00
parent bf229f488a
commit f0638c5f71

View File

@ -0,0 +1,28 @@
; Test that functions with dynamic allocas get inlined in a case where
; naively inlining it would result in a miscompilation.
; RUN: llvm-as < %s | opt -inline &&
; RUN: llvm-as < %s | opt -inline | llvm-dis | grep llvm.stacksave &&
; RUN: llvm-as < %s | opt -inline | llvm-dis | not grep callee
declare void %ext(int*)
implementation
internal void %callee(uint %N) {
%P = alloca int, uint %N ;; dynamic alloca
call void %ext(int* %P)
ret void
}
void %foo(uint %N) {
br label %Loop
Loop:
%count = phi uint [0, %0], [%next, %Loop]
%next = add uint %count, 1
call void %callee(uint %N)
%cond = seteq uint %count, 100000
br bool %cond, label %out, label %Loop
out:
ret void
}