mirror of
https://github.com/openhwgroup/cvw
synced 2025-02-11 06:05:49 +00:00
Checked in fma16_template.v
This commit is contained in:
parent
d24178aa34
commit
d2282d5e87
@ -128,7 +128,7 @@ void printF64(char *msg, float64_t f) {
|
|||||||
printf("_");
|
printf("_");
|
||||||
printf("%04x", (conv.v >> 32) & 0xFFFF);
|
printf("%04x", (conv.v >> 32) & 0xFFFF);
|
||||||
printf("_");
|
printf("_");
|
||||||
printf("%04x", (conv.v >> 16));
|
printf("%04x", (conv.v >> 16) & 0xFFFF);
|
||||||
printf("_");
|
printf("_");
|
||||||
printf("%04x", (conv.v & 0xFFFF));
|
printf("%04x", (conv.v & 0xFFFF));
|
||||||
printf(" = %lg = %s: Biased Exp %d Fract 0x%lx\n", conv.d, sci, exp, fract);
|
printf(" = %lg = %s: Biased Exp %d Fract 0x%lx\n", conv.d, sci, exp, fract);
|
||||||
|
24
pipelined/src/fma/fma16_template.v
Normal file
24
pipelined/src/fma/fma16_template.v
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
// fma16.sv
|
||||||
|
// David_Harris@hmc.edu 26 February 2022
|
||||||
|
// 16-bit floating-point multiply-accumulate
|
||||||
|
|
||||||
|
// Operation: general purpose multiply, add, fma, with optional negation
|
||||||
|
// If mul=1, p = x * y. Else p = x.
|
||||||
|
// If add=1, result = p + z. Else result = p.
|
||||||
|
// If negr or negz = 1, negate result or z to handle negations and subtractions
|
||||||
|
// fadd: mul = 0, add = 1, negr = negz = 0
|
||||||
|
// fsub: mul = 0, add = 1, negr = 0, negz = 1
|
||||||
|
// fmul: mul = 1, add = 0, negr = 0, negz = 0
|
||||||
|
// fmadd: mul = 1, add = 1, negr = 0, negz = 0
|
||||||
|
// fmsub: mul = 1, add = 1, negr = 0, negz = 1
|
||||||
|
// fnmadd: mul = 1, add = 1, negr = 1, negz = 0
|
||||||
|
// fnmsub: mul = 1, add = 1, negr = 1, negz = 1
|
||||||
|
|
||||||
|
module fma16(
|
||||||
|
input logic [15:0] x, y, z,
|
||||||
|
input logic mul, add, negr, negz,
|
||||||
|
input logic [1:0] roundmode, // 00: rz, 01: rne, 10: rp, 11: rn
|
||||||
|
output logic [15:0] result);
|
||||||
|
|
||||||
|
endmodule
|
||||||
|
|
Loading…
Reference in New Issue
Block a user