v8
V8 is Google’s open source high-performance JavaScript and WebAssembly engine, written in C++.
Loading...
Searching...
No Matches
extension-riscv-f.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_F_H_
6#define V8_CODEGEN_RISCV_EXTENSION_RISCV_F_H_
7
12
13namespace v8 {
14namespace internal {
16 // RV32F Standard Extension
17 public:
18 void flw(FPURegister rd, Register rs1, int16_t imm12);
19 void fsw(FPURegister source, Register base, int16_t imm12);
28 void fadd_s(FPURegister rd, FPURegister rs1, FPURegister rs2,
29 FPURoundingMode frm = RNE);
30 void fsub_s(FPURegister rd, FPURegister rs1, FPURegister rs2,
31 FPURoundingMode frm = RNE);
32 void fmul_s(FPURegister rd, FPURegister rs1, FPURegister rs2,
33 FPURoundingMode frm = RNE);
34 void fdiv_s(FPURegister rd, FPURegister rs1, FPURegister rs2,
35 FPURoundingMode frm = RNE);
37 void fsgnj_s(FPURegister rd, FPURegister rs1, FPURegister rs2);
40 void fmin_s(FPURegister rd, FPURegister rs1, FPURegister rs2);
41 void fmax_s(FPURegister rd, FPURegister rs1, FPURegister rs2);
42 void fcvt_w_s(Register rd, FPURegister rs1, FPURoundingMode frm = RNE);
44 void fmv_x_w(Register rd, FPURegister rs1);
45 void feq_s(Register rd, FPURegister rs1, FPURegister rs2);
46 void flt_s(Register rd, FPURegister rs1, FPURegister rs2);
47 void fle_s(Register rd, FPURegister rs1, FPURegister rs2);
48 void fclass_s(Register rd, FPURegister rs1);
49 void fcvt_s_w(FPURegister rd, Register rs1, FPURoundingMode frm = RNE);
51 void fmv_w_x(FPURegister rd, Register rs1);
52
53#ifdef V8_TARGET_ARCH_RISCV64
54 // RV64F Standard Extension (in addition to RV32F)
55 void fcvt_l_s(Register rd, FPURegister rs1, FPURoundingMode frm = RNE);
56 void fcvt_lu_s(Register rd, FPURegister rs1, FPURoundingMode frm = RNE);
57 void fcvt_s_l(FPURegister rd, Register rs1, FPURoundingMode frm = RNE);
58 void fcvt_s_lu(FPURegister rd, Register rs1, FPURoundingMode frm = RNE);
59#endif
60
61 void fmv_s(FPURegister rd, FPURegister rs) { fsgnj_s(rd, rs, rs); }
62 void fabs_s(FPURegister rd, FPURegister rs) { fsgnjx_s(rd, rs, rs); }
63 void fneg_s(FPURegister rd, FPURegister rs) { fsgnjn_s(rd, rs, rs); }
64};
65} // namespace internal
66} // namespace v8
67#endif // V8_CODEGEN_RISCV_EXTENSION_RISCV_F_H_
void fsgnjn_s(FPURegister rd, FPURegister rs1, FPURegister rs2)
void fmax_s(FPURegister rd, FPURegister rs1, FPURegister rs2)
void fmadd_s(FPURegister rd, FPURegister rs1, FPURegister rs2, FPURegister rs3, FPURoundingMode frm=RNE)
void fmv_w_x(FPURegister rd, Register rs1)
void feq_s(Register rd, FPURegister rs1, FPURegister rs2)
void fsgnjx_s(FPURegister rd, FPURegister rs1, FPURegister rs2)
void fsw(FPURegister source, Register base, int16_t imm12)
void fdiv_s(FPURegister rd, FPURegister rs1, FPURegister rs2, FPURoundingMode frm=RNE)
void fadd_s(FPURegister rd, FPURegister rs1, FPURegister rs2, FPURoundingMode frm=RNE)
void fcvt_s_w(FPURegister rd, Register rs1, FPURoundingMode frm=RNE)
void fsub_s(FPURegister rd, FPURegister rs1, FPURegister rs2, FPURoundingMode frm=RNE)
void fcvt_wu_s(Register rd, FPURegister rs1, FPURoundingMode frm=RNE)
void flt_s(Register rd, FPURegister rs1, FPURegister rs2)
void fclass_s(Register rd, FPURegister rs1)
void fsgnj_s(FPURegister rd, FPURegister rs1, FPURegister rs2)
void fmv_x_w(Register rd, FPURegister rs1)
void fle_s(Register rd, FPURegister rs1, FPURegister rs2)
void fcvt_w_s(Register rd, FPURegister rs1, FPURoundingMode frm=RNE)
void fabs_s(FPURegister rd, FPURegister rs)
void fnmadd_s(FPURegister rd, FPURegister rs1, FPURegister rs2, FPURegister rs3, FPURoundingMode frm=RNE)
void fneg_s(FPURegister rd, FPURegister rs)
void fmin_s(FPURegister rd, FPURegister rs1, FPURegister rs2)
void fmul_s(FPURegister rd, FPURegister rs1, FPURegister rs2, FPURoundingMode frm=RNE)
void fsqrt_s(FPURegister rd, FPURegister rs1, FPURoundingMode frm=RNE)
void fmsub_s(FPURegister rd, FPURegister rs1, FPURegister rs2, FPURegister rs3, FPURoundingMode frm=RNE)
void fcvt_s_wu(FPURegister rd, Register rs1, FPURoundingMode frm=RNE)
void fmv_s(FPURegister rd, FPURegister rs)
void flw(FPURegister rd, Register rs1, int16_t imm12)
void fnmsub_s(FPURegister rd, FPURegister rs1, FPURegister rs2, FPURegister rs3, FPURoundingMode frm=RNE)