mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
gensoc: support user-defined CSR regions
This commit is contained in:
parent
8ae3a00a94
commit
aac34f011f
3 changed files with 34 additions and 30 deletions
4
make.py
4
make.py
|
@ -152,7 +152,7 @@ CPU type: {}
|
|||
flash_boot_address = None
|
||||
mem_header = cpuif.get_mem_header(soc.cpu_memory_regions, flash_boot_address)
|
||||
write_to_file("software/include/generated/mem.h", boilerplate + mem_header)
|
||||
csr_header = cpuif.get_csr_header(soc.csr_base, soc.csrbankarray, soc.interrupt_map)
|
||||
csr_header = cpuif.get_csr_header(soc.cpu_csr_regions, soc.interrupt_map)
|
||||
write_to_file("software/include/generated/csr.h", boilerplate + csr_header)
|
||||
for sdram_phy in ["sdrphy", "ddrphy"]:
|
||||
if hasattr(soc, sdram_phy):
|
||||
|
@ -160,7 +160,7 @@ CPU type: {}
|
|||
write_to_file("software/include/generated/sdram_phy.h", boilerplate + sdram_phy_header)
|
||||
|
||||
if actions["build-csr-csv"]:
|
||||
csr_csv = cpuif.get_csr_csv(soc.csr_base, soc.csrbankarray)
|
||||
csr_csv = cpuif.get_csr_csv(soc.cpu_csr_regions)
|
||||
write_to_file(args.csr_csv, csr_csv)
|
||||
|
||||
if actions["build-bios"]:
|
||||
|
|
|
@ -14,7 +14,6 @@ from misoclib.sdram import dfii
|
|||
from misoclib.sdram.minicon import Minicon
|
||||
|
||||
class GenSoC(Module):
|
||||
csr_base = 0xe0000000
|
||||
csr_map = {
|
||||
"crg": 0, # user
|
||||
"uart": 1, # provided by default
|
||||
|
@ -41,6 +40,7 @@ class GenSoC(Module):
|
|||
self.l2_size = l2_size
|
||||
self.cpu_type = cpu_type
|
||||
self.cpu_memory_regions = []
|
||||
self.cpu_csr_regions = [] # list of (name, origin, busword, csr_list/Memory)
|
||||
self._rom_registered = False
|
||||
|
||||
# Wishbone
|
||||
|
@ -103,6 +103,9 @@ class GenSoC(Module):
|
|||
def add_cpu_memory_region(self, name, origin, length):
|
||||
self.cpu_memory_regions.append((name, origin, length))
|
||||
|
||||
def add_cpu_csr_region(self, name, origin, busword, obj):
|
||||
self.cpu_csr_regions.append((name, origin, busword, obj))
|
||||
|
||||
def do_finalize(self):
|
||||
if not self._rom_registered:
|
||||
raise FinalizeError("Need to call GenSoC.register_rom()")
|
||||
|
@ -115,6 +118,10 @@ class GenSoC(Module):
|
|||
self.submodules.csrbankarray = csrgen.BankArray(self,
|
||||
lambda name, memory: self.csr_map[name if memory is None else name + "_" + memory.name_override])
|
||||
self.submodules.csrcon = csr.Interconnect(self.wishbone2csr.csr, self.csrbankarray.get_buses())
|
||||
for name, csrs, mapaddr, rmap in self.csrbankarray.banks:
|
||||
self.add_cpu_csr_region(name, 0xe0000000+0x800*mapaddr, flen(rmap.bus.dat_w), csrs)
|
||||
for name, memory, mapaddr, mmap in self.csrbankarray.srams:
|
||||
self.add_cpu_csr_region(name, 0xe0000000+0x800*mapaddr, flen(rmap.bus.dat_w), memory)
|
||||
|
||||
# Interrupts
|
||||
for k, v in sorted(self.interrupt_map.items(), key=itemgetter(1)):
|
||||
|
|
|
@ -68,37 +68,34 @@ def _get_rw_functions(reg_name, reg_base, nwords, busword, read_only):
|
|||
r += "}\n"
|
||||
return r
|
||||
|
||||
def get_csr_header(csr_base, bank_array, interrupt_map):
|
||||
def get_csr_header(regions, interrupt_map):
|
||||
r = "#ifndef __GENERATED_CSR_H\n#define __GENERATED_CSR_H\n#include <hw/common.h>\n"
|
||||
for name, csrs, mapaddr, rmap in bank_array.banks:
|
||||
r += "\n/* "+name+" */\n"
|
||||
reg_base = csr_base + 0x800*mapaddr
|
||||
r += "#define "+name.upper()+"_BASE "+hex(reg_base)+"\n"
|
||||
busword = flen(rmap.bus.dat_w)
|
||||
for csr in csrs:
|
||||
nr = (csr.size + busword - 1)//busword
|
||||
r += _get_rw_functions(name + "_" + csr.name, reg_base, nr, busword, isinstance(csr, CSRStatus))
|
||||
reg_base += 4*nr
|
||||
try:
|
||||
interrupt_nr = interrupt_map[name]
|
||||
except KeyError:
|
||||
pass
|
||||
for name, origin, busword, obj in regions:
|
||||
if isinstance(obj, Memory):
|
||||
fullname = name + "_" + memory.name_override
|
||||
r += "#define "+fullname.upper()+"_BASE "+hex(origin)+"\n"
|
||||
else:
|
||||
r += "#define "+name.upper()+"_INTERRUPT "+str(interrupt_nr)+"\n"
|
||||
for name, memory, mapaddr, mmap in bank_array.srams:
|
||||
mem_base = csr_base + 0x800*mapaddr
|
||||
fullname = name + "_" + memory.name_override
|
||||
r += "#define "+fullname.upper()+"_BASE "+hex(mem_base)+"\n"
|
||||
r += "\n/* "+name+" */\n"
|
||||
r += "#define "+name.upper()+"_BASE "+hex(origin)+"\n"
|
||||
for csr in obj:
|
||||
nr = (csr.size + busword - 1)//busword
|
||||
r += _get_rw_functions(name + "_" + csr.name, origin, nr, busword, isinstance(csr, CSRStatus))
|
||||
origin += 4*nr
|
||||
try:
|
||||
interrupt_nr = interrupt_map[name]
|
||||
except KeyError:
|
||||
pass
|
||||
else:
|
||||
r += "#define "+name.upper()+"_INTERRUPT "+str(interrupt_nr)+"\n"
|
||||
r += "\n#endif\n"
|
||||
return r
|
||||
|
||||
def get_csr_csv(csr_base, bank_array):
|
||||
def get_csr_csv(regions):
|
||||
r = ""
|
||||
for name, csrs, mapaddr, rmap in bank_array.banks:
|
||||
reg_base = csr_base + 0x800*mapaddr
|
||||
busword = flen(rmap.bus.dat_w)
|
||||
for csr in csrs:
|
||||
nr = (csr.size + busword - 1)//busword
|
||||
r += "{}_{},0x{:08x},{},{}\n".format(name, csr.name, reg_base, nr, "ro" if isinstance(csr, CSRStatus) else "rw")
|
||||
reg_base += 4*nr
|
||||
for name, origin, busword, obj in regions:
|
||||
if not isinstance(obj, Memory):
|
||||
for csr in obj:
|
||||
nr = (csr.size + busword - 1)//busword
|
||||
r += "{}_{},0x{:08x},{},{}\n".format(name, csr.name, origin, nr, "ro" if isinstance(csr, CSRStatus) else "rw")
|
||||
origin += 4*nr
|
||||
return r
|
||||
|
|
Loading…
Reference in a new issue