llvm/llvm/test/MC/RISCV/rv32-hypervisor-csr-names.s

# RUN: llvm-mc %s -triple=riscv32 -riscv-no-aliases -show-encoding \
# RUN:     | FileCheck -check-prefixes=CHECK-INST,CHECK-ENC %s
# RUN: llvm-mc -filetype=obj -triple riscv32 < %s \
# RUN:     | llvm-objdump -d - \
# RUN:     | FileCheck -check-prefix=CHECK-INST-ALIAS %s

##################################
# Hypervisor Configuration
##################################

# henvcfgh
# name
# CHECK-INST: csrrs t1, henvcfgh, zero
# CHECK-ENC: encoding: [0x73,0x23,0xa0,0x61]
# CHECK-INST-ALIAS: csrr t1, henvcfgh
# uimm12
# CHECK-INST: csrrs t2, henvcfgh, zero
# CHECK-ENC: encoding: [0xf3,0x23,0xa0,0x61]
# CHECK-INST-ALIAS: csrr t2, henvcfgh
# name
csrrs t1, henvcfgh, zero
# uimm12
csrrs t2, 0x61A, zero

#####################################################
# Hypervisor Counter/Timer Virtualization Registers
#####################################################

# htimedeltah
# name
# CHECK-INST: csrrs t1, htimedeltah, zero
# CHECK-ENC: encoding: [0x73,0x23,0x50,0x61]
# CHECK-INST-ALIAS: csrr t1, htimedeltah
# uimm12
# CHECK-INST: csrrs t2, htimedeltah, zero
# CHECK-ENC: encoding: [0xf3,0x23,0x50,0x61]
# CHECK-INST-ALIAS: csrr t2, htimedeltah
# name
csrrs t1, htimedeltah, zero
# uimm12
csrrs t2, 0x615, zero

################################
# Virtual Supervisor Registers
################################

# vstimecmph
# name
# CHECK-INST: csrrs t1, vstimecmph, zero
# CHECK-ENC: encoding: [0x73,0x23,0xd0,0x25]
# CHECK-INST-ALIAS: csrr t1, vstimecmph
# uimm12
# CHECK-INST: csrrs t2, vstimecmph, zero
# CHECK-ENC: encoding: [0xf3,0x23,0xd0,0x25]
# CHECK-INST-ALIAS: csrr t2, vstimecmph
# name
csrrs t1, vstimecmph, zero
# uimm12
csrrs t2, 0x25D, zero

#########################################
# State Enable Extension (Smstateen)
#########################################

# hstateen0h
# name
# CHECK-INST: csrrs t1, hstateen0h, zero
# CHECK-ENC: encoding: [0x73,0x23,0xc0,0x61]
# CHECK-INST-ALIAS: csrr t1, hstateen0h
# uimm12
# CHECK-INST: csrrs t2, hstateen0h, zero
# CHECK-ENC: encoding: [0xf3,0x23,0xc0,0x61]
# CHECK-INST-ALIAS: csrr t2, hstateen0h
# name
csrrs t1, hstateen0h, zero
# uimm12
csrrs t2, 0x61C, zero

# hstateen1h
# name
# CHECK-INST: csrrs t1, hstateen1h, zero
# CHECK-ENC: encoding: [0x73,0x23,0xd0,0x61]
# CHECK-INST-ALIAS: csrr t1, hstateen1h
# uimm12
# CHECK-INST: csrrs t2, hstateen1h, zero
# CHECK-ENC: encoding: [0xf3,0x23,0xd0,0x61]
# CHECK-INST-ALIAS: csrr t2, hstateen1h
# name
csrrs t1, hstateen1h, zero
# uimm12
csrrs t2, 0x61D, zero

# hstateen2h
# name
# CHECK-INST: csrrs t1, hstateen2h, zero
# CHECK-ENC: encoding: [0x73,0x23,0xe0,0x61]
# CHECK-INST-ALIAS: csrr t1, hstateen2h
# uimm12
# CHECK-INST: csrrs t2, hstateen2h, zero
# CHECK-ENC: encoding: [0xf3,0x23,0xe0,0x61]
# CHECK-INST-ALIAS: csrr t2, hstateen2h
# name
csrrs t1, hstateen2h, zero
# uimm12
csrrs t2, 0x61E, zero

# hstateen3h
# name
# CHECK-INST: csrrs t1, hstateen3h, zero
# CHECK-ENC: encoding: [0x73,0x23,0xf0,0x61]
# CHECK-INST-ALIAS: csrr t1, hstateen3h
# uimm12
# CHECK-INST: csrrs t2, hstateen3h, zero
# CHECK-ENC: encoding: [0xf3,0x23,0xf0,0x61]
# CHECK-INST-ALIAS: csrr t2, hstateen3h
# name
csrrs t1, hstateen3h, zero
# uimm12
csrrs t2, 0x61F, zero

#########################################
# Advanced Interrupt Architecture (Smaia and Ssaia)
#########################################

# hidelegh
# name
# CHECK-INST: csrrs t1, hidelegh, zero
# CHECK-ENC: encoding: [0x73,0x23,0x30,0x61]
# CHECK-INST-ALIAS: csrr t1, hidelegh
# uimm12
# CHECK-INST: csrrs t2, hidelegh, zero
# CHECK-ENC: encoding: [0xf3,0x23,0x30,0x61]
# CHECK-INST-ALIAS: csrr t2, hidelegh
# name
csrrs t1, hidelegh, zero
# uimm12
csrrs t2, 0x613, zero

# hvienh
# name
# CHECK-INST: csrrs t1, hvienh, zero
# CHECK-ENC: encoding: [0x73,0x23,0x80,0x61]
# CHECK-INST-ALIAS: csrr t1, hvienh
# uimm12
# CHECK-INST: csrrs t2, hvienh, zero
# CHECK-ENC: encoding: [0xf3,0x23,0x80,0x61]
# CHECK-INST-ALIAS: csrr t2, hvienh
# name
csrrs t1, hvienh, zero
# uimm12
csrrs t2, 0x618, zero

# hviph
# name
# CHECK-INST: csrrs t1, hviph, zero
# CHECK-ENC: encoding: [0x73,0x23,0x50,0x65]
# CHECK-INST-ALIAS: csrr t1, hviph
# uimm12
# CHECK-INST: csrrs t2, hviph, zero
# CHECK-ENC: encoding: [0xf3,0x23,0x50,0x65]
# CHECK-INST-ALIAS: csrr t2, hviph
# name
csrrs t1, hviph, zero
# uimm12
csrrs t2, 0x655, zero

# hviprio1h
# name
# CHECK-INST: csrrs t1, hviprio1h, zero
# CHECK-ENC: encoding: [0x73,0x23,0x60,0x65]
# CHECK-INST-ALIAS: csrr t1, hviprio1h
# uimm12
# CHECK-INST: csrrs t2, hviprio1h, zero
# CHECK-ENC: encoding: [0xf3,0x23,0x60,0x65]
# CHECK-INST-ALIAS: csrr t2, hviprio1h
# name
csrrs t1, hviprio1h, zero
# uimm12
csrrs t2, 0x656, zero

# hviprio2h
# name
# CHECK-INST: csrrs t1, hviprio2h, zero
# CHECK-ENC: encoding: [0x73,0x23,0x70,0x65]
# CHECK-INST-ALIAS: csrr t1, hviprio2h
# uimm12
# CHECK-INST: csrrs t2, hviprio2h, zero
# CHECK-ENC: encoding: [0xf3,0x23,0x70,0x65]
# CHECK-INST-ALIAS: csrr t2, hviprio2h
# name
csrrs t1, hviprio2h, zero
# uimm12
csrrs t2, 0x657, zero

# vsieh
# name
# CHECK-INST: csrrs t1, vsieh, zero
# CHECK-ENC: encoding: [0x73,0x23,0x40,0x21]
# CHECK-INST-ALIAS: csrr t1, vsieh
# uimm12
# CHECK-INST: csrrs t2, vsieh, zero
# CHECK-ENC: encoding: [0xf3,0x23,0x40,0x21]
# CHECK-INST-ALIAS: csrr t2, vsieh
# name
csrrs t1, vsieh, zero
# uimm12
csrrs t2, 0x214, zero

# vsiph
# name
# CHECK-INST: csrrs t1, vsiph, zero
# CHECK-ENC: encoding: [0x73,0x23,0x40,0x25]
# CHECK-INST-ALIAS: csrr t1, vsiph
# uimm12
# CHECK-INST: csrrs t2, vsiph, zero
# CHECK-ENC: encoding: [0xf3,0x23,0x40,0x25]
# CHECK-INST-ALIAS: csrr t2, vsiph
# name
csrrs t1, vsiph, zero
# uimm12
csrrs t2, 0x254, zero