artiq/artiq/gateware/amp/kernel_cpu.py

46 lines
1.5 KiB
Python
Raw Normal View History

2015-11-04 00:35:03 +08:00
from migen import *
from misoc.interconnect.csr import *
from misoc.interconnect import wishbone
2021-08-17 11:07:18 +08:00
from misoc.cores import vexriscv
from misoc.integration.wb_slaves import WishboneSlaveManager
class KernelCPU(Module):
def __init__(self, platform,
exec_address=0x45000000,
main_mem_origin=0x40000000,
l2_size=8192):
self._reset = CSRStorage(reset=1)
# # #
self._wb_slaves = WishboneSlaveManager(0x80000000)
# CPU core
self.clock_domains.cd_sys_kernel = ClockDomain()
self.comb += [
self.cd_sys_kernel.clk.eq(ClockSignal()),
self.cd_sys_kernel.rst.eq(self._reset.storage)
]
2021-11-08 12:37:36 +08:00
kasli_v1 = isinstance(platform, kasli.Platform) and platform.hw_rev in ("v1.0", "v1.1")
2015-11-04 00:35:03 +08:00
self.submodules.cpu = ClockDomainsRenamer("sys_kernel")(
2021-11-08 12:37:36 +08:00
vexriscv.VexRiscv(platform, exec_address,
variant="VexRiscv_IMA" if kasli_v1 else "VexRiscv_G"))
# DRAM access
self.wb_sdram = wishbone.Interface()
self.add_wb_slave(main_mem_origin, 0x10000000, self.wb_sdram)
def get_csrs(self):
return [self._reset]
def do_finalize(self):
self.submodules.wishbonecon = wishbone.InterconnectShared(
[self.cpu.ibus, self.cpu.dbus],
self._wb_slaves.get_interconnect_slaves(), register=True)
def add_wb_slave(self, origin, length, interface):
if self.finalized:
raise FinalizeError
self._wb_slaves.add(origin, length, interface)