

access from the general interface that goes to ITIM(CTRL or MEM; See addrMaybelnScratchpad(io.s1\_paddr)) region always hit, but may return unspecified data





|                                                                          | io.imem.req.valid := take_pc<br>io.imem.req.bits.speculative := !take_pc_wb<br>io.imem.req.bits.pc :=<br>Mux(wb_xcpt    csr.io.eret, csr.io.evec, // exception or [m s]ret<br>Mux(replay_wb, wb_reg_pc, // replay | csr.io.evec returns the right redirection addr<br>for interrupt/exception and the ebreak/ecall/<br>eret case | a csr access op can be detected at ID, but<br>only send this request to CSR module at WB<br>stage. The CSR responds at the same cycle. | csr.io.rw.addr := wb_reg_inst(31,20)<br>csr.io.rw.cmd := CSR.maskCmd(wb_reg_<br>valid, wb_ctrl.csr)<br>csr.io.rw.wdata := wb_reg_wdata | the CSR module then docodes the op, and io.<br>eret may therefore be asserted | io.eret := insn_call    insn_break    ins<br>io.evec := tvec |
|--------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|--------------------------------------------------------------|
| -                                                                        |                                                                                                                                                                                                                   | for replay, just redirect to the pc of insn in<br>WB stage                                                   |                                                                                                                                        |                                                                                                                                        |                                                                               |                                                              |
|                                                                          | mem_npc)) // nosh or branch misprediction                                                                                                                                                                         | mem_npcit's important to note that this s                                                                    | also covers the                                                                                                                        |                                                                                                                                        |                                                                               |                                                              |
| se,m(s)tval are among io_dec.csr >= CSRs.<br>rs will flush the pipeline. |                                                                                                                                                                                                                   | flush case? why flush is needed                                                                              | erstanding the<br>d?                                                                                                                   |                                                                                                                                        |                                                                               |                                                              |
|                                                                          |                                                                                                                                                                                                                   |                                                                                                              |                                                                                                                                        |                                                                                                                                        |                                                                               |                                                              |

