mirror of
				https://github.com/openhwgroup/cvw
				synced 2025-02-11 06:05:49 +00:00 
			
		
		
		
	Removed ZForwardEnE and replaced with ZEnE.
Similar for YForwardEnE.
This commit is contained in:
		
							parent
							
								
									ca67e5588d
								
							
						
					
					
						commit
						f6f66cb79e
					
				| @ -49,7 +49,6 @@ module fctrl ( | ||||
|   output logic [`FMTBITS-1:0] FmtE, FmtM,             // FP format
 | ||||
|   output logic 		         FDivStartE, IDivStartE,             // Start division or squareroot
 | ||||
|   output logic              XEnE, YEnE, ZEnE, | ||||
|   output logic              YEnForwardE, ZEnForwardE, | ||||
|   output logic 		         FWriteIntE, FCvtIntE, FWriteIntM,                         // Write to integer register
 | ||||
|   output logic [2:0] 	      OpCtrlE, OpCtrlM,       // Select which opperation to do in each component
 | ||||
|   output logic [1:0] 	      FResSelE, FResSelM, FResSelW,       // Select one of the results that finish in the memory stage
 | ||||
| @ -206,9 +205,9 @@ module fctrl ( | ||||
|     assign XEnE = ~(((FResSelE==2'b10)&~FWriteIntE)|((FResSelE==2'b11)&FRegWriteE)|((FResSelE==2'b01)&(PostProcSelE==2'b00)&OpCtrlE[2])); | ||||
| //                  load/class                                    mv               cvt
 | ||||
|     assign YEnE = ~(((FResSelE==2'b10)&(FWriteIntE|FRegWriteE))|(FResSelE==2'b11)|((FResSelE==2'b01)&((PostProcSelE==2'b00)|((PostProcSelE==2'b01)&OpCtrlE[0]))));     | ||||
|     assign ZEnE = (PostProcSelE==2'b10)&(FResSelE==2'b01)&(~OpCtrlE[2]|OpCtrlE[1]); | ||||
|     assign YEnForwardE = ~(((FResSelE==2'b10)&(FWriteIntE|FRegWriteE))|(FResSelE==2'b11)|((FResSelE==2'b01)&((PostProcSelE==2'b00)|((PostProcSelE==2'b01)&OpCtrlE[0]))));     | ||||
|     assign ZEnForwardE = (PostProcSelE==2'b10)&(FResSelE==2'b01)&~OpCtrlE[2]; | ||||
| 
 | ||||
|     assign ZEnE        = (PostProcSelE==2'b10)&(FResSelE==2'b01)&(~OpCtrlE[2]|OpCtrlE[1]); | ||||
|    | ||||
| 
 | ||||
| //  Final Res Sel:
 | ||||
| //        fp      int
 | ||||
|  | ||||
| @ -77,7 +77,6 @@ module fpu ( | ||||
|    logic [1:0] 	      PostProcSelE, PostProcSelM; // select result in the post processing unit
 | ||||
|    logic [4:0] 	      Adr1E, Adr2E, Adr3E;                // adresses of each input
 | ||||
|    logic                XEnE, YEnE, ZEnE; | ||||
|    logic                YEnForwardE, ZEnForwardE; | ||||
| 
 | ||||
|    // regfile signals
 | ||||
|    logic [`FLEN-1:0] FRD1D, FRD2D, FRD3D;                // Read Data from FP register - decode stage
 | ||||
| @ -168,7 +167,7 @@ module fpu ( | ||||
|    fctrl fctrl (.Funct7D(InstrD[31:25]), .OpD(InstrD[6:0]), .Rs2D(InstrD[24:20]), .Funct3D(InstrD[14:12]),  | ||||
|                .Funct3E, .MDUE, .InstrD, | ||||
|                .StallE, .StallM, .StallW, .FlushE, .FlushM, .FlushW, .FRM_REGW, .STATUS_FS, .FDivBusyE, | ||||
|                .reset, .clk, .FRegWriteM, .FRegWriteW, .FrmM, .FmtE, .FmtM, .YEnForwardE, .ZEnForwardE, | ||||
|                .reset, .clk, .FRegWriteM, .FRegWriteW, .FrmM, .FmtE, .FmtM, | ||||
|                .FDivStartE, .IDivStartE, .FWriteIntE, .FCvtIntE, .FWriteIntM, .OpCtrlE, .OpCtrlM, .IllegalFPUInstrM, .XEnE, .YEnE, .ZEnE, | ||||
|                .FResSelE, .FResSelM, .FResSelW, .PostProcSelE, .PostProcSelM, .FCvtIntW, .Adr1E, .Adr2E, .Adr3E); | ||||
| 
 | ||||
| @ -198,7 +197,7 @@ module fpu ( | ||||
|    // Hazard unit for FPU  
 | ||||
|    //    - determines if any forwarding or stalls are needed
 | ||||
|    fhazard fhazard(.Adr1E, .Adr2E, .Adr3E, .FRegWriteM, .FRegWriteW, .RdM, .RdW, .FResSelM,  | ||||
|                    .XEnE, .YEnE(YEnForwardE), .ZEnE(ZEnForwardE), .FPUStallD, .ForwardXE, .ForwardYE, .ForwardZE); | ||||
|                    .XEnE, .YEnE, .ZEnE, .FPUStallD, .ForwardXE, .ForwardYE, .ForwardZE); | ||||
| 
 | ||||
|    // forwarding muxs
 | ||||
|    mux3  #(`FLEN)  fxemux (FRD1E, FPUResultW, PreFpResM, ForwardXE, XE); | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user