1
0

replace ioDCache with ioMem

This commit is contained in:
Andrew Waterman 2012-02-27 18:36:09 -08:00
parent 1d41a41afa
commit 2b1c07c723
7 changed files with 15 additions and 30 deletions

View File

@ -20,12 +20,11 @@ class ioMem() extends Bundle
class ioMemArbiter(n: Int) extends Bundle() { class ioMemArbiter(n: Int) extends Bundle() {
val mem = new ioMem(); val mem = new ioMem();
val requestor = Vec(n) { new ioDCache() } val requestor = Vec(n) { new ioMem().flip() }
} }
class rocketMemArbiter(n: Int) extends Component { class rocketMemArbiter(n: Int) extends Component {
val io = new ioMemArbiter(n); val io = new ioMemArbiter(n);
require(io.mem.req_tag.getWidth >= log2up(n) + io.requestor(0).req_tag.getWidth)
var req_val = Bool(false) var req_val = Bool(false)
var req_rdy = io.mem.req_rdy var req_rdy = io.mem.req_rdy

View File

@ -216,7 +216,7 @@ class CoherenceHubNoDir extends CoherenceHub {
val io = new Bundle { val io = new Bundle {
val tiles = Vec(NTILES) { new ioTileLink() } val tiles = Vec(NTILES) { new ioTileLink() }
val mem = new ioDCache().flip val mem = new ioMem
} }
val trackerList = (0 until NGLOBAL_XACTS).map(new XactTracker(_)) val trackerList = (0 until NGLOBAL_XACTS).map(new XactTracker(_))

View File

@ -183,8 +183,8 @@ object Constants
val COHERENCE_DATA_BITS = (1 << OFFSET_BITS)*8 val COHERENCE_DATA_BITS = (1 << OFFSET_BITS)*8
val TILE_ID_BITS = 1 val TILE_ID_BITS = 1
val TILE_XACT_ID_BITS = 1 // log2(NMSHR) val TILE_XACT_ID_BITS = 1 // log2(NMSHR)
val GLOBAL_XACT_ID_BITS = IDX_BITS // if one active xact per set val GLOBAL_XACT_ID_BITS = 4
val NGLOBAL_XACTS = 1 << IDX_BITS val NGLOBAL_XACTS = 1 << GLOBAL_XACT_ID_BITS
val TTYPE_BITS = 2 val TTYPE_BITS = 2
val X_READ_SHARED = UFix(0, TTYPE_BITS) val X_READ_SHARED = UFix(0, TTYPE_BITS)
@ -198,11 +198,10 @@ object Constants
val P_COPY = UFix(2, PTYPE_BITS) val P_COPY = UFix(2, PTYPE_BITS)
// external memory interface // external memory interface
val IMEM_TAG_BITS = 1; val MEM_TAG_BITS = 4
val DMEM_TAG_BITS = ceil(log(NMSHR)/log(2)).toInt; val MEM_DATA_BITS = 128
val MEM_TAG_BITS = 2 + max(IMEM_TAG_BITS, DMEM_TAG_BITS); val REFILL_CYCLES = (1 << OFFSET_BITS)*8/MEM_DATA_BITS
val MEM_DATA_BITS = 128; require(MEM_TAG_BITS >= max(log2up(NMSHR)+1, GLOBAL_XACT_ID_BITS))
val REFILL_CYCLES = (1 << OFFSET_BITS)*8/MEM_DATA_BITS;
val DTLB_ENTRIES = 8; val DTLB_ENTRIES = 8;
val ITLB_ENTRIES = 8; val ITLB_ENTRIES = 8;

View File

@ -26,7 +26,7 @@ class rocketHTIF(w: Int, ncores: Int) extends Component
val io = new Bundle { val io = new Bundle {
val host = new ioHost(w) val host = new ioHost(w)
val cpu = Vec(ncores) { new ioHTIF().flip() } val cpu = Vec(ncores) { new ioHTIF().flip() }
val mem = new ioDCache().flip() val mem = new ioMem
} }
val short_request_bits = 64 val short_request_bits = 64

View File

@ -20,7 +20,7 @@ class ioImem(view: List[String] = null) extends Bundle (view)
class ioRocketICache extends Bundle() class ioRocketICache extends Bundle()
{ {
val cpu = new ioImem(); val cpu = new ioImem();
val mem = new ioDCache().flip() val mem = new ioMem
} }
// basic direct mapped instruction cache // basic direct mapped instruction cache

View File

@ -6,8 +6,8 @@ import Constants._;
import scala.math._; import scala.math._;
class ioIPrefetcher extends Bundle() { class ioIPrefetcher extends Bundle() {
val icache = new ioDCache(); val icache = new ioMem().flip
val mem = new ioDCache().flip() val mem = new ioMem
val invalidate = Bool(INPUT) val invalidate = Bool(INPUT)
} }

View File

@ -136,7 +136,7 @@ class DataArrayArrayReq extends Bundle {
class MemReq extends Bundle { class MemReq extends Bundle {
val rw = Bool() val rw = Bool()
val addr = UFix(width = PADDR_BITS-OFFSET_BITS) val addr = UFix(width = PADDR_BITS-OFFSET_BITS)
val tag = Bits(width = DMEM_TAG_BITS) val tag = Bits(width = MEM_TAG_BITS)
} }
class WritebackReq extends Bundle { class WritebackReq extends Bundle {
@ -281,7 +281,7 @@ class MSHRFile extends Component {
val req_way_oh = Bits(NWAYS, INPUT) val req_way_oh = Bits(NWAYS, INPUT)
val mem_resp_val = Bool(INPUT) val mem_resp_val = Bool(INPUT)
val mem_resp_tag = Bits(DMEM_TAG_BITS, INPUT) val mem_resp_tag = Bits(MEM_TAG_BITS, INPUT)
val mem_resp_idx = Bits(IDX_BITS, OUTPUT) val mem_resp_idx = Bits(IDX_BITS, OUTPUT)
val mem_resp_way_oh = Bits(NWAYS, OUTPUT) val mem_resp_way_oh = Bits(NWAYS, OUTPUT)
@ -670,19 +670,6 @@ class ioDmem(view: List[String] = null) extends Bundle(view) {
val resp_data_subword = Bits(64, OUTPUT); val resp_data_subword = Bits(64, OUTPUT);
val resp_tag = Bits(DCACHE_TAG_BITS, OUTPUT); val resp_tag = Bits(DCACHE_TAG_BITS, OUTPUT);
} }
// interface between D$ and next level in memory hierarchy
class ioDCache(view: List[String] = null) extends Bundle(view) {
val req_addr = UFix(PADDR_BITS - OFFSET_BITS, INPUT);
val req_tag = UFix(DMEM_TAG_BITS, INPUT);
val req_val = Bool(INPUT);
val req_rdy = Bool(OUTPUT);
val req_wdata = Bits(MEM_DATA_BITS, INPUT);
val req_rw = Bool(INPUT);
val resp_data = Bits(MEM_DATA_BITS, OUTPUT);
val resp_tag = Bits(DMEM_TAG_BITS, OUTPUT);
val resp_val = Bool(OUTPUT);
}
abstract class HellaCache extends Component { abstract class HellaCache extends Component {
def isHit ( cmd: Bits, state: UFix): Bool def isHit ( cmd: Bits, state: UFix): Bool
@ -698,7 +685,7 @@ abstract class HellaCache extends Component {
class HellaCacheUniproc extends HellaCache with ThreeStateIncoherence { class HellaCacheUniproc extends HellaCache with ThreeStateIncoherence {
val io = new Bundle { val io = new Bundle {
val cpu = new ioDmem() val cpu = new ioDmem()
val mem = new ioDCache().flip val mem = new ioMem
} }
val lines = 1 << IDX_BITS val lines = 1 << IDX_BITS