mirror of
				https://github.com/openhwgroup/cvw
				synced 2025-02-11 06:05:49 +00:00 
			
		
		
		
	Merge branch 'main' of github.com:davidharrishmc/riscv-wally into main
This commit is contained in:
		
						commit
						424012ce97
					
				| @ -9,7 +9,6 @@ add wave -noupdate /testbenchfp/Res | |||||||
| add wave -noupdate /testbenchfp/Ans | add wave -noupdate /testbenchfp/Ans | ||||||
| add wave -noupdate /testbenchfp/DivStart | add wave -noupdate /testbenchfp/DivStart | ||||||
| add wave -noupdate /testbenchfp/FDivBusyE | add wave -noupdate /testbenchfp/FDivBusyE | ||||||
| add wave -noupdate /testbenchfp/fdivsqrt/fdivsqrt/fdivsqrtfsm/state |  | ||||||
| add wave -group {PostProc} -noupdate /testbenchfp/postprocess/* | add wave -group {PostProc} -noupdate /testbenchfp/postprocess/* | ||||||
| add wave -group {PostProc} -noupdate /testbenchfp/postprocess/specialcase/* | add wave -group {PostProc} -noupdate /testbenchfp/postprocess/specialcase/* | ||||||
| add wave -group {PostProc} -noupdate /testbenchfp/postprocess/flags/* | add wave -group {PostProc} -noupdate /testbenchfp/postprocess/flags/* | ||||||
| @ -20,22 +19,5 @@ add wave -group {PostProc} -noupdate /testbenchfp/postprocess/round/* | |||||||
| add wave -group {PostProc} -noupdate /testbenchfp/postprocess/fmashiftcalc/* | add wave -group {PostProc} -noupdate /testbenchfp/postprocess/fmashiftcalc/* | ||||||
| add wave -group {PostProc} -noupdate /testbenchfp/postprocess/divshiftcalc/* | add wave -group {PostProc} -noupdate /testbenchfp/postprocess/divshiftcalc/* | ||||||
| add wave -group {PostProc} -noupdate /testbenchfp/postprocess/cvtshiftcalc/* | add wave -group {PostProc} -noupdate /testbenchfp/postprocess/cvtshiftcalc/* | ||||||
| add wave -group {Divide} -noupdate /testbenchfp/fdivsqrt/fdivsqrt/fdivsqrtiter/WC |  | ||||||
| add wave -group {Divide} -noupdate /testbenchfp/fdivsqrt/fdivsqrt/fdivsqrtiter/WS |  | ||||||
| #add wave -group {Divide} -noupdate /testbenchfp/fdivsqrt/fdivsqrt/fdivsqrtiter/WCA |  | ||||||
| #add wave -group {Divide} -noupdate /testbenchfp/fdivsqrt/fdivsqrt/fdivsqrtiter/WSA |  | ||||||
| add wave -group {Divide} -noupdate /testbenchfp/fdivsqrt/fdivsqrt/fdivsqrtiter/U |  | ||||||
| add wave -group {Divide} -noupdate /testbenchfp/fdivsqrt/fdivsqrt/fdivsqrtiter/UM |  | ||||||
| add wave -group {Divide} -noupdate /testbenchfp/fdivsqrt/fdivsqrt/fdivsqrtiter/UNext |  | ||||||
| add wave -group {Divide} -noupdate /testbenchfp/fdivsqrt/fdivsqrt/fdivsqrtiter/UMNext |  | ||||||
| add wave -group {Divide} -noupdate /testbenchfp/fdivsqrt/fdivsqrt/fdivsqrtiter/* |  | ||||||
| # add wave -group {Divide} -group inter0 -noupdate /testbenchfp/fdivsqrt/fdivsqrt/fdivsqrtiter/interations[0]/stage/fdivsqrtstage/* |  | ||||||
| # add wave -group {Divide} -group inter0 -noupdate /testbenchfp/fdivsqrt/fdivsqrt/fdivsqrtiter/interations[0]/stage/fdivsqrtstage/otfc/otfc2/* |  | ||||||
| # add wave -group {Divide} -group inter0 -noupdate /testbenchfp/fdivsqrt/fdivsqrt/fdivsqrtiter/interations[0]/stage/fdivsqrtstage/qsel/qsel2/* |  | ||||||
| # add wave -group {Divide} -group inter0 -noupdate /testbenchfp/fdivsqrt/fdivsqrt/fdivsqrtiter/interations[0]/fdivsqrtstage/stage/genblk1/qsel4/* |  | ||||||
| add wave -group {Divide} -noupdate /testbenchfp/fdivsqrt/fdivsqrt/fdivsqrtpreproc/* |  | ||||||
| add wave -group {Divide} -noupdate /testbenchfp/fdivsqrt/fdivsqrt/fdivsqrtpreproc/expcalc/* |  | ||||||
| add wave -group {Divide} -noupdate /testbenchfp/fdivsqrt/fdivsqrt/fdivsqrtfsm/* |  | ||||||
| add wave -group {Sqrt} -noupdate -recursive /testbenchfp/fdivsqrt/fdivsqrt/* |  | ||||||
| add wave -group {Testbench} -noupdate /testbenchfp/* | add wave -group {Testbench} -noupdate /testbenchfp/* | ||||||
| add wave -group {Testbench} -noupdate /testbenchfp/readvectors/* | add wave -group {Testbench} -noupdate /testbenchfp/readvectors/* | ||||||
|  | |||||||
| @ -46,7 +46,9 @@ module fmaadd( | |||||||
|     output logic [3*`NF+5:0]    Sm           // the positive sum
 |     output logic [3*`NF+5:0]    Sm           // the positive sum
 | ||||||
| ); | ); | ||||||
|     logic [3*`NF+5:0]    PreSum, NegPreSum; // possibly negitive sum
 |     logic [3*`NF+5:0]    PreSum, NegPreSum; // possibly negitive sum
 | ||||||
|  |     logic [3*`NF+5:0]    PreSumdebug, NegPreSumdebug; // possibly negitive sum
 | ||||||
|     logic                NegSum;        // was the sum negitive
 |     logic                NegSum;        // was the sum negitive
 | ||||||
|  |     logic                NegSumdebug;        // was the sum negitive
 | ||||||
| 
 | 
 | ||||||
|     ///////////////////////////////////////////////////////////////////////////////
 |     ///////////////////////////////////////////////////////////////////////////////
 | ||||||
|     // Addition
 |     // Addition
 | ||||||
| @ -58,12 +60,13 @@ module fmaadd( | |||||||
|     assign PmKilled = KillProd ? '0 : Pm; |     assign PmKilled = KillProd ? '0 : Pm; | ||||||
|     // Do the addition
 |     // Do the addition
 | ||||||
|     //      - calculate a positive and negitive sum in parallel
 |     //      - calculate a positive and negitive sum in parallel
 | ||||||
|     //              Zsticky             Psticky
 |     // if there was a small negitive number killed in the alignment stage one needs to be subtracted from the sum
 | ||||||
|     // PreSum    -1 = don't add 1     +1 = add 2
 |     //      prod - addend where some of the addend is put into the sticky bit then don't add +1 from negation 
 | ||||||
|     // NegPreSum +1 = add 2           -1 = don't add 1
 |     //          ie ~(InvA&ZmSticky&~KillProd)&InvA = (~ZmSticky|KillProd)&InvA
 | ||||||
|     // for NegPreSum the product is set to -1 whenever the product is killed, therefore add 1, 2 or 0
 |     //      addend - prod where product is killed (and not exactly zero) then don't add +1 from negation 
 | ||||||
|     assign {NegSum, PreSum} = {{`NF+3{1'b0}}, PmKilled, 1'b0, InvA&ZmSticky&KillProd} + {InvA, AmInv} + {{3*`NF+6{1'b0}}, InvA&~((ZmSticky&~KillProd))}; |     //          ie ~(InvA&ZmSticky&KillProd)&InvA = (~ZmSticky|~KillProd)&InvA
 | ||||||
|     assign NegPreSum = Am + {{`NF+2{1'b1}}, ~PmKilled, 2'b11} + {(3*`NF+4)'(0), ZmSticky&~KillProd, ~(ZmSticky)}; |     assign {NegSum, PreSum} = {{`NF+3{1'b0}}, PmKilled, 2'b0} + {InvA, AmInv} + {{3*`NF+6{1'b0}}, (~ZmSticky|KillProd)&InvA}; | ||||||
|  |     assign NegPreSum = Am + {{`NF+2{1'b1}}, ~PmKilled, 2'b0} + {(3*`NF+3)'(0), (~ZmSticky|~KillProd)&InvA, 2'b0}; | ||||||
|       |       | ||||||
|     // Choose the positive sum and accompanying LZA result.
 |     // Choose the positive sum and accompanying LZA result.
 | ||||||
|     assign Sm = NegSum ? NegPreSum : PreSum; |     assign Sm = NegSum ? NegPreSum : PreSum; | ||||||
|  | |||||||
| @ -55,11 +55,10 @@ module fmaalign( | |||||||
|     // This could have been done using Pe, but ACnt is on the critical path so we replicate logic for speed
 |     // This could have been done using Pe, but ACnt is on the critical path so we replicate logic for speed
 | ||||||
|     assign ACnt = {2'b0, Xe} + {2'b0, Ye} - {2'b0, (`NE)'(`BIAS)} + (`NE+2)'(`NF+3) - {2'b0, Ze}; |     assign ACnt = {2'b0, Xe} + {2'b0, Ye} - {2'b0, (`NE)'(`BIAS)} + (`NE+2)'(`NF+3) - {2'b0, Ze}; | ||||||
| 
 | 
 | ||||||
|     // Defualt Addition without shifting
 |     // Defualt Addition with only inital left shift
 | ||||||
|     //          |   54'b0    |  106'b(product)  | 2'b0 |
 |     //          |   54'b0    |  106'b(product)  | 2'b0 |
 | ||||||
|     //          | addnend |
 |     //          | addnend |
 | ||||||
| 
 | 
 | ||||||
|     // the 1'b0 before the added is because the product's mantissa has two bits before the binary point (xx.xxxxxxxxxx...)
 |  | ||||||
|     assign ZmPreshifted = {Zm,(3*`NF+5)'(0)}; |     assign ZmPreshifted = {Zm,(3*`NF+5)'(0)}; | ||||||
|      |      | ||||||
|     assign KillProd = (ACnt[`NE+1]&~ZZero)|XZero|YZero; |     assign KillProd = (ACnt[`NE+1]&~ZZero)|XZero|YZero; | ||||||
| @ -77,7 +76,7 @@ module fmaalign( | |||||||
|             ZmSticky = ~(XZero|YZero); |             ZmSticky = ~(XZero|YZero); | ||||||
| 
 | 
 | ||||||
|         // If the addend is too small to effect the addition        
 |         // If the addend is too small to effect the addition        
 | ||||||
|         //      - The addend has to shift two past the end of the addend to be considered too small
 |         //      - The addend has to shift two past the end of the product to be considered too small
 | ||||||
|         //      - The 2 extra bits are needed for rounding
 |         //      - The 2 extra bits are needed for rounding
 | ||||||
| 
 | 
 | ||||||
|         //          |   54'b0    |  106'b(product)  | 2'b0 |
 |         //          |   54'b0    |  106'b(product)  | 2'b0 |
 | ||||||
|  | |||||||
| @ -689,8 +689,8 @@ module testbenchfp; | |||||||
|             .Xe(Xe), .Ye(Ye), .Ze(Ze),  |             .Xe(Xe), .Ye(Ye), .Ze(Ze),  | ||||||
|             .Xm(Xm), .Ym(Ym), .Zm(Zm), |             .Xm(Xm), .Ym(Ym), .Zm(Zm), | ||||||
|             .XZero, .YZero, .ZZero, .Ss, .Se, |             .XZero, .YZero, .ZZero, .Ss, .Se, | ||||||
|             .OpCtrl(OpCtrlVal), .Fmt(ModFmt), .Sm, .NegSum, .InvA, .SCnt, .As, .Ps, |             .OpCtrl(OpCtrlVal), .Fmt(ModFmt), .Sm, .InvA, .SCnt, .As, .Ps, | ||||||
|             .Pe, .ZmSticky, .KillProd);  |             .ZmSticky);  | ||||||
|   end |   end | ||||||
|                |                | ||||||
|   postprocess postprocess(.Xs(Xs), .Ys(Ys), .PostProcSel(UnitVal[1:0]), |   postprocess postprocess(.Xs(Xs), .Ys(Ys), .PostProcSel(UnitVal[1:0]), | ||||||
| @ -700,8 +700,8 @@ module testbenchfp; | |||||||
|               .XZero(XZero), .YZero(YZero), .ZZero(ZZero), .CvtShiftAmt(CvtShiftAmtE), |               .XZero(XZero), .YZero(YZero), .ZZero(ZZero), .CvtShiftAmt(CvtShiftAmtE), | ||||||
|               .XInf(XInf), .YInf(YInf), .ZInf(ZInf), .CvtCs(CvtResSgnE), .ToInt(WriteIntVal), |               .XInf(XInf), .YInf(YInf), .ZInf(ZInf), .CvtCs(CvtResSgnE), .ToInt(WriteIntVal), | ||||||
|               .XSNaN(XSNaN), .YSNaN(YSNaN), .ZSNaN(ZSNaN), .CvtLzcIn(CvtLzcInE), .IntZero, |               .XSNaN(XSNaN), .YSNaN(YSNaN), .ZSNaN(ZSNaN), .CvtLzcIn(CvtLzcInE), .IntZero, | ||||||
|               .FmaKillProd(KillProd), .FmaZmS(ZmSticky), .FmaPe(Pe), .DivDone, .FmaSe(Se), |               .FmaZmS(ZmSticky), .FmaSe(Se), | ||||||
|               .FmaSm(Sm), .FmaNegSum(NegSum), .FmaInvA(InvA), .FmaSCnt(SCnt), .FmaAs(As), .FmaPs(Ps), .Fmt(ModFmt), .Frm(FrmVal),  |               .FmaSm(Sm), .FmaSCnt(SCnt), .FmaAs(As), .FmaPs(Ps), .Fmt(ModFmt), .Frm(FrmVal),  | ||||||
|               .PostProcFlg(Flg), .PostProcRes(FpRes), .FCvtIntRes(IntRes)); |               .PostProcFlg(Flg), .PostProcRes(FpRes), .FCvtIntRes(IntRes)); | ||||||
|    |    | ||||||
|   if (TEST === "cvtfp" | TEST === "cvtint" | TEST === "all") begin : fcvt |   if (TEST === "cvtfp" | TEST === "cvtint" | TEST === "all") begin : fcvt | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user