mirror of
https://github.com/SpinalHDL/VexRiscv.git
synced 2025-01-03 03:43:39 -05:00
Add Murax 0.55 DMIPS/Mhz
This commit is contained in:
parent
087e3dda89
commit
de33128e01
2 changed files with 24 additions and 14 deletions
12
README.md
12
README.md
|
@ -222,16 +222,18 @@ There is some measurements of Briey SoC timings and area :
|
||||||
## Murax SoC
|
## Murax SoC
|
||||||
|
|
||||||
Murax is a very light SoC (fit in ICE40 FPGA) which could work without any external component.
|
Murax is a very light SoC (fit in ICE40 FPGA) which could work without any external component.
|
||||||
|
- VexRiscv RV32I[M]
|
||||||
- ICE40-hx8k + icestorm => 53 Mhz, 2142 LC
|
|
||||||
- 0.37 DMIPS/Mhz
|
|
||||||
- 8 kB of on-chip ram
|
|
||||||
- JTAG debugger (eclipse/GDB/openocd ready)
|
- JTAG debugger (eclipse/GDB/openocd ready)
|
||||||
|
- 8 kB of on-chip ram
|
||||||
- Interrupt support
|
- Interrupt support
|
||||||
- APB bus for peripherals
|
- APB bus for peripherals
|
||||||
- 32 GPIO pin
|
- 32 GPIO pin
|
||||||
- one 16 bits prescaler, two 16 bits timers
|
- one 16 bits prescaler, two 16 bits timers
|
||||||
|
|
||||||
|
Depending the CPU configuration, on the ICE40-hx8k FPGA with icestorm for synthesis, the full SoC will get following area/performance :
|
||||||
|
- RV32I interlocked stages => 53 Mhz, 2142 LC 0.37 DMIPS/Mhz
|
||||||
|
- RV32I bypassed stages => 53 Mhz, 2463 LC 0.55 DMIPS/Mhz
|
||||||
|
|
||||||
You can find its implementation there : src/main/scala/vexriscv/demo/Murax.scala
|
You can find its implementation there : src/main/scala/vexriscv/demo/Murax.scala
|
||||||
|
|
||||||
|
|
||||||
|
@ -253,7 +255,7 @@ To connect OpenOCD (https://github.com/SpinalHDL/openocd_riscv) to the simulatio
|
||||||
src/openocd -f tcl/interface/jtag_tcp.cfg -c "set MURAX_CPU0_YAML /home/spinalvm/Spinal/VexRiscv/cpu0.yaml" -f tcl/target/murax.cfg
|
src/openocd -f tcl/interface/jtag_tcp.cfg -c "set MURAX_CPU0_YAML /home/spinalvm/Spinal/VexRiscv/cpu0.yaml" -f tcl/target/murax.cfg
|
||||||
```
|
```
|
||||||
|
|
||||||
There is some measurements of Murax SoC timings and area :
|
There is some measurements of Murax SoC timings and area for the 0.37 DMIPS/Mhz SoC version :
|
||||||
|
|
||||||
```
|
```
|
||||||
Murax ->
|
Murax ->
|
||||||
|
|
|
@ -29,6 +29,10 @@ import vexriscv.{plugin, VexRiscvConfig, VexRiscv}
|
||||||
|
|
||||||
case class MuraxConfig(coreFrequency : HertzNumber,
|
case class MuraxConfig(coreFrequency : HertzNumber,
|
||||||
onChipRamSize : BigInt,
|
onChipRamSize : BigInt,
|
||||||
|
bypassExecute : Boolean,
|
||||||
|
bypassMemory: Boolean,
|
||||||
|
bypassWriteBack: Boolean,
|
||||||
|
bypassWriteBackBuffer : Boolean,
|
||||||
pipelineDBus : Boolean,
|
pipelineDBus : Boolean,
|
||||||
pipelineMainBus : Boolean,
|
pipelineMainBus : Boolean,
|
||||||
pipelineApbBridge : Boolean){
|
pipelineApbBridge : Boolean){
|
||||||
|
@ -37,11 +41,15 @@ case class MuraxConfig(coreFrequency : HertzNumber,
|
||||||
|
|
||||||
object MuraxConfig{
|
object MuraxConfig{
|
||||||
def default = MuraxConfig(
|
def default = MuraxConfig(
|
||||||
coreFrequency = 12 MHz,
|
coreFrequency = 12 MHz,
|
||||||
onChipRamSize = 8 kB,
|
onChipRamSize = 8 kB,
|
||||||
pipelineDBus = true,
|
bypassExecute = false,
|
||||||
pipelineMainBus = false,
|
bypassMemory = false,
|
||||||
pipelineApbBridge = true
|
bypassWriteBack = false,
|
||||||
|
bypassWriteBackBuffer = false,
|
||||||
|
pipelineDBus = true,
|
||||||
|
pipelineMainBus = false,
|
||||||
|
pipelineApbBridge = true
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -158,10 +166,10 @@ case class Murax(config : MuraxConfig) extends Component{
|
||||||
new LightShifterPlugin,
|
new LightShifterPlugin,
|
||||||
new DebugPlugin(debugClockDomain),
|
new DebugPlugin(debugClockDomain),
|
||||||
new HazardSimplePlugin(
|
new HazardSimplePlugin(
|
||||||
bypassExecute = false,
|
bypassExecute = bypassExecute,
|
||||||
bypassMemory = false,
|
bypassMemory = bypassMemory,
|
||||||
bypassWriteBack = false,
|
bypassWriteBack = bypassWriteBack,
|
||||||
bypassWriteBackBuffer = false,
|
bypassWriteBackBuffer = bypassWriteBackBuffer,
|
||||||
pessimisticUseSrc = false,
|
pessimisticUseSrc = false,
|
||||||
pessimisticWriteRegFile = false,
|
pessimisticWriteRegFile = false,
|
||||||
pessimisticAddressMatch = false
|
pessimisticAddressMatch = false
|
||||||
|
|
Loading…
Reference in a new issue