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