Teach ScalarEvolution how to reason about no-wrap flags on loops
[llvm/avr.git] / test / Transforms / Inline / inline-invoke-tail.ll
blob961f6789fe4d05cb0d15b3eeb947feb66da3dda1
1 ; RUN: opt < %s -inline -S | not grep {tail call void @llvm.memcpy.i32}
2 ; PR3550
4 define internal void @foo(i32* %p, i32* %q) {
5         %pp = bitcast i32* %p to i8*
6         %qq = bitcast i32* %q to i8*
7         tail call void @llvm.memcpy.i32(i8* %pp, i8* %qq, i32 4, i32 1)
8         ret void
11 declare void @llvm.memcpy.i32(i8* nocapture, i8* nocapture, i32, i32) nounwind
13 define i32 @main() {
14         %a = alloca i32         ; <i32*> [#uses=3]
15         %b = alloca i32         ; <i32*> [#uses=2]
16         store i32 1, i32* %a, align 4
17         store i32 0, i32* %b, align 4
18         invoke void @foo(i32* %a, i32* %b)
19                         to label %invcont unwind label %lpad
21 invcont:
22         %retval = load i32* %a, align 4
23         ret i32 %retval
25 lpad:
26         %eh_ptr = call i8* @llvm.eh.exception()
27         %eh_select = call i32 (i8*, i8*, ...)* @llvm.eh.selector.i32(i8* %eh_ptr, i8* bitcast (i32 (...)* @__gxx_personality_v0 to i8*), i8* null)
28         unreachable
31 declare i8* @llvm.eh.exception() nounwind
33 declare i32 @llvm.eh.selector.i32(i8*, i8*, ...) nounwind
35 declare i32 @__gxx_personality_v0(...)