mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
soc: simplify integrated memory parameters
This commit is contained in:
parent
273242b399
commit
369086a178
11 changed files with 48 additions and 70 deletions
6
make.py
6
make.py
|
@ -125,9 +125,9 @@ CPU type: {}
|
||||||
actions["build-bios"] = True
|
actions["build-bios"] = True
|
||||||
if not actions["load-bitstream"]:
|
if not actions["load-bitstream"]:
|
||||||
actions["flash-bitstream"] = True
|
actions["flash-bitstream"] = True
|
||||||
if not soc.with_integrated_rom:
|
if not soc.integrated_rom_size:
|
||||||
actions["flash-bios"] = True
|
actions["flash-bios"] = True
|
||||||
if actions["build-bitstream"] and soc.with_integrated_rom:
|
if actions["build-bitstream"] and soc.integrated_rom_size:
|
||||||
actions["build-bios"] = True
|
actions["build-bios"] = True
|
||||||
if actions["build-bios"]:
|
if actions["build-bios"]:
|
||||||
actions["build-headers"] = True
|
actions["build-headers"] = True
|
||||||
|
@ -176,7 +176,7 @@ CPU type: {}
|
||||||
raise OSError("BIOS build failed")
|
raise OSError("BIOS build failed")
|
||||||
|
|
||||||
if actions["build-bitstream"]:
|
if actions["build-bitstream"]:
|
||||||
if soc.with_integrated_rom:
|
if soc.integrated_rom_size:
|
||||||
with open(bios_file, "rb") as boot_file:
|
with open(bios_file, "rb") as boot_file:
|
||||||
boot_data = []
|
boot_data = []
|
||||||
while True:
|
while True:
|
||||||
|
|
|
@ -34,9 +34,9 @@ class SoC(Module):
|
||||||
}
|
}
|
||||||
def __init__(self, platform, clk_freq,
|
def __init__(self, platform, clk_freq,
|
||||||
cpu_type="lm32", cpu_reset_address=0x00000000,
|
cpu_type="lm32", cpu_reset_address=0x00000000,
|
||||||
with_integrated_rom=False, rom_size=0x8000,
|
integrated_rom_size=0,
|
||||||
with_integrated_sram=True, sram_size=4096,
|
integrated_sram_size=4096,
|
||||||
with_integrated_main_ram=False, main_ram_size=64*1024,
|
integrated_main_ram_size=0,
|
||||||
with_csr=True, csr_data_width=8, csr_address_width=14,
|
with_csr=True, csr_data_width=8, csr_address_width=14,
|
||||||
with_uart=True, uart_baudrate=115200,
|
with_uart=True, uart_baudrate=115200,
|
||||||
with_identifier=True,
|
with_identifier=True,
|
||||||
|
@ -45,19 +45,13 @@ class SoC(Module):
|
||||||
self.clk_freq = clk_freq
|
self.clk_freq = clk_freq
|
||||||
|
|
||||||
self.cpu_type = cpu_type
|
self.cpu_type = cpu_type
|
||||||
if with_integrated_rom:
|
if integrated_rom_size:
|
||||||
self.cpu_reset_address = 0
|
cpu_reset_address = 0
|
||||||
else:
|
self.cpu_reset_address = cpu_reset_address
|
||||||
self.cpu_reset_address = cpu_reset_address
|
|
||||||
|
|
||||||
self.with_integrated_rom = with_integrated_rom
|
self.integrated_rom_size = integrated_rom_size
|
||||||
self.rom_size = rom_size
|
self.integrated_sram_size = integrated_sram_size
|
||||||
|
self.integrated_main_ram_size = integrated_main_ram_size
|
||||||
self.with_integrated_sram = with_integrated_sram
|
|
||||||
self.sram_size = sram_size
|
|
||||||
|
|
||||||
self.with_integrated_main_ram = with_integrated_main_ram
|
|
||||||
self.main_ram_size = main_ram_size
|
|
||||||
|
|
||||||
self.with_uart = with_uart
|
self.with_uart = with_uart
|
||||||
self.uart_baudrate = uart_baudrate
|
self.uart_baudrate = uart_baudrate
|
||||||
|
@ -84,18 +78,18 @@ class SoC(Module):
|
||||||
self.add_wb_master(self.cpu_or_bridge.ibus)
|
self.add_wb_master(self.cpu_or_bridge.ibus)
|
||||||
self.add_wb_master(self.cpu_or_bridge.dbus)
|
self.add_wb_master(self.cpu_or_bridge.dbus)
|
||||||
|
|
||||||
if with_integrated_rom:
|
if integrated_rom_size:
|
||||||
self.submodules.rom = wishbone.SRAM(rom_size, read_only=True)
|
self.submodules.rom = wishbone.SRAM(integrated_rom_size, read_only=True)
|
||||||
self.register_rom(self.rom.bus, rom_size)
|
self.register_rom(self.rom.bus, integrated_rom_size)
|
||||||
|
|
||||||
if with_integrated_sram:
|
if integrated_sram_size:
|
||||||
self.submodules.sram = wishbone.SRAM(sram_size)
|
self.submodules.sram = wishbone.SRAM(integrated_sram_size)
|
||||||
self.register_mem("sram", self.mem_map["sram"], self.sram.bus, sram_size)
|
self.register_mem("sram", self.mem_map["sram"], self.sram.bus, integrated_sram_size)
|
||||||
|
|
||||||
# Note: Main Ram can be used when no external SDRAM is available and use SDRAM mapping.
|
# Note: Main Ram can be used when no external SDRAM is available and use SDRAM mapping.
|
||||||
if with_integrated_main_ram:
|
if integrated_main_ram_size:
|
||||||
self.submodules.main_ram = wishbone.SRAM(main_ram_size)
|
self.submodules.main_ram = wishbone.SRAM(integrated_main_ram_size)
|
||||||
self.register_mem("main_ram", self.mem_map["main_ram"], self.main_ram.bus, main_ram_size)
|
self.register_mem("main_ram", self.mem_map["main_ram"], self.main_ram.bus, integrated_main_ram_size)
|
||||||
|
|
||||||
if with_csr:
|
if with_csr:
|
||||||
self.submodules.wishbone2csr = wishbone2csr.WB2CSR(bus_csr=csr.Interface(csr_data_width, csr_address_width))
|
self.submodules.wishbone2csr = wishbone2csr.WB2CSR(bus_csr=csr.Interface(csr_data_width, csr_address_width))
|
||||||
|
|
|
@ -78,7 +78,7 @@ class SDRAMSoC(SoC):
|
||||||
raise NotImplementedError("Unsupported SDRAM width of {} > 32".format(sdram_width))
|
raise NotImplementedError("Unsupported SDRAM width of {} > 32".format(sdram_width))
|
||||||
|
|
||||||
def do_finalize(self):
|
def do_finalize(self):
|
||||||
if not self.with_integrated_main_ram:
|
if not self.integrated_ram_size:
|
||||||
if not self._sdram_phy_registered:
|
if not self._sdram_phy_registered:
|
||||||
raise FinalizeError("Need to call SDRAMSoC.register_sdram_phy()")
|
raise FinalizeError("Need to call SDRAMSoC.register_sdram_phy()")
|
||||||
SoC.do_finalize(self)
|
SoC.do_finalize(self)
|
||||||
|
|
|
@ -1,12 +1,8 @@
|
||||||
from migen.fhdl.std import *
|
from migen.fhdl.std import *
|
||||||
from migen.bus import wishbone
|
|
||||||
|
|
||||||
from misoclib.cpu.peripherals import gpio
|
|
||||||
from misoclib.mem import sdram
|
|
||||||
from misoclib.mem.sdram.module import IS42S16160
|
from misoclib.mem.sdram.module import IS42S16160
|
||||||
from misoclib.mem.sdram.phy import gensdrphy
|
from misoclib.mem.sdram.phy import gensdrphy
|
||||||
from misoclib.mem.sdram.core.lasmicon import LASMIconSettings
|
from misoclib.mem.sdram.core.lasmicon import LASMIconSettings
|
||||||
from misoclib.com import uart
|
|
||||||
from misoclib.soc.sdram import SDRAMSoC
|
from misoclib.soc.sdram import SDRAMSoC
|
||||||
|
|
||||||
class _PLL(Module):
|
class _PLL(Module):
|
||||||
|
@ -86,13 +82,13 @@ class BaseSoC(SDRAMSoC):
|
||||||
def __init__(self, platform, sdram_controller_settings=LASMIconSettings(), **kwargs):
|
def __init__(self, platform, sdram_controller_settings=LASMIconSettings(), **kwargs):
|
||||||
SDRAMSoC.__init__(self, platform,
|
SDRAMSoC.__init__(self, platform,
|
||||||
clk_freq=100*1000000,
|
clk_freq=100*1000000,
|
||||||
with_integrated_rom=True,
|
integrated_rom_size=0x8000,
|
||||||
sdram_controller_settings=sdram_controller_settings,
|
sdram_controller_settings=sdram_controller_settings,
|
||||||
**kwargs)
|
**kwargs)
|
||||||
|
|
||||||
self.submodules.crg = _CRG(platform)
|
self.submodules.crg = _CRG(platform)
|
||||||
|
|
||||||
if not self.with_integrated_main_ram:
|
if not self.integrated_main_ram_size:
|
||||||
self.submodules.sdrphy = gensdrphy.GENSDRPHY(platform.request("sdram"), IS42S16160(self.clk_freq))
|
self.submodules.sdrphy = gensdrphy.GENSDRPHY(platform.request("sdram"), IS42S16160(self.clk_freq))
|
||||||
self.register_sdram_phy(self.sdrphy)
|
self.register_sdram_phy(self.sdrphy)
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,6 @@
|
||||||
from migen.fhdl.std import *
|
from migen.fhdl.std import *
|
||||||
from migen.genlib.resetsync import AsyncResetSynchronizer
|
from migen.genlib.resetsync import AsyncResetSynchronizer
|
||||||
|
|
||||||
from misoclib.mem import sdram
|
|
||||||
from misoclib.mem.sdram.module import MT8JTF12864
|
from misoclib.mem.sdram.module import MT8JTF12864
|
||||||
from misoclib.mem.sdram.phy import k7ddrphy
|
from misoclib.mem.sdram.phy import k7ddrphy
|
||||||
from misoclib.mem.sdram.core.lasmicon import LASMIconSettings
|
from misoclib.mem.sdram.core.lasmicon import LASMIconSettings
|
||||||
|
@ -85,20 +84,18 @@ class BaseSoC(SDRAMSoC):
|
||||||
|
|
||||||
self.submodules.crg = _CRG(platform)
|
self.submodules.crg = _CRG(platform)
|
||||||
|
|
||||||
if not self.with_integrated_main_ram:
|
if not self.integrated_main_ram_size:
|
||||||
self.submodules.ddrphy = k7ddrphy.K7DDRPHY(platform.request("ddram"), MT8JTF12864(self.clk_freq))
|
self.submodules.ddrphy = k7ddrphy.K7DDRPHY(platform.request("ddram"), MT8JTF12864(self.clk_freq))
|
||||||
self.register_sdram_phy(self.ddrphy)
|
self.register_sdram_phy(self.ddrphy)
|
||||||
|
|
||||||
spiflash_pads = platform.request("spiflash")
|
if not self.integrated_rom_size:
|
||||||
spiflash_pads.clk = Signal()
|
spiflash_pads = platform.request("spiflash")
|
||||||
self.specials += Instance("STARTUPE2",
|
spiflash_pads.clk = Signal()
|
||||||
i_CLK=0, i_GSR=0, i_GTS=0, i_KEYCLEARB=0, i_PACK=0,
|
self.specials += Instance("STARTUPE2",
|
||||||
i_USRCCLKO=spiflash_pads.clk, i_USRCCLKTS=0, i_USRDONEO=1, i_USRDONETS=1)
|
i_CLK=0, i_GSR=0, i_GTS=0, i_KEYCLEARB=0, i_PACK=0,
|
||||||
self.submodules.spiflash = spiflash.SpiFlash(spiflash_pads, dummy=11, div=2)
|
i_USRCCLKO=spiflash_pads.clk, i_USRCCLKTS=0, i_USRDONEO=1, i_USRDONETS=1)
|
||||||
self.flash_boot_address = 0xb00000
|
self.submodules.spiflash = spiflash.SpiFlash(spiflash_pads, dummy=11, div=2)
|
||||||
|
self.flash_boot_address = 0xb00000
|
||||||
# If not in ROM, BIOS is in SPI flash
|
|
||||||
if not self.with_integrated_rom:
|
|
||||||
self.register_rom(self.spiflash.bus)
|
self.register_rom(self.spiflash.bus)
|
||||||
|
|
||||||
class MiniSoC(BaseSoC):
|
class MiniSoC(BaseSoC):
|
||||||
|
|
|
@ -3,11 +3,9 @@ from fractions import Fraction
|
||||||
from migen.fhdl.std import *
|
from migen.fhdl.std import *
|
||||||
from migen.genlib.resetsync import AsyncResetSynchronizer
|
from migen.genlib.resetsync import AsyncResetSynchronizer
|
||||||
|
|
||||||
from misoclib.mem import sdram
|
|
||||||
from misoclib.mem.sdram.module import AS4C16M16
|
from misoclib.mem.sdram.module import AS4C16M16
|
||||||
from misoclib.mem.sdram.phy import gensdrphy
|
from misoclib.mem.sdram.phy import gensdrphy
|
||||||
from misoclib.mem.sdram.core.lasmicon import LASMIconSettings
|
from misoclib.mem.sdram.core.lasmicon import LASMIconSettings
|
||||||
from misoclib.mem.flash import spiflash
|
|
||||||
from misoclib.soc.sdram import SDRAMSoC
|
from misoclib.soc.sdram import SDRAMSoC
|
||||||
|
|
||||||
class _CRG(Module):
|
class _CRG(Module):
|
||||||
|
@ -66,13 +64,13 @@ class BaseSoC(SDRAMSoC):
|
||||||
def __init__(self, platform, sdram_controller_settings=LASMIconSettings(), **kwargs):
|
def __init__(self, platform, sdram_controller_settings=LASMIconSettings(), **kwargs):
|
||||||
clk_freq = 80*1000000
|
clk_freq = 80*1000000
|
||||||
SDRAMSoC.__init__(self, platform, clk_freq,
|
SDRAMSoC.__init__(self, platform, clk_freq,
|
||||||
with_integrated_rom=True,
|
integrated_rom_size=0x8000,
|
||||||
sdram_controller_settings=sdram_controller_settings,
|
sdram_controller_settings=sdram_controller_settings,
|
||||||
**kwargs)
|
**kwargs)
|
||||||
|
|
||||||
self.submodules.crg = _CRG(platform, clk_freq)
|
self.submodules.crg = _CRG(platform, clk_freq)
|
||||||
|
|
||||||
if not self.with_integrated_main_ram:
|
if not self.integrated_main_ram_size:
|
||||||
self.submodules.sdrphy = gensdrphy.GENSDRPHY(platform.request("sdram"), AS4C16M16(clk_freq))
|
self.submodules.sdrphy = gensdrphy.GENSDRPHY(platform.request("sdram"), AS4C16M16(clk_freq))
|
||||||
self.register_sdram_phy(self.sdrphy)
|
self.register_sdram_phy(self.sdrphy)
|
||||||
|
|
||||||
|
|
|
@ -44,7 +44,7 @@ class BaseSoC(SDRAMSoC):
|
||||||
|
|
||||||
self.submodules.crg = mxcrg.MXCRG(_MXClockPads(platform), self.clk_freq)
|
self.submodules.crg = mxcrg.MXCRG(_MXClockPads(platform), self.clk_freq)
|
||||||
|
|
||||||
if not self.with_integrated_main_ram:
|
if not self.integrated_main_ram_size:
|
||||||
self.submodules.ddrphy = s6ddrphy.S6DDRPHY(platform.request("ddram"), MT46V32M16(self.clk_freq),
|
self.submodules.ddrphy = s6ddrphy.S6DDRPHY(platform.request("ddram"), MT46V32M16(self.clk_freq),
|
||||||
rd_bitslip=0, wr_bitslip=3, dqs_ddr_alignment="C1")
|
rd_bitslip=0, wr_bitslip=3, dqs_ddr_alignment="C1")
|
||||||
self.register_sdram_phy(self.ddrphy)
|
self.register_sdram_phy(self.ddrphy)
|
||||||
|
@ -53,7 +53,7 @@ class BaseSoC(SDRAMSoC):
|
||||||
self.ddrphy.clk4x_rd_strb.eq(self.crg.clk4x_rd_strb)
|
self.ddrphy.clk4x_rd_strb.eq(self.crg.clk4x_rd_strb)
|
||||||
]
|
]
|
||||||
|
|
||||||
if not self.with_integrated_rom:
|
if not self.integrated_rom_size:
|
||||||
clk_period_ns = 1000000000/self.clk_freq
|
clk_period_ns = 1000000000/self.clk_freq
|
||||||
self.submodules.norflash = norflash16.NorFlash16(platform.request("norflash"),
|
self.submodules.norflash = norflash16.NorFlash16(platform.request("norflash"),
|
||||||
ceil(110/clk_period_ns), ceil(50/clk_period_ns))
|
ceil(110/clk_period_ns), ceil(50/clk_period_ns))
|
||||||
|
|
|
@ -3,7 +3,6 @@ from fractions import Fraction
|
||||||
from migen.fhdl.std import *
|
from migen.fhdl.std import *
|
||||||
from migen.genlib.resetsync import AsyncResetSynchronizer
|
from migen.genlib.resetsync import AsyncResetSynchronizer
|
||||||
|
|
||||||
from misoclib.mem import sdram
|
|
||||||
from misoclib.mem.sdram.module import MT46H32M16
|
from misoclib.mem.sdram.module import MT46H32M16
|
||||||
from misoclib.mem.sdram.phy import s6ddrphy
|
from misoclib.mem.sdram.phy import s6ddrphy
|
||||||
from misoclib.mem.sdram.core.lasmicon import LASMIconSettings
|
from misoclib.mem.sdram.core.lasmicon import LASMIconSettings
|
||||||
|
@ -97,8 +96,6 @@ class BaseSoC(SDRAMSoC):
|
||||||
|
|
||||||
def __init__(self, platform, sdram_controller_settings=LASMIconSettings(), **kwargs):
|
def __init__(self, platform, sdram_controller_settings=LASMIconSettings(), **kwargs):
|
||||||
clk_freq = 75*1000000
|
clk_freq = 75*1000000
|
||||||
if not kwargs.get("with_integrated_rom"):
|
|
||||||
kwargs["rom_size"] = 0x1000000 # 128 Mb
|
|
||||||
SDRAMSoC.__init__(self, platform, clk_freq,
|
SDRAMSoC.__init__(self, platform, clk_freq,
|
||||||
cpu_reset_address=0x170000, # 1.5 MB
|
cpu_reset_address=0x170000, # 1.5 MB
|
||||||
sdram_controller_settings=sdram_controller_settings,
|
sdram_controller_settings=sdram_controller_settings,
|
||||||
|
@ -106,7 +103,7 @@ class BaseSoC(SDRAMSoC):
|
||||||
|
|
||||||
self.submodules.crg = _CRG(platform, clk_freq)
|
self.submodules.crg = _CRG(platform, clk_freq)
|
||||||
|
|
||||||
if not self.with_integrated_main_ram:
|
if not self.integrated_main_ram_size:
|
||||||
self.submodules.ddrphy = s6ddrphy.S6DDRPHY(platform.request("ddram"), MT46H32M16(self.clk_freq),
|
self.submodules.ddrphy = s6ddrphy.S6DDRPHY(platform.request("ddram"), MT46H32M16(self.clk_freq),
|
||||||
rd_bitslip=1, wr_bitslip=3, dqs_ddr_alignment="C1")
|
rd_bitslip=1, wr_bitslip=3, dqs_ddr_alignment="C1")
|
||||||
self.comb += [
|
self.comb += [
|
||||||
|
@ -118,10 +115,9 @@ class BaseSoC(SDRAMSoC):
|
||||||
""")
|
""")
|
||||||
self.register_sdram_phy(self.ddrphy)
|
self.register_sdram_phy(self.ddrphy)
|
||||||
|
|
||||||
self.submodules.spiflash = spiflash.SpiFlash(platform.request("spiflash4x"), dummy=10, div=4)
|
if not self.integrated_rom_size:
|
||||||
# If not in ROM, BIOS is in SPI flash
|
self.submodules.spiflash = spiflash.SpiFlash(platform.request("spiflash4x"), dummy=10, div=4)
|
||||||
if not self.with_integrated_rom:
|
|
||||||
self.flash_boot_address = 0x180000
|
self.flash_boot_address = 0x180000
|
||||||
self.register_rom(self.spiflash.bus)
|
self.register_rom(self.spiflash.bus, 0x1000000)
|
||||||
|
|
||||||
default_subtarget = BaseSoC
|
default_subtarget = BaseSoC
|
||||||
|
|
|
@ -3,7 +3,6 @@ from fractions import Fraction
|
||||||
from migen.fhdl.std import *
|
from migen.fhdl.std import *
|
||||||
from migen.genlib.resetsync import AsyncResetSynchronizer
|
from migen.genlib.resetsync import AsyncResetSynchronizer
|
||||||
|
|
||||||
from misoclib.mem import sdram
|
|
||||||
from misoclib.mem.sdram.module import MT48LC4M16
|
from misoclib.mem.sdram.module import MT48LC4M16
|
||||||
from misoclib.mem.sdram.phy import gensdrphy
|
from misoclib.mem.sdram.phy import gensdrphy
|
||||||
from misoclib.mem.sdram.core.lasmicon import LASMIconSettings
|
from misoclib.mem.sdram.core.lasmicon import LASMIconSettings
|
||||||
|
@ -77,15 +76,13 @@ class BaseSoC(SDRAMSoC):
|
||||||
|
|
||||||
self.submodules.crg = _CRG(platform, clk_freq)
|
self.submodules.crg = _CRG(platform, clk_freq)
|
||||||
|
|
||||||
if not self.with_integrated_main_ram:
|
if not self.integrated_main_ram_size:
|
||||||
self.submodules.sdrphy = gensdrphy.GENSDRPHY(platform.request("sdram"), MT48LC4M16(clk_freq))
|
self.submodules.sdrphy = gensdrphy.GENSDRPHY(platform.request("sdram"), MT48LC4M16(clk_freq))
|
||||||
self.register_sdram_phy(self.sdrphy)
|
self.register_sdram_phy(self.sdrphy)
|
||||||
|
|
||||||
self.submodules.spiflash = spiflash.SpiFlash(platform.request("spiflash2x"), dummy=4, div=6)
|
if not self.integrated_rom_size:
|
||||||
self.flash_boot_address = 0x70000
|
self.submodules.spiflash = spiflash.SpiFlash(platform.request("spiflash2x"), dummy=4, div=6)
|
||||||
|
self.flash_boot_address = 0x70000
|
||||||
# If not in ROM, BIOS is in SPI flash
|
|
||||||
if not self.with_integrated_rom:
|
|
||||||
self.register_rom(self.spiflash.bus)
|
self.register_rom(self.spiflash.bus)
|
||||||
|
|
||||||
default_subtarget = BaseSoC
|
default_subtarget = BaseSoC
|
||||||
|
|
|
@ -10,8 +10,8 @@ class BaseSoC(SoC):
|
||||||
def __init__(self, platform, **kwargs):
|
def __init__(self, platform, **kwargs):
|
||||||
SoC.__init__(self, platform,
|
SoC.__init__(self, platform,
|
||||||
clk_freq=int((1/(platform.default_clk_period))*1000000000),
|
clk_freq=int((1/(platform.default_clk_period))*1000000000),
|
||||||
with_integrated_rom=True,
|
integrated_rom_size=0x8000,
|
||||||
with_integrated_main_ram=True, main_ram_size=16*1024,
|
integrated_main_ram_size=16*1024,
|
||||||
**kwargs)
|
**kwargs)
|
||||||
self.submodules.crg = CRG(platform.request(platform.default_clk_name))
|
self.submodules.crg = CRG(platform.request(platform.default_clk_name))
|
||||||
|
|
||||||
|
|
|
@ -9,7 +9,7 @@ class BaseSoC(SoC):
|
||||||
def __init__(self, platform, **kwargs):
|
def __init__(self, platform, **kwargs):
|
||||||
SoC.__init__(self, platform,
|
SoC.__init__(self, platform,
|
||||||
clk_freq=100*1000000,
|
clk_freq=100*1000000,
|
||||||
with_integrated_rom=True,
|
integrated_rom_size=0x8000,
|
||||||
**kwargs)
|
**kwargs)
|
||||||
self.submodules.crg = CRG(platform.request("clk100"), ~platform.request("rst_n"))
|
self.submodules.crg = CRG(platform.request("clk100"), ~platform.request("rst_n"))
|
||||||
self.comb += platform.request("user_led", 0).eq(ResetSignal())
|
self.comb += platform.request("user_led", 0).eq(ResetSignal())
|
||||||
|
|
Loading…
Reference in a new issue