Renamed PCR to CSR
This commit is contained in:
parent
11dbd4221a
commit
2f88c5ca9d
@ -21,7 +21,7 @@ trait ScalarOpConstants {
|
|||||||
val PC_EX = UInt(0, 2)
|
val PC_EX = UInt(0, 2)
|
||||||
val PC_MEM = UInt(1, 2)
|
val PC_MEM = UInt(1, 2)
|
||||||
val PC_WB = UInt(2, 2)
|
val PC_WB = UInt(2, 2)
|
||||||
val PC_PCR = UInt(3, 2)
|
val PC_CSR = UInt(3, 2)
|
||||||
|
|
||||||
val A1_X = Bits("b??", 2)
|
val A1_X = Bits("b??", 2)
|
||||||
val A1_ZERO = UInt(0, 2)
|
val A1_ZERO = UInt(0, 2)
|
||||||
|
@ -553,7 +553,7 @@ class Control extends CoreModule
|
|||||||
take_pc_wb := replay_wb || wb_xcpt || io.dpath.eret
|
take_pc_wb := replay_wb || wb_xcpt || io.dpath.eret
|
||||||
|
|
||||||
io.dpath.sel_pc :=
|
io.dpath.sel_pc :=
|
||||||
Mux(wb_xcpt || io.dpath.eret, PC_PCR, // exception or [m|s]ret
|
Mux(wb_xcpt || io.dpath.eret, PC_CSR, // exception or [m|s]ret
|
||||||
Mux(replay_wb, PC_WB, // replay
|
Mux(replay_wb, PC_WB, // replay
|
||||||
PC_MEM))
|
PC_MEM))
|
||||||
|
|
||||||
@ -589,7 +589,7 @@ class Control extends CoreModule
|
|||||||
io.dpath.bypass_src(i) := PriorityEncoder(doBypass(i))
|
io.dpath.bypass_src(i) := PriorityEncoder(doBypass(i))
|
||||||
}
|
}
|
||||||
|
|
||||||
// stall for RAW/WAW hazards on PCRs, loads, AMOs, and mul/div in execute stage.
|
// stall for RAW/WAW hazards on CSRs, loads, AMOs, and mul/div in execute stage.
|
||||||
val id_renx1_not0 = id_ctrl.rxs1 && id_raddr1 != UInt(0)
|
val id_renx1_not0 = id_ctrl.rxs1 && id_raddr1 != UInt(0)
|
||||||
val id_renx2_not0 = id_ctrl.rxs2 && id_raddr2 != UInt(0)
|
val id_renx2_not0 = id_ctrl.rxs2 && id_raddr2 != UInt(0)
|
||||||
val id_wen_not0 = id_ctrl.wxd && id_waddr != UInt(0)
|
val id_wen_not0 = id_ctrl.wxd && id_waddr != UInt(0)
|
||||||
@ -605,7 +605,7 @@ class Control extends CoreModule
|
|||||||
io.fpu.dec.wen && id_waddr === io.dpath.ex_waddr)
|
io.fpu.dec.wen && id_waddr === io.dpath.ex_waddr)
|
||||||
val id_ex_hazard = ex_reg_valid && (data_hazard_ex && ex_cannot_bypass || fp_data_hazard_ex)
|
val id_ex_hazard = ex_reg_valid && (data_hazard_ex && ex_cannot_bypass || fp_data_hazard_ex)
|
||||||
|
|
||||||
// stall for RAW/WAW hazards on PCRs, LB/LH, and mul/div in memory stage.
|
// stall for RAW/WAW hazards on CSRs, LB/LH, and mul/div in memory stage.
|
||||||
val mem_mem_cmd_bh =
|
val mem_mem_cmd_bh =
|
||||||
if (params(FastLoadWord)) Bool(!params(FastLoadByte)) && mem_reg_slow_bypass
|
if (params(FastLoadWord)) Bool(!params(FastLoadByte)) && mem_reg_slow_bypass
|
||||||
else Bool(true)
|
else Bool(true)
|
||||||
|
@ -166,17 +166,17 @@ class Datapath extends CoreModule
|
|||||||
require(params(CoreDCacheReqTagBits) >= 6)
|
require(params(CoreDCacheReqTagBits) >= 6)
|
||||||
|
|
||||||
// processor control regfile read
|
// processor control regfile read
|
||||||
val pcr = Module(new CSRFile)
|
val csr = Module(new CSRFile)
|
||||||
pcr.io.host <> io.host
|
csr.io.host <> io.host
|
||||||
pcr.io <> io.ctrl
|
csr.io <> io.ctrl
|
||||||
pcr.io <> io.fpu
|
csr.io <> io.fpu
|
||||||
pcr.io.rocc <> io.rocc
|
csr.io.rocc <> io.rocc
|
||||||
pcr.io.pc := wb_reg_pc
|
csr.io.pc := wb_reg_pc
|
||||||
pcr.io.uarch_counters.foreach(_ := Bool(false))
|
csr.io.uarch_counters.foreach(_ := Bool(false))
|
||||||
|
|
||||||
io.ptw.ptbr := pcr.io.ptbr
|
io.ptw.ptbr := csr.io.ptbr
|
||||||
io.ptw.invalidate := pcr.io.fatc
|
io.ptw.invalidate := csr.io.fatc
|
||||||
io.ptw.status := pcr.io.status
|
io.ptw.status := csr.io.status
|
||||||
|
|
||||||
// memory stage
|
// memory stage
|
||||||
mem_reg_kill := ex_reg_kill
|
mem_reg_kill := ex_reg_kill
|
||||||
@ -246,7 +246,7 @@ class Datapath extends CoreModule
|
|||||||
}
|
}
|
||||||
wb_wdata := Mux(dmem_resp_valid && dmem_resp_xpu, io.dmem.resp.bits.data_subword,
|
wb_wdata := Mux(dmem_resp_valid && dmem_resp_xpu, io.dmem.resp.bits.data_subword,
|
||||||
Mux(io.ctrl.ll_wen, ll_wdata,
|
Mux(io.ctrl.ll_wen, ll_wdata,
|
||||||
Mux(io.ctrl.csr_cmd != CSR.N, pcr.io.rw.rdata,
|
Mux(io.ctrl.csr_cmd != CSR.N, csr.io.rw.rdata,
|
||||||
wb_reg_wdata)))
|
wb_reg_wdata)))
|
||||||
|
|
||||||
val wb_wen = io.ctrl.ll_wen || io.ctrl.wb_wen
|
val wb_wen = io.ctrl.ll_wen || io.ctrl.wb_wen
|
||||||
@ -258,9 +258,9 @@ class Datapath extends CoreModule
|
|||||||
io.ctrl.fp_sboard_clra := dmem_resp_waddr
|
io.ctrl.fp_sboard_clra := dmem_resp_waddr
|
||||||
|
|
||||||
// processor control regfile write
|
// processor control regfile write
|
||||||
pcr.io.rw.addr := wb_reg_inst(31,20)
|
csr.io.rw.addr := wb_reg_inst(31,20)
|
||||||
pcr.io.rw.cmd := io.ctrl.csr_cmd
|
csr.io.rw.cmd := io.ctrl.csr_cmd
|
||||||
pcr.io.rw.wdata := wb_reg_wdata
|
csr.io.rw.wdata := wb_reg_wdata
|
||||||
|
|
||||||
io.rocc.cmd.bits.inst := new RoCCInstruction().fromBits(wb_reg_inst)
|
io.rocc.cmd.bits.inst := new RoCCInstruction().fromBits(wb_reg_inst)
|
||||||
io.rocc.cmd.bits.rs1 := wb_reg_wdata
|
io.rocc.cmd.bits.rs1 := wb_reg_wdata
|
||||||
@ -269,7 +269,7 @@ class Datapath extends CoreModule
|
|||||||
// hook up I$
|
// hook up I$
|
||||||
io.imem.req.bits.pc :=
|
io.imem.req.bits.pc :=
|
||||||
Mux(io.ctrl.sel_pc === PC_MEM, mem_npc,
|
Mux(io.ctrl.sel_pc === PC_MEM, mem_npc,
|
||||||
Mux(io.ctrl.sel_pc === PC_PCR, pcr.io.evec,
|
Mux(io.ctrl.sel_pc === PC_CSR, csr.io.evec,
|
||||||
wb_reg_pc)).toUInt // PC_WB
|
wb_reg_pc)).toUInt // PC_WB
|
||||||
io.imem.btb_update.bits.pc := mem_reg_pc
|
io.imem.btb_update.bits.pc := mem_reg_pc
|
||||||
io.imem.btb_update.bits.target := io.imem.req.bits.pc
|
io.imem.btb_update.bits.target := io.imem.req.bits.pc
|
||||||
@ -283,7 +283,7 @@ class Datapath extends CoreModule
|
|||||||
io.ctrl.wb_waddr := wb_reg_inst(11,7)
|
io.ctrl.wb_waddr := wb_reg_inst(11,7)
|
||||||
|
|
||||||
printf("C%d: %d [%d] pc=[%x] W[r%d=%x][%d] R[r%d=%x] R[r%d=%x] inst=[%x] DASM(%x)\n",
|
printf("C%d: %d [%d] pc=[%x] W[r%d=%x][%d] R[r%d=%x] R[r%d=%x] inst=[%x] DASM(%x)\n",
|
||||||
io.host.id, pcr.io.time(32,0), io.ctrl.retire, wb_reg_pc,
|
io.host.id, csr.io.time(32,0), io.ctrl.retire, wb_reg_pc,
|
||||||
Mux(wb_wen, wb_waddr, UInt(0)), wb_wdata, wb_wen,
|
Mux(wb_wen, wb_waddr, UInt(0)), wb_wdata, wb_wen,
|
||||||
wb_reg_inst(19,15), Reg(next=Reg(next=ex_rs(0))),
|
wb_reg_inst(19,15), Reg(next=Reg(next=ex_rs(0))),
|
||||||
wb_reg_inst(24,20), Reg(next=Reg(next=ex_rs(1))),
|
wb_reg_inst(24,20), Reg(next=Reg(next=ex_rs(1))),
|
||||||
|
Loading…
Reference in New Issue
Block a user