# # This file is part of LiteX. # # Copyright (c) 2020 Florent Kermarrec <florent@enjoy-digital.fr> # SPDX-License-Identifier: BSD-2-Clause import unittest from migen import * from litex.soc.cores.clock import * class TestClock(unittest.TestCase): # Xilinx / Spartan 6 def test_s6_pll(self): pll = S6PLL() pll.register_clkin(Signal(), 100e6) for i in range(pll.nclkouts_max): pll.create_clkout(ClockDomain("clkout{}".format(i)), 200e6) pll.compute_config() def test_s6_dcm(self): dcm = S6DCM() dcm.register_clkin(Signal(), 100e6) for i in range(dcm.nclkouts_max): dcm.create_clkout(ClockDomain("clkout{}".format(i)), 200e6) dcm.compute_config() # Xilinx / 7-Series def test_s7_pll(self): pll = S7PLL() pll.register_clkin(Signal(), 100e6) for i in range(pll.nclkouts_max): pll.create_clkout(ClockDomain("clkout{}".format(i)), 200e6) pll.compute_config() def test_s7_mmcm(self): mmcm = S7MMCM() mmcm.register_clkin(Signal(), 100e6) for i in range(mmcm.nclkouts_max): mmcm.create_clkout(ClockDomain("clkout{}".format(i)), 200e6) mmcm.compute_config() # Xilinx / Ultrascale def test_us_pll(self): pll = USPLL() pll.register_clkin(Signal(), 100e6) for i in range(pll.nclkouts_max): pll.create_clkout(ClockDomain("clkout{}".format(i)), 200e6) pll.compute_config() def test_us_mmcm(self): mmcm = USMMCM() mmcm.register_clkin(Signal(), 100e6) for i in range(mmcm.nclkouts_max): mmcm.create_clkout(ClockDomain("clkout{}".format(i)), 200e6) mmcm.compute_config() # Xilinx / Ultrascale Plus def test_us_ppll(self): pll = USPPLL() pll.register_clkin(Signal(), 100e6) for i in range(pll.nclkouts_max): pll.create_clkout(ClockDomain("clkout{}".format(i)), 200e6) pll.compute_config() def test_us_pmmcm(self): mmcm = USPMMCM() mmcm.register_clkin(Signal(), 100e6) for i in range(mmcm.nclkouts_max): mmcm.create_clkout(ClockDomain("clkout{}".format(i)), 200e6) mmcm.compute_config() # Intel / CycloneIV def test_cycloneiv_pll(self): pll = CycloneIVPLL() pll.register_clkin(Signal(), 50e6) for i in range(pll.nclkouts_max): pll.create_clkout(ClockDomain("clkout{}".format(i)), 100e6) pll.compute_config() # Intel / CycloneV def test_cyclonev_pll(self): pll = CycloneVPLL() pll.register_clkin(Signal(), 50e6) for i in range(pll.nclkouts_max): pll.create_clkout(ClockDomain("clkout{}".format(i)), 100e6) pll.compute_config() # Intel / Cyclone10 def test_cyclone10_pll(self): pll = Cyclone10LPPLL() pll.register_clkin(Signal(), 50e6) for i in range(pll.nclkouts_max): pll.create_clkout(ClockDomain("clkout{}".format(i)), 100e6) pll.compute_config() # Intel / Max10 def test_max10_pll(self): pll = Max10PLL() pll.register_clkin(Signal(), 50e6) for i in range(pll.nclkouts_max): pll.create_clkout(ClockDomain("clkout{}".format(i)), 100e6) pll.compute_config() # Lattice / iCE40 def test_ice40_pll(self): pll = USMMCM() pll.register_clkin(Signal(), 100e6) for i in range(pll.nclkouts_max): pll.create_clkout(ClockDomain("clkout{}".format(i)), 200e6) pll.compute_config() # Lattice / ECP5 def test_ecp5_pll(self): pll = ECP5PLL() pll.register_clkin(Signal(), 100e6) for i in range(pll.nclkouts_max-1): pll.create_clkout(ClockDomain("clkout{}".format(i)), 200e6, uses_dpa=(i != 0)) pll.expose_dpa() pll.compute_config() # Test corner cases that have historically had trouble: pll = ECP5PLL() pll.register_clkin(Signal(), 100e6) pll.create_clkout(ClockDomain("clkout1"), 350e6) pll.create_clkout(ClockDomain("clkout2"), 350e6) pll.create_clkout(ClockDomain("clkout3"), 175e6) pll.create_clkout(ClockDomain("clkout4"), 175e6) pll.compute_config() def test_ecp5_dynamic_delay(self): delay = ECP5DynamicDelay(i=Signal(), o=Signal(), taps=Signal(7)) delay = ECP5DynamicDelay() # Lattice / NX def test_nxpll(self): pll = NXPLL() pll.register_clkin(Signal(), 100e6) for i in range(pll.nclkouts_max): pll.create_clkout(ClockDomain("clkout{}".format(i)), 200e6) pll.compute_config()