Skip to content

Commit 79d13bf

Browse files
committed
Revert "Revert "[GlobalISel][IRTranslator] Emit trap intrinsic for "unreachable"""
This reverts commit d95cd81. Re-land the original patch now that the bug this exposed in selection has been fixed by 6bc64e2
1 parent e9f4fa7 commit 79d13bf

File tree

3 files changed

+48
-3
lines changed

3 files changed

+48
-3
lines changed

llvm/include/llvm/CodeGen/GlobalISel/IRTranslator.h

Lines changed: 2 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -467,9 +467,8 @@ class IRTranslator : public MachineFunctionPass {
467467
bool translateSIToFP(const User &U, MachineIRBuilder &MIRBuilder) {
468468
return translateCast(TargetOpcode::G_SITOFP, U, MIRBuilder);
469469
}
470-
bool translateUnreachable(const User &U, MachineIRBuilder &MIRBuilder) {
471-
return true;
472-
}
470+
bool translateUnreachable(const User &U, MachineIRBuilder &MIRBuilder);
471+
473472
bool translateSExt(const User &U, MachineIRBuilder &MIRBuilder) {
474473
return translateCast(TargetOpcode::G_SEXT, U, MIRBuilder);
475474
}

llvm/lib/CodeGen/GlobalISel/IRTranslator.cpp

Lines changed: 22 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -2701,6 +2701,28 @@ bool IRTranslator::translateVAArg(const User &U, MachineIRBuilder &MIRBuilder) {
27012701
return true;
27022702
}
27032703

2704+
bool IRTranslator::translateUnreachable(const User &U, MachineIRBuilder &MIRBuilder) {
2705+
if (!MF->getTarget().Options.TrapUnreachable)
2706+
return true;
2707+
2708+
auto &UI = cast<UnreachableInst>(U);
2709+
// We may be able to ignore unreachable behind a noreturn call.
2710+
if (MF->getTarget().Options.NoTrapAfterNoreturn) {
2711+
const BasicBlock &BB = *UI.getParent();
2712+
if (&UI != &BB.front()) {
2713+
BasicBlock::const_iterator PredI =
2714+
std::prev(BasicBlock::const_iterator(UI));
2715+
if (const CallInst *Call = dyn_cast<CallInst>(&*PredI)) {
2716+
if (Call->doesNotReturn())
2717+
return true;
2718+
}
2719+
}
2720+
}
2721+
2722+
MIRBuilder.buildIntrinsic(Intrinsic::trap, ArrayRef<Register>(), true);
2723+
return true;
2724+
}
2725+
27042726
bool IRTranslator::translateInsertElement(const User &U,
27052727
MachineIRBuilder &MIRBuilder) {
27062728
// If it is a <1 x Ty> vector, use the scalar as it is
Lines changed: 24 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,24 @@
1+
; NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
2+
; RUN: llc -O0 -mtriple=aarch64-apple-ios -global-isel -stop-after=irtranslator %s -o - | FileCheck %s
3+
4+
declare void @llvm.trap()
5+
6+
define void @unreachable() {
7+
; CHECK-LABEL: name: unreachable
8+
; CHECK: bb.1 (%ir-block.0):
9+
; CHECK-NEXT: G_INTRINSIC_W_SIDE_EFFECTS intrinsic(@llvm.trap)
10+
unreachable
11+
ret void
12+
}
13+
14+
declare void @foo() noreturn
15+
define void @trap_call_noreturn() {
16+
; CHECK-LABEL: name: trap_call_noreturn
17+
; CHECK: bb.1 (%ir-block.0):
18+
; CHECK-NEXT: ADJCALLSTACKDOWN 0, 0, implicit-def $sp, implicit $sp
19+
; CHECK-NEXT: BL @foo, csr_darwin_aarch64_aapcs, implicit-def $lr, implicit $sp
20+
; CHECK-NEXT: ADJCALLSTACKUP 0, 0, implicit-def $sp, implicit $sp
21+
call void @foo()
22+
unreachable
23+
ret void
24+
}

0 commit comments

Comments
 (0)