llvm-project/llvm/test/MC/MBlaze/mblaze_special.s

168 lines
4.8 KiB
ArmAsm

# RUN: llvm-mc -triple mblaze-unknown-unknown -show-encoding %s | FileCheck %s
# Test to ensure that all special instructions and special registers can be
# parsed by the assembly parser correctly.
# TYPE A: OPCODE RD RA RB FLAGS
# BINARY: 011011 00000 00000 00000 00000000000
# CHECK: mfs
# BINARY: 100101 00000 00000 10000 00000000000
# CHECK: encoding: [0x94,0x00,0x80,0x00]
mfs r0, rpc
# CHECK: msrclr
# BINARY: 100101 00000 100010 000000000000000
# CHECK: encoding: [0x94,0x11,0x00,0x00]
msrclr r0, 0x0
# CHECK: msrset
# BINARY: 100101 00000 100000 000000000000000
# CHECK: encoding: [0x94,0x10,0x00,0x00]
msrset r0, 0x0
# CHECK: mts
# BINARY: 100101 00000 00000 11 00000000000000
# CHECK: encoding: [0x94,0x00,0xc0,0x00]
mts rpc, r0
# CHECK: wdc
# BINARY: 100100 00000 00000 00001 00001100100
# CHECK: encoding: [0x90,0x00,0x08,0x64]
wdc r0, r1
# CHECK: wdc.clear
# BINARY: 100100 00000 00000 00001 00001100110
# CHECK: encoding: [0x90,0x00,0x08,0x66]
wdc.clear r0, r1
# CHECK: wdc.flush
# BINARY: 100100 00000 00000 00001 00001110100
# CHECK: encoding: [0x90,0x00,0x08,0x74]
wdc.flush r0, r1
# CHECK: wic
# BINARY: 100100 00000 00000 00001 00001101000
# CHECK: encoding: [0x90,0x00,0x08,0x68]
wic r0, r1
# CHECK: mfs
# BINARY: 100101 00001 00000 10000 00000000000
# CHECK: encoding: [0x94,0x20,0x80,0x00]
mfs r1, rpc
# CHECK: mfs
# BINARY: 100101 00001 00000 10000 00000000001
# CHECK: encoding: [0x94,0x20,0x80,0x01]
mfs r1, rmsr
# CHECK: mfs
# BINARY: 100101 00001 00000 10000 00000000011
# CHECK: encoding: [0x94,0x20,0x80,0x03]
mfs r1, rear
# CHECK: mfs
# BINARY: 100101 00001 00000 10000 00000000101
# CHECK: encoding: [0x94,0x20,0x80,0x05]
mfs r1, resr
# CHECK: mfs
# BINARY: 100101 00001 00000 10000 00000000111
# CHECK: encoding: [0x94,0x20,0x80,0x07]
mfs r1, rfsr
# CHECK: mfs
# BINARY: 100101 00001 00000 10000 00000001011
# CHECK: encoding: [0x94,0x20,0x80,0x0b]
mfs r1, rbtr
# CHECK: mfs
# BINARY: 100101 00001 00000 10000 00000001101
# CHECK: encoding: [0x94,0x20,0x80,0x0d]
mfs r1, redr
# CHECK: mfs
# BINARY: 100101 00001 00000 10010 00000000000
# CHECK: encoding: [0x94,0x20,0x90,0x00]
mfs r1, rpid
# CHECK: mfs
# BINARY: 100101 00001 00000 10010 00000000001
# CHECK: encoding: [0x94,0x20,0x90,0x01]
mfs r1, rzpr
# CHECK: mfs
# BINARY: 100101 00001 00000 10010 00000000010
# CHECK: encoding: [0x94,0x20,0x90,0x02]
mfs r1, rtlbx
# CHECK: mfs
# BINARY: 100101 00001 00000 10010 00000000100
# CHECK: encoding: [0x94,0x20,0x90,0x04]
mfs r1, rtlbhi
# CHECK: mfs
# BINARY: 100101 00001 00000 10010 00000000011
# CHECK: encoding: [0x94,0x20,0x90,0x03]
mfs r1, rtlblo
# CHECK: mfs
# BINARY: 100101 00001 00000 10100 00000000000
# CHECK: encoding: [0x94,0x20,0xa0,0x00]
mfs r1, rpvr0
# CHECK: mfs
# BINARY: 100101 00001 00000 10100 00000000001
# CHECK: encoding: [0x94,0x20,0xa0,0x01]
mfs r1, rpvr1
# CHECK: mfs
# BINARY: 100101 00001 00000 10100 00000000010
# CHECK: encoding: [0x94,0x20,0xa0,0x02]
mfs r1, rpvr2
# CHECK: mfs
# BINARY: 100101 00001 00000 10100 00000000011
# CHECK: encoding: [0x94,0x20,0xa0,0x03]
mfs r1, rpvr3
# CHECK: mfs
# BINARY: 100101 00001 00000 10100 00000000100
# CHECK: encoding: [0x94,0x20,0xa0,0x04]
mfs r1, rpvr4
# CHECK: mfs
# BINARY: 100101 00001 00000 10100 00000000101
# CHECK: encoding: [0x94,0x20,0xa0,0x05]
mfs r1, rpvr5
# CHECK: mfs
# BINARY: 100101 00001 00000 10100 00000000110
# CHECK: encoding: [0x94,0x20,0xa0,0x06]
mfs r1, rpvr6
# CHECK: mfs
# BINARY: 100101 00001 00000 10100 00000000111
# CHECK: encoding: [0x94,0x20,0xa0,0x07]
mfs r1, rpvr7
# CHECK: mfs
# BINARY: 100101 00001 00000 10100 00000001000
# CHECK: encoding: [0x94,0x20,0xa0,0x08]
mfs r1, rpvr8
# CHECK: mfs
# BINARY: 100101 00001 00000 10100 00000001001
# CHECK: encoding: [0x94,0x20,0xa0,0x09]
mfs r1, rpvr9
# CHECK: mfs
# BINARY: 100101 00001 00000 10100 00000001010
# CHECK: encoding: [0x94,0x20,0xa0,0x0a]
mfs r1, rpvr10
# CHECK: mfs
# BINARY: 100101 00001 00000 10100 00000001011
# CHECK: encoding: [0x94,0x20,0xa0,0x0b]
mfs r1, rpvr11