v8
V8 is Google’s open source high-performance JavaScript and WebAssembly engine, written in C++.
Loading...
Searching...
No Matches
extension-riscv-d.h
Go to the documentation of this file.
1// Copyright 2022 the V8 project authors. All rights reserved.
2// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
5#ifndef V8_CODEGEN_RISCV_EXTENSION_RISCV_D_H_
6#define V8_CODEGEN_RISCV_EXTENSION_RISCV_D_H_
7
12
13namespace v8 {
14namespace internal {
16 // RV32D Standard Extension
17 public:
18 void fld(FPURegister rd, Register rs1, int16_t imm12);
19 void fsd(FPURegister source, Register base, int16_t imm12);
28 void fadd_d(FPURegister rd, FPURegister rs1, FPURegister rs2,
29 FPURoundingMode frm = RNE);
30 void fsub_d(FPURegister rd, FPURegister rs1, FPURegister rs2,
31 FPURoundingMode frm = RNE);
32 void fmul_d(FPURegister rd, FPURegister rs1, FPURegister rs2,
33 FPURoundingMode frm = RNE);
34 void fdiv_d(FPURegister rd, FPURegister rs1, FPURegister rs2,
35 FPURoundingMode frm = RNE);
37 void fsgnj_d(FPURegister rd, FPURegister rs1, FPURegister rs2);
40 void fmin_d(FPURegister rd, FPURegister rs1, FPURegister rs2);
41 void fmax_d(FPURegister rd, FPURegister rs1, FPURegister rs2);
44 void feq_d(Register rd, FPURegister rs1, FPURegister rs2);
45 void flt_d(Register rd, FPURegister rs1, FPURegister rs2);
46 void fle_d(Register rd, FPURegister rs1, FPURegister rs2);
47 void fclass_d(Register rd, FPURegister rs1);
48 void fcvt_w_d(Register rd, FPURegister rs1, FPURoundingMode frm = RNE);
50 void fcvt_d_w(FPURegister rd, Register rs1, FPURoundingMode frm = RNE);
52
53#ifdef V8_TARGET_ARCH_RISCV64
54 // RV64D Standard Extension (in addition to RV32D)
55 void fcvt_l_d(Register rd, FPURegister rs1, FPURoundingMode frm = RNE);
56 void fcvt_lu_d(Register rd, FPURegister rs1, FPURoundingMode frm = RNE);
57 void fmv_x_d(Register rd, FPURegister rs1);
58 void fcvt_d_l(FPURegister rd, Register rs1, FPURoundingMode frm = RNE);
59 void fcvt_d_lu(FPURegister rd, Register rs1, FPURoundingMode frm = RNE);
60 void fmv_d_x(FPURegister rd, Register rs1);
61#endif
62
63 void fmv_d(FPURegister rd, FPURegister rs) { fsgnj_d(rd, rs, rs); }
64 void fabs_d(FPURegister rd, FPURegister rs) { fsgnjx_d(rd, rs, rs); }
65 void fneg_d(FPURegister rd, FPURegister rs) { fsgnjn_d(rd, rs, rs); }
66};
67} // namespace internal
68} // namespace v8
69#endif // V8_CODEGEN_RISCV_EXTENSION_RISCV_D_H_
void fsgnjx_d(FPURegister rd, FPURegister rs1, FPURegister rs2)
void fcvt_wu_d(Register rd, FPURegister rs1, FPURoundingMode frm=RNE)
void fsub_d(FPURegister rd, FPURegister rs1, FPURegister rs2, FPURoundingMode frm=RNE)
void fcvt_s_d(FPURegister rd, FPURegister rs1, FPURoundingMode frm=RNE)
void fsgnjn_d(FPURegister rd, FPURegister rs1, FPURegister rs2)
void fadd_d(FPURegister rd, FPURegister rs1, FPURegister rs2, FPURoundingMode frm=RNE)
void flt_d(Register rd, FPURegister rs1, FPURegister rs2)
void fcvt_d_s(FPURegister rd, FPURegister rs1, FPURoundingMode frm=RNE)
void fabs_d(FPURegister rd, FPURegister rs)
void feq_d(Register rd, FPURegister rs1, FPURegister rs2)
void fcvt_w_d(Register rd, FPURegister rs1, FPURoundingMode frm=RNE)
void fle_d(Register rd, FPURegister rs1, FPURegister rs2)
void fnmsub_d(FPURegister rd, FPURegister rs1, FPURegister rs2, FPURegister rs3, FPURoundingMode frm=RNE)
void fneg_d(FPURegister rd, FPURegister rs)
void fsgnj_d(FPURegister rd, FPURegister rs1, FPURegister rs2)
void fcvt_d_w(FPURegister rd, Register rs1, FPURoundingMode frm=RNE)
void fsqrt_d(FPURegister rd, FPURegister rs1, FPURoundingMode frm=RNE)
void fld(FPURegister rd, Register rs1, int16_t imm12)
void fsd(FPURegister source, Register base, int16_t imm12)
void fdiv_d(FPURegister rd, FPURegister rs1, FPURegister rs2, FPURoundingMode frm=RNE)
void fnmadd_d(FPURegister rd, FPURegister rs1, FPURegister rs2, FPURegister rs3, FPURoundingMode frm=RNE)
void fmax_d(FPURegister rd, FPURegister rs1, FPURegister rs2)
void fmul_d(FPURegister rd, FPURegister rs1, FPURegister rs2, FPURoundingMode frm=RNE)
void fmsub_d(FPURegister rd, FPURegister rs1, FPURegister rs2, FPURegister rs3, FPURoundingMode frm=RNE)
void fmadd_d(FPURegister rd, FPURegister rs1, FPURegister rs2, FPURegister rs3, FPURoundingMode frm=RNE)
void fcvt_d_wu(FPURegister rd, Register rs1, FPURoundingMode frm=RNE)
void fmin_d(FPURegister rd, FPURegister rs1, FPURegister rs2)
void fclass_d(Register rd, FPURegister rs1)
void fmv_d(FPURegister rd, FPURegister rs)