mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-28 04:33:05 +00:00
[Thumb2] BXJ should be undefined for v7M, v8A
The Thumb2 BXJ instruction (Branch and Exchange Jazelle) is not defined for v7M or v8A. It is defined for all other Thumb2-supporting architectures (v6T2, v7A and v7R). git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@218445 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
2e8d2c727c
commit
f220c5387b
@ -3632,7 +3632,7 @@ def t2IT : Thumb2XI<(outs), (ins it_pred:$cc, it_mask:$mask),
|
||||
// Branch and Exchange Jazelle -- for disassembly only
|
||||
// Rm = Inst{19-16}
|
||||
def t2BXJ : T2I<(outs), (ins rGPR:$func), NoItinerary, "bxj", "\t$func", []>,
|
||||
Sched<[WriteBr]> {
|
||||
Sched<[WriteBr]>, Requires<[IsThumb2, IsNotMClass, PreV8]> {
|
||||
bits<4> func;
|
||||
let Inst{31-27} = 0b11110;
|
||||
let Inst{26} = 0;
|
||||
|
10
test/MC/ARM/thumb2-bxj.s
Normal file
10
test/MC/ARM/thumb2-bxj.s
Normal file
@ -0,0 +1,10 @@
|
||||
@ RUN: llvm-mc -triple=thumbv6t2--none-eabi -show-encoding < %s | FileCheck %s
|
||||
@ RUN: llvm-mc -triple=thumbv7a--none-eabi -show-encoding < %s | FileCheck %s
|
||||
@ RUN: llvm-mc -triple=thumbv7r--none-eabi -show-encoding < %s | FileCheck %s
|
||||
@ RUN: not llvm-mc -triple=thumbv7m--none-eabi -show-encoding < %s 2>&1 | FileCheck %s --check-prefix=UNDEF
|
||||
@ RUN: not llvm-mc -triple=thumbv8a--none-eabi -show-encoding < %s 2>&1 | FileCheck %s --check-prefix=UNDEF
|
||||
|
||||
bxj r2
|
||||
|
||||
@ CHECK: bxj r2 @ encoding: [0xc2,0xf3,0x00,0x8f]
|
||||
@ UNDEF: error: instruction requires: arm-mode
|
Loading…
Reference in New Issue
Block a user