mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-26 04:32:44 +01:00
5d333b2d27
This patch updates the X86 lowering so that the Exception Pointer and Selector are 64-bit wide only if Subtarget.isTarget64BitLP64. Patch by João Porto Reviewers: dschuff, rnk Differential Revision: http://reviews.llvm.org/D12111 llvm-svn: 245454
28 lines
880 B
LLVM
28 lines
880 B
LLVM
; 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
|
|
}
|