mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-23 11:13:28 +01:00
1d13d635fc
This is an alternative to D66980, which was reverted. Instead of inserting a pseudo instruction that optionally expands to nothing, add a pass that inserts int3 when appropriate after basic block layout. Reviewers: hans Differential Revision: https://reviews.llvm.org/D67201 llvm-svn: 371466
37 lines
1.1 KiB
LLVM
37 lines
1.1 KiB
LLVM
; RUN: llc -o - %s -mtriple=x86_64-linux-gnu | FileCheck %s --check-prefixes=CHECK,NORMAL
|
|
; RUN: llc -o - %s -mtriple=x86_64-windows-msvc | FileCheck %s --check-prefixes=CHECK,NORMAL
|
|
; RUN: llc -o - %s -mtriple=x86_64-scei-ps4 | FileCheck %s --check-prefixes=CHECK,TRAP_AFTER_NORETURN
|
|
; RUN: llc -o - %s -mtriple=x86_64-apple-darwin | FileCheck %s --check-prefixes=CHECK,NO_TRAP_AFTER_NORETURN
|
|
|
|
; CHECK-LABEL: call_exit:
|
|
; CHECK: callq {{_?}}exit
|
|
; TRAP_AFTER_NORETURN: ud2
|
|
; NO_TRAP_AFTER_NORETURN-NOT: ud2
|
|
; NORMAL-NOT: ud2
|
|
define i32 @call_exit() noreturn nounwind {
|
|
tail call void @exit(i32 0)
|
|
unreachable
|
|
}
|
|
|
|
; CHECK-LABEL: trap:
|
|
; CHECK: ud2
|
|
; TRAP_AFTER_NORETURN: ud2
|
|
; NO_TRAP_AFTER_NORETURN-NOT: ud2
|
|
; NORMAL-NOT: ud2
|
|
define i32 @trap() noreturn nounwind {
|
|
tail call void @llvm.trap()
|
|
unreachable
|
|
}
|
|
|
|
; CHECK-LABEL: unreachable:
|
|
; TRAP_AFTER_NORETURN: ud2
|
|
; NO_TRAP_AFTER_NORETURN: ud2
|
|
; NORMAL-NOT: ud2
|
|
; NORMAL: # -- End function
|
|
define i32 @unreachable() noreturn nounwind {
|
|
unreachable
|
|
}
|
|
|
|
declare void @llvm.trap() nounwind noreturn
|
|
declare void @exit(i32 %rc) nounwind noreturn
|