From e34456c9fc4b173b0bf0f87a0e7f0c44c3e2a2c1 Mon Sep 17 00:00:00 2001 From: Luca Bertaccini Date: Tue, 25 Jun 2024 18:29:03 +0200 Subject: [PATCH] Add FP8ALT (4,3) support --- docs/README.md | 3 ++- src/fpnew_opgroup_multifmt_slice.sv | 4 ++-- src/fpnew_pkg.sv | 25 ++++++++++++++----------- 3 files changed, 18 insertions(+), 14 deletions(-) diff --git a/docs/README.md b/docs/README.md index 529193eb..177273be 100644 --- a/docs/README.md +++ b/docs/README.md @@ -134,10 +134,11 @@ Enumeration of type `logic [2:0]` holding the supported FP formats. | `FP16` | IEEE binary16 | 16 bit | 5 | 10 | | `FP8` | binary8 | 8 bit | 5 | 2 | | `FP16ALT` | binary16alt | 16 bit | 8 | 7 | +| `FP8ALT` | binary8alt | 8 bit | 4 | 3 | The following global parameters associated with FP formats are set in `fpnew_pkg`: ```SystemVerilog -localparam int unsigned NUM_FP_FORMATS = 5; +localparam int unsigned NUM_FP_FORMATS = 6; localparam int unsigned FP_FORMAT_BITS = $clog2(NUM_FP_FORMATS); ``` diff --git a/src/fpnew_opgroup_multifmt_slice.sv b/src/fpnew_opgroup_multifmt_slice.sv index 61145562..ff73043a 100644 --- a/src/fpnew_opgroup_multifmt_slice.sv +++ b/src/fpnew_opgroup_multifmt_slice.sv @@ -70,9 +70,9 @@ module fpnew_opgroup_multifmt_slice #( if ((DivSqrtSel == fpnew_pkg::TH32) && !((FpFmtConfig[0] == 1) && (FpFmtConfig[1:NUM_FORMATS-1] == '0))) begin $fatal(1, "T-Head-based DivSqrt unit supported only in FP32-only configurations. \ Set DivSqrtSel = THMULTI or DivSqrtSel = PULP to use a multi-format divider"); - end else if ((DivSqrtSel == fpnew_pkg::THMULTI) && (FpFmtConfig[3] == 1'b1)) begin + end else if ((DivSqrtSel == fpnew_pkg::THMULTI) && (FpFmtConfig[3] == 1'b1 || FpFmtConfig[5] == 1'b1)) begin $warning("The DivSqrt unit of C910 (instantiated by DivSqrtSel = THMULTI) does not support \ -FP8. Please use the PULP DivSqrt unit when in need of div/sqrt operations on FP8."); +FP8, FP8alt. Please use the PULP DivSqrt unit when in need of div/sqrt operations on FP8, FP8alt."); end end diff --git a/src/fpnew_pkg.sv b/src/fpnew_pkg.sv index 0167305f..3b75a252 100644 --- a/src/fpnew_pkg.sv +++ b/src/fpnew_pkg.sv @@ -25,6 +25,7 @@ package fpnew_pkg; // | FP16 | IEEE binary16 | 16 bit | 5 | 10 // | FP8 | binary8 | 8 bit | 5 | 2 // | FP16ALT | binary16alt | 16 bit | 8 | 7 + // | FP8ALT | binary8alt | 8 bit | 4 | 3 // *NOTE:* Add new formats only at the end of the enumeration for backwards compatibilty! // Encoding for a format @@ -33,7 +34,7 @@ package fpnew_pkg; int unsigned man_bits; } fp_encoding_t; - localparam int unsigned NUM_FP_FORMATS = 5; // change me to add formats + localparam int unsigned NUM_FP_FORMATS = 6; // change me to add formats localparam int unsigned FP_FORMAT_BITS = $clog2(NUM_FP_FORMATS); // FP formats @@ -42,7 +43,8 @@ package fpnew_pkg; FP64 = 'd1, FP16 = 'd2, FP8 = 'd3, - FP16ALT = 'd4 + FP16ALT = 'd4, + FP8ALT = 'd5 // add new formats here } fp_format_e; @@ -52,14 +54,15 @@ package fpnew_pkg; '{11, 52}, // IEEE binary64 (double) '{5, 10}, // IEEE binary16 (half) '{5, 2}, // custom binary8 - '{8, 7} // custom binary16alt + '{8, 7}, // custom binary16alt + '{4, 3} // custom binary8alt // add new formats here }; typedef logic [0:NUM_FP_FORMATS-1] fmt_logic_t; // Logic indexed by FP format (for masks) typedef logic [0:NUM_FP_FORMATS-1][31:0] fmt_unsigned_t; // Unsigned indexed by FP format - localparam fmt_logic_t CPK_FORMATS = 5'b11000; // FP32 and FP64 can provide CPK only + localparam fmt_logic_t CPK_FORMATS = 6'b110000; // FP32 and FP64 can provide CPK only // --------- // INT TYPES @@ -221,7 +224,7 @@ package fpnew_pkg; Width: 64, EnableVectors: 1'b0, EnableNanBox: 1'b1, - FpFmtMask: 5'b11000, + FpFmtMask: 6'b110000, IntFmtMask: 4'b0011 }; @@ -229,7 +232,7 @@ package fpnew_pkg; Width: 64, EnableVectors: 1'b1, EnableNanBox: 1'b1, - FpFmtMask: 5'b11000, + FpFmtMask: 6'b110000, IntFmtMask: 4'b0010 }; @@ -237,7 +240,7 @@ package fpnew_pkg; Width: 32, EnableVectors: 1'b0, EnableNanBox: 1'b1, - FpFmtMask: 5'b10000, + FpFmtMask: 6'b100000, IntFmtMask: 4'b0010 }; @@ -245,7 +248,7 @@ package fpnew_pkg; Width: 64, EnableVectors: 1'b1, EnableNanBox: 1'b1, - FpFmtMask: 5'b11111, + FpFmtMask: 6'b111111, IntFmtMask: 4'b1111 }; @@ -253,7 +256,7 @@ package fpnew_pkg; Width: 32, EnableVectors: 1'b1, EnableNanBox: 1'b1, - FpFmtMask: 5'b10111, + FpFmtMask: 6'b101111, IntFmtMask: 4'b1110 }; @@ -261,7 +264,7 @@ package fpnew_pkg; Width: 32, EnableVectors: 1'b1, EnableNanBox: 1'b1, - FpFmtMask: 5'b10001, + FpFmtMask: 6'b100010, IntFmtMask: 4'b0110 }; @@ -409,7 +412,7 @@ package fpnew_pkg; // Returns the maximum number of lanes in the FPU according to width, format config and vectors function automatic int unsigned num_divsqrt_lanes(int unsigned width, fmt_logic_t cfg, logic vec, divsqrt_unit_t DivSqrtSel); automatic fmt_logic_t cfg_tmp; - cfg_tmp = (DivSqrtSel == THMULTI) ? cfg & 5'b11101 : cfg; + cfg_tmp = (DivSqrtSel == THMULTI) ? cfg & 6'b111010 : cfg; return vec ? width / min_fp_width(cfg_tmp) : 1; // if no vectors, only one lane endfunction