mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-13 20:32:21 +00:00
Select @llvm.trap to the special B with 1111 condition (i.e. trap) instruction.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@103459 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
7d9663c70b
commit
fb3611daad
@ -384,6 +384,8 @@ ARMTargetLowering::ARMTargetLowering(TargetMachine &TM)
|
||||
setOperationAction(ISD::GlobalTLSAddress, MVT::i32, Custom);
|
||||
setOperationAction(ISD::BlockAddress, MVT::i32, Custom);
|
||||
|
||||
setOperationAction(ISD::TRAP, MVT::Other, Legal);
|
||||
|
||||
// Use the default implementation.
|
||||
setOperationAction(ISD::VASTART, MVT::Other, Custom);
|
||||
setOperationAction(ISD::VAARG, MVT::Other, Expand);
|
||||
|
@ -791,8 +791,8 @@ def DBG : AI<(outs), (ins i32imm:$opt), MiscFrm, NoItinerary, "dbg", "\t$opt",
|
||||
}
|
||||
|
||||
// A5.4 Permanently UNDEFINED instructions.
|
||||
def TRAP : AI<(outs), (ins), MiscFrm, NoItinerary, "trap", "",
|
||||
[/* For disassembly only; pattern left blank */]>,
|
||||
let isBarrier = 1, isTerminator = 1 in
|
||||
def TRAP : AXI<(outs), (ins), MiscFrm, NoItinerary, "trap", [(trap)]>,
|
||||
Requires<[IsARM]> {
|
||||
let Inst{27-25} = 0b011;
|
||||
let Inst{24-20} = 0b11111;
|
||||
|
@ -417,9 +417,10 @@ def tSVC : T1pI<(outs), (ins i32imm:$svc), IIC_Br, "svc", "\t$svc", []>,
|
||||
}
|
||||
}
|
||||
|
||||
// A8.6.16 B: Encoding T1 -- for disassembly only
|
||||
// A8.6.16 B: Encoding T1
|
||||
// If Inst{11-8} == 0b1110 then UNDEFINED
|
||||
def tTRAP : T1I<(outs), (ins), IIC_Br, "trap", []>, Encoding16 {
|
||||
let isBarrier = 1, isTerminator = 1 in
|
||||
def tTRAP : TI<(outs), (ins), IIC_Br, "trap", [(trap)]>, Encoding16 {
|
||||
let Inst{15-12} = 0b1101;
|
||||
let Inst{11-8} = 0b1110;
|
||||
}
|
||||
|
12
test/CodeGen/ARM/trap.ll
Normal file
12
test/CodeGen/ARM/trap.ll
Normal file
@ -0,0 +1,12 @@
|
||||
; RUN: llc < %s -march=arm | FileCheck %s
|
||||
; rdar://7961298
|
||||
|
||||
define arm_apcscc void @t() nounwind {
|
||||
entry:
|
||||
; CHECK: t:
|
||||
; CHECK: trap
|
||||
call void @llvm.trap()
|
||||
unreachable
|
||||
}
|
||||
|
||||
declare void @llvm.trap() nounwind
|
12
test/CodeGen/Thumb/trap.ll
Normal file
12
test/CodeGen/Thumb/trap.ll
Normal file
@ -0,0 +1,12 @@
|
||||
; RUN: llc < %s -march=thumb | FileCheck %s
|
||||
; rdar://7961298
|
||||
|
||||
define arm_apcscc void @t() nounwind {
|
||||
entry:
|
||||
; CHECK: t:
|
||||
; CHECK: trap
|
||||
call void @llvm.trap()
|
||||
unreachable
|
||||
}
|
||||
|
||||
declare void @llvm.trap() nounwind
|
Loading…
Reference in New Issue
Block a user