OpenCores
URL https://opencores.org/ocsvn/ft816float/ft816float/trunk

Subversion Repositories ft816float

[/] [ft816float/] [trunk/] [rtl/] [verilog2/] [DFPNormalize.sv] - Diff between revs 50 and 51

Go to most recent revision | Show entire file | Details | Blame | View Log

Rev 50 Rev 51
Line 41... Line 41...
import fp::*;
import fp::*;
 
 
module DFPNormalize(clk, ce, i, o, under_i, under_o, inexact_o);
module DFPNormalize(clk, ce, i, o, under_i, under_o, inexact_o);
input clk;
input clk;
input ce;
input ce;
input [219:0] i;                // expanded format input
input [243:0] i;                // expanded format input
output [119:0] o;               // normalized output + guard, sticky and round bits, + 1 whole digit
output [131:0] o;               // normalized output + guard, sticky and round bits, + 1 whole digit
input under_i;
input under_i;
output under_o;
output under_o;
output inexact_o;
output inexact_o;
 
 
integer n;
integer n;
Line 58... Line 58...
reg sx0;
reg sx0;
reg nan0;
reg nan0;
reg inf0;
reg inf0;
 
 
always @*
always @*
        xo0 <= i[215:200];
        xo0 <= i[239:224];
always @*
always @*
        so0 <= i[218];          // sign doesn't change
        so0 <= i[242];          // sign doesn't change
always @*
always @*
        sx0 <= i[216];
        sx0 <= i[240];
always @*
always @*
        nan0 <= i[219];
        nan0 <= i[243];
always @*
always @*
        inf0 <= i[217] || xo0==16'h9999 && i[196];
        inf0 <= i[241] || xo0==16'h9999 && i[220];
 
 
// ----------------------------------------------------------------------------
// ----------------------------------------------------------------------------
// Clock #1
// Clock #1
// - Capture exponent information
// - Capture exponent information
// ----------------------------------------------------------------------------
// ----------------------------------------------------------------------------
reg xInf1a, xInf1b, xInf1c;
reg xInf1a, xInf1b, xInf1c;
wire [219:0] i1;
wire [243:0] i1;
delay #(.WID(220),.DEP(1)) u11 (.clk(clk), .ce(ce), .i(i), .o(i1));
delay #(.WID(244),.DEP(1)) u11 (.clk(clk), .ce(ce), .i(i), .o(i1));
 
 
always @(posedge clk)
always @(posedge clk)
        if (ce) xInf1a <= xo0==16'h9999 & !under_i;
        if (ce) xInf1a <= xo0==16'h9999 & !under_i;
always @(posedge clk)
always @(posedge clk)
        if (ce) xInf1b <= xo0==16'h9998 & !under_i;
        if (ce) xInf1b <= xo0==16'h9998 & !under_i;
Line 99... Line 99...
delay #(.WID(1),.DEP(1)) u22 (.clk(clk), .ce(ce), .i(xInf1b), .o(xInf2b));
delay #(.WID(1),.DEP(1)) u22 (.clk(clk), .ce(ce), .i(xInf1b), .o(xInf2b));
delay #(.WID(16),.DEP(2)) u23 (.clk(clk), .ce(ce), .i(xo0), .o(xo2));
delay #(.WID(16),.DEP(2)) u23 (.clk(clk), .ce(ce), .i(xo0), .o(xo2));
delay #(.WID(1),.DEP(2)) u24 (.clk(clk), .ce(ce), .i(under_i), .o(under2));
delay #(.WID(1),.DEP(2)) u24 (.clk(clk), .ce(ce), .i(under_i), .o(under2));
 
 
always @(posedge clk)
always @(posedge clk)
        if (ce) incExpByOne2 <= !xInf1a & i1[196];
        if (ce) incExpByOne2 <= !xInf1a & i1[220];
 
 
// ----------------------------------------------------------------------------
// ----------------------------------------------------------------------------
// Clock #3
// Clock #3
// - increment exponent
// - increment exponent
// - detect a zero mantissa
// - detect a zero mantissa
// ----------------------------------------------------------------------------
// ----------------------------------------------------------------------------
 
 
wire incExpByOne3;
wire incExpByOne3;
wire [219:0] i3;
wire [243:0] i3;
reg [15:0] xo3;
reg [15:0] xo3;
reg zeroMan3;
reg zeroMan3;
delay #(.WID(1),.DEP(1)) u32 (.clk(clk), .ce(ce), .i(incExpByOne2), .o(incExpByOne3));
delay #(.WID(1),.DEP(1)) u32 (.clk(clk), .ce(ce), .i(incExpByOne2), .o(incExpByOne3));
delay #(.WID(220),.DEP(3)) u33 (.clk(clk), .ce(ce), .i(i[219:0]), .o(i3));
delay #(.WID(244),.DEP(3)) u33 (.clk(clk), .ce(ce), .i(i[243:0]), .o(i3));
 
 
wire [15:0] xo2a;
wire [15:0] xo2a;
BCDAddN #(.N(4)) ubcdan1
BCDAddN #(.N(4)) ubcdan1
(
(
        .ci(1'b0),
        .ci(1'b0),
Line 138... Line 138...
// - If infinity is reached then set the mantissa to zero
// - If infinity is reached then set the mantissa to zero
//   shift mantissa left to reduce to a single whole digit
//   shift mantissa left to reduce to a single whole digit
// - create sticky bit
// - create sticky bit
// ----------------------------------------------------------------------------
// ----------------------------------------------------------------------------
 
 
reg [103:0] mo4;
reg [115:0] mo4;
reg inexact4;
reg inexact4;
 
 
always @(posedge clk)
always @(posedge clk)
if(ce)
if(ce)
casez({zeroMan3,incExpByOne3})
casez({zeroMan3,incExpByOne3})
2'b1?:  mo4 <= 1'd0;
2'b1?:  mo4 <= 1'd0;
2'b01:  mo4 <= {i3[199:100],3'b0,|i3[99:0]};
2'b01:  mo4 <= {i3[223:112],3'b0,|i3[111:0]};
default:        mo4 <= {i3[195:96],3'b0,|i3[95:0]};
default:        mo4 <= {i3[219:108],3'b0,|i3[107:0]};
endcase
endcase
 
 
always @(posedge clk)
always @(posedge clk)
if(ce)
if(ce)
casez({zeroMan3,incExpByOne3})
casez({zeroMan3,incExpByOne3})
2'b1?:  inexact4 <= 1'd0;
2'b1?:  inexact4 <= 1'd0;
2'b01:  inexact4 <= |i3[99:0];
2'b01:  inexact4 <= |i3[111:0];
default:        inexact4 <= |i3[95:0];
default:        inexact4 <= |i3[107:0];
endcase
endcase
 
 
// ----------------------------------------------------------------------------
// ----------------------------------------------------------------------------
// Clock edge #5
// Clock edge #5
// - count leading zeros
// - count leading zeros
Line 209... Line 209...
reg got_one;
reg got_one;
always @*
always @*
begin
begin
  got_one = 1'b0;
  got_one = 1'b0;
  lzc = 8'h00;
  lzc = 8'h00;
  for (n = 103; n >= 0; n = n - 4) begin
  for (n = 115; n >= 0; n = n - 4) begin
    if (!got_one) begin
    if (!got_one) begin
      if (mo4[n]|mo4[n-1]|mo4[n-2]|mo4[n-3])
      if (mo4[n]|mo4[n-1]|mo4[n-2]|mo4[n-3])
        got_one = 1'b1;
        got_one = 1'b1;
      else
      else
        lzc = lzc + 1'b1;
        lzc = lzc + 1'b1;
Line 223... Line 223...
always @(posedge clk)
always @(posedge clk)
  if (ce) leadingZeros5 <= lzc;
  if (ce) leadingZeros5 <= lzc;
`else
`else
always @(posedge clk)
always @(posedge clk)
if (ce)
if (ce)
casez(mo4[99:92])
casez(mo4[111:103])
8'h00000000:    leadingZeros5 <= 8'd2;
8'h00000000:    leadingZeros5 <= 8'd2;
8'h0000????:    leadingZeros5 <= 8'd1;
8'h0000????:    leadingZeros5 <= 8'd1;
default:                        leadingZeros5 <= 8'd0;
default:                        leadingZeros5 <= 8'd0;
endcase
endcase
`endif
`endif
Line 247... Line 247...
reg [7:0] lshiftAmt6;
reg [7:0] lshiftAmt6;
reg [7:0] rshiftAmt6;
reg [7:0] rshiftAmt6;
wire rightOrLeft6;      // 0=left,1=right
wire rightOrLeft6;      // 0=left,1=right
wire xInf6;
wire xInf6;
wire [15:0] xo6;
wire [15:0] xo6;
wire [103:0] mo6;
wire [115:0] mo6;
wire zeroMan6;
wire zeroMan6;
vtdl #(1) u61 (.clk(clk), .ce(ce), .a(4'd5), .d(under_i), .q(rightOrLeft6) );
vtdl #(1) u61 (.clk(clk), .ce(ce), .a(4'd5), .d(under_i), .q(rightOrLeft6) );
delay #(.WID(16),.DEP(1)) u62 (.clk(clk), .ce(ce), .i(xo5), .o(xo6));
delay #(.WID(16),.DEP(1)) u62 (.clk(clk), .ce(ce), .i(xo5), .o(xo6));
delay #(.WID(104),.DEP(2)) u63 (.clk(clk), .ce(ce), .i(mo4), .o(mo6) );
delay #(.WID(116),.DEP(2)) u63 (.clk(clk), .ce(ce), .i(mo4), .o(mo6) );
delay #(.WID(1),.DEP(1)) u64 (.clk(clk), .ce(ce), .i(xInf5), .o(xInf6) );
delay #(.WID(1),.DEP(1)) u64 (.clk(clk), .ce(ce), .i(xInf5), .o(xInf6) );
delay #(.WID(1),.DEP(3)) u65 (.clk(clk), .ce(ce),  .i(zeroMan3), .o(zeroMan6));
delay #(.WID(1),.DEP(3)) u65 (.clk(clk), .ce(ce),  .i(zeroMan3), .o(zeroMan6));
delay #(.WID(1),.DEP(5)) u66 (.clk(clk), .ce(ce), .i(sx0), .o(sx5) );
delay #(.WID(1),.DEP(5)) u66 (.clk(clk), .ce(ce), .i(sx0), .o(sx5) );
 
 
wire [13:0] xo5d = xo5[3:0] + xo5[7:4] * 10 + xo5[11:8] * 100 + xo5[15:12] * 1000;
wire [13:0] xo5d = xo5[3:0] + xo5[7:4] * 10 + xo5[11:8] * 100 + xo5[15:12] * 1000;
Line 273... Line 273...
// - figure sticky bit
// - figure sticky bit
// ----------------------------------------------------------------------------
// ----------------------------------------------------------------------------
 
 
reg [15:0] xo7;
reg [15:0] xo7;
wire rightOrLeft7;
wire rightOrLeft7;
reg [103:0] mo7l, mo7r;
reg [115:0] mo7l, mo7r;
reg St6,St7;
reg St6,St7;
delay #(.WID(1),.DEP(1)) u71 (.clk(clk), .ce(ce), .i(rightOrLeft6), .o(rightOrLeft7));
delay #(.WID(1),.DEP(1)) u71 (.clk(clk), .ce(ce), .i(rightOrLeft6), .o(rightOrLeft7));
 
 
wire [11:0] lshftAmtBCD;
wire [11:0] lshftAmtBCD;
wire [15:0] xo7d;
wire [15:0] xo7d;
Line 306... Line 306...
 
 
// The sticky bit is set if the bits shifted out on a right shift are set.
// The sticky bit is set if the bits shifted out on a right shift are set.
always @*
always @*
begin
begin
  St6 = 1'b0;
  St6 = 1'b0;
  for (n = 0; n < 104; n = n + 1)
  for (n = 0; n < 116; n = n + 1)
    if (n <= rshiftAmt6 + 1) St6 = St6|mo6[n];
    if (n <= rshiftAmt6 + 1) St6 = St6|mo6[n];
end
end
always @(posedge clk)
always @(posedge clk)
  if (ce) St7 <= St6;
  if (ce) St7 <= St6;
 
 
Line 319... Line 319...
// - select mantissa
// - select mantissa
// ----------------------------------------------------------------------------
// ----------------------------------------------------------------------------
 
 
wire so,sxo,nano,info;
wire so,sxo,nano,info;
wire [15:0] xo;
wire [15:0] xo;
reg [103:0] mo;
reg [115:0] mo;
vtdl #(1) u81 (.clk(clk), .ce(ce), .a(4'd7), .d(so0), .q(so) );
vtdl #(1) u81 (.clk(clk), .ce(ce), .a(4'd7), .d(so0), .q(so) );
delay #(.WID(16),.DEP(1)) u82 (.clk(clk), .ce(ce), .i(xo7), .o(xo));
delay #(.WID(16),.DEP(1)) u82 (.clk(clk), .ce(ce), .i(xo7), .o(xo));
vtdl #(.WID(1)) u83 (.clk(clk), .ce(ce), .a(4'd3), .d(inexact4), .q(inexact_o));
vtdl #(.WID(1)) u83 (.clk(clk), .ce(ce), .a(4'd3), .d(inexact4), .q(inexact_o));
delay #(.WID(1),.DEP(1)) u84 (.clk(clk), .ce(ce), .i(rightOrLeft7), .o(under_o));
delay #(.WID(1),.DEP(1)) u84 (.clk(clk), .ce(ce), .i(rightOrLeft7), .o(under_o));
vtdl #(1) u85 (.clk(clk), .ce(ce), .a(4'd7), .d(sx0), .q(sxo) );
vtdl #(1) u85 (.clk(clk), .ce(ce), .a(4'd7), .d(sx0), .q(sxo) );
Line 331... Line 331...
vtdl #(1) u87 (.clk(clk), .ce(ce), .a(4'd7), .d(inf0), .q(info) );
vtdl #(1) u87 (.clk(clk), .ce(ce), .a(4'd7), .d(inf0), .q(info) );
 
 
always @(posedge clk)
always @(posedge clk)
        if (ce) mo <= rightOrLeft7 ? mo7r|{St7,4'b0} : mo7l;
        if (ce) mo <= rightOrLeft7 ? mo7r|{St7,4'b0} : mo7l;
 
 
assign o = {nano,so,info,sxo,xo,mo[103:4]};
assign o = {nano,so,info,sxo,xo,mo[115:4]};
 
 
endmodule
endmodule
 
 

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.