mirror of
				https://github.com/openhwgroup/cvw
				synced 2025-02-11 06:05:49 +00:00 
			
		
		
		
	Select original compressed or uncompressed instruction for MTVAL on illegal instruction fault
This commit is contained in:
		
							parent
							
								
									32c54db595
								
							
						
					
					
						commit
						c4c7f5378e
					
				| @ -32,7 +32,7 @@ | ||||
| `include "wally-config.vh" | ||||
| 
 | ||||
| module decompress ( | ||||
|   input  logic [31:0] InstrRawD,         // 32-bit instruction or raw un decompress instruction
 | ||||
|   input  logic [31:0] InstrRawD,         // 32-bit instruction or raw compressed 16-bit instruction in bottom half
 | ||||
|   output logic [31:0] InstrD,            // Decompressed instruction
 | ||||
|   output logic        IllegalCompInstrD  // Invalid decompressed instruction
 | ||||
| ); | ||||
|  | ||||
| @ -62,6 +62,7 @@ module ifu ( | ||||
|   output logic [`XLEN-1:0]  PC2NextF,                                 // Selected PC between branch prediction and next valid PC if CSRWriteFence
 | ||||
|   output logic [31:0] 		InstrD,                                   // The decoded instruction in Decode stage
 | ||||
|   output logic [31:0]       InstrM,                                   // The decoded instruction in Memory stage
 | ||||
|   output logic [31:0]       InstrOrigM,                                   // Original compressed or uncompressed instruction in Memory stage for Illegal Instruction MTVAL
 | ||||
|   output logic [`XLEN-1:0] 	PCM,                                      // Memory stage instruction address
 | ||||
|   // branch predictor
 | ||||
|   output logic [3:0] 		InstrClassM,                              // The valid instruction class. 1-hot encoded as jalr, ret, jr (not ret), j, br
 | ||||
| @ -116,6 +117,7 @@ module ifu ( | ||||
|   logic                        CompressedF;                           // The fetched instruction is compressed
 | ||||
|   logic                        CompressedD;                           // The decoded instruction is compressed
 | ||||
|   logic                        CompressedE;                           // The execution instruction is compressed
 | ||||
|   logic                        CompressedM;                           // The execution instruction is compressed
 | ||||
|   logic [31:0] 				   PostSpillInstrRawF;                    // Fetch instruction after merge two halves of spill
 | ||||
|   logic [31:0] 				   InstrRawD;                             // Non-decompressed instruction in the Decode stage
 | ||||
|   logic                  IllegalIEUInstrD;                 // IEU Instruction (regular or compressed) is not good
 | ||||
| @ -135,6 +137,7 @@ module ifu ( | ||||
|   logic                        BusCommittedF;                         // Bus memory operation in flight, delay interrupts
 | ||||
|   logic 					   CacheCommittedF;                       // I$ memory operation started, delay interrupts
 | ||||
|   logic                        SelIROM;                               // PMA indicates instruction address is in the IROM
 | ||||
|   logic [15:0]       InstrRawE, InstrRawM; | ||||
|    | ||||
|   assign PCFExt = {2'b00, PCSpillF}; | ||||
| 
 | ||||
| @ -386,4 +389,9 @@ module ifu ( | ||||
|   flopenrc #(1) CompressedEReg(clk, reset, FlushE, ~StallE, CompressedD, CompressedE); | ||||
|   assign PCLinkE = PCE + (CompressedE ? 2 : 4); | ||||
| 
 | ||||
|   // pipeline original compressed instruction in case it is needed for MTVAL on an illegal instruction exception
 | ||||
|   flopenrc #(16) InstrRawEReg(clk, reset, FlushE, ~StallE, InstrRawD[15:0], InstrRawE); | ||||
|   flopenrc #(16) InstrRawMReg(clk, reset, FlushM, ~StallM, InstrRawE, InstrRawM); | ||||
|   flopenrc #(1)  CompressedMReg(clk, reset, FlushM, ~StallM, CompressedE, CompressedM); | ||||
|   mux2     #(32) InstrOrigMux(InstrM, {16'b0, InstrRawM}, CompressedM, InstrOrigM);  | ||||
| endmodule | ||||
|  | ||||
| @ -37,6 +37,7 @@ module csr #(parameter | ||||
|   input  logic             FlushM, FlushW, | ||||
|   input  logic             StallE, StallM, StallW, | ||||
|   input  logic [31:0]      InstrM,                    // current instruction
 | ||||
|   input  logic [31:0]      InstrOrigM,                // Original compressed or uncompressed instruction in Memory stage for Illegal Instruction MTVAL
 | ||||
|   input  logic [`XLEN-1:0] PCM, PC2NextF,             // program counter, next PC going to trap/return logic
 | ||||
|   input  logic [`XLEN-1:0] SrcAM, IEUAdrM,            // SrcA and memory address from IEU
 | ||||
|   input  logic             CSRReadM, CSRWriteM,       // read or write CSR
 | ||||
| @ -133,7 +134,7 @@ module csr #(parameter | ||||
|     if (InterruptM)           NextFaultMtvalM = 0; | ||||
|     else case (CauseM) | ||||
|       12, 1, 3:               NextFaultMtvalM = PCM;  // Instruction page/access faults, breakpoint
 | ||||
|       2:                      NextFaultMtvalM = {{(`XLEN-32){1'b0}}, InstrM}; // Illegal instruction fault // *** this should probably set to the uncompressed instruction
 | ||||
|       2:                      NextFaultMtvalM = {{(`XLEN-32){1'b0}}, InstrOrigM}; // Illegal instruction fault 
 | ||||
|       0, 4, 6, 13, 15, 5, 7:  NextFaultMtvalM = IEUAdrM; // Instruction misaligned, Load/Store Misaligned/page/access faults
 | ||||
|       default:                NextFaultMtvalM = 0; // Ecall, interrupts
 | ||||
|     endcase | ||||
|  | ||||
| @ -37,6 +37,7 @@ module privileged ( | ||||
|   input  logic  CSRReadM, CSRWriteM,         // Read or write CSRs
 | ||||
|   input  logic [`XLEN-1:0] SrcAM,                                     // GPR register to write
 | ||||
|   input  logic [31:0]      InstrM,                                    // Instruction
 | ||||
|   input  logic [31:0]      InstrOrigM,                                // Original compressed or uncompressed instruction in Memory stage for Illegal Instruction MTVAL
 | ||||
|   input  logic [`XLEN-1:0] IEUAdrM,                                   // address from IEU
 | ||||
|   input  logic [`XLEN-1:0] PCM, PC2NextF,                             // program counter, next PC going to trap/return PC logic
 | ||||
|   // control signals
 | ||||
| @ -126,7 +127,7 @@ module privileged ( | ||||
| 
 | ||||
|   // Control and Status Registers
 | ||||
|   csr csr(.clk, .reset, .FlushM, .FlushW, .StallE, .StallM, .StallW, | ||||
|     .InstrM, .PCM, .SrcAM, .IEUAdrM, .PC2NextF, | ||||
|     .InstrM, .InstrOrigM, .PCM, .SrcAM, .IEUAdrM, .PC2NextF, | ||||
|     .CSRReadM, .CSRWriteM, .TrapM, .mretM, .sretM, .wfiM, .IntPendingM, .InterruptM, | ||||
|     .MTimerInt, .MExtInt, .SExtInt, .MSwInt, | ||||
|     .MTIME_CLINT, .InstrValidM, .FRegWriteM, .LoadStallD, .StoreStallD, | ||||
|  | ||||
| @ -62,7 +62,7 @@ module wallypipelinedcore ( | ||||
|   logic [`XLEN-1:0] 			  SrcAM; | ||||
|   logic [2:0]                    Funct3E; | ||||
|   logic [31:0]                   InstrD; | ||||
|   logic [31:0] 					 InstrM; | ||||
|   logic [31:0] 					 InstrM, InstrOrigM; | ||||
|   logic [`XLEN-1:0]               PCSpillF, PCE, PCLinkE; | ||||
|   logic [`XLEN-1:0] 			  PCM; | ||||
|   logic [`XLEN-1:0]               CSRReadValW, MDUResultW; | ||||
| @ -176,7 +176,7 @@ module wallypipelinedcore ( | ||||
|     .PCLinkE, .PCSrcE, .IEUAdrE, .IEUAdrM, .PCE, .BPWrongE,  .BPWrongM,  | ||||
|     // Mem
 | ||||
|     .CommittedF, .UnalignedPCNextF, .InvalidateICacheM, .CSRWriteFenceM, | ||||
|     .InstrD, .InstrM, .PCM, .InstrClassM, .BPDirPredWrongM, | ||||
|     .InstrD, .InstrM, .InstrOrigM, .PCM, .InstrClassM, .BPDirPredWrongM, | ||||
|     .BTAWrongM, .RASPredPCWrongM, .IClassWrongM, | ||||
|     // Faults out
 | ||||
|     .IllegalBaseInstrD, .IllegalFPUInstrD, .InstrPageFaultF, .IllegalIEUFPUInstrD, .InstrMisalignedFaultM, | ||||
| @ -286,7 +286,7 @@ module wallypipelinedcore ( | ||||
|       .clk, .reset, | ||||
|       .FlushD, .FlushE, .FlushM, .FlushW, .StallD, .StallE, .StallM, .StallW, | ||||
|       .CSRReadM, .CSRWriteM, .SrcAM, .PCM, .PC2NextF, | ||||
|       .InstrM, .CSRReadValW, .UnalignedPCNextF, | ||||
|       .InstrM, .InstrOrigM, .CSRReadValW, .UnalignedPCNextF, | ||||
|       .RetM, .TrapM, .sfencevmaM, .InvalidateICacheM, .DCacheStallM, .ICacheStallF, | ||||
|       .InstrValidM, .CommittedM, .CommittedF, | ||||
|       .FRegWriteM, .LoadStallD, .StoreStallD, | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user