mirror of
https://github.com/SpinalHDL/VexRiscv.git
synced 2025-01-03 03:43:39 -05:00
Fix SMP for configuration without writeback stage.
Include SMP core into the single core tests regressions
This commit is contained in:
parent
4a49b23636
commit
03a0445775
2 changed files with 11 additions and 7 deletions
|
@ -565,8 +565,8 @@ class DataCache(val p : DataCacheConfig) extends Component{
|
||||||
|
|
||||||
//Ensure write to read consistency
|
//Ensure write to read consistency
|
||||||
val consistancyCheck = (withInvalidate || withWriteResponse) generate new Area {
|
val consistancyCheck = (withInvalidate || withWriteResponse) generate new Area {
|
||||||
val fenceConsistent = (if(withInvalidate) sync.fenceConsistent else pending.done) && !io.cpu.writeBack.fenceValid && !io.cpu.memory.fenceValid //Pessimistic fence tracking
|
val fenceConsistent = (if(withInvalidate) sync.fenceConsistent else pending.done) && !io.cpu.writeBack.fenceValid && (if(mergeExecuteMemory) True else !io.cpu.memory.fenceValid) //Pessimistic fence tracking
|
||||||
val totalyConsistent = (if(withInvalidate) sync.totalyConsistent else pending.done) && !(io.cpu.memory.isValid && io.cpu.memory.isWrite) && !(io.cpu.writeBack.isValid && io.cpu.memory.isWrite)
|
val totalyConsistent = (if(withInvalidate) sync.totalyConsistent else pending.done) && (if(mergeExecuteMemory) True else !(io.cpu.memory.isValid && io.cpu.memory.isWrite)) && !(io.cpu.writeBack.isValid && io.cpu.memory.isWrite)
|
||||||
when(io.cpu.execute.isValid /*&& (!io.cpu.execute.args.wr || isAmo)*/){
|
when(io.cpu.execute.isValid /*&& (!io.cpu.execute.args.wr || isAmo)*/){
|
||||||
when(!fenceConsistent || io.cpu.execute.totalyConsistent && !totalyConsistent){
|
when(!fenceConsistent || io.cpu.execute.totalyConsistent && !totalyConsistent){
|
||||||
io.cpu.execute.haltIt := True
|
io.cpu.execute.haltIt := True
|
||||||
|
|
|
@ -427,8 +427,10 @@ class DBusDimension extends VexRiscvDimension("DBus") {
|
||||||
var cacheSize = 0
|
var cacheSize = 0
|
||||||
var wayCount = 0
|
var wayCount = 0
|
||||||
val withLrSc = catchAll
|
val withLrSc = catchAll
|
||||||
val withAmo = catchAll && r.nextBoolean()
|
val withSmp = withLrSc && r.nextBoolean()
|
||||||
val dBusRspSlavePipe, relaxedMemoryTranslationRegister = r.nextBoolean()
|
val withAmo = catchAll && r.nextBoolean() || withSmp
|
||||||
|
val dBusRspSlavePipe = r.nextBoolean() || withSmp
|
||||||
|
val relaxedMemoryTranslationRegister = r.nextBoolean()
|
||||||
val earlyWaysHits = r.nextBoolean() && !noWriteBack
|
val earlyWaysHits = r.nextBoolean() && !noWriteBack
|
||||||
val dBusCmdMasterPipe, dBusCmdSlavePipe = false //As it create test bench issues
|
val dBusCmdMasterPipe, dBusCmdSlavePipe = false //As it create test bench issues
|
||||||
|
|
||||||
|
@ -436,8 +438,8 @@ class DBusDimension extends VexRiscvDimension("DBus") {
|
||||||
cacheSize = 512 << r.nextInt(5)
|
cacheSize = 512 << r.nextInt(5)
|
||||||
wayCount = 1 << r.nextInt(3)
|
wayCount = 1 << r.nextInt(3)
|
||||||
}while(cacheSize/wayCount < 512 || (catchAll && cacheSize/wayCount > 4096))
|
}while(cacheSize/wayCount < 512 || (catchAll && cacheSize/wayCount > 4096))
|
||||||
new VexRiscvPosition("Cached" + "S" + cacheSize + "W" + wayCount + "BPL" + bytePerLine + (if(dBusCmdMasterPipe) "Cmp " else "") + (if(dBusCmdSlavePipe) "Csp " else "") + (if(dBusRspSlavePipe) "Rsp " else "") + (if(relaxedMemoryTranslationRegister) "Rmtr " else "") + (if(earlyWaysHits) "Ewh " else "") + (if(withAmo) "Amo " else "")) {
|
new VexRiscvPosition("Cached" + "S" + cacheSize + "W" + wayCount + "BPL" + bytePerLine + (if(dBusCmdMasterPipe) "Cmp " else "") + (if(dBusCmdSlavePipe) "Csp " else "") + (if(dBusRspSlavePipe) "Rsp " else "") + (if(relaxedMemoryTranslationRegister) "Rmtr " else "") + (if(earlyWaysHits) "Ewh " else "") + (if(withAmo) "Amo " else "") + (if(withSmp) "Smp " else "")) {
|
||||||
override def testParam = "DBUS=CACHED " + (if(withLrSc) "LRSC=yes " else "") + (if(withAmo) "AMO=yes " else "")
|
override def testParam = "DBUS=CACHED " + (if(withLrSc) "LRSC=yes " else "") + (if(withAmo) "AMO=yes " else "") + (if(withSmp) "DBUS_EXCLUSIVE=yes DBUS_INVALIDATE=yes " else "")
|
||||||
|
|
||||||
override def applyOn(config: VexRiscvConfig): Unit = {
|
override def applyOn(config: VexRiscvConfig): Unit = {
|
||||||
config.plugins += new DBusCachedPlugin(
|
config.plugins += new DBusCachedPlugin(
|
||||||
|
@ -453,7 +455,9 @@ class DBusDimension extends VexRiscvDimension("DBus") {
|
||||||
catchUnaligned = catchAll,
|
catchUnaligned = catchAll,
|
||||||
withLrSc = withLrSc,
|
withLrSc = withLrSc,
|
||||||
withAmo = withAmo,
|
withAmo = withAmo,
|
||||||
earlyWaysHits = earlyWaysHits
|
earlyWaysHits = earlyWaysHits,
|
||||||
|
withExclusive = withSmp,
|
||||||
|
withInvalidate = withSmp
|
||||||
),
|
),
|
||||||
dBusCmdMasterPipe = dBusCmdMasterPipe,
|
dBusCmdMasterPipe = dBusCmdMasterPipe,
|
||||||
dBusCmdSlavePipe = dBusCmdSlavePipe,
|
dBusCmdSlavePipe = dBusCmdSlavePipe,
|
||||||
|
|
Loading…
Reference in a new issue