From 88f7d5f019b0e26d470923bb30514ff568c8f111 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Fin=20Maa=C3=9F?= Date: Tue, 8 Oct 2024 13:27:59 +0200 Subject: [PATCH 1/5] finix_trion_t20_bga256_dev_kit: fix ClockSignal MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Fin Maaß --- litex_boards/targets/efinix_trion_t20_bga256_dev_kit.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/litex_boards/targets/efinix_trion_t20_bga256_dev_kit.py b/litex_boards/targets/efinix_trion_t20_bga256_dev_kit.py index 92fe6e261..04db654de 100755 --- a/litex_boards/targets/efinix_trion_t20_bga256_dev_kit.py +++ b/litex_boards/targets/efinix_trion_t20_bga256_dev_kit.py @@ -69,7 +69,7 @@ def __init__(self, sys_clk_freq=100e6, with_spi_flash=False, with_led_chaser=Tru # SDR SDRAM -------------------------------------------------------------------------------- if not self.integrated_main_ram_size and sys_clk_freq <= 50e6 : - self.specials += ClkOutput(ClockSignal(self.cd_sys_ps), platform.request("sdram_clock")) + self.specials += ClkOutput(ClockSignal("sys_ps"), platform.request("sdram_clock")) self.sdrphy = GENSDRPHY(platform.request("sdram"), sys_clk_freq) self.add_sdram("sdram", From 362a28b72ac6adc5dcd8a24e34520c84ef65969f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Fin=20Maa=C3=9F?= Date: Tue, 8 Oct 2024 13:40:30 +0200 Subject: [PATCH 2/5] efinix: fix reset MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit fix reset on all efinix boards. To reset the PLL a pulse is needed, which has to be driven by a clock that is not generated by the PLL. Signed-off-by: Fin Maaß --- litex_boards/platforms/efinix_t8f81_dev_kit.py | 1 + .../efinix_titanium_ti60_f225_dev_kit.py | 1 + .../efinix_trion_t120_bga576_dev_kit.py | 1 + .../platforms/efinix_trion_t20_bga256_dev_kit.py | 1 + .../platforms/efinix_trion_t20_mipi_dev_kit.py | 1 + litex_boards/platforms/efinix_xyloni_dev_kit.py | 1 + .../platforms/jungle_electronics_fireant.py | 1 + litex_boards/targets/efinix_t8f81_dev_kit.py | 14 ++++++++++++-- .../targets/efinix_ti375_c529_dev_kit.py | 16 +++++++++++++--- .../targets/efinix_titanium_ti60_f225_dev_kit.py | 14 ++++++++++++-- .../targets/efinix_trion_t120_bga576_dev_kit.py | 16 ++++++++++++---- .../targets/efinix_trion_t20_bga256_dev_kit.py | 7 +++++-- .../targets/efinix_trion_t20_mipi_dev_kit.py | 14 ++++++++++++-- litex_boards/targets/efinix_xyloni_dev_kit.py | 14 ++++++++++++-- .../targets/jungle_electronics_fireant.py | 14 ++++++++++++-- 15 files changed, 97 insertions(+), 19 deletions(-) diff --git a/litex_boards/platforms/efinix_t8f81_dev_kit.py b/litex_boards/platforms/efinix_t8f81_dev_kit.py index 870d4456d..983b680d9 100644 --- a/litex_boards/platforms/efinix_t8f81_dev_kit.py +++ b/litex_boards/platforms/efinix_t8f81_dev_kit.py @@ -52,6 +52,7 @@ class Platform(EfinixPlatform): default_clk_name = "clk33" + default_clk_freq = 33.333e6 default_clk_period = 1e9/33.333e6 def __init__(self, toolchain="efinity"): diff --git a/litex_boards/platforms/efinix_titanium_ti60_f225_dev_kit.py b/litex_boards/platforms/efinix_titanium_ti60_f225_dev_kit.py index a1620e9a2..71cd848ac 100644 --- a/litex_boards/platforms/efinix_titanium_ti60_f225_dev_kit.py +++ b/litex_boards/platforms/efinix_titanium_ti60_f225_dev_kit.py @@ -183,6 +183,7 @@ def rgmii_ethernet_qse_ios(con, n=""): class Platform(EfinixPlatform): default_clk_name = "clk25" + default_clk_freq = 25e6 default_clk_period = 1e9/50e6 def __init__(self, toolchain="efinity"): diff --git a/litex_boards/platforms/efinix_trion_t120_bga576_dev_kit.py b/litex_boards/platforms/efinix_trion_t120_bga576_dev_kit.py index 81b7f6f40..a0e19c2ae 100644 --- a/litex_boards/platforms/efinix_trion_t120_bga576_dev_kit.py +++ b/litex_boards/platforms/efinix_trion_t120_bga576_dev_kit.py @@ -174,6 +174,7 @@ def usb_pmod_io(pmod): class Platform(EfinixPlatform): default_clk_name = "clk40" + default_clk_freq = 40e6 default_clk_period = 1e9/40e6 def __init__(self, toolchain="efinity"): diff --git a/litex_boards/platforms/efinix_trion_t20_bga256_dev_kit.py b/litex_boards/platforms/efinix_trion_t20_bga256_dev_kit.py index e3f88dfb4..04435f7c8 100644 --- a/litex_boards/platforms/efinix_trion_t20_bga256_dev_kit.py +++ b/litex_boards/platforms/efinix_trion_t20_bga256_dev_kit.py @@ -113,6 +113,7 @@ class Platform(EfinixPlatform): default_clk_name = "clk50" + default_clk_freq = 50e6 default_clk_period = 1e9/50e6 def __init__(self, toolchain="efinity"): diff --git a/litex_boards/platforms/efinix_trion_t20_mipi_dev_kit.py b/litex_boards/platforms/efinix_trion_t20_mipi_dev_kit.py index 8746b3bd5..15b7e2cc9 100644 --- a/litex_boards/platforms/efinix_trion_t20_mipi_dev_kit.py +++ b/litex_boards/platforms/efinix_trion_t20_mipi_dev_kit.py @@ -64,6 +64,7 @@ class Platform(EfinixPlatform): default_clk_name = "clk50" + default_clk_freq = 50e6 default_clk_period = 1e9/50e6 def __init__(self, toolchain="efinity"): diff --git a/litex_boards/platforms/efinix_xyloni_dev_kit.py b/litex_boards/platforms/efinix_xyloni_dev_kit.py index 350f09bc6..d11c7b5f8 100644 --- a/litex_boards/platforms/efinix_xyloni_dev_kit.py +++ b/litex_boards/platforms/efinix_xyloni_dev_kit.py @@ -71,6 +71,7 @@ class Platform(EfinixPlatform): default_clk_name = "clk33" + default_clk_freq = 33.333e6 default_clk_period = 1e9/33.333e6 def __init__(self, toolchain="efinity"): diff --git a/litex_boards/platforms/jungle_electronics_fireant.py b/litex_boards/platforms/jungle_electronics_fireant.py index 376463f3b..82660c523 100644 --- a/litex_boards/platforms/jungle_electronics_fireant.py +++ b/litex_boards/platforms/jungle_electronics_fireant.py @@ -49,6 +49,7 @@ class Platform(EfinixPlatform): default_clk_name = "clk33" + default_clk_freq = 33.33e6 default_clk_period = 1e9/33.33e6 def __init__(self, toolchain="efinity"): diff --git a/litex_boards/targets/efinix_t8f81_dev_kit.py b/litex_boards/targets/efinix_t8f81_dev_kit.py index 528ca3ad3..9c9110703 100755 --- a/litex_boards/targets/efinix_t8f81_dev_kit.py +++ b/litex_boards/targets/efinix_t8f81_dev_kit.py @@ -13,6 +13,7 @@ from migen.genlib.resetsync import AsyncResetSynchronizer from litex.gen import * +from litex.gen.genlib.misc import WaitTimer from litex_boards.platforms import efinix_t8f81_dev_kit @@ -28,16 +29,25 @@ class _CRG(LiteXModule): def __init__(self, platform, sys_clk_freq): self.rst = Signal() self.cd_sys = ClockDomain() + self.cd_rst = ClockDomain(reset_less=True) # # # clk33 = platform.request("clk33") rst_n = platform.request("user_btn", 0) + self.comb += self.cd_rst.clk.eq(clk33) + + # A pulse is necessary to do a reset. + self.rst_pulse = Signal() + self.reset_timer = reset_timer = ClockDomainsRenamer("rst")(WaitTimer(25e-6*platform.default_clk_freq)) + self.comb += self.rst_pulse.eq(self.rst ^ reset_timer.done) + self.comb += reset_timer.wait.eq(self.rst) + # PLL. self.pll = pll = TRIONPLL(platform) - self.comb += pll.reset.eq(~rst_n | self.rst) - pll.register_clkin(clk33, 33.333e6) + self.comb += pll.reset.eq(~rst_n | self.rst_pulse) + pll.register_clkin(clk33, platform.default_clk_freq) pll.create_clkout(self.cd_sys, sys_clk_freq, with_reset=True) # BaseSoC ------------------------------------------------------------------------------------------ diff --git a/litex_boards/targets/efinix_ti375_c529_dev_kit.py b/litex_boards/targets/efinix_ti375_c529_dev_kit.py index 6b0f2b2ff..ecd7dd625 100755 --- a/litex_boards/targets/efinix_ti375_c529_dev_kit.py +++ b/litex_boards/targets/efinix_ti375_c529_dev_kit.py @@ -10,6 +10,7 @@ from migen.genlib.resetsync import AsyncResetSynchronizer from litex.gen import * +from litex.gen.genlib.misc import WaitTimer from litex.build.io import DDROutput, SDROutput, SDRTristate from litex.build.generic_platform import Subsignal, Pins, Misc, IOStandard @@ -39,11 +40,12 @@ class _CRG(LiteXModule): def __init__(self, platform, sys_clk_freq, cpu_clk_freq): - #self.rst = Signal() + self.rst = Signal() self.cd_sys = ClockDomain() self.cd_usb = ClockDomain() self.cd_video = ClockDomain() self.cd_cpu = ClockDomain() + self.cd_rst = ClockDomain(reset_less=True) # # # @@ -51,10 +53,18 @@ def __init__(self, platform, sys_clk_freq, cpu_clk_freq): clk100 = platform.request("clk100") rst_n = platform.request("user_btn", 0) + self.comb += self.cd_rst.clk.eq(clk100) + + # A pulse is necessary to do a reset. + self.rst_pulse = Signal() + self.reset_timer = reset_timer = ClockDomainsRenamer("rst")(WaitTimer(25e-6*platform.default_clk_freq)) + self.comb += self.rst_pulse.eq(self.rst ^ reset_timer.done) + self.comb += reset_timer.wait.eq(self.rst) + # PLL. self.pll = pll = TITANIUMPLL(platform) - self.comb += pll.reset.eq(~rst_n) - pll.register_clkin(clk100, 100e6) + self.comb += pll.reset.eq(~rst_n | self.rst_pulse) + pll.register_clkin(clk100, platform.default_clk_freq) # You can use CLKOUT0 only for clocks with a maximum frequency of 4x # (integer) of the reference clock. If all your system clocks do not fall within # this range, you should dedicate one unused clock for CLKOUT0. diff --git a/litex_boards/targets/efinix_titanium_ti60_f225_dev_kit.py b/litex_boards/targets/efinix_titanium_ti60_f225_dev_kit.py index 9f3c539a3..bf03dbbd2 100755 --- a/litex_boards/targets/efinix_titanium_ti60_f225_dev_kit.py +++ b/litex_boards/targets/efinix_titanium_ti60_f225_dev_kit.py @@ -10,6 +10,7 @@ from migen.genlib.resetsync import AsyncResetSynchronizer from litex.gen import * +from litex.gen.genlib.misc import WaitTimer from litex_boards.platforms import efinix_titanium_ti60_f225_dev_kit @@ -31,16 +32,25 @@ def __init__(self, platform, sys_clk_freq): self.cd_sys = ClockDomain() self.cd_sys2x = ClockDomain() self.cd_sys2x_ps = ClockDomain() + self.cd_rst = ClockDomain(reset_less=True) # # # clk25 = platform.request("clk25") rst_n = platform.request("user_btn", 0) + self.comb += self.cd_rst.clk.eq(clk25) + + # A pulse is necessary to do a reset. + self.rst_pulse = Signal() + self.reset_timer = reset_timer = ClockDomainsRenamer("rst")(WaitTimer(25e-6*platform.default_clk_freq)) + self.comb += self.rst_pulse.eq(self.rst ^ reset_timer.done) + self.comb += reset_timer.wait.eq(self.rst) + # PLL self.pll = pll = TITANIUMPLL(platform) - self.comb += pll.reset.eq(~rst_n | self.rst) - pll.register_clkin(clk25, 25e6) + self.comb += pll.reset.eq(~rst_n | self.rst_pulse) + pll.register_clkin(clk25, platform.default_clk_freq) # You can use CLKOUT0 only for clocks with a maximum frequency of 4x # (integer) of the reference clock. If all your system clocks do not fall within # this range, you should dedicate one unused clock for CLKOUT0. diff --git a/litex_boards/targets/efinix_trion_t120_bga576_dev_kit.py b/litex_boards/targets/efinix_trion_t120_bga576_dev_kit.py index 587ec5f79..22aee546a 100755 --- a/litex_boards/targets/efinix_trion_t120_bga576_dev_kit.py +++ b/litex_boards/targets/efinix_trion_t120_bga576_dev_kit.py @@ -13,6 +13,7 @@ from migen.genlib.resetsync import AsyncResetSynchronizer from litex.gen import * +from litex.gen.genlib.misc import WaitTimer from litex_boards.platforms import efinix_trion_t120_bga576_dev_kit @@ -29,20 +30,27 @@ class _CRG(LiteXModule): def __init__(self, platform, sys_clk_freq): - #self.rst = Signal() + self.rst = Signal() self.cd_sys = ClockDomain() + self.cd_rst = ClockDomain(reset_less=True) # # # clk40 = platform.request("clk40") rst_n = platform.request("user_btn", 0) + self.comb += self.cd_rst.clk.eq(clk40) + + # A pulse is necessary to do a reset. + self.rst_pulse = Signal() + self.reset_timer = reset_timer = ClockDomainsRenamer("rst")(WaitTimer(25e-6*platform.default_clk_freq)) + self.comb += self.rst_pulse.eq(self.rst ^ reset_timer.done) + self.comb += reset_timer.wait.eq(self.rst) # PLL self.pll = pll = TRIONPLL(platform) - #self.comb += pll.reset.eq(~rst_n | self.rst) - self.comb += pll.reset.eq(~rst_n) - pll.register_clkin(clk40, 40e6) + self.comb += pll.reset.eq(~rst_n | self.rst_pulse) + pll.register_clkin(clk40, platform.default_clk_freq) pll.create_clkout(self.cd_sys, sys_clk_freq, with_reset=True, name="axi_clk") # BaseSoC ------------------------------------------------------------------------------------------ diff --git a/litex_boards/targets/efinix_trion_t20_bga256_dev_kit.py b/litex_boards/targets/efinix_trion_t20_bga256_dev_kit.py index 04db654de..a0829619d 100755 --- a/litex_boards/targets/efinix_trion_t20_bga256_dev_kit.py +++ b/litex_boards/targets/efinix_trion_t20_bga256_dev_kit.py @@ -35,6 +35,7 @@ def __init__(self, platform, sys_clk_freq): self.rst = Signal() self.cd_sys = ClockDomain() self.cd_sys_ps = ClockDomain() + self.cd_rst = ClockDomain(reset_less=True) # # # @@ -42,16 +43,18 @@ def __init__(self, platform, sys_clk_freq): clk50 = platform.request("clk50") rst_n = platform.request("user_btn", 0) + self.comb += self.cd_rst.clk.eq(clk50) + # A pulse is necessary to do a reset. self.rst_pulse = Signal() - reset_timer = WaitTimer(25e-6*sys_clk_freq) + self.reset_timer = reset_timer = ClockDomainsRenamer("rst")(WaitTimer(25e-6*platform.default_clk_freq)) self.comb += self.rst_pulse.eq(self.rst ^ reset_timer.done) self.comb += reset_timer.wait.eq(self.rst) # PLL. self.pll = pll = TRIONPLL(platform) self.comb += pll.reset.eq(~rst_n | self.rst_pulse) - pll.register_clkin(clk50, 50e6) + pll.register_clkin(clk50, platform.default_clk_freq) pll.create_clkout(self.cd_sys, sys_clk_freq, with_reset=True) pll.create_clkout(self.cd_sys_ps, sys_clk_freq, phase=180) diff --git a/litex_boards/targets/efinix_trion_t20_mipi_dev_kit.py b/litex_boards/targets/efinix_trion_t20_mipi_dev_kit.py index e117289a8..92133dbfc 100755 --- a/litex_boards/targets/efinix_trion_t20_mipi_dev_kit.py +++ b/litex_boards/targets/efinix_trion_t20_mipi_dev_kit.py @@ -10,6 +10,7 @@ from migen.genlib.resetsync import AsyncResetSynchronizer from litex.gen import * +from litex.gen.genlib.misc import WaitTimer from litex_boards.platforms import efinix_trion_t20_mipi_dev_kit @@ -26,16 +27,25 @@ class _CRG(LiteXModule): def __init__(self, platform, sys_clk_freq): self.rst = Signal() self.cd_sys = ClockDomain() + self.cd_rst = ClockDomain(reset_less=True) # # # clk50 = platform.request("clk50") rst_n = platform.request("user_btn", 0) + self.comb += self.cd_rst.clk.eq(clk50) + + # A pulse is necessary to do a reset. + self.rst_pulse = Signal() + self.reset_timer = reset_timer = ClockDomainsRenamer("rst")(WaitTimer(25e-6*platform.default_clk_freq)) + self.comb += self.rst_pulse.eq(self.rst ^ reset_timer.done) + self.comb += reset_timer.wait.eq(self.rst) + # PLL self.pll = pll = TRIONPLL(platform) - self.comb += pll.reset.eq(~rst_n | self.rst) - pll.register_clkin(clk50, 50e6) + self.comb += pll.reset.eq(~rst_n | self.rst_pulse) + pll.register_clkin(clk50, platform.default_clk_freq) pll.create_clkout(self.cd_sys, sys_clk_freq, with_reset=True) # BaseSoC ------------------------------------------------------------------------------------------ diff --git a/litex_boards/targets/efinix_xyloni_dev_kit.py b/litex_boards/targets/efinix_xyloni_dev_kit.py index 1dfcc5c06..17fbb7f77 100755 --- a/litex_boards/targets/efinix_xyloni_dev_kit.py +++ b/litex_boards/targets/efinix_xyloni_dev_kit.py @@ -12,6 +12,7 @@ from migen.genlib.resetsync import AsyncResetSynchronizer from litex.gen import * +from litex.gen.genlib.misc import WaitTimer from litex_boards.platforms import efinix_xyloni_dev_kit @@ -27,16 +28,25 @@ class _CRG(LiteXModule): def __init__(self, platform, sys_clk_freq): self.rst = Signal() self.cd_sys = ClockDomain() + self.cd_rst = ClockDomain(reset_less=True) # # # clk33 = platform.request("clk33") rst_n = platform.request("user_btn", 0) + self.comb += self.cd_rst.clk.eq(clk33) + + # A pulse is necessary to do a reset. + self.rst_pulse = Signal() + self.reset_timer = reset_timer = ClockDomainsRenamer("rst")(WaitTimer(25e-6*platform.default_clk_freq)) + self.comb += self.rst_pulse.eq(self.rst ^ reset_timer.done) + self.comb += reset_timer.wait.eq(self.rst) + # PLL. self.pll = pll = TRIONPLL(platform) - self.comb += pll.reset.eq(~rst_n | self.rst) - pll.register_clkin(clk33, 33.333e6) + self.comb += pll.reset.eq(~rst_n | self.rst_pulse) + pll.register_clkin(clk33, platform.default_clk_freq) pll.create_clkout(self.cd_sys, sys_clk_freq, with_reset=True) # BaseSoC ------------------------------------------------------------------------------------------ diff --git a/litex_boards/targets/jungle_electronics_fireant.py b/litex_boards/targets/jungle_electronics_fireant.py index 91e288c14..a6fa79be6 100755 --- a/litex_boards/targets/jungle_electronics_fireant.py +++ b/litex_boards/targets/jungle_electronics_fireant.py @@ -13,6 +13,7 @@ from migen.genlib.resetsync import AsyncResetSynchronizer from litex.gen import * +from litex.gen.genlib.misc import WaitTimer from litex_boards.platforms import jungle_electronics_fireant @@ -31,16 +32,25 @@ class _CRG(LiteXModule): def __init__(self, platform, sys_clk_freq): self.rst = Signal() self.cd_sys = ClockDomain() + self.cd_rst = ClockDomain(reset_less=True) # # # clk33 = platform.request("clk33") rst_n = platform.request("user_btn", 0) + self.comb += self.cd_rst.clk.eq(clk33) + + # A pulse is necessary to do a reset. + self.rst_pulse = Signal() + self.reset_timer = reset_timer = ClockDomainsRenamer("rst")(WaitTimer(25e-6*platform.default_clk_freq)) + self.comb += self.rst_pulse.eq(self.rst ^ reset_timer.done) + self.comb += reset_timer.wait.eq(self.rst) + # PLL. self.pll = pll = TRIONPLL(platform) - self.comb += pll.reset.eq(~rst_n | self.rst) - pll.register_clkin(clk33, 33.333e6) + self.comb += pll.reset.eq(~rst_n | self.rst_pulse) + pll.register_clkin(clk33, platform.default_clk_freq) pll.create_clkout(self.cd_sys, sys_clk_freq, with_reset=True) # Default peripherals From 3b8c55802f9305920c9f97e72efb0fd2d570f972 Mon Sep 17 00:00:00 2001 From: Gwenhael Goavec-Merou Date: Wed, 6 Nov 2024 16:58:11 +0100 Subject: [PATCH 3/5] platforms/limesdr_mini_v2.py: fixed SPI Flash pinout MOSI <-> MISO --- litex_boards/platforms/limesdr_mini_v2.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/litex_boards/platforms/limesdr_mini_v2.py b/litex_boards/platforms/limesdr_mini_v2.py index 41b3c3273..91ebff9f5 100644 --- a/litex_boards/platforms/limesdr_mini_v2.py +++ b/litex_boards/platforms/limesdr_mini_v2.py @@ -37,8 +37,8 @@ ("spiflash", 0, Subsignal("cs_n", Pins("U17")), Subsignal("clk", Pins("U16")), - Subsignal("miso", Pins("U18")), - Subsignal("mosi", Pins("T18")), + Subsignal("miso", Pins("T18")), + Subsignal("mosi", Pins("U18")), IOStandard("LVCMOS33"), ), From eb43cd3ca9eaefab53e97d6cdfd2cd3b385c9a37 Mon Sep 17 00:00:00 2001 From: Oleg Libin Date: Fri, 8 Nov 2024 15:54:00 +0500 Subject: [PATCH 4/5] Update sipeed_tang_nano_4k.py replace kB to KILOBYTE --- litex_boards/targets/sipeed_tang_nano_4k.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/litex_boards/targets/sipeed_tang_nano_4k.py b/litex_boards/targets/sipeed_tang_nano_4k.py index afb9f6abe..69e6d1a65 100755 --- a/litex_boards/targets/sipeed_tang_nano_4k.py +++ b/litex_boards/targets/sipeed_tang_nano_4k.py @@ -86,12 +86,12 @@ def __init__(self, toolchain="gowin", sys_clk_freq=27e6, # Use EMCU's SRAM. self.bus.add_region("sram", SoCRegion( origin = self.cpu.mem_map["sram"], - size = 16 * kB, + size = 16 * KILOBYTE, )) # Use ECMU's FLASH as ROM. self.bus.add_region("rom", SoCRegion( origin = self.cpu.mem_map["rom"], - size = 32 * kB, + size = 32 * KILOBYTE, linker = True, )) # No Gowin EMCU ---------------------------------------------------------------------------- From 15ad3ab3414c07be17ca7065cebf7c50e29daca5 Mon Sep 17 00:00:00 2001 From: Gwenhael Goavec-Merou Date: Sat, 9 Nov 2024 07:20:51 +0100 Subject: [PATCH 5/5] platforms/limesdr_mini_v2.py: commented spiflash clk pad. Must be used via USRMCLK. Automatically done by LiteSPI --- litex_boards/platforms/limesdr_mini_v2.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/litex_boards/platforms/limesdr_mini_v2.py b/litex_boards/platforms/limesdr_mini_v2.py index 91ebff9f5..ab2ff79dd 100644 --- a/litex_boards/platforms/limesdr_mini_v2.py +++ b/litex_boards/platforms/limesdr_mini_v2.py @@ -36,7 +36,7 @@ # SPIFlash ("spiflash", 0, Subsignal("cs_n", Pins("U17")), - Subsignal("clk", Pins("U16")), + #Subsignal("clk", Pins("U16")), Subsignal("miso", Pins("T18")), Subsignal("mosi", Pins("U18")), IOStandard("LVCMOS33"),