mirror of
https://github.com/SpinalHDL/VexRiscv.git
synced 2025-01-03 03:43:39 -05:00
Merge pull request #124 from tomverbeure/uinstret
Add uinstret support.
This commit is contained in:
commit
24b676ce30
7 changed files with 26 additions and 10 deletions
|
@ -159,5 +159,7 @@ object Riscv{
|
||||||
|
|
||||||
def UCYCLE = 0xC00 // UR Machine ucycle counter.
|
def UCYCLE = 0xC00 // UR Machine ucycle counter.
|
||||||
def UCYCLEH = 0xC80
|
def UCYCLEH = 0xC80
|
||||||
|
def UINSTRET = 0xC02 // UR Machine instructions-retired counter.
|
||||||
|
def UINSTRETH = 0xC82 // UR Upper 32 bits of minstret, RV32I only.
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -147,7 +147,8 @@ object BrieyConfig{
|
||||||
minstretAccess = CsrAccess.NONE,
|
minstretAccess = CsrAccess.NONE,
|
||||||
ecallGen = false,
|
ecallGen = false,
|
||||||
wfiGenAsWait = false,
|
wfiGenAsWait = false,
|
||||||
ucycleAccess = CsrAccess.NONE
|
ucycleAccess = CsrAccess.NONE,
|
||||||
|
uinstretAccess = CsrAccess.NONE
|
||||||
)
|
)
|
||||||
),
|
),
|
||||||
new YamlPlugin("cpu0.yaml")
|
new YamlPlugin("cpu0.yaml")
|
||||||
|
|
|
@ -126,7 +126,8 @@ object VexRiscvAhbLite3{
|
||||||
minstretAccess = CsrAccess.NONE,
|
minstretAccess = CsrAccess.NONE,
|
||||||
ecallGen = false,
|
ecallGen = false,
|
||||||
wfiGenAsWait = false,
|
wfiGenAsWait = false,
|
||||||
ucycleAccess = CsrAccess.NONE
|
ucycleAccess = CsrAccess.NONE,
|
||||||
|
uinstretAccess = CsrAccess.NONE
|
||||||
)
|
)
|
||||||
),
|
),
|
||||||
new YamlPlugin("cpu0.yaml")
|
new YamlPlugin("cpu0.yaml")
|
||||||
|
|
|
@ -124,7 +124,8 @@ object VexRiscvAvalonForSim{
|
||||||
minstretAccess = CsrAccess.NONE,
|
minstretAccess = CsrAccess.NONE,
|
||||||
ecallGen = false,
|
ecallGen = false,
|
||||||
wfiGenAsWait = false,
|
wfiGenAsWait = false,
|
||||||
ucycleAccess = CsrAccess.NONE
|
ucycleAccess = CsrAccess.NONE,
|
||||||
|
uinstretAccess = CsrAccess.NONE
|
||||||
)
|
)
|
||||||
),
|
),
|
||||||
new YamlPlugin("cpu0.yaml")
|
new YamlPlugin("cpu0.yaml")
|
||||||
|
|
|
@ -121,7 +121,8 @@ object VexRiscvAvalonWithIntegratedJtag{
|
||||||
minstretAccess = CsrAccess.NONE,
|
minstretAccess = CsrAccess.NONE,
|
||||||
ecallGen = false,
|
ecallGen = false,
|
||||||
wfiGenAsWait = false,
|
wfiGenAsWait = false,
|
||||||
ucycleAccess = CsrAccess.NONE
|
ucycleAccess = CsrAccess.NONE,
|
||||||
|
uinstretAccess = CsrAccess.NONE
|
||||||
)
|
)
|
||||||
),
|
),
|
||||||
new YamlPlugin("cpu0.yaml")
|
new YamlPlugin("cpu0.yaml")
|
||||||
|
|
|
@ -122,7 +122,8 @@ object VexRiscvAxi4WithIntegratedJtag{
|
||||||
minstretAccess = CsrAccess.NONE,
|
minstretAccess = CsrAccess.NONE,
|
||||||
ecallGen = false,
|
ecallGen = false,
|
||||||
wfiGenAsWait = false,
|
wfiGenAsWait = false,
|
||||||
ucycleAccess = CsrAccess.NONE
|
ucycleAccess = CsrAccess.NONE,
|
||||||
|
uinstretAccess = CsrAccess.NONE
|
||||||
)
|
)
|
||||||
),
|
),
|
||||||
new YamlPlugin("cpu0.yaml")
|
new YamlPlugin("cpu0.yaml")
|
||||||
|
|
|
@ -49,6 +49,7 @@ case class CsrPluginConfig(
|
||||||
mcycleAccess : CsrAccess,
|
mcycleAccess : CsrAccess,
|
||||||
minstretAccess : CsrAccess,
|
minstretAccess : CsrAccess,
|
||||||
ucycleAccess : CsrAccess,
|
ucycleAccess : CsrAccess,
|
||||||
|
uinstretAccess : CsrAccess = CsrAccess.NONE,
|
||||||
wfiGenAsWait : Boolean,
|
wfiGenAsWait : Boolean,
|
||||||
ecallGen : Boolean,
|
ecallGen : Boolean,
|
||||||
xtvecModeGen : Boolean = false,
|
xtvecModeGen : Boolean = false,
|
||||||
|
@ -100,6 +101,7 @@ object CsrPluginConfig{
|
||||||
mcycleAccess = CsrAccess.NONE,
|
mcycleAccess = CsrAccess.NONE,
|
||||||
minstretAccess = CsrAccess.NONE,
|
minstretAccess = CsrAccess.NONE,
|
||||||
ucycleAccess = CsrAccess.NONE,
|
ucycleAccess = CsrAccess.NONE,
|
||||||
|
uinstretAccess = CsrAccess.NONE,
|
||||||
wfiGenAsWait = true,
|
wfiGenAsWait = true,
|
||||||
ecallGen = true,
|
ecallGen = true,
|
||||||
xtvecModeGen = false,
|
xtvecModeGen = false,
|
||||||
|
@ -140,6 +142,7 @@ object CsrPluginConfig{
|
||||||
mcycleAccess = CsrAccess.READ_WRITE,
|
mcycleAccess = CsrAccess.READ_WRITE,
|
||||||
minstretAccess = CsrAccess.READ_WRITE,
|
minstretAccess = CsrAccess.READ_WRITE,
|
||||||
ucycleAccess = CsrAccess.READ_ONLY,
|
ucycleAccess = CsrAccess.READ_ONLY,
|
||||||
|
uinstretAccess = CsrAccess.READ_ONLY,
|
||||||
wfiGenAsWait = true,
|
wfiGenAsWait = true,
|
||||||
ecallGen = true,
|
ecallGen = true,
|
||||||
xtvecModeGen = false,
|
xtvecModeGen = false,
|
||||||
|
@ -180,7 +183,8 @@ object CsrPluginConfig{
|
||||||
minstretAccess = CsrAccess.READ_WRITE,
|
minstretAccess = CsrAccess.READ_WRITE,
|
||||||
ecallGen = true,
|
ecallGen = true,
|
||||||
wfiGenAsWait = true,
|
wfiGenAsWait = true,
|
||||||
ucycleAccess = CsrAccess.READ_ONLY
|
ucycleAccess = CsrAccess.READ_ONLY,
|
||||||
|
uinstretAccess = CsrAccess.READ_ONLY
|
||||||
)
|
)
|
||||||
|
|
||||||
def all2(mtvecInit : BigInt) : CsrPluginConfig = CsrPluginConfig(
|
def all2(mtvecInit : BigInt) : CsrPluginConfig = CsrPluginConfig(
|
||||||
|
@ -202,6 +206,7 @@ object CsrPluginConfig{
|
||||||
ecallGen = true,
|
ecallGen = true,
|
||||||
wfiGenAsWait = true,
|
wfiGenAsWait = true,
|
||||||
ucycleAccess = CsrAccess.READ_ONLY,
|
ucycleAccess = CsrAccess.READ_ONLY,
|
||||||
|
uinstretAccess = CsrAccess.READ_ONLY,
|
||||||
supervisorGen = true,
|
supervisorGen = true,
|
||||||
sscratchGen = true,
|
sscratchGen = true,
|
||||||
stvecAccess = CsrAccess.READ_WRITE,
|
stvecAccess = CsrAccess.READ_WRITE,
|
||||||
|
@ -233,7 +238,8 @@ object CsrPluginConfig{
|
||||||
minstretAccess = CsrAccess.NONE,
|
minstretAccess = CsrAccess.NONE,
|
||||||
ecallGen = false,
|
ecallGen = false,
|
||||||
wfiGenAsWait = false,
|
wfiGenAsWait = false,
|
||||||
ucycleAccess = CsrAccess.NONE
|
ucycleAccess = CsrAccess.NONE,
|
||||||
|
uinstretAccess = CsrAccess.NONE
|
||||||
)
|
)
|
||||||
|
|
||||||
def smallest(mtvecInit : BigInt) = CsrPluginConfig(
|
def smallest(mtvecInit : BigInt) = CsrPluginConfig(
|
||||||
|
@ -254,7 +260,8 @@ object CsrPluginConfig{
|
||||||
minstretAccess = CsrAccess.NONE,
|
minstretAccess = CsrAccess.NONE,
|
||||||
ecallGen = false,
|
ecallGen = false,
|
||||||
wfiGenAsWait = false,
|
wfiGenAsWait = false,
|
||||||
ucycleAccess = CsrAccess.NONE
|
ucycleAccess = CsrAccess.NONE,
|
||||||
|
uinstretAccess = CsrAccess.NONE
|
||||||
)
|
)
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -586,6 +593,8 @@ class CsrPlugin(val config: CsrPluginConfig) extends Plugin[VexRiscv] with Excep
|
||||||
//User CSR
|
//User CSR
|
||||||
ucycleAccess(CSR.UCYCLE, mcycle(31 downto 0))
|
ucycleAccess(CSR.UCYCLE, mcycle(31 downto 0))
|
||||||
ucycleAccess(CSR.UCYCLEH, mcycle(63 downto 32))
|
ucycleAccess(CSR.UCYCLEH, mcycle(63 downto 32))
|
||||||
|
uinstretAccess(CSR.UINSTRET, minstret(31 downto 0))
|
||||||
|
uinstretAccess(CSR.UINSTRETH, minstret(63 downto 32))
|
||||||
|
|
||||||
pipeline(MPP) := mstatus.MPP
|
pipeline(MPP) := mstatus.MPP
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue