# RUN: llvm-mc %s -triple=riscv32 -mattr=+zfinx -riscv-no-aliases \ # RUN: | FileCheck -check-prefix=CHECK-INST %s # RUN: llvm-mc %s -triple=riscv32 -mattr=+zfinx \ # RUN: | FileCheck -check-prefix=CHECK-ALIAS %s # RUN: llvm-mc %s -triple=riscv64 -mattr=+zfinx -riscv-no-aliases \ # RUN: | FileCheck -check-prefix=CHECK-INST %s # RUN: llvm-mc %s -triple=riscv64 -mattr=+zfinx \ # RUN: | FileCheck -check-prefix=CHECK-ALIAS %s # RUN: llvm-mc -filetype=obj -triple riscv32 -mattr=+zfinx %s \ # RUN: | llvm-objdump -d --mattr=+zfinx -M no-aliases - \ # RUN: | FileCheck -check-prefix=CHECK-INST %s # RUN: llvm-mc -filetype=obj -triple riscv32 -mattr=+zfinx %s \ # RUN: | llvm-objdump -d --mattr=+zfinx - \ # RUN: | FileCheck -check-prefix=CHECK-ALIAS %s # RUN: llvm-mc -filetype=obj -triple riscv64 -mattr=+zfinx %s \ # RUN: | llvm-objdump -d --mattr=+zfinx -M no-aliases - \ # RUN: | FileCheck -check-prefix=CHECK-INST %s # RUN: llvm-mc -filetype=obj -triple riscv64 -mattr=+zfinx %s \ # RUN: | llvm-objdump -d --mattr=+zfinx - \ # RUN: | FileCheck -check-prefix=CHECK-ALIAS %s ##===----------------------------------------------------------------------===## ## Assembler Pseudo Instructions (User-Level ISA, Version 2.2, Chapter 20) ##===----------------------------------------------------------------------===## # CHECK-INST: fsgnjx.s s1, s2, s2 # CHECK-ALIAS: fabs.s s1, s2 fabs.s s1, s2 # CHECK-INST: fsgnjn.s s2, s3, s3 # CHECK-ALIAS: fneg.s s2, s3 fneg.s s2, s3 # CHECK-INST: flt.s tp, s6, s5 # CHECK-ALIAS: flt.s tp, s6, s5 fgt.s x4, s5, s6 # CHECK-INST: fle.s t2, s1, s0 # CHECK-ALIAS: fle.s t2, s1, s0 fge.s x7, x8, x9 ##===----------------------------------------------------------------------===## ## Aliases which omit the rounding mode. ##===----------------------------------------------------------------------===## # CHECK-INST: fmadd.s a0, a1, a2, a3, dyn # CHECK-ALIAS: fmadd.s a0, a1, a2, a3 fmadd.s x10, x11, x12, x13 # CHECK-INST: fmsub.s a4, a5, a6, a7, dyn # CHECK-ALIAS: fmsub.s a4, a5, a6, a7 fmsub.s x14, x15, x16, x17 # CHECK-INST: fnmsub.s s2, s3, s4, s5, dyn # CHECK-ALIAS: fnmsub.s s2, s3, s4, s5 fnmsub.s x18, x19, x20, x21 # CHECK-INST: fnmadd.s s6, s7, s8, s9, dyn # CHECK-ALIAS: fnmadd.s s6, s7, s8, s9 fnmadd.s x22, x23, x24, x25 # CHECK-INST: fadd.s s10, s11, t3, dyn # CHECK-ALIAS: fadd.s s10, s11, t3 fadd.s x26, x27, x28 # CHECK-INST: fsub.s t4, t5, t6, dyn # CHECK-ALIAS: fsub.s t4, t5, t6 fsub.s x29, x30, x31 # CHECK-INST: fmul.s s0, s1, s2, dyn # CHECK-ALIAS: fmul.s s0, s1, s2 fmul.s s0, s1, s2 # CHECK-INST: fdiv.s s3, s4, s5, dyn # CHECK-ALIAS: fdiv.s s3, s4, s5 fdiv.s s3, s4, s5 # CHECK-INST: sqrt.s s6, s7, dyn # CHECK-ALIAS: sqrt.s s6, s7 fsqrt.s s6, s7 # CHECK-INST: fcvt.w.s a0, s5, dyn # CHECK-ALIAS: fcvt.w.s a0, s5 fcvt.w.s a0, s5 # CHECK-INST: fcvt.wu.s a1, s6, dyn # CHECK-ALIAS: fcvt.wu.s a1, s6 fcvt.wu.s a1, s6 # CHECK-INST: fcvt.s.w t6, a4, dyn # CHECK-ALIAS: fcvt.s.w t6, a4 fcvt.s.w t6, a4 # CHECK-INST: fcvt.s.wu s0, a5, dyn # CHECK-ALIAS: fcvt.s.wu s0, a5 fcvt.s.wu s0, a5