| ; RUN: llc < %s -mtriple=x86_64-none-none-gnux32 -mcpu=generic | FileCheck %s |
| ; RUN: llc < %s -mtriple=x86_64-none-none-gnux32 -mcpu=generic -fast-isel | FileCheck %s |
| ; |
| ; Ensures that landingpad instructions in x32 use the right Exception Pointer |
| ; and Exception Selector registers. |
| |
| declare void @foo() |
| declare void @bar(i8*, i32) noreturn |
| declare i32 @__gxx_personality_v0(...) |
| |
| define void @test1() uwtable personality i32 (...)* @__gxx_personality_v0 { |
| entry: |
| invoke void @foo() to label %done unwind label %lpad |
| done: |
| ret void |
| lpad: |
| %0 = landingpad { i8*, i32 } cleanup |
| ; The Exception Pointer is %eax; the Exception Selector, %edx. |
| ; CHECK: LBB{{[^%]*}} %lpad |
| ; CHECK-DAG: movl %eax, {{.*}} |
| ; CHECK-DAG: movl %edx, {{.*}} |
| ; CHECK: callq bar |
| %1 = extractvalue { i8*, i32 } %0, 0 |
| %2 = extractvalue { i8*, i32 } %0, 1 |
| call void @bar(i8* %1, i32 %2) |
| unreachable |
| } |