Source code

Revision control

Copy as Markdown

Other Tools

// Copyright 2022 the V8 project authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "jit/riscv64/extension/extension-riscv-zfh.h"
namespace js::jit {
// RV32F Standard Extension
void AssemblerRISCVZfh::flh(FPURegister rd, Register rs1, int16_t imm12) {
GenInstrLoadFP_ri(0b001, rd, rs1, imm12);
}
void AssemblerRISCVZfh::fsh(FPURegister source, Register base, int16_t imm12) {
GenInstrStoreFP_rri(0b001, base, source, imm12);
}
void AssemblerRISCVZfh::fmadd_h(FPURegister rd, FPURegister rs1,
FPURegister rs2, FPURegister rs3,
FPURoundingMode frm) {
GenInstrR4(0b10, MADD, rd, rs1, rs2, rs3, frm);
}
void AssemblerRISCVZfh::fmsub_h(FPURegister rd, FPURegister rs1,
FPURegister rs2, FPURegister rs3,
FPURoundingMode frm) {
GenInstrR4(0b10, MSUB, rd, rs1, rs2, rs3, frm);
}
void AssemblerRISCVZfh::fnmsub_h(FPURegister rd, FPURegister rs1,
FPURegister rs2, FPURegister rs3,
FPURoundingMode frm) {
GenInstrR4(0b10, NMSUB, rd, rs1, rs2, rs3, frm);
}
void AssemblerRISCVZfh::fnmadd_h(FPURegister rd, FPURegister rs1,
FPURegister rs2, FPURegister rs3,
FPURoundingMode frm) {
GenInstrR4(0b10, NMADD, rd, rs1, rs2, rs3, frm);
}
void AssemblerRISCVZfh::fadd_h(FPURegister rd, FPURegister rs1, FPURegister rs2,
FPURoundingMode frm) {
GenInstrALUFP_rr(0b0000010, frm, rd, rs1, rs2);
}
void AssemblerRISCVZfh::fsub_h(FPURegister rd, FPURegister rs1, FPURegister rs2,
FPURoundingMode frm) {
GenInstrALUFP_rr(0b0000110, frm, rd, rs1, rs2);
}
void AssemblerRISCVZfh::fmul_h(FPURegister rd, FPURegister rs1, FPURegister rs2,
FPURoundingMode frm) {
GenInstrALUFP_rr(0b0001010, frm, rd, rs1, rs2);
}
void AssemblerRISCVZfh::fdiv_h(FPURegister rd, FPURegister rs1, FPURegister rs2,
FPURoundingMode frm) {
GenInstrALUFP_rr(0b0001110, frm, rd, rs1, rs2);
}
void AssemblerRISCVZfh::fsqrt_h(FPURegister rd, FPURegister rs1,
FPURoundingMode frm) {
GenInstrALUFP_rr(0b0101110, frm, rd, rs1, zero_reg);
}
void AssemblerRISCVZfh::fsgnj_h(FPURegister rd, FPURegister rs1,
FPURegister rs2) {
GenInstrALUFP_rr(0b0010010, 0b000, rd, rs1, rs2);
}
void AssemblerRISCVZfh::fsgnjn_h(FPURegister rd, FPURegister rs1,
FPURegister rs2) {
GenInstrALUFP_rr(0b0010010, 0b001, rd, rs1, rs2);
}
void AssemblerRISCVZfh::fsgnjx_h(FPURegister rd, FPURegister rs1,
FPURegister rs2) {
GenInstrALUFP_rr(0b0010010, 0b010, rd, rs1, rs2);
}
void AssemblerRISCVZfh::fmin_h(FPURegister rd, FPURegister rs1,
FPURegister rs2) {
GenInstrALUFP_rr(0b0010110, 0b000, rd, rs1, rs2);
}
void AssemblerRISCVZfh::fmax_h(FPURegister rd, FPURegister rs1,
FPURegister rs2) {
GenInstrALUFP_rr(0b0010110, 0b001, rd, rs1, rs2);
}
void AssemblerRISCVZfh::feq_h(Register rd, FPURegister rs1, FPURegister rs2) {
GenInstrALUFP_rr(0b1010010, 0b010, rd, rs1, rs2);
}
void AssemblerRISCVZfh::flt_h(Register rd, FPURegister rs1, FPURegister rs2) {
GenInstrALUFP_rr(0b1010010, 0b001, rd, rs1, rs2);
}
void AssemblerRISCVZfh::fle_h(Register rd, FPURegister rs1, FPURegister rs2) {
GenInstrALUFP_rr(0b1010010, 0b000, rd, rs1, rs2);
}
void AssemblerRISCVZfh::fclass_h(Register rd, FPURegister rs1) {
GenInstrALUFP_rr(0b1110010, 0b001, rd, rs1, zero_reg);
}
void AssemblerRISCVZfh::fcvt_h_w(FPURegister rd, Register rs1,
FPURoundingMode frm) {
GenInstrALUFP_rr(0b1101010, frm, rd, rs1, zero_reg);
}
void AssemblerRISCVZfh::fcvt_h_wu(FPURegister rd, Register rs1,
FPURoundingMode frm) {
GenInstrALUFP_rr(0b1101010, frm, rd, rs1, Register::FromCode(1));
}
void AssemblerRISCVZfh::fcvt_w_h(Register rd, FPURegister rs1,
FPURoundingMode frm) {
GenInstrALUFP_rr(0b1100010, frm, rd, rs1, zero_reg);
}
void AssemblerRISCVZfh::fcvt_wu_h(Register rd, FPURegister rs1,
FPURoundingMode frm) {
GenInstrALUFP_rr(0b1100010, frm, rd, rs1, Register::FromCode(1));
}
void AssemblerRISCVZfh::fmv_h_x(FPURegister rd, Register rs1) {
GenInstrALUFP_rr(0b1111010, 0b000, rd, rs1, zero_reg);
}
void AssemblerRISCVZfh::fmv_x_h(Register rd, FPURegister rs1) {
GenInstrALUFP_rr(0b1110010, 0b000, rd, rs1, zero_reg);
}
void AssemblerRISCVZfh::fcvt_h_d(FPURegister rd, FPURegister rs1,
FPURoundingMode frm) {
GenInstrALUFP_rr(0b0100010, frm, rd, rs1, Register::FromCode(1));
}
void AssemblerRISCVZfh::fcvt_d_h(FPURegister rd, FPURegister rs1,
FPURoundingMode frm) {
GenInstrALUFP_rr(0b0100001, frm, rd, rs1, Register::FromCode(2));
}
void AssemblerRISCVZfh::fcvt_h_s(FPURegister rd, FPURegister rs1,
FPURoundingMode frm) {
GenInstrALUFP_rr(0b0100010, frm, rd, rs1, zero_reg);
}
void AssemblerRISCVZfh::fcvt_s_h(FPURegister rd, FPURegister rs1,
FPURoundingMode frm) {
GenInstrALUFP_rr(0b0100000, frm, rd, rs1, Register::FromCode(2));
}
// RV64F Standard Extension (in addition to RV32F)
void AssemblerRISCVZfh::fcvt_l_h(Register rd, FPURegister rs1,
FPURoundingMode frm) {
GenInstrALUFP_rr(0b1100010, frm, rd, rs1, Register::FromCode(2));
}
void AssemblerRISCVZfh::fcvt_lu_h(Register rd, FPURegister rs1,
FPURoundingMode frm) {
GenInstrALUFP_rr(0b1100010, frm, rd, rs1, Register::FromCode(3));
}
void AssemblerRISCVZfh::fcvt_h_l(FPURegister rd, Register rs1,
FPURoundingMode frm) {
GenInstrALUFP_rr(0b1101010, frm, rd, rs1, Register::FromCode(2));
}
void AssemblerRISCVZfh::fcvt_h_lu(FPURegister rd, Register rs1,
FPURoundingMode frm) {
GenInstrALUFP_rr(0b1101010, frm, rd, rs1, Register::FromCode(3));
}
} // namespace js::jit