mirror of
				https://github.com/openhwgroup/cvw
				synced 2025-02-11 06:05:49 +00:00 
			
		
		
		
	Merge pull request #124 from ross144/main
Added additional performance counters. Ch 5 is update todate with these changes.
This commit is contained in:
		
						commit
						17adba5fd5
					
				| @ -156,7 +156,7 @@ def GeometricAverage(benchmarks, field): | ||||
|     return Product ** (1.0/index) | ||||
| 
 | ||||
| def ComputeGeometricAverage(benchmarks): | ||||
|     fields = ['BDMR', 'BTMR', 'RASMPR', 'ClassMPR', 'ICacheMR', 'DCacheMR'] | ||||
|     fields = ['BDMR', 'BTMR', 'RASMPR', 'ClassMPR', 'ICacheMR', 'DCacheMR', 'CPI'] | ||||
|     AllAve = {} | ||||
|     for field in fields: | ||||
|         Product = 1 | ||||
| @ -248,11 +248,11 @@ if(sys.argv[1] == '-b'): | ||||
|                     dct[PredType] = (currSize, currPercent) | ||||
|         print(dct) | ||||
|         fig, axes = plt.subplots() | ||||
|         marker={'twobit' : '^', 'gshare' : 'o', 'global' : 's', 'gshareBasic' : '*', 'globalBasic' : 'x'} | ||||
|         colors={'twobit' : 'black', 'gshare' : 'blue', 'global' : 'dodgerblue', 'gshareBasic' : 'turquoise', 'globalBasic' : 'lightsteelblue'} | ||||
|         marker={'twobit' : '^', 'gshare' : 'o', 'global' : 's', 'gshareBasic' : '*', 'globalBasic' : 'x', 'btb': 'x'} | ||||
|         colors={'twobit' : 'black', 'gshare' : 'blue', 'global' : 'dodgerblue', 'gshareBasic' : 'turquoise', 'globalBasic' : 'lightsteelblue', 'btb' : 'blue'} | ||||
|         for cat in dct: | ||||
|             (x, y) = dct[cat] | ||||
|             x=[int(2**int(v)/4) for v in x] | ||||
|             x=[int(2**int(v)) for v in x] | ||||
|             print(x, y) | ||||
|             axes.plot(x,y, color=colors[cat]) | ||||
|             axes.scatter(x,y, label=cat, marker=marker[cat], color=colors[cat]) | ||||
| @ -262,9 +262,9 @@ if(sys.argv[1] == '-b'): | ||||
|         axes.legend(loc='upper left') | ||||
|         axes.set_xscale("log") | ||||
|         axes.set_ylabel('Prediction Accuracy') | ||||
|         axes.set_xlabel('Size (bytes)') | ||||
|         axes.set_xticks([16, 64, 256, 1024, 4096, 16384])         | ||||
|         axes.set_xticklabels([16, 64, 256, 1024, 4096, 16384]) | ||||
|         axes.set_xlabel('Entries') | ||||
|         axes.set_xticks([64, 256, 1024, 4096, 16384, 65536])         | ||||
|         axes.set_xticklabels([64, 256, 1024, 4096, 16384, 65536]) | ||||
|         axes.grid(color='b', alpha=0.5, linestyle='dashed', linewidth=0.5) | ||||
|     plt.show() | ||||
|      | ||||
| @ -272,7 +272,9 @@ if(sys.argv[1] == '-b'): | ||||
| else: | ||||
|     # steps 1 and 2 | ||||
|     benchmarks = ProcessFile(sys.argv[1]) | ||||
|     ComputeAverage(benchmarks) | ||||
|     print(benchmarks[0]) | ||||
|     ComputeAll(benchmarks) | ||||
|     ComputeGeometricAverage(benchmarks) | ||||
|     # 3 process into useful data | ||||
|     # cache hit rates | ||||
|     # cache fill time | ||||
| @ -280,7 +282,6 @@ else: | ||||
|     # hazard counts | ||||
|     # CPI | ||||
|     # instruction distribution | ||||
|     ComputeAll(benchmarks) | ||||
|     for benchmark in benchmarks: | ||||
|         printStats(benchmark) | ||||
| 
 | ||||
|  | ||||
| @ -134,7 +134,7 @@ | ||||
| 
 | ||||
| `define BPRED_SUPPORTED 1 | ||||
| `define BPRED_TYPE "BP_GSHARE" // BP_GSHARE_BASIC, BP_GLOBAL, BP_GLOBAL_BASIC, BP_TWOBIT | ||||
| `define BPRED_SIZE 10 | ||||
| `define BPRED_SIZE 16 | ||||
| `define BTB_SIZE 10 | ||||
| 
 | ||||
| `define SVADU_SUPPORTED 0 | ||||
|  | ||||
| @ -29,4 +29,4 @@ | ||||
| IMPERAS_TOOLS=$(pwd)/imperas.ic \ | ||||
| OTHERFLAGS="+TRACE2LOG_ENABLE=1 VERBOSE=1" \ | ||||
| TESTDIR=${WALLY}/tests/riscof/work/wally-riscv-arch-test/rv64i_m/privilege/src/Lee.S/  \ | ||||
| vsim  -do "do wally-pipelined-imperas.do rv64gc" | ||||
| vsim  -do "do wally-imperas.do rv64gc" | ||||
|  | ||||
| @ -38,7 +38,9 @@ module controller( | ||||
|   output logic [2:0]  ImmSrcD,                 // Type of immediate extension
 | ||||
|   input  logic        IllegalIEUFPUInstrD,     // Illegal IEU and FPU instruction
 | ||||
|   output logic        IllegalBaseInstrD,       // Illegal I-type instruction, or illegal RV32 access to upper 16 registers
 | ||||
|   // Execute stage control signals             
 | ||||
|   output logic        JumpD,                   // Jump instruction
 | ||||
|   output logic        BranchD,                 // Branch instruction
 | ||||
|    // Execute stage control signals             
 | ||||
|   input  logic 	      StallE, FlushE,          // Stall, flush Execute stage
 | ||||
|   input  logic [1:0]  FlagsE,                  // Comparison flags ({eq, lt})
 | ||||
|   input  logic        FWriteIntE,              // Write integer register, coming from FPU controller
 | ||||
| @ -51,7 +53,8 @@ module controller( | ||||
|   output logic        IntDivE,                 // Integer divide
 | ||||
|   output logic        MDUE,                    // MDU (multiply/divide) operatio
 | ||||
|   output logic        W64E,                    // RV64 W-type operation
 | ||||
|   output logic        JumpE,	                 // jump instruction
 | ||||
|   output logic        JumpE,                   // jump instruction
 | ||||
|   output logic        BranchE,                 // Branch instruction
 | ||||
|   output logic        SCE,                     // Store Conditional instruction
 | ||||
|   output logic        BranchSignedE,           // Branch comparison operands are signed (if it's a branch)
 | ||||
|   // Memory stage control signals
 | ||||
| @ -63,9 +66,7 @@ module controller( | ||||
|   output logic        RegWriteM,               // Instruction writes a register (needed for Hazard unit)
 | ||||
|   output logic        InvalidateICacheM, FlushDCacheM, // Invalidate I$, flush D$
 | ||||
|   output logic        InstrValidD, InstrValidE, InstrValidM, // Instruction is valid
 | ||||
|   output logic        BranchD, BranchE, | ||||
|   output logic        JumpD, | ||||
| 
 | ||||
|   output logic        FenceM,                  // Fence instruction
 | ||||
|   output logic        FWriteIntM,              // FPU controller writes integer register file
 | ||||
|   // Writeback stage control signals
 | ||||
|   input  logic        StallW, FlushW,          // Stall, flush Writeback stage
 | ||||
| @ -109,7 +110,7 @@ module controller( | ||||
|   logic        IEURegWriteE;                   // Register write 
 | ||||
|   logic        IllegalERegAdrD;                // RV32E attempts to write upper 16 registers
 | ||||
|   logic [1:0]  AtomicE;                        // Atomic instruction 
 | ||||
|   logic        FenceD, FenceE, FenceM;         // Fence instruction
 | ||||
|   logic        FenceD, FenceE;                 // Fence instruction
 | ||||
|   logic        SFenceVmaD;                     // sfence.vma instruction
 | ||||
|   logic        IntDivM;                        // Integer divide instruction
 | ||||
|     | ||||
|  | ||||
| @ -71,7 +71,8 @@ module ieu ( | ||||
|   output logic 		          FCvtIntStallD, LoadStallD,       // Stall causes from IEU to hazard unit
 | ||||
|   output logic              MDUStallD, CSRRdStallD, StoreStallD, | ||||
|   output logic 		          CSRReadM, CSRWriteM, PrivilegedM,// CSR read, CSR write, is privileged instruction
 | ||||
|   output logic 		          CSRWriteFenceM                   // CSR write or fence instruction needs to flush subsequent instructions
 | ||||
|   output logic 		          CSRWriteFenceM,                   // CSR write or fence instruction needs to flush subsequent instructions
 | ||||
|   output logic                FenceM | ||||
| ); | ||||
| 
 | ||||
|   logic [2:0] ImmSrcD;                                       // Select type of immediate extension 
 | ||||
| @ -99,7 +100,7 @@ module ieu ( | ||||
|     .Funct3E, .IntDivE, .MDUE, .W64E, .BranchD, .BranchE, .JumpD, .JumpE, .SCE, .BranchSignedE, .StallM, .FlushM, .MemRWM, | ||||
|     .CSRReadM, .CSRWriteM, .PrivilegedM, .AtomicM, .Funct3M, | ||||
|     .RegWriteM, .InvalidateICacheM, .FlushDCacheM, .InstrValidM, .InstrValidE, .InstrValidD, .FWriteIntM, | ||||
|     .StallW, .FlushW, .RegWriteW, .IntDivW, .ResultSrcW, .CSRWriteFenceM, .StoreStallD); | ||||
|     .StallW, .FlushW, .RegWriteW, .IntDivW, .ResultSrcW, .CSRWriteFenceM, .FenceM, .StoreStallD); | ||||
| 
 | ||||
|   datapath   dp( | ||||
|     .clk, .reset, .ImmSrcD, .InstrD, .StallE, .FlushE, .ForwardAE, .ForwardBE, | ||||
|  | ||||
| @ -59,13 +59,12 @@ module bpred ( | ||||
|   input logic [`XLEN-1:0]  IEUAdrM,                   // The branch/jump target address
 | ||||
|   input logic [`XLEN-1:0]  PCLinkE,                   // The address following the branch instruction. (AKA Fall through address)
 | ||||
|   output logic [3:0]       InstrClassM,               // The valid instruction class. 1-hot encoded as call, return, jr (not return), j, br
 | ||||
|   output logic             JumpOrTakenBranchM,        // The valid instruction class. 1-hot encoded as call, return, jr (not return), j, br
 | ||||
| 
 | ||||
|   // Report branch prediction status
 | ||||
|   output logic             BPWrongE,              // Prediction is wrong
 | ||||
|   output logic             BPWrongM,              // Prediction is wrong
 | ||||
|   output logic             BPDirPredWrongM,           // Prediction direction is wrong
 | ||||
|   output logic             BTBPredPCWrongM,           // Prediction target wrong
 | ||||
|   output logic             BTAWrongM,           // Prediction target wrong
 | ||||
|   output logic             RASPredPCWrongM,           // RAS prediction is wrong
 | ||||
|   output logic             IClassWrongM // Class prediction is wrong
 | ||||
|   ); | ||||
| @ -196,7 +195,6 @@ module bpred ( | ||||
|   else	assign NextValidPCE = PCE; | ||||
| 
 | ||||
|   if(`ZICOUNTERS_SUPPORTED) begin | ||||
|     logic 					JumpOrTakenBranchE; | ||||
|     logic [`XLEN-1:0] 	    RASPCD, RASPCE; | ||||
|     logic 					BTBPredPCWrongE, RASPredPCWrongE;	 | ||||
|     // performance counters
 | ||||
| @ -209,21 +207,18 @@ module bpred ( | ||||
|     // could be wrong or the fall through address selected for branch predict not taken.
 | ||||
|     // By pipeline the BTB's PC and RAS address through the pipeline we can measure the accuracy of
 | ||||
|     // both without the above inaccuracies.
 | ||||
| 	// **** use BTAWrongM from BTB.
 | ||||
|     assign BTBPredPCWrongE = (BTAE != IEUAdrE) & (BranchE | JumpE & ~ReturnE) & PCSrcE; | ||||
|     assign RASPredPCWrongE = (RASPCE != IEUAdrE) & ReturnE & PCSrcE; | ||||
| 
 | ||||
|     assign JumpOrTakenBranchE = (BranchE & PCSrcE) | JumpE; | ||||
|      | ||||
|     flopenrc #(1) JumpOrTakenBranchMReg(clk, reset, FlushM, ~StallM, JumpOrTakenBranchE, JumpOrTakenBranchM); | ||||
| 
 | ||||
|     flopenrc #(`XLEN) RASTargetDReg(clk, reset, FlushD, ~StallD, RASPCF, RASPCD); | ||||
|     flopenrc #(`XLEN) RASTargetEReg(clk, reset, FlushE, ~StallE, RASPCD, RASPCE); | ||||
|     flopenrc #(3) BPPredWrongRegM(clk, reset, FlushM, ~StallM,  | ||||
| 				  {BPDirPredWrongE, BTBPredPCWrongE, RASPredPCWrongE}, | ||||
| 				  {BPDirPredWrongM, BTBPredPCWrongM, RASPredPCWrongM}); | ||||
| 				  {BPDirPredWrongM, BTAWrongM, RASPredPCWrongM}); | ||||
|      | ||||
|   end else begin | ||||
|     assign {BTBPredPCWrongM, RASPredPCWrongM, JumpOrTakenBranchM} = '0; | ||||
|     assign {BTAWrongM, RASPredPCWrongM} = '0; | ||||
|   end | ||||
| 
 | ||||
|   // **** Fix me
 | ||||
|  | ||||
| @ -65,11 +65,11 @@ module ifu ( | ||||
|   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
 | ||||
|   output logic              JumpOrTakenBranchM, | ||||
|   output logic 				BPDirPredWrongM,                      // Prediction direction is wrong
 | ||||
|   output logic 				BTBPredPCWrongM,                          // Prediction target wrong
 | ||||
|   output logic 				BPDirPredWrongM,                          // Prediction direction is wrong
 | ||||
|   output logic 				BTAWrongM,                          // Prediction target wrong
 | ||||
|   output logic 				RASPredPCWrongM,                          // RAS prediction is wrong
 | ||||
|   output logic 				IClassWrongM,               // Class prediction is wrong
 | ||||
|   output logic 				IClassWrongM,                             // Class prediction is wrong
 | ||||
|   output logic 			    ICacheStallF,                             // I$ busy with multicycle operation
 | ||||
|   // Faults
 | ||||
|   input logic 				IllegalBaseInstrD,                   // Illegal non-compressed instruction
 | ||||
|   input logic         IllegalFPUInstrD,                    // Illegal FP instruction
 | ||||
| @ -88,7 +88,7 @@ module ifu ( | ||||
|   input logic [1:0] 		STATUS_MPP,                               // Status CSR: previous machine privilege level
 | ||||
|   input logic               sfencevmaM,                               // Virtual memory address fence, invalidate TLB entries
 | ||||
|   output logic 				ITLBMissF,                                // ITLB miss causes HPTW (hardware pagetable walker) walk
 | ||||
|   output logic              InstrUpdateDAF,                        // ITLB hit needs to update dirty or access bits
 | ||||
|   output logic              InstrUpdateDAF,                           // ITLB hit needs to update dirty or access bits
 | ||||
|   input  var logic [7:0] PMPCFG_ARRAY_REGW[`PMP_ENTRIES-1:0],         // PMP configuration from privileged unit
 | ||||
|   input  var logic [`XLEN-1:0] PMPADDR_ARRAY_REGW[`PMP_ENTRIES-1:0],  // PMP address from privileged unit
 | ||||
|   output logic 				InstrAccessFaultF,                        // Instruction access fault 
 | ||||
| @ -128,7 +128,6 @@ module ifu ( | ||||
|   logic 					   CacheableF;                            // PMA indicates instruction address is cacheable
 | ||||
|   logic 					   SelNextSpillF;                         // In a spill, stall pipeline and gate local stallF
 | ||||
|   logic 					   BusStall;                              // Bus interface busy with multicycle operation
 | ||||
|   logic 					   ICacheStallF;                          // I$ busy with multicycle operation
 | ||||
|   logic 					   IFUCacheBusStallD;                     // EIther I$ or bus busy with multicycle operation
 | ||||
|   logic 					   GatedStallD;                           // StallD gated by selected next spill
 | ||||
|   // branch predictor signal
 | ||||
| @ -331,13 +330,13 @@ module ifu ( | ||||
|                 .FlushD, .FlushE, .FlushM, .FlushW, .InstrValidD, .InstrValidE,  | ||||
|                 .BranchD, .BranchE, .JumpD, .JumpE, | ||||
|                 .InstrD, .PCNextF, .PCPlus2or4F, .PC1NextF, .PCE, .PCM, .PCSrcE, .IEUAdrE, .IEUAdrM, .PCF, .NextValidPCE, | ||||
|                 .PCD, .PCLinkE, .InstrClassM, .BPWrongE, .PostSpillInstrRawF, .JumpOrTakenBranchM, .BPWrongM, | ||||
|                 .BPDirPredWrongM, .BTBPredPCWrongM, .RASPredPCWrongM, .IClassWrongM); | ||||
|                 .PCD, .PCLinkE, .InstrClassM, .BPWrongE, .PostSpillInstrRawF, .BPWrongM, | ||||
|                 .BPDirPredWrongM, .BTAWrongM, .RASPredPCWrongM, .IClassWrongM); | ||||
| 
 | ||||
|   end else begin : bpred | ||||
|     mux2 #(`XLEN) pcmux1(.d0(PCPlus2or4F), .d1(IEUAdrE), .s(PCSrcE), .y(PC1NextF));     | ||||
|     assign BPWrongE = PCSrcE; | ||||
|     assign {InstrClassM, BPDirPredWrongM, BTBPredPCWrongM, RASPredPCWrongM, IClassWrongM} = '0; | ||||
|     assign {InstrClassM, BPDirPredWrongM, BTAWrongM, RASPredPCWrongM, IClassWrongM} = '0; | ||||
|     assign NextValidPCE = PCE; | ||||
|   end       | ||||
| 
 | ||||
|  | ||||
| @ -54,6 +54,7 @@ module lsu ( | ||||
|   input  logic [1:0]          PrivilegeModeW,                       // Current privilege mode
 | ||||
|   input  logic                BigEndianM,                           // Swap byte order to big endian
 | ||||
|   input  logic                sfencevmaM,                           // Virtual memory address fence, invalidate TLB entries
 | ||||
|   output logic                DCacheStallM,                         // D$ busy with multicycle operation
 | ||||
|   // fpu
 | ||||
|   input  logic [`FLEN-1:0]    FWriteDataM,                          // Write data from FPU
 | ||||
|   input  logic                FpLoadStoreM,                         // Selects FPU as store for write data
 | ||||
| @ -103,7 +104,6 @@ module lsu ( | ||||
| 
 | ||||
|   logic                     GatedStallW;                            // Hazard unit StallW gated when SelHPTW = 1
 | ||||
|   | ||||
|   logic                     DCacheStallM;                           // D$ busy with multicycle operation
 | ||||
|   logic                     BusStall;                               // Bus interface busy with multicycle operation
 | ||||
|   logic                     HPTWStall;                              // HPTW busy with multicycle operation
 | ||||
| 
 | ||||
|  | ||||
| @ -44,6 +44,7 @@ module csr #(parameter | ||||
|   input  logic             mretM, sretM, wfiM,        // return or WFI instruction
 | ||||
|   input  logic             IntPendingM,               // at least one interrupt is pending and could occur if enabled
 | ||||
|   input  logic             InterruptM,                // interrupt is occurring
 | ||||
|   input  logic             ExceptionM,                // interrupt is occurring
 | ||||
|   input  logic             MTimerInt,                 // timer interrupt
 | ||||
|   input  logic             MExtInt, SExtInt,          // external interrupt (from PLIC) 
 | ||||
|   input  logic             MSwInt,                    // software interrupt
 | ||||
| @ -57,17 +58,23 @@ module csr #(parameter | ||||
|   input  logic             SelHPTW,                   // hardware page table walker active, so base endianness on supervisor mode
 | ||||
|   // inputs for performance counters
 | ||||
|   input  logic             LoadStallD, | ||||
|   input  logic             StoreStallD, | ||||
|   input  logic             ICacheStallF, | ||||
|   input  logic             DCacheStallM, | ||||
|   input  logic             BPDirPredWrongM, | ||||
|   input  logic             BTBPredPCWrongM, | ||||
|   input  logic             BTAWrongM, | ||||
|   input  logic             RASPredPCWrongM, | ||||
|   input  logic             IClassWrongM, | ||||
|   input  logic             BPWrongM,                              // branch predictor is wrong
 | ||||
|   input  logic [3:0]       InstrClassM, | ||||
|   input  logic             JumpOrTakenBranchM,                               // actual instruction class
 | ||||
|   input  logic             DCacheMiss, | ||||
|   input  logic             DCacheAccess, | ||||
|   input  logic             ICacheMiss, | ||||
|   input  logic             ICacheAccess, | ||||
|   input  logic             sfencevmaM, | ||||
|   input  logic             FenceM, | ||||
|   input  logic             DivBusyE,                                  // integer divide busy
 | ||||
|   input  logic             FDivBusyE,                                 // floating point divide busy
 | ||||
|   // outputs from CSRs
 | ||||
|   output logic [1:0]       STATUS_MPP, | ||||
|   output logic             STATUS_SPP, STATUS_TSR, STATUS_TVM, | ||||
| @ -258,9 +265,10 @@ module csr #(parameter | ||||
|    | ||||
|   if (`ZICOUNTERS_SUPPORTED) begin:counters | ||||
|     csrc  counters(.clk, .reset, .StallE, .StallM, .FlushM, | ||||
|       .InstrValidNotFlushedM, .LoadStallD, .CSRMWriteM, | ||||
|       .BPDirPredWrongM, .BTBPredPCWrongM, .RASPredPCWrongM, .IClassWrongM, .JumpOrTakenBranchM, .BPWrongM, | ||||
|       .InstrClassM, .DCacheMiss, .DCacheAccess, .ICacheMiss, .ICacheAccess, | ||||
|       .InstrValidNotFlushedM, .LoadStallD, .StoreStallD, .CSRWriteM, .CSRMWriteM, | ||||
|       .BPDirPredWrongM, .BTAWrongM, .RASPredPCWrongM, .IClassWrongM, .BPWrongM, | ||||
|       .InstrClassM, .DCacheMiss, .DCacheAccess, .ICacheMiss, .ICacheAccess, .sfencevmaM, | ||||
|       .InterruptM, .ExceptionM, .FenceM, .ICacheStallF, .DCacheStallM, .DivBusyE, .FDivBusyE, | ||||
|       .CSRAdrM, .PrivilegeModeW, .CSRWriteValM, | ||||
|       .MCOUNTINHIBIT_REGW, .MCOUNTEREN_REGW, .SCOUNTEREN_REGW, | ||||
|       .MTIME_CLINT,  .CSRCReadValM, .IllegalCSRCAccessM); | ||||
|  | ||||
| @ -43,20 +43,28 @@ module csrc #(parameter | ||||
|   input  logic 	            clk, reset, | ||||
|   input  logic 	            StallE, StallM,  | ||||
|   input  logic              FlushM,  | ||||
|   input  logic 	            InstrValidNotFlushedM, LoadStallD, CSRMWriteM, | ||||
|   input  logic 	            InstrValidNotFlushedM, LoadStallD, StoreStallD,  | ||||
|   input  logic              CSRMWriteM, CSRWriteM, | ||||
|   input  logic 	            BPDirPredWrongM, | ||||
|   input  logic 	            BTBPredPCWrongM, | ||||
|   input  logic 	            BTAWrongM, | ||||
|   input  logic 	            RASPredPCWrongM, | ||||
|   input  logic 	            IClassWrongM, | ||||
|   input  logic              BPWrongM,                              // branch predictor is wrong
 | ||||
|   input  logic [3:0]        InstrClassM, | ||||
|   input  logic              JumpOrTakenBranchM,                               // actual instruction class
 | ||||
|   input  logic 	            DCacheMiss, | ||||
|   input  logic 	            DCacheAccess, | ||||
|   input  logic 	            ICacheMiss, | ||||
|   input  logic 	            ICacheAccess, | ||||
|   input  logic              ICacheStallF, | ||||
|   input  logic              DCacheStallM, | ||||
|   input  logic              sfencevmaM, | ||||
|   input  logic              InterruptM, | ||||
|   input  logic              ExceptionM, | ||||
|   input  logic              FenceM, | ||||
|   input  logic              DivBusyE,                                  // integer divide busy
 | ||||
|   input  logic              FDivBusyE,                                 // floating point divide busy
 | ||||
|   input  logic [11:0] 	    CSRAdrM, | ||||
|   input  logic [1:0] 	      PrivilegeModeW, | ||||
|   input  logic [1:0] 	    PrivilegeModeW, | ||||
|   input  logic [`XLEN-1:0]  CSRWriteValM, | ||||
|   input  logic [31:0] 	    MCOUNTINHIBIT_REGW, MCOUNTEREN_REGW, SCOUNTEREN_REGW, | ||||
|   input  logic [63:0] 	    MTIME_CLINT,  | ||||
| @ -68,6 +76,7 @@ module csrc #(parameter | ||||
|   logic [`XLEN-1:0] HPMCOUNTER_REGW[`COUNTERS-1:0]; | ||||
|   logic [`XLEN-1:0]         HPMCOUNTERH_REGW[`COUNTERS-1:0]; | ||||
|   logic                     LoadStallE, LoadStallM; | ||||
|   logic                     StoreStallE, StoreStallM; | ||||
|   logic [`COUNTERS-1:0]     WriteHPMCOUNTERM; | ||||
|   logic [`COUNTERS-1:0]     CounterEvent; | ||||
|   logic [63:0]              HPMCOUNTERPlusM[`COUNTERS-1:0]; | ||||
| @ -75,8 +84,8 @@ module csrc #(parameter | ||||
|   genvar i; | ||||
| 
 | ||||
|   // Interface signals
 | ||||
|   flopenrc #(1) LoadStallEReg(.clk, .reset, .clear(1'b0), .en(~StallE), .d(LoadStallD), .q(LoadStallE));  // don't flush the load stall during a load stall.
 | ||||
|   flopenrc #(1) LoadStallMReg(.clk, .reset, .clear(FlushM), .en(~StallM), .d(LoadStallE), .q(LoadStallM));	 | ||||
|   flopenrc #(2) LoadStallEReg(.clk, .reset, .clear(1'b0), .en(~StallE), .d({StoreStallD, LoadStallD}), .q({StoreStallE, LoadStallE}));  // don't flush the load stall during a load stall.
 | ||||
|   flopenrc #(2) LoadStallMReg(.clk, .reset, .clear(FlushM), .en(~StallM), .d({StoreStallE, LoadStallE}), .q({StoreStallM, LoadStallM}));	 | ||||
|    | ||||
|   // Determine when to increment each counter
 | ||||
|   assign CounterEvent[0] = 1'b1;                                                        // MCYCLE always increments
 | ||||
| @ -85,20 +94,29 @@ module csrc #(parameter | ||||
|   if(`QEMU) begin: cevent // No other performance counters in QEMU
 | ||||
|     assign CounterEvent[`COUNTERS-1:3] = 0; | ||||
|   end else begin: cevent                                                                // User-defined counters
 | ||||
|     assign CounterEvent[3] = LoadStallM & InstrValidNotFlushedM;                        // Load Stalls. don't want to suppress on flush as this only happens if flushed.
 | ||||
|     assign CounterEvent[4] = BPDirPredWrongM & InstrValidNotFlushedM;               // Branch predictor wrong direction
 | ||||
|     assign CounterEvent[5] = InstrClassM[0] & InstrValidNotFlushedM;                    // branch instruction
 | ||||
|     assign CounterEvent[6] = BTBPredPCWrongM & InstrValidNotFlushedM;                   // branch predictor wrong target
 | ||||
|     assign CounterEvent[7] = JumpOrTakenBranchM & InstrValidNotFlushedM;                // jump or taken branch instructions
 | ||||
|     assign CounterEvent[8] = RASPredPCWrongM & InstrValidNotFlushedM;                   // return address stack wrong address
 | ||||
|     assign CounterEvent[9] = InstrClassM[2] & InstrValidNotFlushedM;                    // return instructions
 | ||||
|     assign CounterEvent[3] = InstrClassM[0] & InstrValidNotFlushedM;                    // branch instruction
 | ||||
|     assign CounterEvent[4] = InstrClassM[1] & ~InstrClassM[2] & InstrValidNotFlushedM;  // jump and not return instructions
 | ||||
|     assign CounterEvent[5] = InstrClassM[2] & InstrValidNotFlushedM;                    // return instructions
 | ||||
| 	assign CounterEvent[6] = BPWrongM & InstrValidNotFlushedM;                     // branch predictor wrong
 | ||||
|     assign CounterEvent[7] = BPDirPredWrongM & InstrValidNotFlushedM;                   // Branch predictor wrong direction
 | ||||
|     assign CounterEvent[8] = BTAWrongM & InstrValidNotFlushedM;                   // branch predictor wrong target
 | ||||
|     assign CounterEvent[9] = RASPredPCWrongM & InstrValidNotFlushedM;                   // return address stack wrong address
 | ||||
|     assign CounterEvent[10] = IClassWrongM & InstrValidNotFlushedM;       // instruction class predictor wrong
 | ||||
|     assign CounterEvent[11] = DCacheAccess & InstrValidNotFlushedM;                     // data cache access
 | ||||
|     assign CounterEvent[12] = DCacheMiss;                                               // data cache miss. Miss asserted 1 cycle at start of cache miss
 | ||||
|     assign CounterEvent[13] = ICacheAccess & InstrValidNotFlushedM;                     // instruction cache access
 | ||||
|     assign CounterEvent[14] = ICacheMiss;                                               // instruction cache miss. Miss asserted 1 cycle at start of cache miss
 | ||||
| 	assign CounterEvent[15] = BPWrongM & InstrValidNotFlushedM;                     // branch predictor wrong
 | ||||
|     assign CounterEvent[`COUNTERS-1:16] = 0; // eventually give these sources, including FP instructions, I$/D$ misses, branches and mispredictions
 | ||||
|     assign CounterEvent[11] = LoadStallM & InstrValidNotFlushedM;                       // Load Stalls. don't want to suppress on flush as this only happens if flushed.
 | ||||
|     assign CounterEvent[12] = StoreStallM & InstrValidNotFlushedM;                      //  Store Stall
 | ||||
|     assign CounterEvent[13] = DCacheAccess & InstrValidNotFlushedM;                     // data cache access
 | ||||
|     assign CounterEvent[14] = DCacheMiss;                                               // data cache miss. Miss asserted 1 cycle at start of cache miss
 | ||||
|     assign CounterEvent[15] = DCacheStallM;                                             // d cache miss cycles
 | ||||
|     assign CounterEvent[16] = ICacheAccess & InstrValidNotFlushedM;                     // instruction cache access
 | ||||
|     assign CounterEvent[17] = ICacheMiss;                                               // instruction cache miss. Miss asserted 1 cycle at start of cache miss
 | ||||
|     assign CounterEvent[18] = ICacheStallF;                                             // i cache miss cycles
 | ||||
|     assign CounterEvent[19] = CSRWriteM & InstrValidNotFlushedM;                        // CSR writes
 | ||||
|     assign CounterEvent[20] = FenceM & InstrValidNotFlushedM;                           // fence.i
 | ||||
|     assign CounterEvent[21] = sfencevmaM & InstrValidNotFlushedM;                       // sfence.vma
 | ||||
|     assign CounterEvent[22] = InterruptM;                                               // interrupt, InstrValidNotFlushedM will be low
 | ||||
|     assign CounterEvent[23] = ExceptionM;                                               // exceptions, InstrValidNotFlushedM will be low
 | ||||
|     assign CounterEvent[24] = DivBusyE | FDivBusyE;                                     // division cycles *** RT: might need to be delay until the next cycle
 | ||||
|     assign CounterEvent[`COUNTERS-1:25] = 0; // eventually give these sources, including FP instructions, I$/D$ misses, branches and mispredictions
 | ||||
|   end | ||||
|    | ||||
|   // Counter update and write logic
 | ||||
|  | ||||
| @ -46,17 +46,21 @@ module privileged ( | ||||
|   // processor events for performance counter logging
 | ||||
|   input  logic             FRegWriteM,                                // instruction will write floating-point registers
 | ||||
|   input  logic             LoadStallD,                                // load instruction is stalling
 | ||||
|   input  logic 		         BPDirPredWrongM,                     // branch predictor guessed wrong directoin
 | ||||
|   input  logic 		         BTBPredPCWrongM,                         // branch predictor guessed wrong target
 | ||||
|   input  logic 		         RASPredPCWrongM,                         // return adddress stack guessed wrong target
 | ||||
|   input  logic 		         IClassWrongM,              // branch predictor guessed wrong instruction class
 | ||||
|   input  logic             BPWrongM,                              // branch predictor is wrong
 | ||||
|   input  logic             StoreStallD,                               // store instruction is stalling
 | ||||
|   input  logic             ICacheStallF,                              // I cache stalled
 | ||||
|   input  logic             DCacheStallM,                              // D cache stalled
 | ||||
|   input  logic 		       BPDirPredWrongM,                           // branch predictor guessed wrong direction
 | ||||
|   input  logic 		       BTAWrongM,                           // branch predictor guessed wrong target
 | ||||
|   input  logic 		       RASPredPCWrongM,                           // return adddress stack guessed wrong target
 | ||||
|   input  logic 		       IClassWrongM,                              // branch predictor guessed wrong instruction class
 | ||||
|   input  logic             BPWrongM,                                  // branch predictor is wrong
 | ||||
|   input  logic [3:0]       InstrClassM,                               // actual instruction class
 | ||||
|   input  logic             JumpOrTakenBranchM,                               // actual instruction class
 | ||||
|   input  logic             DCacheMiss,                                // data cache miss
 | ||||
|   input  logic             DCacheAccess,                              // data cache accessed (hit or miss)
 | ||||
|   input  logic             ICacheMiss,                                // instruction cache miss
 | ||||
|   input  logic             ICacheAccess,                              // instruction cache access
 | ||||
|   input  logic             DivBusyE,                                  // integer divide busy
 | ||||
|   input  logic             FDivBusyE,                                 // floating point divide busy
 | ||||
|   // fault sources
 | ||||
|   input  logic             InstrAccessFaultF,                         // instruction access fault
 | ||||
|   input  logic             LoadAccessFaultM, StoreAmoAccessFaultM,    // load or store access fault
 | ||||
| @ -84,6 +88,7 @@ module privileged ( | ||||
|   // control outputs  
 | ||||
|   output logic             RetM, TrapM,                               // return instruction, or trap
 | ||||
|   output logic             sfencevmaM,                                // sfence.vma instruction
 | ||||
|   input  logic             FenceM,                                    // fence instruction
 | ||||
|   output logic             BigEndianM,                                // Use big endian in current privilege mode
 | ||||
|   // Fault outputs
 | ||||
|   output logic             BreakpointFaultM, EcallFaultM,             // breakpoint and Ecall traps should retire
 | ||||
| @ -106,9 +111,9 @@ module privileged ( | ||||
|   logic                    DelegateM;                                 // trap should be delegated
 | ||||
|   logic                    wfiM;                                      // wait for interrupt instruction
 | ||||
|   logic                    IntPendingM;                               // interrupt is pending, even if not enabled.  ends wfi
 | ||||
|   logic InterruptM;                         // interrupt occuring
 | ||||
| 
 | ||||
| 
 | ||||
|   logic 				   InterruptM;                                // interrupt occuring
 | ||||
|   logic                    ExceptionM;                                // Memory stage instruction caused a fault
 | ||||
|   | ||||
|   // track the current privilege level
 | ||||
|   privmode privmode(.clk, .reset, .StallW, .TrapM, .mretM, .sretM, .DelegateM, | ||||
|     .STATUS_MPP, .STATUS_SPP, .NextPrivilegeModeM, .PrivilegeModeW); | ||||
| @ -124,9 +129,10 @@ module privileged ( | ||||
|     .InstrM, .PCM, .SrcAM, .IEUAdrM, .PC2NextF, | ||||
|     .CSRReadM, .CSRWriteM, .TrapM, .mretM, .sretM, .wfiM, .IntPendingM, .InterruptM, | ||||
|     .MTimerInt, .MExtInt, .SExtInt, .MSwInt, | ||||
|     .MTIME_CLINT, .InstrValidM, .FRegWriteM, .LoadStallD, | ||||
|     .BPDirPredWrongM, .BTBPredPCWrongM, .RASPredPCWrongM, .BPWrongM, | ||||
|     .IClassWrongM, .InstrClassM, .DCacheMiss, .DCacheAccess, .ICacheMiss, .ICacheAccess, .JumpOrTakenBranchM, | ||||
|     .MTIME_CLINT, .InstrValidM, .FRegWriteM, .LoadStallD, .StoreStallD, | ||||
|     .BPDirPredWrongM, .BTAWrongM, .RASPredPCWrongM, .BPWrongM, | ||||
|     .sfencevmaM, .ExceptionM, .FenceM, .ICacheStallF, .DCacheStallM, .DivBusyE, .FDivBusyE, | ||||
|     .IClassWrongM, .InstrClassM, .DCacheMiss, .DCacheAccess, .ICacheMiss, .ICacheAccess, | ||||
|     .NextPrivilegeModeM, .PrivilegeModeW, .CauseM, .SelHPTW, | ||||
|     .STATUS_MPP, .STATUS_SPP, .STATUS_TSR, .STATUS_TVM, | ||||
|     .STATUS_MIE, .STATUS_SIE, .STATUS_MXR, .STATUS_SUM, .STATUS_MPRV, .STATUS_TW, .STATUS_FS, | ||||
| @ -149,7 +155,7 @@ module privileged ( | ||||
|     .mretM, .sretM, .PrivilegeModeW,  | ||||
|     .MIP_REGW, .MIE_REGW, .MIDELEG_REGW, .MEDELEG_REGW, .STATUS_MIE, .STATUS_SIE, | ||||
|     .InstrValidM, .CommittedM, .CommittedF, | ||||
|     .TrapM, .RetM, .wfiM, .InterruptM, .IntPendingM, .DelegateM, .WFIStallM, .CauseM); | ||||
|     .TrapM, .RetM, .wfiM, .InterruptM, .ExceptionM, .IntPendingM, .DelegateM, .WFIStallM, .CauseM); | ||||
| endmodule | ||||
| 
 | ||||
| 
 | ||||
|  | ||||
| @ -45,6 +45,7 @@ module trap ( | ||||
|   output logic 		                             TrapM,                                           // Trap is occurring
 | ||||
|   output logic 		                             RetM,                                            // Return instruction being executed
 | ||||
|   output logic 		                             InterruptM,                                      // Interrupt is occurring
 | ||||
|   output logic                                   ExceptionM,                                      // exception is occurring
 | ||||
|   output logic 		                             IntPendingM,                                     // Interrupt is pending, might occur if enabled
 | ||||
|   output logic 		                             DelegateM,                                       // Delegate trap to supervisor handler
 | ||||
|   output logic 		                             WFIStallM,                                       // Stall due to WFI instruction
 | ||||
| @ -52,7 +53,6 @@ module trap ( | ||||
| ); | ||||
| 
 | ||||
|   logic                                        MIntGlobalEnM, SIntGlobalEnM;                    // Global interupt enables
 | ||||
|   logic                                        ExceptionM;                                      // exception is occurring
 | ||||
|   logic                                        Committed;                                       // LSU or IFU has committed to a bus operation that can't be interrupted
 | ||||
|   logic                                        BothInstrAccessFaultM;                           // instruction or HPTW ITLB fill caused an Instruction Access Fault
 | ||||
|   logic [11:0]       PendingIntsM, ValidIntsM, EnabledIntsM;          // interrupts are pending, valid, or enabled
 | ||||
|  | ||||
| @ -142,7 +142,7 @@ module wallypipelinedcore ( | ||||
|    | ||||
|   logic                          BPWrongE, BPWrongM; | ||||
|   logic                          BPDirPredWrongM; | ||||
|   logic                          BTBPredPCWrongM; | ||||
|   logic                          BTAWrongM; | ||||
|   logic                          RASPredPCWrongM; | ||||
|   logic                          IClassWrongM; | ||||
|   logic [3:0]                    InstrClassM; | ||||
| @ -160,14 +160,15 @@ module wallypipelinedcore ( | ||||
|   logic                          BigEndianM; | ||||
|   logic                          FCvtIntE; | ||||
|   logic                          CommittedF; | ||||
|   logic 						 JumpOrTakenBranchM; | ||||
|   logic 						 BranchD, BranchE, JumpD, JumpE; | ||||
|   logic 						 FenceM; | ||||
|   logic 						 DCacheStallM, ICacheStallF; | ||||
|    | ||||
|   // instruction fetch unit: PC, branch prediction, instruction cache
 | ||||
|   ifu ifu(.clk, .reset, | ||||
|     .StallF, .StallD, .StallE, .StallM, .StallW, .FlushD, .FlushE, .FlushM, .FlushW, | ||||
|     .InstrValidM, .InstrValidE, .InstrValidD, | ||||
|     .BranchD, .BranchE, .JumpD, .JumpE, | ||||
|     .BranchD, .BranchE, .JumpD, .JumpE, .ICacheStallF, | ||||
|     // Fetch
 | ||||
|     .HRDATA, .PCFSpill, .IFUHADDR, .PC2NextF, | ||||
|     .IFUStallF, .IFUHBURST, .IFUHTRANS, .IFUHSIZE, .IFUHREADY, .IFUHWRITE, | ||||
| @ -176,8 +177,8 @@ module wallypipelinedcore ( | ||||
|     .PCLinkE, .PCSrcE, .IEUAdrE, .IEUAdrM, .PCE, .BPWrongE,  .BPWrongM,  | ||||
|     // Mem
 | ||||
|     .CommittedF, .UnalignedPCNextF, .InvalidateICacheM, .CSRWriteFenceM, | ||||
|     .InstrD, .InstrM, .PCM, .InstrClassM, .BPDirPredWrongM, .JumpOrTakenBranchM, | ||||
|     .BTBPredPCWrongM, .RASPredPCWrongM, .IClassWrongM, | ||||
|     .InstrD, .InstrM, .PCM, .InstrClassM, .BPDirPredWrongM, | ||||
|     .BTAWrongM, .RASPredPCWrongM, .IClassWrongM, | ||||
|     // Faults out
 | ||||
|     .IllegalBaseInstrD, .IllegalFPUInstrD, .InstrPageFaultF, .IllegalIEUFPUInstrD, .InstrMisalignedFaultM, | ||||
|     // mmu management
 | ||||
| @ -208,7 +209,7 @@ module wallypipelinedcore ( | ||||
|      // hazards
 | ||||
|      .StallD, .StallE, .StallM, .StallW, .FlushD, .FlushE, .FlushM, .FlushW, | ||||
|      .FCvtIntStallD, .LoadStallD, .MDUStallD, .CSRRdStallD, .PCSrcE, | ||||
|      .CSRReadM, .CSRWriteM, .PrivilegedM, .CSRWriteFenceM, .StoreStallD);  | ||||
|      .CSRReadM, .CSRWriteM, .PrivilegedM, .CSRWriteFenceM, .FenceM, .StoreStallD);  | ||||
| 
 | ||||
|   lsu lsu( | ||||
|     .clk, .reset, .StallM, .FlushM, .StallW, .FlushW, | ||||
| @ -231,6 +232,7 @@ module wallypipelinedcore ( | ||||
|     .STATUS_MPRV,  // from csr            
 | ||||
|     .STATUS_MPP,  // from csr      
 | ||||
|     .sfencevmaM,                   // connects to privilege
 | ||||
|     .DCacheStallM,                  // connects to privilege
 | ||||
|     .LoadPageFaultM,   // connects to privilege
 | ||||
|     .StoreAmoPageFaultM, // connects to privilege
 | ||||
|     .LoadMisalignedFaultM, // connects to privilege
 | ||||
| @ -286,12 +288,12 @@ module wallypipelinedcore ( | ||||
|       .FlushD, .FlushE, .FlushM, .FlushW, .StallD, .StallE, .StallM, .StallW, | ||||
|       .CSRReadM, .CSRWriteM, .SrcAM, .PCM, .PC2NextF, | ||||
|       .InstrM, .CSRReadValW, .UnalignedPCNextF, | ||||
|       .RetM, .TrapM, .sfencevmaM, | ||||
|       .RetM, .TrapM, .sfencevmaM, .FenceM, .DCacheStallM, .ICacheStallF, | ||||
|       .InstrValidM, .CommittedM, .CommittedF, | ||||
|       .FRegWriteM, .LoadStallD, | ||||
|       .BPDirPredWrongM, .BTBPredPCWrongM, .BPWrongM, | ||||
|       .RASPredPCWrongM, .IClassWrongM, | ||||
|       .InstrClassM, .JumpOrTakenBranchM, .DCacheMiss, .DCacheAccess, .ICacheMiss, .ICacheAccess, .PrivilegedM, | ||||
|       .FRegWriteM, .LoadStallD, .StoreStallD, | ||||
|       .BPDirPredWrongM, .BTAWrongM, .BPWrongM, | ||||
|       .RASPredPCWrongM, .IClassWrongM, .DivBusyE, .FDivBusyE, | ||||
|       .InstrClassM, .DCacheMiss, .DCacheAccess, .ICacheMiss, .ICacheAccess, .PrivilegedM, | ||||
|       .InstrPageFaultF, .LoadPageFaultM, .StoreAmoPageFaultM, | ||||
|       .InstrMisalignedFaultM, .IllegalIEUFPUInstrD,  | ||||
|       .LoadMisalignedFaultM, .StoreAmoMisalignedFaultM, | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user