# This file is Copyright (c) 2017-2019 Florent Kermarrec # This file is Copyright (c) 2019 Tim 'mithro' Ansell # License: BSD import subprocess import unittest import os from migen import * from litex.soc.integration.builder import * RUNNING_ON_TRAVIS = (os.getenv('TRAVIS', 'false').lower() == 'true') def build_test(socs): errors = 0 for soc in socs: os.system("rm -rf build") builder = Builder(soc, output_dir="./build", compile_software=False, compile_gateware=False) builder.build() errors += not os.path.isfile("./build/gateware/top.v") os.system("rm -rf build") return errors class TestTargets(unittest.TestCase): # Build simple design for all platforms def test_simple(self): platforms = [] # Xilinx Spartan6 platforms.append("linsn_rv901t") platforms.append("minispartan6") platforms.append("pipistrello") platforms.append("sp605") # Xilinx Artix7 platforms.append("ac701") platforms.append("aller") platforms.append("arty") platforms.append("mimas_a7") platforms.append("netv2") platforms.append("nexys4ddr") platforms.append("nexys_video") platforms.append("tagus") # Xilinx Kintex7 platforms.append("genesys2") platforms.append("kc705") platforms.append("kx2") platforms.append("nereid") # Xilinx Virtex7 platforms.append("vc707") # Xilinx Kintex Ultrascale platforms.append("kcu105") # Xilinx Zynq Ultrascale+ platforms.append("zcu104") # Xilinx Virtex Ultrascale+ platforms.append("vcu118") # Intel Cyclone4 platforms.append("de0nano") platforms.append("de2_115") # Intel Cyclone5 platforms.append("de1soc") platforms.append("de10nano") # Intel Max10 platforms.append("de10lite") # Lattice iCE40 platforms.append("fomu_evt") platforms.append("fomu_hacker") platforms.append("fomu_pvt") platforms.append("tinyfpga_bx") # Lattice MachXO2 platforms.append("machxo3") # Lattice ECP3 platforms.append("versa_ecp3") # Lattice ECP5 platforms.append("ecp5_evn") platforms.append("hadbadge") platforms.append("orangecrab_r0_1") platforms.append("orangecrab_r0_2") platforms.append("trellisboard") platforms.append("ulx3s") platforms.append("versa_ecp5") platforms.append("colorlight_5a_75b") # Microsemi PolarFire platforms.append("avalanche") for name in platforms: with self.subTest(platform=name): cmd = """\ litex_boards/targets/simple.py litex_boards.platforms.{} \ --no-compile-software \ --no-compile-gateware \ --uart-name="stub" \ """.format(name) subprocess.check_call(cmd, shell=True)