mirror of
				https://github.com/openhwgroup/cvw
				synced 2025-02-11 06:05:49 +00:00 
			
		
		
		
	Fixed Type 5b interaction between dcache and hptw.
This is a load concurrent with ITLBMiss.
This commit is contained in:
		
							parent
							
								
									6aff6b0fa3
								
							
						
					
					
						commit
						d830721a11
					
				| @ -5,42 +5,26 @@ add wave -noupdate /testbench/reset | |||||||
| add wave -noupdate /testbench/reset_ext | add wave -noupdate /testbench/reset_ext | ||||||
| add wave -noupdate -radix unsigned /testbench/InstrCountW | add wave -noupdate -radix unsigned /testbench/InstrCountW | ||||||
| add wave -noupdate /testbench/dut/hart/SATP_REGW | add wave -noupdate /testbench/dut/hart/SATP_REGW | ||||||
| add wave -noupdate -expand -group HDU -expand -group traps /testbench/dut/hart/priv/trap/InstrMisalignedFaultM | add wave -noupdate -group HDU -expand -group hazards /testbench/dut/hart/hzu/BPPredWrongE | ||||||
| add wave -noupdate -expand -group HDU -expand -group traps /testbench/dut/hart/priv/trap/InstrAccessFaultM | add wave -noupdate -group HDU -expand -group hazards /testbench/dut/hart/hzu/CSRWritePendingDEM | ||||||
| add wave -noupdate -expand -group HDU -expand -group traps /testbench/dut/hart/priv/trap/IllegalInstrFaultM | add wave -noupdate -group HDU -expand -group hazards /testbench/dut/hart/hzu/RetM | ||||||
| add wave -noupdate -expand -group HDU -expand -group traps /testbench/dut/hart/priv/trap/BreakpointFaultM | add wave -noupdate -group HDU -expand -group hazards -color Pink /testbench/dut/hart/hzu/TrapM | ||||||
| add wave -noupdate -expand -group HDU -expand -group traps /testbench/dut/hart/priv/trap/LoadMisalignedFaultM | add wave -noupdate -group HDU -expand -group hazards /testbench/dut/hart/hzu/LoadStallD | ||||||
| add wave -noupdate -expand -group HDU -expand -group traps /testbench/dut/hart/priv/trap/StoreMisalignedFaultM | add wave -noupdate -group HDU -expand -group hazards /testbench/dut/hart/hzu/StoreStallD | ||||||
| add wave -noupdate -expand -group HDU -expand -group traps /testbench/dut/hart/priv/trap/LoadAccessFaultM | add wave -noupdate -group HDU -expand -group hazards /testbench/dut/hart/hzu/ICacheStallF | ||||||
| add wave -noupdate -expand -group HDU -expand -group traps /testbench/dut/hart/priv/trap/StoreAccessFaultM | add wave -noupdate -group HDU -expand -group hazards /testbench/dut/hart/hzu/LSUStall | ||||||
| add wave -noupdate -expand -group HDU -expand -group traps /testbench/dut/hart/priv/trap/EcallFaultM | add wave -noupdate -group HDU -expand -group hazards /testbench/dut/hart/MulDivStallD | ||||||
| add wave -noupdate -expand -group HDU -expand -group traps /testbench/dut/hart/priv/trap/InstrPageFaultM | add wave -noupdate -group HDU -expand -group hazards /testbench/dut/hart/hzu/DivBusyE | ||||||
| add wave -noupdate -expand -group HDU -expand -group traps /testbench/dut/hart/priv/trap/LoadPageFaultM | add wave -noupdate -group HDU -expand -group Flush -color Yellow /testbench/dut/hart/hzu/FlushF | ||||||
| add wave -noupdate -expand -group HDU -expand -group traps /testbench/dut/hart/priv/trap/StorePageFaultM | add wave -noupdate -group HDU -expand -group Flush -color Yellow /testbench/dut/hart/FlushD | ||||||
| add wave -noupdate -expand -group HDU -expand -group traps /testbench/dut/hart/priv/trap/InterruptM | add wave -noupdate -group HDU -expand -group Flush -color Yellow /testbench/dut/hart/FlushE | ||||||
| add wave -noupdate -expand -group HDU -group interrupts /testbench/dut/hart/priv/trap/PendingIntsM | add wave -noupdate -group HDU -expand -group Flush -color Yellow /testbench/dut/hart/FlushM | ||||||
| add wave -noupdate -expand -group HDU -group interrupts /testbench/dut/hart/priv/trap/CommittedM | add wave -noupdate -group HDU -expand -group Flush -color Yellow /testbench/dut/hart/FlushW | ||||||
| add wave -noupdate -expand -group HDU -group interrupts /testbench/dut/hart/priv/trap/InstrValidM | add wave -noupdate -group HDU -expand -group Stall -color Orange /testbench/dut/hart/StallF | ||||||
| add wave -noupdate -expand -group HDU -expand -group hazards /testbench/dut/hart/hzu/BPPredWrongE | add wave -noupdate -group HDU -expand -group Stall -color Orange /testbench/dut/hart/StallD | ||||||
| add wave -noupdate -expand -group HDU -expand -group hazards /testbench/dut/hart/hzu/CSRWritePendingDEM | add wave -noupdate -group HDU -expand -group Stall -color Orange /testbench/dut/hart/StallE | ||||||
| add wave -noupdate -expand -group HDU -expand -group hazards /testbench/dut/hart/hzu/RetM | add wave -noupdate -group HDU -expand -group Stall -color Orange /testbench/dut/hart/StallM | ||||||
| add wave -noupdate -expand -group HDU -expand -group hazards -color Pink /testbench/dut/hart/hzu/TrapM | add wave -noupdate -group HDU -expand -group Stall -color Orange /testbench/dut/hart/StallW | ||||||
| add wave -noupdate -expand -group HDU -expand -group hazards /testbench/dut/hart/hzu/LoadStallD |  | ||||||
| add wave -noupdate -expand -group HDU -expand -group hazards /testbench/dut/hart/hzu/StoreStallD |  | ||||||
| add wave -noupdate -expand -group HDU -expand -group hazards /testbench/dut/hart/hzu/ICacheStallF |  | ||||||
| add wave -noupdate -expand -group HDU -expand -group hazards /testbench/dut/hart/hzu/LSUStall |  | ||||||
| add wave -noupdate -expand -group HDU -expand -group hazards /testbench/dut/hart/MulDivStallD |  | ||||||
| add wave -noupdate -expand -group HDU -expand -group hazards /testbench/dut/hart/hzu/DivBusyE |  | ||||||
| add wave -noupdate -expand -group HDU -expand -group Flush -color Yellow /testbench/dut/hart/hzu/FlushF |  | ||||||
| add wave -noupdate -expand -group HDU -expand -group Flush -color Yellow /testbench/dut/hart/FlushD |  | ||||||
| add wave -noupdate -expand -group HDU -expand -group Flush -color Yellow /testbench/dut/hart/FlushE |  | ||||||
| add wave -noupdate -expand -group HDU -expand -group Flush -color Yellow /testbench/dut/hart/FlushM |  | ||||||
| add wave -noupdate -expand -group HDU -expand -group Flush -color Yellow /testbench/dut/hart/FlushW |  | ||||||
| add wave -noupdate -expand -group HDU -expand -group Stall -color Orange /testbench/dut/hart/StallF |  | ||||||
| add wave -noupdate -expand -group HDU -expand -group Stall -color Orange /testbench/dut/hart/StallD |  | ||||||
| add wave -noupdate -expand -group HDU -expand -group Stall -color Orange /testbench/dut/hart/StallE |  | ||||||
| add wave -noupdate -expand -group HDU -expand -group Stall -color Orange /testbench/dut/hart/StallM |  | ||||||
| add wave -noupdate -expand -group HDU -expand -group Stall -color Orange /testbench/dut/hart/StallW |  | ||||||
| add wave -noupdate -group PCS /testbench/dut/hart/ifu/PCNextF | add wave -noupdate -group PCS /testbench/dut/hart/ifu/PCNextF | ||||||
| add wave -noupdate -group PCS /testbench/dut/hart/PCF | add wave -noupdate -group PCS /testbench/dut/hart/PCF | ||||||
| add wave -noupdate -group PCS /testbench/dut/hart/ifu/PCD | add wave -noupdate -group PCS /testbench/dut/hart/ifu/PCD | ||||||
| @ -60,16 +44,15 @@ add wave -noupdate -group {Decode Stage} /testbench/dut/hart/ieu/c/RegWriteD | |||||||
| add wave -noupdate -group {Decode Stage} /testbench/dut/hart/ieu/dp/RdD | add wave -noupdate -group {Decode Stage} /testbench/dut/hart/ieu/dp/RdD | ||||||
| add wave -noupdate -group {Decode Stage} /testbench/dut/hart/ieu/dp/Rs1D | add wave -noupdate -group {Decode Stage} /testbench/dut/hart/ieu/dp/Rs1D | ||||||
| add wave -noupdate -group {Decode Stage} /testbench/dut/hart/ieu/dp/Rs2D | add wave -noupdate -group {Decode Stage} /testbench/dut/hart/ieu/dp/Rs2D | ||||||
| add wave -noupdate -expand -group {Execution Stage} /testbench/dut/hart/ifu/PCE | add wave -noupdate -group {Execution Stage} /testbench/dut/hart/ifu/PCE | ||||||
| add wave -noupdate -expand -group {Execution Stage} /testbench/ExpectedPCE | add wave -noupdate -group {Execution Stage} /testbench/ExpectedPCE | ||||||
| add wave -noupdate -expand -group {Execution Stage} /testbench/MepcExpected | add wave -noupdate -group {Execution Stage} /testbench/MepcExpected | ||||||
| add wave -noupdate -expand -group {Execution Stage} /testbench/dut/hart/ifu/InstrE | add wave -noupdate -group {Execution Stage} /testbench/dut/hart/ifu/InstrE | ||||||
| add wave -noupdate -expand -group {Execution Stage} /testbench/InstrEName | add wave -noupdate -group {Execution Stage} /testbench/InstrEName | ||||||
| add wave -noupdate -expand -group {Execution Stage} /testbench/dut/hart/ieu/c/InstrValidE | add wave -noupdate -group {Execution Stage} /testbench/dut/hart/ieu/c/InstrValidE | ||||||
| add wave -noupdate -expand -group {Execution Stage} /testbench/textE | add wave -noupdate -group {Execution Stage} /testbench/textE | ||||||
| add wave -noupdate -expand -group {Execution Stage} -color {Cornflower Blue} /testbench/FunctionName/FunctionName | add wave -noupdate -group {Execution Stage} -color {Cornflower Blue} /testbench/FunctionName/FunctionName | ||||||
| add wave -noupdate -expand -group {Memory Stage} /testbench/checkInstrM | add wave -noupdate -expand -group {Memory Stage} /testbench/checkInstrM | ||||||
| add wave -noupdate -expand -group {Memory Stage} /testbench/dut/hart/priv/trap/InstrValidM |  | ||||||
| add wave -noupdate -expand -group {Memory Stage} /testbench/dut/hart/PCM | add wave -noupdate -expand -group {Memory Stage} /testbench/dut/hart/PCM | ||||||
| add wave -noupdate -expand -group {Memory Stage} /testbench/ExpectedPCM | add wave -noupdate -expand -group {Memory Stage} /testbench/ExpectedPCM | ||||||
| add wave -noupdate -expand -group {Memory Stage} /testbench/dut/hart/InstrM | add wave -noupdate -expand -group {Memory Stage} /testbench/dut/hart/InstrM | ||||||
| @ -154,15 +137,7 @@ add wave -noupdate -group RegFile -group {write regfile mux} /testbench/dut/hart | |||||||
| add wave -noupdate -group alu /testbench/dut/hart/ieu/dp/alu/A | add wave -noupdate -group alu /testbench/dut/hart/ieu/dp/alu/A | ||||||
| add wave -noupdate -group alu /testbench/dut/hart/ieu/dp/alu/B | add wave -noupdate -group alu /testbench/dut/hart/ieu/dp/alu/B | ||||||
| add wave -noupdate -group alu /testbench/dut/hart/ieu/dp/alu/ALUControl | add wave -noupdate -group alu /testbench/dut/hart/ieu/dp/alu/ALUControl | ||||||
| add wave -noupdate -group alu /testbench/dut/hart/ieu/dp/alu/result |  | ||||||
| add wave -noupdate -group alu /testbench/dut/hart/ieu/dp/alu/FlagsE |  | ||||||
| add wave -noupdate -group alu -divider internals | add wave -noupdate -group alu -divider internals | ||||||
| add wave -noupdate -group alu /testbench/dut/hart/ieu/dp/alu/overflow |  | ||||||
| add wave -noupdate -group alu /testbench/dut/hart/ieu/dp/alu/carry |  | ||||||
| add wave -noupdate -group alu /testbench/dut/hart/ieu/dp/alu/zero |  | ||||||
| add wave -noupdate -group alu /testbench/dut/hart/ieu/dp/alu/neg |  | ||||||
| add wave -noupdate -group alu /testbench/dut/hart/ieu/dp/alu/lt |  | ||||||
| add wave -noupdate -group alu /testbench/dut/hart/ieu/dp/alu/ltu |  | ||||||
| add wave -noupdate -group Forward /testbench/dut/hart/ieu/fw/Rs1D | add wave -noupdate -group Forward /testbench/dut/hart/ieu/fw/Rs1D | ||||||
| add wave -noupdate -group Forward /testbench/dut/hart/ieu/fw/Rs2D | add wave -noupdate -group Forward /testbench/dut/hart/ieu/fw/Rs2D | ||||||
| add wave -noupdate -group Forward /testbench/dut/hart/ieu/fw/Rs1E | add wave -noupdate -group Forward /testbench/dut/hart/ieu/fw/Rs1E | ||||||
| @ -180,15 +155,6 @@ add wave -noupdate -group {alu execution stage} /testbench/dut/hart/ieu/dp/Write | |||||||
| add wave -noupdate -group {alu execution stage} /testbench/dut/hart/ieu/dp/ALUResultE | add wave -noupdate -group {alu execution stage} /testbench/dut/hart/ieu/dp/ALUResultE | ||||||
| add wave -noupdate -group {alu execution stage} /testbench/dut/hart/ieu/dp/SrcAE | add wave -noupdate -group {alu execution stage} /testbench/dut/hart/ieu/dp/SrcAE | ||||||
| add wave -noupdate -group {alu execution stage} /testbench/dut/hart/ieu/dp/SrcBE | add wave -noupdate -group {alu execution stage} /testbench/dut/hart/ieu/dp/SrcBE | ||||||
| add wave -noupdate -group muldiv /testbench/dut/hart/mdu/Funct3E |  | ||||||
| add wave -noupdate -group muldiv /testbench/dut/hart/mdu/MulDivE |  | ||||||
| add wave -noupdate -group muldiv /testbench/dut/hart/mdu/W64E |  | ||||||
| add wave -noupdate -group muldiv /testbench/dut/hart/mdu/StallM |  | ||||||
| add wave -noupdate -group muldiv /testbench/dut/hart/mdu/StallW |  | ||||||
| add wave -noupdate -group muldiv /testbench/dut/hart/mdu/FlushM |  | ||||||
| add wave -noupdate -group muldiv /testbench/dut/hart/mdu/FlushW |  | ||||||
| add wave -noupdate -group muldiv /testbench/dut/hart/mdu/MulDivResultW |  | ||||||
| add wave -noupdate -group muldiv /testbench/dut/hart/mdu/DivBusyE |  | ||||||
| add wave -noupdate -group icache -color Gold /testbench/dut/hart/ifu/icache/controller/CurrState | add wave -noupdate -group icache -color Gold /testbench/dut/hart/ifu/icache/controller/CurrState | ||||||
| add wave -noupdate -group icache /testbench/dut/hart/ifu/icache/controller/NextState | add wave -noupdate -group icache /testbench/dut/hart/ifu/icache/controller/NextState | ||||||
| add wave -noupdate -group icache /testbench/dut/hart/ifu/ITLBMissF | add wave -noupdate -group icache /testbench/dut/hart/ifu/ITLBMissF | ||||||
| @ -239,9 +205,13 @@ add wave -noupdate -expand -group AMO_ALU /testbench/dut/hart/lsu/dcache/genblk3 | |||||||
| add wave -noupdate -expand -group AMO_ALU /testbench/dut/hart/lsu/dcache/genblk3/amoalu/srca | add wave -noupdate -expand -group AMO_ALU /testbench/dut/hart/lsu/dcache/genblk3/amoalu/srca | ||||||
| add wave -noupdate -expand -group AMO_ALU /testbench/dut/hart/lsu/dcache/genblk3/amoalu/srcb | add wave -noupdate -expand -group AMO_ALU /testbench/dut/hart/lsu/dcache/genblk3/amoalu/srcb | ||||||
| add wave -noupdate -expand -group AMO_ALU /testbench/dut/hart/lsu/dcache/genblk3/amoalu/width | add wave -noupdate -expand -group AMO_ALU /testbench/dut/hart/lsu/dcache/genblk3/amoalu/width | ||||||
| add wave -noupdate -expand -group lsu -group {LSU ARB} /testbench/dut/hart/lsu/arbiter/SelHPTW | add wave -noupdate -expand -group lsu -color Gold /testbench/dut/hart/lsu/CurrState | ||||||
|  | add wave -noupdate -expand -group lsu /testbench/dut/hart/lsu/SelHPTW | ||||||
|  | add wave -noupdate -expand -group lsu /testbench/dut/hart/lsu/InterlockStall | ||||||
|  | add wave -noupdate -expand -group lsu /testbench/dut/hart/lsu/LSUStall | ||||||
|  | add wave -noupdate -expand -group lsu /testbench/dut/hart/lsu/WalkerInstrPageFaultF | ||||||
|  | add wave -noupdate -expand -group lsu /testbench/dut/hart/lsu/WalkerInstrPageFaultRaw | ||||||
| add wave -noupdate -expand -group lsu -expand -group dcache -color Gold /testbench/dut/hart/lsu/dcache/dcachefsm/CurrState | add wave -noupdate -expand -group lsu -expand -group dcache -color Gold /testbench/dut/hart/lsu/dcache/dcachefsm/CurrState | ||||||
| add wave -noupdate -expand -group lsu -expand -group dcache /testbench/dut/hart/lsu/dcache/WalkerPageFaultM |  | ||||||
| add wave -noupdate -expand -group lsu -expand -group dcache /testbench/dut/hart/lsu/dcache/WriteDataM | add wave -noupdate -expand -group lsu -expand -group dcache /testbench/dut/hart/lsu/dcache/WriteDataM | ||||||
| add wave -noupdate -expand -group lsu -expand -group dcache /testbench/dut/hart/lsu/dcache/SRAMBlockWriteEnableM | add wave -noupdate -expand -group lsu -expand -group dcache /testbench/dut/hart/lsu/dcache/SRAMBlockWriteEnableM | ||||||
| add wave -noupdate -expand -group lsu -expand -group dcache /testbench/dut/hart/lsu/dcache/SRAMWordWriteEnableM | add wave -noupdate -expand -group lsu -expand -group dcache /testbench/dut/hart/lsu/dcache/SRAMWordWriteEnableM | ||||||
| @ -250,6 +220,10 @@ add wave -noupdate -expand -group lsu -expand -group dcache /testbench/dut/hart/ | |||||||
| add wave -noupdate -expand -group lsu -expand -group dcache /testbench/dut/hart/lsu/dcache/SRAMBlockWayWriteEnableM | add wave -noupdate -expand -group lsu -expand -group dcache /testbench/dut/hart/lsu/dcache/SRAMBlockWayWriteEnableM | ||||||
| add wave -noupdate -expand -group lsu -expand -group dcache /testbench/dut/hart/lsu/dcache/SelAdrM | add wave -noupdate -expand -group lsu -expand -group dcache /testbench/dut/hart/lsu/dcache/SelAdrM | ||||||
| add wave -noupdate -expand -group lsu -expand -group dcache /testbench/dut/hart/lsu/dcache/ReadDataBlockM | add wave -noupdate -expand -group lsu -expand -group dcache /testbench/dut/hart/lsu/dcache/ReadDataBlockM | ||||||
|  | add wave -noupdate -expand -group lsu -expand -group dcache /testbench/dut/hart/lsu/SelReplayCPURequest | ||||||
|  | add wave -noupdate -expand -group lsu -expand -group dcache /testbench/dut/hart/lsu/IEUAdrE | ||||||
|  | add wave -noupdate -expand -group lsu -expand -group dcache /testbench/dut/hart/lsu/IEUAdrM | ||||||
|  | add wave -noupdate -expand -group lsu -expand -group dcache /testbench/dut/hart/lsu/dcache/RAdr | ||||||
| add wave -noupdate -expand -group lsu -expand -group dcache -group flush -radix unsigned /testbench/dut/hart/lsu/dcache/FlushAdr | add wave -noupdate -expand -group lsu -expand -group dcache -group flush -radix unsigned /testbench/dut/hart/lsu/dcache/FlushAdr | ||||||
| add wave -noupdate -expand -group lsu -expand -group dcache -group flush /testbench/dut/hart/lsu/dcache/FlushWay | add wave -noupdate -expand -group lsu -expand -group dcache -group flush /testbench/dut/hart/lsu/dcache/FlushWay | ||||||
| add wave -noupdate -expand -group lsu -expand -group dcache -group flush /testbench/dut/hart/lsu/dcache/VictimDirtyWay | add wave -noupdate -expand -group lsu -expand -group dcache -group flush /testbench/dut/hart/lsu/dcache/VictimDirtyWay | ||||||
| @ -404,7 +378,6 @@ add wave -noupdate -expand -group lsu -group pmp /testbench/dut/hart/lsu/dmmu/pm | |||||||
| add wave -noupdate -expand -group lsu -expand -group ptwalker -color Gold /testbench/dut/hart/lsu/hptw/genblk1/WalkerState | add wave -noupdate -expand -group lsu -expand -group ptwalker -color Gold /testbench/dut/hart/lsu/hptw/genblk1/WalkerState | ||||||
| add wave -noupdate -expand -group lsu -expand -group ptwalker /testbench/dut/hart/lsu/hptw/PCF | add wave -noupdate -expand -group lsu -expand -group ptwalker /testbench/dut/hart/lsu/hptw/PCF | ||||||
| add wave -noupdate -expand -group lsu -expand -group ptwalker /testbench/dut/hart/lsu/hptw/genblk1/TranslationVAdr | add wave -noupdate -expand -group lsu -expand -group ptwalker /testbench/dut/hart/lsu/hptw/genblk1/TranslationVAdr | ||||||
| add wave -noupdate -expand -group lsu -expand -group ptwalker /testbench/dut/hart/lsu/hptw/TranslationPAdr |  | ||||||
| add wave -noupdate -expand -group lsu -expand -group ptwalker /testbench/dut/hart/lsu/hptw/HPTWReadPTE | add wave -noupdate -expand -group lsu -expand -group ptwalker /testbench/dut/hart/lsu/hptw/HPTWReadPTE | ||||||
| add wave -noupdate -expand -group lsu -expand -group ptwalker /testbench/dut/hart/lsu/hptw/PTE | add wave -noupdate -expand -group lsu -expand -group ptwalker /testbench/dut/hart/lsu/hptw/PTE | ||||||
| add wave -noupdate -expand -group lsu -expand -group ptwalker -group types /testbench/dut/hart/lsu/hptw/ITLBMissF | add wave -noupdate -expand -group lsu -expand -group ptwalker -group types /testbench/dut/hart/lsu/hptw/ITLBMissF | ||||||
| @ -414,24 +387,6 @@ add wave -noupdate -expand -group lsu -expand -group ptwalker -group types /test | |||||||
| add wave -noupdate -expand -group lsu -expand -group ptwalker -group types /testbench/dut/hart/lsu/hptw/WalkerInstrPageFaultF | add wave -noupdate -expand -group lsu -expand -group ptwalker -group types /testbench/dut/hart/lsu/hptw/WalkerInstrPageFaultF | ||||||
| add wave -noupdate -expand -group lsu -expand -group ptwalker -group types /testbench/dut/hart/lsu/hptw/WalkerLoadPageFaultM | add wave -noupdate -expand -group lsu -expand -group ptwalker -group types /testbench/dut/hart/lsu/hptw/WalkerLoadPageFaultM | ||||||
| add wave -noupdate -expand -group lsu -expand -group ptwalker -group types /testbench/dut/hart/lsu/hptw/WalkerStorePageFaultM | add wave -noupdate -expand -group lsu -expand -group ptwalker -group types /testbench/dut/hart/lsu/hptw/WalkerStorePageFaultM | ||||||
| add wave -noupdate -group csr -color Gray90 -radix unsigned /testbench/dut/hart/priv/csr/genblk1/counters/genblk1/INSTRET_REGW |  | ||||||
| add wave -noupdate -group csr /testbench/dut/hart/priv/csr/genblk1/counters/genblk1/HPMCOUNTER_REGW |  | ||||||
| add wave -noupdate -group csr -expand -group machine /testbench/dut/hart/priv/csr/genblk1/csrm/MIE_REGW |  | ||||||
| add wave -noupdate -group csr -expand -group machine /testbench/dut/hart/priv/csr/MIP_REGW |  | ||||||
| add wave -noupdate -group csr -expand -group machine /testbench/dut/hart/priv/csr/genblk1/csrm/MSTATUS_REGW |  | ||||||
| add wave -noupdate -group csr -expand -group machine /testbench/dut/hart/priv/csr/genblk1/csrm/MEPC_REGW |  | ||||||
| add wave -noupdate -group csr -expand -group machine /testbench/dut/hart/priv/csr/genblk1/csrm/MTVAL_REGW |  | ||||||
| add wave -noupdate -group csr -expand -group machine /testbench/dut/hart/priv/csr/MTVEC_REGW |  | ||||||
| add wave -noupdate -group csr -expand -group machine /testbench/dut/hart/priv/csr/genblk1/csrm/MCAUSE_REGW |  | ||||||
| add wave -noupdate -group csr -expand -group machine /testbench/dut/hart/priv/csr/genblk1/csrm/MEDELEG_REGW |  | ||||||
| add wave -noupdate -group csr -expand -group machine /testbench/dut/hart/priv/csr/genblk1/csrm/MIDELEG_REGW |  | ||||||
| add wave -noupdate -group csr -expand -group machine -color Brown /testbench/dut/hart/priv/PrivilegeModeW |  | ||||||
| add wave -noupdate -group csr -expand -group supervisor /testbench/dut/hart/priv/csr/STVEC_REGW |  | ||||||
| add wave -noupdate -group csr -expand -group supervisor /testbench/dut/hart/priv/csr/genblk1/csrs/STVAL |  | ||||||
| add wave -noupdate -group csr -expand -group supervisor /testbench/dut/hart/priv/csr/genblk1/csrs/genblk1/SCAUSE_REGW |  | ||||||
| add wave -noupdate -group csr -expand -group supervisor /testbench/dut/hart/priv/csr/genblk1/csrs/SIP_REGW |  | ||||||
| add wave -noupdate -group csr -expand -group supervisor /testbench/dut/hart/priv/csr/genblk1/csrs/SIE_REGW |  | ||||||
| add wave -noupdate -group csr -expand -group supervisor /testbench/dut/hart/priv/csr/genblk1/csrs/SEPC_REGW |  | ||||||
| add wave -noupdate -group itlb /testbench/dut/hart/ifu/immu/TLBWrite | add wave -noupdate -group itlb /testbench/dut/hart/ifu/immu/TLBWrite | ||||||
| add wave -noupdate -group itlb /testbench/dut/hart/ifu/ITLBMissF | add wave -noupdate -group itlb /testbench/dut/hart/ifu/ITLBMissF | ||||||
| add wave -noupdate -group itlb /testbench/dut/hart/ifu/immu/PhysicalAddress | add wave -noupdate -group itlb /testbench/dut/hart/ifu/immu/PhysicalAddress | ||||||
| @ -504,7 +459,6 @@ add wave -noupdate -group UART /testbench/dut/uncore/uart/uart/HADDR | |||||||
| add wave -noupdate -group UART /testbench/dut/uncore/uart/uart/HWRITE | add wave -noupdate -group UART /testbench/dut/uncore/uart/uart/HWRITE | ||||||
| add wave -noupdate -group UART /testbench/dut/uncore/uart/uart/HWDATA | add wave -noupdate -group UART /testbench/dut/uncore/uart/uart/HWDATA | ||||||
| add wave -noupdate -group {debug trace} -expand -group mem -color Yellow /testbench/dut/hart/FlushW | add wave -noupdate -group {debug trace} -expand -group mem -color Yellow /testbench/dut/hart/FlushW | ||||||
| add wave -noupdate -group {debug trace} -expand -group mem /testbench/dut/hart/priv/trap/InstrValidM |  | ||||||
| add wave -noupdate -group {debug trace} -expand -group mem /testbench/checkInstrM | add wave -noupdate -group {debug trace} -expand -group mem /testbench/checkInstrM | ||||||
| add wave -noupdate -group {debug trace} -expand -group mem /testbench/dut/hart/PCM | add wave -noupdate -group {debug trace} -expand -group mem /testbench/dut/hart/PCM | ||||||
| add wave -noupdate -group {debug trace} -expand -group mem /testbench/ExpectedPCM | add wave -noupdate -group {debug trace} -expand -group mem /testbench/ExpectedPCM | ||||||
| @ -518,19 +472,15 @@ add wave -noupdate -group {debug trace} -expand -group wb /testbench/textW | |||||||
| add wave -noupdate -group {pc selection} /testbench/dut/hart/ifu/PCNext2F | add wave -noupdate -group {pc selection} /testbench/dut/hart/ifu/PCNext2F | ||||||
| add wave -noupdate -group {pc selection} /testbench/dut/hart/ifu/PrivilegedNextPCM | add wave -noupdate -group {pc selection} /testbench/dut/hart/ifu/PrivilegedNextPCM | ||||||
| add wave -noupdate -group {pc selection} /testbench/dut/hart/ifu/PrivilegedChangePCM | add wave -noupdate -group {pc selection} /testbench/dut/hart/ifu/PrivilegedChangePCM | ||||||
| add wave -noupdate -group {pc selection} /testbench/dut/hart/priv/PrivilegedNextPCM |  | ||||||
| add wave -noupdate -group {pc selection} /testbench/dut/hart/priv/trap/PrivilegedVectoredTrapVector |  | ||||||
| add wave -noupdate -group {pc selection} /testbench/dut/hart/priv/trap/PrivilegedTrapVector |  | ||||||
| add wave -noupdate /testbench/dut/hart/ifu/PCCorrectE | add wave -noupdate /testbench/dut/hart/ifu/PCCorrectE | ||||||
| add wave -noupdate /testbench/dut/hart/ifu/PCSrcE | add wave -noupdate /testbench/dut/hart/ifu/PCSrcE | ||||||
| add wave -noupdate /testbench/dut/hart/ieu/c/BranchTakenE | add wave -noupdate /testbench/dut/hart/ieu/c/BranchTakenE | ||||||
| add wave -noupdate /testbench/dut/hart/ieu/c/BranchE | add wave -noupdate /testbench/dut/hart/ieu/c/BranchE | ||||||
| add wave -noupdate /testbench/dut/hart/ifu/PCTargetE |  | ||||||
| add wave -noupdate /testbench/dut/hart/ifu/PCLinkE | add wave -noupdate /testbench/dut/hart/ifu/PCLinkE | ||||||
| add wave -noupdate /testbench/dut/hart/lsu/DCtoAHBSizeM | add wave -noupdate /testbench/dut/hart/lsu/DCtoAHBSizeM | ||||||
| TreeUpdate [SetDefaultTree] | TreeUpdate [SetDefaultTree] | ||||||
| WaveRestoreCursors {{Cursor 23} {14157765 ns} 0} {{Cursor 3} {29725 ns} 1} | WaveRestoreCursors {{Cursor 23} {14157765 ns} 0} {{Cursor 3} {29725 ns} 1} {{Cursor 5} {163846 ns} 0} | ||||||
| quietly wave cursor active 1 | quietly wave cursor active 3 | ||||||
| configure wave -namecolwidth 250 | configure wave -namecolwidth 250 | ||||||
| configure wave -valuecolwidth 314 | configure wave -valuecolwidth 314 | ||||||
| configure wave -justifyvalue left | configure wave -justifyvalue left | ||||||
| @ -545,4 +495,4 @@ configure wave -griddelta 40 | |||||||
| configure wave -timeline 0 | configure wave -timeline 0 | ||||||
| configure wave -timelineunits ns | configure wave -timelineunits ns | ||||||
| update | update | ||||||
| WaveRestoreZoom {14157667 ns} {14157811 ns} | WaveRestoreZoom {163681 ns} {164021 ns} | ||||||
|  | |||||||
| @ -186,7 +186,8 @@ module lsu | |||||||
| 	  STATE_T0_READY: if(DTLBMissM | ITLBMissF) InterlockStall = 1'b1; | 	  STATE_T0_READY: if(DTLBMissM | ITLBMissF) InterlockStall = 1'b1; | ||||||
| 	  STATE_T3_DTLB_MISS: if (~WalkerPageFaultM) InterlockStall = 1'b1; | 	  STATE_T3_DTLB_MISS: if (~WalkerPageFaultM) InterlockStall = 1'b1; | ||||||
| 	  STATE_T4_ITLB_MISS: if (~WalkerInstrPageFaultRaw) InterlockStall = 1'b1; | 	  STATE_T4_ITLB_MISS: if (~WalkerInstrPageFaultRaw) InterlockStall = 1'b1; | ||||||
| 	  STATE_T5_ITLB_MISS: if (~WalkerInstrPageFaultRaw) InterlockStall = 1'b1; | 	  STATE_T5_ITLB_MISS: InterlockStall = 1'b1; | ||||||
|  | 	  //STATE_T0_FAULT_REPLAY: if (~WalkerInstrPageFaultF) InterlockStall = 1'b1;
 | ||||||
| 	  STATE_T7_DITLB_MISS: if (~WalkerPageFaultM) InterlockStall = 1'b1; | 	  STATE_T7_DITLB_MISS: if (~WalkerPageFaultM) InterlockStall = 1'b1; | ||||||
| 	  default: InterlockStall = 1'b0; | 	  default: InterlockStall = 1'b0; | ||||||
| 	endcase | 	endcase | ||||||
| @ -194,7 +195,7 @@ module lsu | |||||||
|    |    | ||||||
|    |    | ||||||
|   // When replaying CPU memory request after PTW select the IEUAdrM for correct address.
 |   // When replaying CPU memory request after PTW select the IEUAdrM for correct address.
 | ||||||
|   assign SelReplayCPURequest = NextState == STATE_T0_REPLAY; |   assign SelReplayCPURequest = (NextState == STATE_T0_REPLAY) | (NextState == STATE_T0_FAULT_REPLAY); | ||||||
|   assign SelHPTW = (CurrState == STATE_T3_DTLB_MISS) | (CurrState == STATE_T4_ITLB_MISS) | |   assign SelHPTW = (CurrState == STATE_T3_DTLB_MISS) | (CurrState == STATE_T4_ITLB_MISS) | | ||||||
| 				  (CurrState == STATE_T5_ITLB_MISS) | (CurrState == STATE_T7_DITLB_MISS); | 				  (CurrState == STATE_T5_ITLB_MISS) | (CurrState == STATE_T7_DITLB_MISS); | ||||||
|   assign IgnoreRequest = CurrState == STATE_T0_READY & (ITLBMissF | DTLBMissM); |   assign IgnoreRequest = CurrState == STATE_T0_READY & (ITLBMissF | DTLBMissM); | ||||||
|  | |||||||
| @ -199,7 +199,7 @@ module hptw | |||||||
| //	    LEVEL0: if (ValidLeafPTE) 	NextWalkerState = LEAF;
 | //	    LEVEL0: if (ValidLeafPTE) 	NextWalkerState = LEAF;
 | ||||||
| //				else 				NextWalkerState = FAULT;
 | //				else 				NextWalkerState = FAULT;
 | ||||||
| 	    LEAF:                       NextWalkerState = IDLE; // updates TLB
 | 	    LEAF:                       NextWalkerState = IDLE; // updates TLB
 | ||||||
| 	    FAULT: if (ITLBMissF & AnyCPUReqM) NextWalkerState = FAULT; | 	    FAULT: if (ITLBMissF & AnyCPUReqM) NextWalkerState = FAULT; /// **** BUG: Stays in fault 1 cycle longer than it should.
 | ||||||
|  	                        else NextWalkerState = IDLE; |  	                        else NextWalkerState = IDLE; | ||||||
| 	    default: begin | 	    default: begin | ||||||
| 	      // synthesis translate_off
 | 	      // synthesis translate_off
 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user