Add Murax 0.55 DMIPS/Mhz

This commit is contained in:
Charles Papon 2017-07-30 02:42:14 +02:00
parent 087e3dda89
commit de33128e01
2 changed files with 24 additions and 14 deletions

View file

@ -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 ->

View file

@ -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