summaryrefslogtreecommitdiffstats
path: root/test/CodeGen/X86/fast-isel-extract.ll
blob: f63396e40ca453b2ff558bdbbb4d74becfcc0532 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
; RUN: llc < %s -mtriple x86_64-apple-darwin11 -O0 -fast-isel-abort | FileCheck %s

%struct.x = type { i64, i64 }
%addovf = type { i32, i1 }
declare %struct.x @f()

define void @test1(i64*) nounwind ssp {
  %2 = tail call %struct.x @f() nounwind
  %3 = extractvalue %struct.x %2, 0
  %4 = add i64 %3, 10
  store i64 %4, i64* %0
  ret void
; CHECK: test1:
; CHECK: callq _f
; CHECK-NEXT: addq	$10, %rax
}

define void @test2(i64*) nounwind ssp {
  %2 = tail call %struct.x @f() nounwind
  %3 = extractvalue %struct.x %2, 1
  %4 = add i64 %3, 10
  store i64 %4, i64* %0
  ret void
; CHECK: test2:
; CHECK: callq _f
; CHECK-NEXT: addq	$10, %rdx
}

declare %addovf @llvm.sadd.with.overflow.i32(i32, i32) nounwind readnone

define void @test3(i32 %x, i32 %y, i32* %z) {
  %r = call %addovf @llvm.sadd.with.overflow.i32(i32 %x, i32 %y)
  %sum = extractvalue %addovf %r, 0
  %sum3 = mul i32 %sum, 3
  %bit = extractvalue %addovf %r, 1
  br i1 %bit, label %then, label %end
  
then:
  store i32 %sum3, i32* %z
  br label %end

end:
  ret void
; CHECK: test3
; CHECK: addl
; CHECK: seto %al
; CHECK: testb $1, %al
}