Teach ScalarEvolution how to reason about no-wrap flags on loops
[llvm/avr.git] / test / Assembler / insertextractvalue.ll
blob2f5521fba87254e5ec374642aac83992aba5adcb
1 ; RUN: llvm-as < %s | llvm-dis > %t
2 ; RUN: grep insertvalue %t | count 1
3 ; RUN: grep extractvalue %t | count 1
5 define float @foo({{i32},{float, double}}* %p) nounwind {
6   %t = load {{i32},{float, double}}* %p
7   %s = extractvalue {{i32},{float, double}} %t, 1, 0
8   %r = insertvalue {{i32},{float, double}} %t, double 2.0, 1, 1
9   store {{i32},{float, double}} %r, {{i32},{float, double}}* %p
10   ret float %s
12 define float @bar({{i32},{float, double}}* %p) nounwind {
13   store {{i32},{float, double}} insertvalue ({{i32},{float, double}}{{i32}{i32 4},{float, double}{float 4.0, double 5.0}}, double 20.0, 1, 1), {{i32},{float, double}}* %p
14   ret float extractvalue ({{i32},{float, double}}{{i32}{i32 3},{float, double}{float 7.0, double 9.0}}, 1, 0)
16 define float @car({{i32},{float, double}}* %p) nounwind {
17   store {{i32},{float, double}} insertvalue ({{i32},{float, double}} undef, double 20.0, 1, 1), {{i32},{float, double}}* %p
18   ret float extractvalue ({{i32},{float, double}} undef, 1, 0)
20 define float @dar({{i32},{float, double}}* %p) nounwind {
21   store {{i32},{float, double}} insertvalue ({{i32},{float, double}} zeroinitializer, double 20.0, 1, 1), {{i32},{float, double}}* %p
22   ret float extractvalue ({{i32},{float, double}} zeroinitializer, 1, 0)
26 ; PR4963
27 define <{ i32, i32 }> @test57() {
28   ret <{ i32, i32 }> insertvalue (<{ i32, i32 }> zeroinitializer, i32 4, 1)