mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
soc/cpu/vexriscv-smp add --without-out-of-order-decode and --with-wishbone-memory
This commit is contained in:
parent
01a2fc11e2
commit
ae2cd31573
1 changed files with 47 additions and 34 deletions
|
@ -47,6 +47,8 @@ class VexRiscvSMP(CPU):
|
|||
dcache_width = 32
|
||||
icache_width = 32
|
||||
aes_instruction = False
|
||||
out_of_order_decoder = True
|
||||
wishbone_memory = False
|
||||
|
||||
@staticmethod
|
||||
def args_fill(parser):
|
||||
|
@ -60,7 +62,8 @@ class VexRiscvSMP(CPU):
|
|||
parser.add_argument("--icache-size", default=None, help="L1 instruction cache size in byte per CPU.")
|
||||
parser.add_argument("--icache-ways", default=None, help="L1 instruction cache ways per CPU")
|
||||
parser.add_argument("--aes-instruction", default=None, help="Enable AES instruction acceleration.")
|
||||
|
||||
parser.add_argument("--without-out-of-order-decoder", action='store_true', help="Reduce area at cost of peripheral access speed")
|
||||
parser.add_argument("--with-wishbone-memory" , action='store_true', help="Disable native litedram interface")
|
||||
|
||||
@staticmethod
|
||||
def args_read(args):
|
||||
|
@ -82,6 +85,9 @@ class VexRiscvSMP(CPU):
|
|||
if(args.dcache_ways): VexRiscvSMP.dcache_ways = int(args.dcache_ways)
|
||||
if(args.icache_ways): VexRiscvSMP.icache_ways = int(args.icache_ways)
|
||||
if(args.aes_instruction): VexRiscvSMP.aes_instruction = bool(args.aes_instruction)
|
||||
if(args.without_out_of_order_decoder): VexRiscvSMP.out_of_order_decoder = False
|
||||
if(args.with_wishbone_memory): VexRiscvSMP.wishbone_memory = True
|
||||
|
||||
|
||||
@property
|
||||
def mem_map(self):
|
||||
|
@ -103,6 +109,7 @@ class VexRiscvSMP(CPU):
|
|||
|
||||
@staticmethod
|
||||
def generate_cluster_name():
|
||||
ldw = f"Ldw{VexRiscvSMP.litedram_width}"
|
||||
VexRiscvSMP.cluster_name = f"VexRiscvLitexSmpCluster_" \
|
||||
f"Cc{VexRiscvSMP.cpu_count}" \
|
||||
"_" \
|
||||
|
@ -114,9 +121,11 @@ class VexRiscvSMP(CPU):
|
|||
f"Ds{VexRiscvSMP.dcache_size}" \
|
||||
f"Dy{VexRiscvSMP.dcache_ways}" \
|
||||
"_" \
|
||||
f"Ldw{VexRiscvSMP.litedram_width}" \
|
||||
f"{ldw if not VexRiscvSMP.wishbone_memory else ''}" \
|
||||
f"{'_Cdma' if VexRiscvSMP.coherent_dma else ''}" \
|
||||
f"{'_Aes' if VexRiscvSMP.aes_instruction else ''}"
|
||||
f"{'_Aes' if VexRiscvSMP.aes_instruction else ''}"\
|
||||
f"{'_Ood' if VexRiscvSMP.out_of_order_decoder else ''}"\
|
||||
f"{'_Wm' if VexRiscvSMP.wishbone_memory else ''}"
|
||||
|
||||
@staticmethod
|
||||
def generate_default_configs():
|
||||
|
@ -192,6 +201,8 @@ class VexRiscvSMP(CPU):
|
|||
gen_args.append(f"--icache-ways={VexRiscvSMP.icache_ways}")
|
||||
gen_args.append(f"--litedram-width={VexRiscvSMP.litedram_width}")
|
||||
gen_args.append(f"--aes-instruction={VexRiscvSMP.aes_instruction}")
|
||||
gen_args.append(f"--out-of-order-decoder={VexRiscvSMP.out_of_order_decoder}")
|
||||
gen_args.append(f"--wishbone-memory={VexRiscvSMP.wishbone_memory}")
|
||||
gen_args.append(f"--netlist-name={VexRiscvSMP.cluster_name}")
|
||||
gen_args.append(f"--netlist-directory={vdir}")
|
||||
|
||||
|
@ -324,6 +335,7 @@ class VexRiscvSMP(CPU):
|
|||
VexRiscvSMP.generate_cluster_name()
|
||||
|
||||
from litedram.common import LiteDRAMNativePort
|
||||
if(not VexRiscvSMP.wishbone_memory):
|
||||
ibus = LiteDRAMNativePort(mode="both", address_width=32, data_width=VexRiscvSMP.litedram_width)
|
||||
dbus = LiteDRAMNativePort(mode="both", address_width=32, data_width=VexRiscvSMP.litedram_width)
|
||||
self.memory_buses.append(ibus)
|
||||
|
@ -362,3 +374,4 @@ class VexRiscvSMP(CPU):
|
|||
|
||||
# Add verilog sources
|
||||
self.add_sources(self.platform)
|
||||
|
||||
|
|
Loading…
Reference in a new issue