travis: simplify, enable and add RISC-V toolchain to build targets

This commit is contained in:
Florent Kermarrec 2019-04-22 08:32:00 +02:00
parent 8c78997089
commit e98ac680c1
5 changed files with 21 additions and 103 deletions

View file

@ -1,51 +0,0 @@
#!/usr/bin/env bash
set -e
# Some colors, use it like following;
# echo -e "Hello ${YELLOW}yellow${NC}"
GRAY='\033[0;30m'
GREEN='\033[0;32m'
YELLOW='\033[0;33m'
PURPLE='\033[0;35m'
NC='\033[0m' # No Color
SPACER="echo -e ${GRAY} - ${NC}"
travis_fold start "environment.create"
travis_time_start
echo -e "Setting up basic ${YELLOW}conda environment${NC}"
echo "-------------------------------------------------------------------"
conda env create -f environment.yml
source activate litex
echo "-------------------------------------------------------------------"
travis_time_finish
travis_fold end "environment.create"
$SPACER
SOC_FILES=$(find litex/boards/targets -name \*.py | grep -v sim | grep -v "__")
COUNT=4
for SOC_FILE in $SOC_FILES; do
SOC=$(echo $SOC_FILE | sed -e's/\.py$//' -e's-/-.-g')
TARGET=$(echo $SOC | sed -e's/.*\.//')
travis_fold start "$SOC.1"
travis_time_start
echo -e "Building ${GREEN}${TARGET}${NC} (${PURPLE}${SOC}${NC})"
echo "-------------------------------------------------------------------"
python -m $SOC --no-compile-gateware
echo "-------------------------------------------------------------------"
travis_time_finish
travis_fold end "$SOC.1"
travis_fold start "$SOC.2"
echo -e "Output of building ${GREEN}${TARGET}${NC} (${PURPLE}${SOC}${NC})"
echo "-------------------------------------------------------------------"
find soc_*$TARGET* | sort
echo "-------------------------------------------------------------------"
travis_fold end "$SOC.2"
$SPACER
done

View file

@ -1,19 +1,16 @@
language: python language: python
python: dist: Xenial
- "3.6" python: "3.6"
install: install:
- wget https://repo.continuum.io/miniconda/Miniconda3-latest-Linux-x86_64.sh -O miniconda.sh # Get Migen / LiteX / Cores
- bash miniconda.sh -b -p $HOME/miniconda - wget https://raw.githubusercontent.com/enjoy-digital/litex/master/litex_setup.py
- export PATH="$HOME/miniconda/bin:$PATH" - python3 litex_setup.py init install
- hash -r
- conda config --set always_yes yes --set changeps1 no
before_script: before_script:
- export -f travis_nanoseconds # Get RISC-V toolchain
- export -f travis_fold - wget https://static.dev.sifive.com/dev-tools/riscv64-unknown-elf-gcc-20171231-x86_64-linux-centos6.tar.gz
- export -f travis_time_start - tar -xvf riscv64-unknown-elf-gcc-20171231-x86_64-linux-centos6.tar.gz
- export -f travis_time_finish - export PATH=$PATH:$PWD/riscv64-unknown-elf-gcc-20171231-x86_64-linux-centos6/bin/
script: script: python setup.py test
- ./.travis-build-socs.sh

17
README
View file

@ -87,23 +87,6 @@ Migen documentation can be found here: https://m-labs.hk/migen/manual
FPGA lessons/tutorials can be found at: https://github.com/enjoy-digital/fpga_101 FPGA lessons/tutorials can be found at: https://github.com/enjoy-digital/fpga_101
[> Medium Quick start guide with Conda
-----------------------------------------
0. Get miniconda by following instructions at https://conda.io/miniconda.html
1. Clone LiteX
git clone --recurse-submodules https://github.com/enjoy-digital/litex.git
2. Create a LiteX environment from environment.yml
conda env create -f environment.yml
3. Enter conda environment
conda activate litex
4. Build the target of your board...:
Go to boards/targets and execute the target you want to build
[> Quick start guide (for advanced users) [> Quick start guide (for advanced users)
----------------------------------------- -----------------------------------------

View file

@ -1,13 +0,0 @@
name: litex
channels:
- timvideos
dependencies:
- python=3.6
- pip
- binutils-lm32-elf
- gcc-lm32-elf-nostdc
- pip:
- git+https://github.com/m-labs/migen.git#egg=migen
- -e .
- git+https://github.com/enjoy-digital/liteeth.git#egg=liteeth
- git+https://github.com/enjoy-digital/litedram.git#egg=litedram

View file

@ -18,53 +18,54 @@ def build_test(socs):
class TestTargets(unittest.TestCase): class TestTargets(unittest.TestCase):
kwargs = {"cpu_type": "vexriscv"}
# altera boards # altera boards
def test_de0nano(self): def test_de0nano(self):
from litex.boards.targets.de0nano import BaseSoC from litex.boards.targets.de0nano import BaseSoC
errors = build_test([BaseSoC()]) errors = build_test([BaseSoC(**self.kwargs)])
self.assertEqual(errors, 0) self.assertEqual(errors, 0)
# xilinx boards # xilinx boards
def test_minispartan6(self): def test_minispartan6(self):
from litex.boards.targets.minispartan6 import BaseSoC from litex.boards.targets.minispartan6 import BaseSoC
errors = build_test([BaseSoC()]) errors = build_test([BaseSoC(**self.kwargs)])
self.assertEqual(errors, 0) self.assertEqual(errors, 0)
def test_arty(self): def test_arty(self):
from litex.boards.targets.arty import BaseSoC, EthernetSoC from litex.boards.targets.arty import BaseSoC, EthernetSoC
errors = build_test([BaseSoC(), EthernetSoC()]) errors = build_test([BaseSoC(**self.kwargs), EthernetSoC(**self.kwargs)])
self.assertEqual(errors, 0) self.assertEqual(errors, 0)
def test_nexys4ddr(self): def test_nexys4ddr(self):
from litex.boards.targets.nexys4ddr import BaseSoC from litex.boards.targets.nexys4ddr import BaseSoC
errors = build_test([BaseSoC()]) errors = build_test([BaseSoC(**self.kwargs)])
self.assertEqual(errors, 0) self.assertEqual(errors, 0)
def test_nexys_video(self): def test_nexys_video(self):
from litex.boards.targets.nexys_video import BaseSoC, EthernetSoC from litex.boards.targets.nexys_video import BaseSoC, EthernetSoC
errors = build_test([BaseSoC(), EthernetSoC()]) errors = build_test([BaseSoC(**self.kwargs), EthernetSoC(**self.kwargs)])
self.assertEqual(errors, 0) self.assertEqual(errors, 0)
def test_genesys2(self): def test_genesys2(self):
from litex.boards.targets.genesys2 import BaseSoC, EthernetSoC from litex.boards.targets.genesys2 import BaseSoC, EthernetSoC
errors = build_test([BaseSoC(), EthernetSoC()]) errors = build_test([BaseSoC(**self.kwargs), EthernetSoC(**self.kwargs)])
self.assertEqual(errors, 0) self.assertEqual(errors, 0)
def test_kc705(self): def test_kc705(self):
from litex.boards.targets.kc705 import BaseSoC, EthernetSoC from litex.boards.targets.kc705 import BaseSoC, EthernetSoC
errors = build_test([BaseSoC(), EthernetSoC()]) errors = build_test([BaseSoC(**self.kwargs), EthernetSoC(**self.kwargs)])
self.assertEqual(errors, 0) self.assertEqual(errors, 0)
# lattice boards # lattice boards
def test_versa_ecp5(self): def test_versa_ecp5(self):
from litex.boards.targets.versa_ecp5 import BaseSoC from litex.boards.targets.versa_ecp5 import BaseSoC
errors = build_test([BaseSoC()]) errors = build_test([BaseSoC(**self.kwargs)])
self.assertEqual(errors, 0) self.assertEqual(errors, 0)
def test_versa_ulx3s(self): def test_versa_ulx3s(self):
from litex.boards.targets.ulx3s import BaseSoC from litex.boards.targets.ulx3s import BaseSoC
errors = build_test([BaseSoC()]) errors = build_test([BaseSoC(**self.kwargs)])
self.assertEqual(errors, 0) self.assertEqual(errors, 0)
# build simple design for all platforms # build simple design for all platforms
@ -85,6 +86,7 @@ class TestTargets(unittest.TestCase):
] ]
for p in platforms: for p in platforms:
os.system("litex_simple litex.boards.platforms." + p + os.system("litex_simple litex.boards.platforms." + p +
" --cpu-type=vexriscv " +
" --no-compile-software " + " --no-compile-software " +
" --no-compile-gateware " + " --no-compile-gateware " +
" --uart-stub=True") " --uart-stub=True")