mirror of
https://github.com/openhwgroup/cvw
synced 2025-02-11 06:05:49 +00:00
Removed lsuArb and placed remaining logic in lsu.sv.
Removed after itlb walk signal as the dcache no longer has any need for this. Formated lsu.sv
This commit is contained in:
parent
019e300a14
commit
30770db4ac
2
wally-pipelined/src/cache/dcache.sv
vendored
2
wally-pipelined/src/cache/dcache.sv
vendored
@ -53,7 +53,6 @@ module dcache
|
|||||||
input logic CacheableM,
|
input logic CacheableM,
|
||||||
// from ptw
|
// from ptw
|
||||||
input logic IgnoreRequest,
|
input logic IgnoreRequest,
|
||||||
output logic MemAfterIWalkDone,
|
|
||||||
// ahb side
|
// ahb side
|
||||||
(* mark_debug = "true" *)output logic [`PA_BITS-1:0] AHBPAdr, // to ahb
|
(* mark_debug = "true" *)output logic [`PA_BITS-1:0] AHBPAdr, // to ahb
|
||||||
(* mark_debug = "true" *)output logic AHBRead,
|
(* mark_debug = "true" *)output logic AHBRead,
|
||||||
@ -358,7 +357,6 @@ module dcache
|
|||||||
.CommittedM,
|
.CommittedM,
|
||||||
.DCacheMiss,
|
.DCacheMiss,
|
||||||
.DCacheAccess,
|
.DCacheAccess,
|
||||||
.MemAfterIWalkDone,
|
|
||||||
.AHBRead,
|
.AHBRead,
|
||||||
.AHBWrite,
|
.AHBWrite,
|
||||||
.SelAdrM,
|
.SelAdrM,
|
||||||
|
3
wally-pipelined/src/cache/dcachefsm.sv
vendored
3
wally-pipelined/src/cache/dcachefsm.sv
vendored
@ -53,8 +53,6 @@ module dcachefsm
|
|||||||
// counter outputs
|
// counter outputs
|
||||||
output logic DCacheMiss,
|
output logic DCacheMiss,
|
||||||
output logic DCacheAccess,
|
output logic DCacheAccess,
|
||||||
// hptw outputs
|
|
||||||
output logic MemAfterIWalkDone,
|
|
||||||
// Bus outputs
|
// Bus outputs
|
||||||
output logic AHBRead,
|
output logic AHBRead,
|
||||||
output logic AHBWrite,
|
output logic AHBWrite,
|
||||||
@ -137,7 +135,6 @@ module dcachefsm
|
|||||||
SelUncached = 1'b0;
|
SelUncached = 1'b0;
|
||||||
SelEvict = 1'b0;
|
SelEvict = 1'b0;
|
||||||
LRUWriteEn = 1'b0;
|
LRUWriteEn = 1'b0;
|
||||||
MemAfterIWalkDone = 1'b0;
|
|
||||||
SelFlush = 1'b0;
|
SelFlush = 1'b0;
|
||||||
FlushAdrCntEn = 1'b0;
|
FlushAdrCntEn = 1'b0;
|
||||||
FlushWayCntEn = 1'b0;
|
FlushWayCntEn = 1'b0;
|
||||||
|
@ -30,116 +30,114 @@
|
|||||||
// *** Ross Thompson amo misalignment check?
|
// *** Ross Thompson amo misalignment check?
|
||||||
module lsu
|
module lsu
|
||||||
(
|
(
|
||||||
input logic clk, reset,
|
input logic clk, reset,
|
||||||
input logic StallM, FlushM, StallW, FlushW,
|
input logic StallM, FlushM, StallW, FlushW,
|
||||||
output logic LSUStall,
|
output logic LSUStall,
|
||||||
// Memory Stage
|
// Memory Stage
|
||||||
|
|
||||||
// connected to cpu (controls)
|
// connected to cpu (controls)
|
||||||
input logic [1:0] MemRWM,
|
input logic [1:0] MemRWM,
|
||||||
input logic [2:0] Funct3M,
|
input logic [2:0] Funct3M,
|
||||||
input logic [6:0] Funct7M,
|
input logic [6:0] Funct7M,
|
||||||
input logic [1:0] AtomicM,
|
input logic [1:0] AtomicM,
|
||||||
input logic ExceptionM,
|
input logic ExceptionM,
|
||||||
input logic PendingInterruptM,
|
input logic PendingInterruptM,
|
||||||
input logic FlushDCacheM,
|
input logic FlushDCacheM,
|
||||||
output logic CommittedM,
|
output logic CommittedM,
|
||||||
output logic SquashSCW,
|
output logic SquashSCW,
|
||||||
output logic DCacheMiss,
|
output logic DCacheMiss,
|
||||||
output logic DCacheAccess,
|
output logic DCacheAccess,
|
||||||
|
|
||||||
// address and write data
|
// address and write data
|
||||||
input logic [`XLEN-1:0] IEUAdrE,
|
input logic [`XLEN-1:0] IEUAdrE,
|
||||||
output logic [`XLEN-1:0] IEUAdrM,
|
output logic [`XLEN-1:0] IEUAdrM,
|
||||||
input logic [`XLEN-1:0] WriteDataM,
|
input logic [`XLEN-1:0] WriteDataM,
|
||||||
output logic [`XLEN-1:0] ReadDataM,
|
output logic [`XLEN-1:0] ReadDataM,
|
||||||
|
|
||||||
// cpu privilege
|
// cpu privilege
|
||||||
input logic [1:0] PrivilegeModeW,
|
input logic [1:0] PrivilegeModeW,
|
||||||
input logic DTLBFlushM,
|
input logic DTLBFlushM,
|
||||||
// faults
|
// faults
|
||||||
output logic DTLBLoadPageFaultM, DTLBStorePageFaultM,
|
output logic DTLBLoadPageFaultM, DTLBStorePageFaultM,
|
||||||
output logic LoadMisalignedFaultM, LoadAccessFaultM,
|
output logic LoadMisalignedFaultM, LoadAccessFaultM,
|
||||||
// cpu hazard unit (trap)
|
// cpu hazard unit (trap)
|
||||||
output logic StoreMisalignedFaultM, StoreAccessFaultM,
|
output logic StoreMisalignedFaultM, StoreAccessFaultM,
|
||||||
|
|
||||||
// connect to ahb
|
// connect to ahb
|
||||||
output logic [`PA_BITS-1:0] DCtoAHBPAdrM,
|
output logic [`PA_BITS-1:0] DCtoAHBPAdrM,
|
||||||
output logic DCtoAHBReadM,
|
output logic DCtoAHBReadM,
|
||||||
output logic DCtoAHBWriteM,
|
output logic DCtoAHBWriteM,
|
||||||
input logic DCfromAHBAck,
|
input logic DCfromAHBAck,
|
||||||
input logic [`XLEN-1:0] DCfromAHBReadData,
|
input logic [`XLEN-1:0] DCfromAHBReadData,
|
||||||
output logic [`XLEN-1:0] DCtoAHBWriteData,
|
output logic [`XLEN-1:0] DCtoAHBWriteData,
|
||||||
output logic [2:0] DCtoAHBSizeM,
|
output logic [2:0] DCtoAHBSizeM,
|
||||||
|
|
||||||
// mmu management
|
// mmu management
|
||||||
|
|
||||||
// page table walker
|
// page table walker
|
||||||
input logic [`XLEN-1:0] SATP_REGW, // from csr
|
input logic [`XLEN-1:0] SATP_REGW, // from csr
|
||||||
input logic STATUS_MXR, STATUS_SUM, STATUS_MPRV,
|
input logic STATUS_MXR, STATUS_SUM, STATUS_MPRV,
|
||||||
input logic [1:0] STATUS_MPP,
|
input logic [1:0] STATUS_MPP,
|
||||||
|
|
||||||
input logic [`XLEN-1:0] PCF,
|
input logic [`XLEN-1:0] PCF,
|
||||||
input logic ITLBMissF,
|
input logic ITLBMissF,
|
||||||
output logic [`XLEN-1:0] PTE,
|
output logic [`XLEN-1:0] PTE,
|
||||||
output logic [1:0] PageType,
|
output logic [1:0] PageType,
|
||||||
output logic ITLBWriteF,
|
output logic ITLBWriteF,
|
||||||
output logic WalkerInstrPageFaultF,
|
output logic WalkerInstrPageFaultF,
|
||||||
output logic WalkerLoadPageFaultM,
|
output logic WalkerLoadPageFaultM,
|
||||||
output logic WalkerStorePageFaultM,
|
output logic WalkerStorePageFaultM,
|
||||||
|
|
||||||
input var logic [7:0] PMPCFG_ARRAY_REGW[`PMP_ENTRIES-1:0],
|
input var logic [7:0] PMPCFG_ARRAY_REGW[`PMP_ENTRIES-1:0],
|
||||||
input var logic [`XLEN-1:0] PMPADDR_ARRAY_REGW[`PMP_ENTRIES-1:0] // *** this one especially has a large note attached to it in pmpchecker.
|
input var logic [`XLEN-1:0] PMPADDR_ARRAY_REGW[`PMP_ENTRIES-1:0] // *** this one especially has a large note attached to it in pmpchecker.
|
||||||
);
|
);
|
||||||
|
|
||||||
logic DTLBPageFaultM;
|
logic DTLBPageFaultM;
|
||||||
logic DataMisalignedM;
|
|
||||||
|
|
||||||
|
|
||||||
logic [`PA_BITS-1:0] MemPAdrM; // from mmu to dcache
|
logic [`PA_BITS-1:0] MemPAdrM; // from mmu to dcache
|
||||||
|
|
||||||
logic DTLBMissM;
|
logic DTLBMissM;
|
||||||
logic DTLBWriteM;
|
logic DTLBWriteM;
|
||||||
logic HPTWStall;
|
logic HPTWStall;
|
||||||
logic [`PA_BITS-1:0] TranslationPAdr;
|
logic [`PA_BITS-1:0] TranslationPAdr;
|
||||||
logic HPTWRead;
|
logic HPTWRead;
|
||||||
logic [1:0] MemRWMtoDCache;
|
logic [1:0] MemRWMtoDCache;
|
||||||
logic [1:0] MemRWMtoLRSC;
|
logic [1:0] MemRWMtoLRSC;
|
||||||
logic [2:0] Funct3MtoDCache;
|
logic [2:0] Funct3MtoDCache;
|
||||||
logic [1:0] AtomicMtoDCache;
|
logic [1:0] AtomicMtoDCache;
|
||||||
logic [`PA_BITS-1:0] MemPAdrNoTranslate;
|
logic [`PA_BITS-1:0] MemPAdrNoTranslate;
|
||||||
logic [11:0] MemAdrE, MemAdrE_RENAME;
|
logic [11:0] MemAdrE, MemAdrE_RENAME;
|
||||||
logic StallWtoDCache;
|
logic StallWtoDCache;
|
||||||
logic MemReadM;
|
logic MemReadM;
|
||||||
logic DataMisalignedMfromDCache;
|
logic DataMisalignedM;
|
||||||
logic DisableTranslation; // used to stop intermediate PTE physical addresses being saved to TLB.
|
logic DCacheStall;
|
||||||
logic DCacheStall;
|
|
||||||
|
|
||||||
logic CacheableM;
|
logic CacheableM;
|
||||||
logic CacheableMtoDCache;
|
logic CacheableMtoDCache;
|
||||||
logic SelPTW;
|
logic SelPTW;
|
||||||
|
|
||||||
logic CommittedMfromDCache;
|
logic CommittedMfromDCache;
|
||||||
logic PendingInterruptMtoDCache;
|
logic PendingInterruptMtoDCache;
|
||||||
// logic FlushWtoDCache;
|
// logic FlushWtoDCache;
|
||||||
logic WalkerPageFaultM;
|
logic WalkerPageFaultM;
|
||||||
|
|
||||||
logic AnyCPUReqM;
|
logic AnyCPUReqM;
|
||||||
logic MemAfterIWalkDone;
|
logic MemAfterIWalkDone;
|
||||||
|
|
||||||
typedef enum {STATE_T0_READY,
|
typedef enum {STATE_T0_READY,
|
||||||
STATE_T0_REPLAY,
|
STATE_T0_REPLAY,
|
||||||
STATE_T0_FAULT_REPLAY,
|
STATE_T0_FAULT_REPLAY,
|
||||||
STATE_T3_DTLB_MISS,
|
STATE_T3_DTLB_MISS,
|
||||||
STATE_T4_ITLB_MISS,
|
STATE_T4_ITLB_MISS,
|
||||||
STATE_T5_ITLB_MISS,
|
STATE_T5_ITLB_MISS,
|
||||||
STATE_T7_DITLB_MISS} statetype;
|
STATE_T7_DITLB_MISS} statetype;
|
||||||
|
|
||||||
statetype CurrState, NextState;
|
statetype CurrState, NextState;
|
||||||
logic InterlockStall;
|
logic InterlockStall;
|
||||||
logic SelReplayCPURequest;
|
logic SelReplayCPURequest;
|
||||||
logic WalkerInstrPageFaultRaw;
|
logic WalkerInstrPageFaultRaw;
|
||||||
logic IgnoreRequest;
|
logic IgnoreRequest;
|
||||||
|
|
||||||
|
|
||||||
assign AnyCPUReqM = (|MemRWM) | (|AtomicM);
|
assign AnyCPUReqM = (|MemRWM) | (|AtomicM);
|
||||||
@ -221,14 +219,14 @@ module lsu
|
|||||||
end // always_comb
|
end // always_comb
|
||||||
|
|
||||||
// signal to CPU it needs to wait on HPTW.
|
// signal to CPU it needs to wait on HPTW.
|
||||||
/* -----\/----- EXCLUDED -----\/-----
|
/* -----\/----- EXCLUDED -----\/-----
|
||||||
// this code has a problem with imperas64mmu as it reads in an invalid uninitalized instruction. InterlockStall becomes x and it propagates
|
// this code has a problem with imperas64mmu as it reads in an invalid uninitalized instruction. InterlockStall becomes x and it propagates
|
||||||
// everywhere. The case statement below implements the same logic but any x on the inputs will resolve to 0.
|
// everywhere. The case statement below implements the same logic but any x on the inputs will resolve to 0.
|
||||||
assign InterlockStall = (CurrState == STATE_T0_READY & (DTLBMissM | ITLBMissF)) |
|
assign InterlockStall = (CurrState == STATE_T0_READY & (DTLBMissM | ITLBMissF)) |
|
||||||
(CurrState == STATE_T3_DTLB_MISS & ~WalkerPageFaultM) | (CurrState == STATE_T4_ITLB_MISS & ~WalkerInstrPageFaultRaw) |
|
(CurrState == STATE_T3_DTLB_MISS & ~WalkerPageFaultM) | (CurrState == STATE_T4_ITLB_MISS & ~WalkerInstrPageFaultRaw) |
|
||||||
(CurrState == STATE_T5_ITLB_MISS & ~WalkerInstrPageFaultRaw) | (CurrState == STATE_T7_DITLB_MISS & ~WalkerPageFaultM);
|
(CurrState == STATE_T5_ITLB_MISS & ~WalkerInstrPageFaultRaw) | (CurrState == STATE_T7_DITLB_MISS & ~WalkerPageFaultM);
|
||||||
|
|
||||||
-----/\----- EXCLUDED -----/\----- */
|
-----/\----- EXCLUDED -----/\----- */
|
||||||
|
|
||||||
always_comb begin
|
always_comb begin
|
||||||
InterlockStall = 1'b0;
|
InterlockStall = 1'b0;
|
||||||
@ -257,64 +255,61 @@ module lsu
|
|||||||
// *** add generate to conditionally create hptw, lsuArb, and mmu
|
// *** add generate to conditionally create hptw, lsuArb, and mmu
|
||||||
// based on `MEM_VIRTMEM
|
// based on `MEM_VIRTMEM
|
||||||
hptw hptw(.clk(clk),
|
hptw hptw(.clk(clk),
|
||||||
.reset(reset),
|
.reset(reset),
|
||||||
.SATP_REGW(SATP_REGW),
|
.SATP_REGW(SATP_REGW),
|
||||||
.PCF(PCF),
|
.PCF(PCF),
|
||||||
.IEUAdrM(IEUAdrM),
|
.IEUAdrM(IEUAdrM),
|
||||||
.ITLBMissF(ITLBMissF & ~PendingInterruptM),
|
.ITLBMissF(ITLBMissF & ~PendingInterruptM),
|
||||||
.DTLBMissM(DTLBMissM & ~PendingInterruptM),
|
.DTLBMissM(DTLBMissM & ~PendingInterruptM),
|
||||||
.MemRWM(MemRWM),
|
.MemRWM(MemRWM),
|
||||||
.PTE(PTE),
|
.PTE(PTE),
|
||||||
.PageType,
|
.PageType,
|
||||||
.ITLBWriteF(ITLBWriteF),
|
.ITLBWriteF(ITLBWriteF),
|
||||||
.DTLBWriteM(DTLBWriteM),
|
.DTLBWriteM(DTLBWriteM),
|
||||||
.HPTWReadPTE(ReadDataM),
|
.HPTWReadPTE(ReadDataM),
|
||||||
.DCacheStall(DCacheStall),
|
.DCacheStall(DCacheStall),
|
||||||
.TranslationPAdr,
|
.TranslationPAdr,
|
||||||
.HPTWRead(HPTWRead),
|
.HPTWRead(HPTWRead),
|
||||||
.HPTWStall,
|
.AnyCPUReqM,
|
||||||
.AnyCPUReqM,
|
.WalkerInstrPageFaultF(WalkerInstrPageFaultRaw),
|
||||||
.MemAfterIWalkDone,
|
.WalkerLoadPageFaultM(WalkerLoadPageFaultM),
|
||||||
.WalkerInstrPageFaultF(WalkerInstrPageFaultRaw),
|
.WalkerStorePageFaultM(WalkerStorePageFaultM));
|
||||||
.WalkerLoadPageFaultM(WalkerLoadPageFaultM),
|
|
||||||
.WalkerStorePageFaultM(WalkerStorePageFaultM));
|
|
||||||
|
|
||||||
assign LSUStall = DCacheStall | InterlockStall;
|
assign LSUStall = DCacheStall | InterlockStall;
|
||||||
|
|
||||||
assign WalkerPageFaultM = WalkerStorePageFaultM | WalkerLoadPageFaultM;
|
assign WalkerPageFaultM = WalkerStorePageFaultM | WalkerLoadPageFaultM;
|
||||||
|
|
||||||
// arbiter between IEU and hptw
|
// arbiter between IEU and hptw
|
||||||
lsuArb arbiter(.clk(clk),
|
logic [2:0] PTWSize;
|
||||||
// HPTW connection
|
logic [`PA_BITS-1:0] TranslationPAdrM;
|
||||||
.SelPTW,
|
logic [`XLEN+1:0] IEUAdrMExt;
|
||||||
.HPTWRead(HPTWRead),
|
|
||||||
.TranslationPAdrE(TranslationPAdr),
|
// multiplex the outputs to LSU
|
||||||
// CPU connection
|
assign MemRWMtoLRSC = SelPTW ? {HPTWRead, 1'b0} : MemRWM;
|
||||||
.MemRWM(MemRWM),
|
|
||||||
.Funct3M(Funct3M),
|
generate
|
||||||
.AtomicM(AtomicM),
|
assign PTWSize = (`XLEN==32 ? 3'b010 : 3'b011); // 32 or 64-bit access from htpw
|
||||||
.IEUAdrM(IEUAdrM),
|
endgenerate
|
||||||
.IEUAdrE(IEUAdrE[11:0]),
|
mux2 #(3) sizemux(Funct3M, PTWSize, SelPTW, Funct3MtoDCache);
|
||||||
.CommittedM(CommittedM),
|
|
||||||
.PendingInterruptM(PendingInterruptM),
|
// this is for the d cache SRAM.
|
||||||
.StallW(StallW),
|
flop #(`PA_BITS) TranslationPAdrMReg(clk, TranslationPAdr, TranslationPAdrM); // delay TranslationPAdrM by a cycle
|
||||||
.DataMisalignedM(DataMisalignedM),
|
|
||||||
// DCACHE
|
assign AtomicMtoDCache = SelPTW ? 2'b00 : AtomicM;
|
||||||
.DisableTranslation(DisableTranslation),
|
assign IEUAdrMExt = {2'b00, IEUAdrM};
|
||||||
.MemRWMtoLRSC(MemRWMtoLRSC),
|
assign MemPAdrNoTranslate = SelPTW ? TranslationPAdrM : IEUAdrMExt[`PA_BITS-1:0];
|
||||||
.Funct3MtoDCache(Funct3MtoDCache),
|
assign MemAdrE = SelPTW ? TranslationPAdr[11:0] : IEUAdrE[11:0];
|
||||||
.AtomicMtoDCache(AtomicMtoDCache),
|
assign StallWtoDCache = SelPTW ? 1'b0 : StallW;
|
||||||
.MemPAdrNoTranslate(MemPAdrNoTranslate),
|
// always block interrupts when using the hardware page table walker.
|
||||||
.MemAdrE(MemAdrE),
|
assign CommittedM = SelPTW ? 1'b1 : CommittedMfromDCache;
|
||||||
.StallWtoDCache(StallWtoDCache),
|
|
||||||
.DataMisalignedMfromDCache(DataMisalignedMfromDCache),
|
|
||||||
.CommittedMfromDCache(CommittedMfromDCache),
|
assign PendingInterruptMtoDCache = SelPTW ? 1'b0 : PendingInterruptM;
|
||||||
.PendingInterruptMtoDCache(PendingInterruptMtoDCache),
|
|
||||||
.DCacheStall(DCacheStall));
|
|
||||||
|
|
||||||
mmu #(.TLB_ENTRIES(`DTLB_ENTRIES), .IMMU(0))
|
mmu #(.TLB_ENTRIES(`DTLB_ENTRIES), .IMMU(0))
|
||||||
dmmu(.clk, .reset, .SATP_REGW, .STATUS_MXR, .STATUS_SUM, .STATUS_MPRV, .STATUS_MPP,
|
dmmu(.clk, .reset, .SATP_REGW, .STATUS_MXR, .STATUS_SUM, .STATUS_MPRV, .STATUS_MPP,
|
||||||
.PrivilegeModeW, .DisableTranslation(DisableTranslation),
|
.PrivilegeModeW, .DisableTranslation(SelPTW),
|
||||||
.PAdr(MemPAdrNoTranslate),
|
.PAdr(MemPAdrNoTranslate),
|
||||||
.VAdr(IEUAdrM),
|
.VAdr(IEUAdrM),
|
||||||
.Size(Funct3MtoDCache[1:0]),
|
.Size(Funct3MtoDCache[1:0]),
|
||||||
@ -353,15 +348,15 @@ module lsu
|
|||||||
// Determine if an Unaligned access is taking place
|
// Determine if an Unaligned access is taking place
|
||||||
always_comb
|
always_comb
|
||||||
case(Funct3MtoDCache[1:0])
|
case(Funct3MtoDCache[1:0])
|
||||||
2'b00: DataMisalignedMfromDCache = 0; // lb, sb, lbu
|
2'b00: DataMisalignedM = 0; // lb, sb, lbu
|
||||||
2'b01: DataMisalignedMfromDCache = MemPAdrNoTranslate[0]; // lh, sh, lhu
|
2'b01: DataMisalignedM = MemPAdrNoTranslate[0]; // lh, sh, lhu
|
||||||
2'b10: DataMisalignedMfromDCache = MemPAdrNoTranslate[1] | MemPAdrNoTranslate[0]; // lw, sw, flw, fsw, lwu
|
2'b10: DataMisalignedM = MemPAdrNoTranslate[1] | MemPAdrNoTranslate[0]; // lw, sw, flw, fsw, lwu
|
||||||
2'b11: DataMisalignedMfromDCache = |MemPAdrNoTranslate[2:0]; // ld, sd, fld, fsd
|
2'b11: DataMisalignedM = |MemPAdrNoTranslate[2:0]; // ld, sd, fld, fsd
|
||||||
endcase
|
endcase
|
||||||
|
|
||||||
// Determine if address is valid
|
// Determine if address is valid
|
||||||
assign LoadMisalignedFaultM = DataMisalignedMfromDCache & MemRWMtoLRSC[1];
|
assign LoadMisalignedFaultM = DataMisalignedM & MemRWMtoLRSC[1];
|
||||||
assign StoreMisalignedFaultM = DataMisalignedMfromDCache & MemRWMtoLRSC[0];
|
assign StoreMisalignedFaultM = DataMisalignedM & MemRWMtoLRSC[0];
|
||||||
|
|
||||||
// conditional
|
// conditional
|
||||||
// 1. ram // controlled by `MEM_DTIM
|
// 1. ram // controlled by `MEM_DTIM
|
||||||
@ -370,37 +365,36 @@ module lsu
|
|||||||
assign MemAdrE_RENAME = SelReplayCPURequest ? IEUAdrM[11:0] : MemAdrE[11:0];
|
assign MemAdrE_RENAME = SelReplayCPURequest ? IEUAdrM[11:0] : MemAdrE[11:0];
|
||||||
|
|
||||||
dcache dcache(.clk(clk),
|
dcache dcache(.clk(clk),
|
||||||
.reset(reset),
|
.reset(reset),
|
||||||
.StallWtoDCache(StallWtoDCache),
|
.StallWtoDCache(StallWtoDCache),
|
||||||
.MemRWM(MemRWMtoDCache),
|
.MemRWM(MemRWMtoDCache),
|
||||||
.Funct3M(Funct3MtoDCache),
|
.Funct3M(Funct3MtoDCache),
|
||||||
.Funct7M(Funct7M),
|
.Funct7M(Funct7M),
|
||||||
.FlushDCacheM,
|
.FlushDCacheM,
|
||||||
.AtomicM(AtomicMtoDCache),
|
.AtomicM(AtomicMtoDCache),
|
||||||
.MemAdrE(MemAdrE_RENAME),
|
.MemAdrE(MemAdrE_RENAME),
|
||||||
.MemPAdrM(MemPAdrM),
|
.MemPAdrM(MemPAdrM),
|
||||||
.VAdr(IEUAdrM[11:0]), // this will be removed once the dcache hptw interlock is removed.
|
.VAdr(IEUAdrM[11:0]), // this will be removed once the dcache hptw interlock is removed.
|
||||||
.WriteDataM(WriteDataM),
|
.WriteDataM(WriteDataM),
|
||||||
.ReadDataM(ReadDataM),
|
.ReadDataM(ReadDataM),
|
||||||
.DCacheStall(DCacheStall),
|
.DCacheStall(DCacheStall),
|
||||||
.CommittedM(CommittedMfromDCache),
|
.CommittedM(CommittedMfromDCache),
|
||||||
.DCacheMiss,
|
.DCacheMiss,
|
||||||
.DCacheAccess,
|
.DCacheAccess,
|
||||||
.ExceptionM(ExceptionM),
|
.ExceptionM(ExceptionM),
|
||||||
.IgnoreRequest,
|
.IgnoreRequest,
|
||||||
.PendingInterruptM(PendingInterruptMtoDCache),
|
.PendingInterruptM(PendingInterruptMtoDCache),
|
||||||
.CacheableM(CacheableMtoDCache),
|
.CacheableM(CacheableMtoDCache),
|
||||||
.MemAfterIWalkDone,
|
|
||||||
|
|
||||||
// AHB connection
|
// AHB connection
|
||||||
.AHBPAdr(DCtoAHBPAdrM),
|
.AHBPAdr(DCtoAHBPAdrM),
|
||||||
.AHBRead(DCtoAHBReadM),
|
.AHBRead(DCtoAHBReadM),
|
||||||
.AHBWrite(DCtoAHBWriteM),
|
.AHBWrite(DCtoAHBWriteM),
|
||||||
.AHBAck(DCfromAHBAck),
|
.AHBAck(DCfromAHBAck),
|
||||||
.HWDATA(DCtoAHBWriteData),
|
.HWDATA(DCtoAHBWriteData),
|
||||||
.HRDATA(DCfromAHBReadData),
|
.HRDATA(DCfromAHBReadData),
|
||||||
.DCtoAHBSizeM
|
.DCtoAHBSizeM
|
||||||
);
|
);
|
||||||
|
|
||||||
endmodule
|
endmodule
|
||||||
|
|
||||||
|
@ -1,105 +0,0 @@
|
|||||||
///////////////////////////////////////////
|
|
||||||
// lsuArb.sv
|
|
||||||
//
|
|
||||||
// Written: Ross THompson and Kip Macsai-Goren
|
|
||||||
// Modified: kmacsaigoren@hmc.edu June 23, 2021
|
|
||||||
//
|
|
||||||
// Purpose: LSU arbiter between the CPU's demand request for data memory and
|
|
||||||
// the page table walker
|
|
||||||
//
|
|
||||||
// A component of the Wally configurable RISC-V project.
|
|
||||||
//
|
|
||||||
// Copyright (C) 2021 Harvey Mudd College & Oklahoma State University
|
|
||||||
//
|
|
||||||
// Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation
|
|
||||||
// files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy,
|
|
||||||
// modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software
|
|
||||||
// is furnished to do so, subject to the following conditions:
|
|
||||||
//
|
|
||||||
// The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
|
|
||||||
//
|
|
||||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
|
|
||||||
// OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
|
|
||||||
// BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT
|
|
||||||
// OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
///////////////////////////////////////////
|
|
||||||
|
|
||||||
`include "wally-config.vh"
|
|
||||||
|
|
||||||
module lsuArb
|
|
||||||
(input logic clk,
|
|
||||||
|
|
||||||
// from page table walker
|
|
||||||
input logic SelPTW,
|
|
||||||
input logic HPTWRead,
|
|
||||||
input logic [`PA_BITS-1:0] TranslationPAdrE,
|
|
||||||
|
|
||||||
// from CPU
|
|
||||||
input logic [1:0] MemRWM,
|
|
||||||
input logic [2:0] Funct3M,
|
|
||||||
input logic [1:0] AtomicM,
|
|
||||||
input logic [`XLEN-1:0] IEUAdrM,
|
|
||||||
input logic [11:0] IEUAdrE,
|
|
||||||
input logic StallW,
|
|
||||||
input logic PendingInterruptM,
|
|
||||||
// to CPU
|
|
||||||
output logic DataMisalignedM,
|
|
||||||
output logic CommittedM,
|
|
||||||
//output logic LSUStall,
|
|
||||||
|
|
||||||
// to D Cache
|
|
||||||
output logic DisableTranslation,
|
|
||||||
output logic [1:0] MemRWMtoLRSC,
|
|
||||||
output logic [2:0] Funct3MtoDCache,
|
|
||||||
output logic [1:0] AtomicMtoDCache,
|
|
||||||
output logic [`PA_BITS-1:0] MemPAdrNoTranslate, // THis name is very bad. need a better name. This is the raw address from either the ieu or the hptw.
|
|
||||||
output logic [11:0] MemAdrE,
|
|
||||||
output logic StallWtoDCache,
|
|
||||||
output logic PendingInterruptMtoDCache,
|
|
||||||
|
|
||||||
|
|
||||||
// from D Cache
|
|
||||||
input logic CommittedMfromDCache,
|
|
||||||
input logic DataMisalignedMfromDCache,
|
|
||||||
input logic DCacheStall
|
|
||||||
|
|
||||||
);
|
|
||||||
|
|
||||||
logic [2:0] PTWSize;
|
|
||||||
logic [`PA_BITS-1:0] TranslationPAdrM;
|
|
||||||
logic [`XLEN+1:0] IEUAdrMExt;
|
|
||||||
|
|
||||||
// multiplex the outputs to LSU
|
|
||||||
assign DisableTranslation = SelPTW; // change names between SelPTW would be confusing in DTLB.
|
|
||||||
assign MemRWMtoLRSC = SelPTW ? {HPTWRead, 1'b0} : MemRWM;
|
|
||||||
|
|
||||||
generate
|
|
||||||
assign PTWSize = (`XLEN==32 ? 3'b010 : 3'b011); // 32 or 64-bit access from htpw
|
|
||||||
endgenerate
|
|
||||||
mux2 #(3) sizemux(Funct3M, PTWSize, SelPTW, Funct3MtoDCache);
|
|
||||||
|
|
||||||
// this is for the d cache SRAM.
|
|
||||||
flop #(`PA_BITS) TranslationPAdrMReg(clk, TranslationPAdrE, TranslationPAdrM); // delay TranslationPAdrM by a cycle
|
|
||||||
|
|
||||||
assign AtomicMtoDCache = SelPTW ? 2'b00 : AtomicM;
|
|
||||||
assign IEUAdrMExt = {2'b00, IEUAdrM};
|
|
||||||
assign MemPAdrNoTranslate = SelPTW ? TranslationPAdrM : IEUAdrMExt[`PA_BITS-1:0];
|
|
||||||
assign MemAdrE = SelPTW ? TranslationPAdrE[11:0] : IEUAdrE[11:0];
|
|
||||||
assign StallWtoDCache = SelPTW ? 1'b0 : StallW;
|
|
||||||
// always block interrupts when using the hardware page table walker.
|
|
||||||
assign CommittedM = SelPTW ? 1'b1 : CommittedMfromDCache;
|
|
||||||
|
|
||||||
// demux the inputs from LSU to walker or cpu's data port.
|
|
||||||
|
|
||||||
// works without the demux 7/18/21 dh. Suggest deleting these and removing fromDCache suffix
|
|
||||||
assign DataMisalignedM = /*SelPTW ? 1'b0 : */DataMisalignedMfromDCache;
|
|
||||||
// *** need to rename DcacheStall and Datastall.
|
|
||||||
// not clear at all. I think it should be LSUStall from the LSU,
|
|
||||||
// which is demuxed to HPTWStall and CPUDataStall? (not sure on this last one).
|
|
||||||
//assign HPTWStall = SelPTW ? DCacheStall : 1'b1;
|
|
||||||
|
|
||||||
assign PendingInterruptMtoDCache = SelPTW ? 1'b0 : PendingInterruptM;
|
|
||||||
|
|
||||||
//assign LSUStall = SelPTW ? 1'b1 : DCacheStall; // *** this is probably going to change.
|
|
||||||
|
|
||||||
endmodule
|
|
@ -39,7 +39,6 @@ module hptw
|
|||||||
input logic [1:0] MemRWM, // 10 = read, 01 = write
|
input logic [1:0] MemRWM, // 10 = read, 01 = write
|
||||||
input logic [`XLEN-1:0] HPTWReadPTE, // page table entry from LSU
|
input logic [`XLEN-1:0] HPTWReadPTE, // page table entry from LSU
|
||||||
input logic DCacheStall, // stall from LSU
|
input logic DCacheStall, // stall from LSU
|
||||||
input logic MemAfterIWalkDone,
|
|
||||||
input logic AnyCPUReqM,
|
input logic AnyCPUReqM,
|
||||||
output logic [`XLEN-1:0] PTE, // page table entry to TLBs
|
output logic [`XLEN-1:0] PTE, // page table entry to TLBs
|
||||||
output logic [1:0] PageType, // page type to TLBs
|
output logic [1:0] PageType, // page type to TLBs
|
||||||
@ -54,7 +53,7 @@ module hptw
|
|||||||
L1_ADR, L1_RD,
|
L1_ADR, L1_RD,
|
||||||
L2_ADR, L2_RD,
|
L2_ADR, L2_RD,
|
||||||
L3_ADR, L3_RD,
|
L3_ADR, L3_RD,
|
||||||
LEAF, LEAF_DELAY, IDLE, FAULT} statetype; // *** placed outside generate statement to remove synthesis errors
|
LEAF, IDLE, FAULT} statetype; // *** placed outside generate statement to remove synthesis errors
|
||||||
|
|
||||||
generate
|
generate
|
||||||
if (`MEM_VIRTMEM) begin
|
if (`MEM_VIRTMEM) begin
|
||||||
@ -198,10 +197,8 @@ module hptw
|
|||||||
else NextWalkerState = LEAF;
|
else NextWalkerState = LEAF;
|
||||||
// LEVEL0: if (ValidLeafPTE) NextWalkerState = LEAF;
|
// LEVEL0: if (ValidLeafPTE) NextWalkerState = LEAF;
|
||||||
// else NextWalkerState = FAULT;
|
// else NextWalkerState = FAULT;
|
||||||
LEAF: if (DTLBWalk) NextWalkerState = IDLE; // updates TLB
|
LEAF: NextWalkerState = IDLE; // updates TLB
|
||||||
else NextWalkerState = IDLE;
|
FAULT: if (ITLBMissF & AnyCPUReqM) NextWalkerState = FAULT;
|
||||||
LEAF_DELAY: NextWalkerState = IDLE; // give time to allow address translation
|
|
||||||
FAULT: if (ITLBMissF & AnyCPUReqM & ~MemAfterIWalkDone) NextWalkerState = FAULT;
|
|
||||||
else NextWalkerState = IDLE;
|
else NextWalkerState = IDLE;
|
||||||
default: begin
|
default: begin
|
||||||
// synthesis translate_off
|
// synthesis translate_off
|
||||||
|
Loading…
Reference in New Issue
Block a user