2015-06-06 20:01:37 +08:00
2016-12-09 18:47:05 +08:00
RISCV_GNU_TOOLCHAIN_GIT_REVISION = 805ee1d
RISCV_GNU_TOOLCHAIN_INSTALL_PREFIX = /opt/riscv32
2016-04-09 18:29:19 +08:00
2016-08-17 07:06:10 +08:00
SHELL = bash
2015-06-27 04:02:22 +08:00
TEST_OBJS = $( addsuffix .o,$( basename $( wildcard tests/*.S) ) )
2015-06-27 05:14:38 +08:00
FIRMWARE_OBJS = firmware/start.o firmware/irq.o firmware/print.o firmware/sieve.o firmware/multest.o firmware/stats.o
2015-07-04 22:31:26 +08:00
GCC_WARNS = -Werror -Wall -Wextra -Wshadow -Wundef -Wpointer-arith -Wcast-qual -Wcast-align -Wwrite-strings
2015-07-04 17:47:19 +08:00
GCC_WARNS += -Wredundant-decls -Wstrict-prototypes -Wmissing-prototypes -pedantic # -Wconversion
2016-12-09 18:47:05 +08:00
TOOLCHAIN_PREFIX = $( RISCV_GNU_TOOLCHAIN_INSTALL_PREFIX) i/bin/riscv32-unknown-elf-
2016-04-09 20:35:17 +08:00
COMPRESSED_ISA = C
2015-06-06 20:01:37 +08:00
2016-05-04 14:57:16 +08:00
test : testbench .vvp firmware /firmware .hex
vvp -N testbench.vvp
2015-06-06 20:01:37 +08:00
2016-05-04 14:57:16 +08:00
testbench.vcd : testbench .vvp firmware /firmware .hex
2016-08-26 20:54:27 +08:00
vvp -N $< +vcd +trace +noerror
2015-07-02 16:45:35 +08:00
2015-07-02 17:01:21 +08:00
view : testbench .vcd
2015-07-02 16:45:35 +08:00
gtkwave $< testbench.gtkw
2016-09-03 21:16:24 +08:00
check : check -yices
2016-08-29 23:23:00 +08:00
2016-09-03 21:16:24 +08:00
check-% : check .smt 2
yosys-smtbmc -s $( subst check-,,$@ ) -t 30 --dump-vcd check.vcd check.smt2
2016-09-14 01:34:14 +08:00
yosys-smtbmc -s $( subst check-,,$@ ) -t 25 --dump-vcd check.vcd -i check.smt2
2015-10-15 05:26:04 +08:00
check.smt2 : picorv 32.v
yosys -v2 -p 'read_verilog -formal picorv32.v' \
-p 'prep -top picorv32 -nordff' \
2016-09-07 18:40:19 +08:00
-p 'assertpmux -noinit; opt -fast' \
2016-08-30 20:37:21 +08:00
-p 'write_smt2 -wires check.smt2'
2015-10-15 05:26:04 +08:00
2016-05-04 14:57:16 +08:00
test_sp : testbench_sp .vvp firmware /firmware .hex
vvp -N testbench_sp.vvp
2015-06-27 05:54:12 +08:00
2016-05-04 14:57:16 +08:00
test_axi : testbench .vvp firmware /firmware .hex
vvp -N testbench.vvp +axi_test
2015-06-07 01:22:28 +08:00
2016-05-04 14:57:16 +08:00
test_synth : testbench_synth .vvp firmware /firmware .hex
vvp -N testbench_synth.vvp
2015-06-30 07:46:25 +08:00
2016-05-04 14:57:16 +08:00
testbench.vvp : testbench .v picorv 32.v
2016-11-23 10:02:02 +08:00
iverilog -o testbench.vvp $( subst C,-DCOMPRESSED_ISA,$( COMPRESSED_ISA) ) -DRISCV_FORMAL testbench.v picorv32.v
2016-05-04 14:57:16 +08:00
chmod -x testbench.vvp
2015-06-06 20:01:37 +08:00
2016-05-04 14:57:16 +08:00
testbench_sp.vvp : testbench .v picorv 32.v
2016-11-23 10:02:02 +08:00
iverilog -o testbench_sp.vvp $( subst C,-DCOMPRESSED_ISA,$( COMPRESSED_ISA) ) -DRISCV_FORMAL -DSP_TEST testbench.v picorv32.v
2016-05-04 14:57:16 +08:00
chmod -x testbench_sp.vvp
2015-06-27 05:54:12 +08:00
2016-05-04 14:57:16 +08:00
testbench_synth.vvp : testbench .v synth .v
iverilog -o testbench_synth.vvp testbench.v synth.v
chmod -x testbench_synth.vvp
2015-06-30 07:46:25 +08:00
synth.v : picorv 32.v scripts /yosys /synth_sim .ys
yosys -qv3 -l synth.log scripts/yosys/synth_sim.ys
2015-06-06 20:01:37 +08:00
firmware/firmware.hex : firmware /firmware .bin firmware /makehex .py
2015-07-16 17:10:02 +08:00
python3 firmware/makehex.py $< 16384 > $@
2015-06-06 20:01:37 +08:00
firmware/firmware.bin : firmware /firmware .elf
2015-07-04 17:47:19 +08:00
$( TOOLCHAIN_PREFIX) objcopy -O binary $< $@
2015-06-06 20:01:37 +08:00
chmod -x $@
2015-06-27 04:02:22 +08:00
firmware/firmware.elf : $( FIRMWARE_OBJS ) $( TEST_OBJS ) firmware /sections .lds
2015-07-04 17:47:19 +08:00
$( TOOLCHAIN_PREFIX) gcc -Os -m32 -ffreestanding -nostdlib -o $@ \
2015-06-06 20:01:37 +08:00
-Wl,-Bstatic,-T,firmware/sections.lds,-Map,firmware/firmware.map,--strip-debug \
2015-06-27 04:02:22 +08:00
$( FIRMWARE_OBJS) $( TEST_OBJS) -lgcc
2015-06-06 20:01:37 +08:00
chmod -x $@
2015-06-25 20:08:39 +08:00
firmware/start.o : firmware /start .S
2016-02-03 23:33:01 +08:00
$( TOOLCHAIN_PREFIX) gcc -c -m32 -march= RV32IM$( COMPRESSED_ISA) Xcustom -o $@ $<
2015-06-25 20:08:39 +08:00
2015-06-27 04:02:22 +08:00
firmware/%.o : firmware /%.c
2016-02-03 23:33:01 +08:00
$( TOOLCHAIN_PREFIX) gcc -c -m32 -march= RV32I$( COMPRESSED_ISA) -Os --std= c99 $( GCC_WARNS) -ffreestanding -nostdlib -o $@ $<
2015-06-27 04:02:22 +08:00
2015-06-06 20:01:37 +08:00
tests/%.o : tests /%.S tests /riscv_test .h tests /test_macros .h
2015-11-04 01:59:12 +08:00
$( TOOLCHAIN_PREFIX) gcc -c -m32 -march= RV32IM -o $@ -DTEST_FUNC_NAME= $( notdir $( basename $<) ) \
2015-06-06 20:01:37 +08:00
-DTEST_FUNC_TXT= '"$(notdir $(basename $<))"' -DTEST_FUNC_RET= $( notdir $( basename $<) ) _ret $<
2016-04-09 18:29:19 +08:00
download-tools :
2016-12-08 21:09:09 +08:00
sudo bash -c ' set -ex; mkdir -p /var/cache/distfiles; \
$( foreach REPO,riscv-gnu-toolchain riscv-binutils-gdb riscv-dejagnu riscv-gcc riscv-glibc riscv-newlib, \
2016-08-17 07:06:10 +08:00
if ! test -d /var/cache/distfiles/$( REPO) .git; then rm -rf /var/cache/distfiles/$( REPO) .git.part; \
git clone --bare https://github.com/riscv/$( REPO) /var/cache/distfiles/$( REPO) .git.part; \
mv /var/cache/distfiles/$( REPO) .git.part /var/cache/distfiles/$( REPO) .git; else \
( cd /var/cache/distfiles/$( REPO) .git; git fetch https://github.com/riscv/$( REPO) ) ; fi ; ) '
2016-04-09 18:29:19 +08:00
d e f i n e b u i l d _ t o o l s _ t e m p l a t e
build-$(1)-tools :
2016-12-09 18:47:05 +08:00
@read -p " This will remove all existing data from $( RISCV_GNU_TOOLCHAIN_INSTALL_PREFIX) $( subst riscv32,,$( 1) ) . Type YES to continue: " reply && [ [ " $$ $$ reply " = = [ Yy] [ Ee] [ Ss] || " $$ $$ reply " = = [ Yy] ] ]
sudo bash -c " set -ex; rm -rf $( RISCV_GNU_TOOLCHAIN_INSTALL_PREFIX) $( subst riscv32,,$( 1) ) ; mkdir -p $( RISCV_GNU_TOOLCHAIN_INSTALL_PREFIX) $( subst riscv32,,$( 1) ) ; chown $$ $$ {USER}. $( RISCV_GNU_TOOLCHAIN_INSTALL_PREFIX) $( subst riscv32,,$( 1) ) "
+$( MAKE) build-$( 1) -tools-bh
2016-04-11 18:46:29 +08:00
build-$(1)-tools-bh :
2016-08-17 07:06:10 +08:00
+set -ex; \
if [ -d /var/cache/distfiles/riscv-gnu-toolchain.git ] ; then reference_riscv_gnu_toolchain = "--reference /var/cache/distfiles/riscv-gnu-toolchain.git" ; else reference_riscv_gnu_toolchain = "" ; fi ; \
if [ -d /var/cache/distfiles/riscv-binutils-gdb.git ] ; then reference_riscv_binutils_gdb = "--reference /var/cache/distfiles/riscv-binutils-gdb.git" ; else reference_riscv_binutils_gdb = "" ; fi ; \
if [ -d /var/cache/distfiles/riscv-dejagnu.git ] ; then reference_riscv_dejagnu = "--reference /var/cache/distfiles/riscv-dejagnu.git" ; else reference_riscv_dejagnu = "" ; fi ; \
if [ -d /var/cache/distfiles/riscv-gcc.git ] ; then reference_riscv_gcc = "--reference /var/cache/distfiles/riscv-gcc.git" ; else reference_riscv_gcc = "" ; fi ; \
if [ -d /var/cache/distfiles/riscv-glibc.git ] ; then reference_riscv_glibc = "--reference /var/cache/distfiles/riscv-glibc.git" ; else reference_riscv_glibc = "" ; fi ; \
2016-12-08 21:09:09 +08:00
if [ -d /var/cache/distfiles/riscv-newlib.git ] ; then reference_riscv_newlib = "--reference /var/cache/distfiles/riscv-newlib.git" ; else reference_riscv_newlib = "" ; fi ; \
2016-08-17 07:06:10 +08:00
rm -rf riscv-gnu-toolchain-$( 1) ; git clone $$ $$ reference_riscv_gnu_toolchain https://github.com/riscv/riscv-gnu-toolchain riscv-gnu-toolchain-$( 1) ; \
2016-12-09 18:47:05 +08:00
cd riscv-gnu-toolchain-$( 1) ; git checkout $( RISCV_GNU_TOOLCHAIN_GIT_REVISION) ; \
2016-08-17 07:06:10 +08:00
git submodule update --init $$ $$ reference_riscv_binutils_gdb riscv-binutils-gdb; \
git submodule update --init $$ $$ reference_riscv_dejagnu riscv-dejagnu; \
git submodule update --init $$ $$ reference_riscv_gcc riscv-gcc; \
git submodule update --init $$ $$ reference_riscv_glibc riscv-glibc; \
2016-12-08 21:09:09 +08:00
git submodule update --init $$ $$ reference_riscv_newlib riscv-newlib; \
2016-12-09 18:47:05 +08:00
mkdir build; cd build; ../configure --with-arch= $( 2) --prefix= $( RISCV_GNU_TOOLCHAIN_INSTALL_PREFIX) $( subst riscv32,,$( 1) ) ; make
2016-04-09 18:29:19 +08:00
.PHONY : build -$( 1) -tools
e n d e f
2016-05-31 22:21:24 +08:00
$( eval $ ( call build_tools_template ,riscv 32i ,RV 32I ) )
$( eval $ ( call build_tools_template ,riscv 32ic ,RV 32IC ) )
$( eval $ ( call build_tools_template ,riscv 32im ,RV 32IM ) )
$( eval $ ( call build_tools_template ,riscv 32imc ,RV 32IMC ) )
2016-04-09 18:29:19 +08:00
2016-04-11 18:46:29 +08:00
build-tools :
2016-12-09 18:47:05 +08:00
@echo " This will remove all existing data from $( RISCV_GNU_TOOLCHAIN_INSTALL_PREFIX) i, $( RISCV_GNU_TOOLCHAIN_INSTALL_PREFIX) ic, $( RISCV_GNU_TOOLCHAIN_INSTALL_PREFIX) im, and $( RISCV_GNU_TOOLCHAIN_INSTALL_PREFIX) imc. "
2016-04-11 18:46:29 +08:00
@read -p "Type YES to continue: " reply && [ [ " $$ reply " = = [ Yy] [ Ee] [ Ss] || " $$ reply " = = [ Yy] ] ]
2016-12-09 18:47:05 +08:00
sudo bash -c " set -ex; rm -rf $( RISCV_GNU_TOOLCHAIN_INSTALL_PREFIX) {i,ic,im,imc}; mkdir -p $( RISCV_GNU_TOOLCHAIN_INSTALL_PREFIX) {i,ic,im,imc}; chown $$ {USER}. $( RISCV_GNU_TOOLCHAIN_INSTALL_PREFIX) {i,ic,im,imc} "
+$( MAKE) build-riscv32i-tools-bh
+$( MAKE) build-riscv32ic-tools-bh
+$( MAKE) build-riscv32im-tools-bh
+$( MAKE) build-riscv32imc-tools-bh
2016-04-11 18:46:29 +08:00
2015-06-30 18:25:05 +08:00
toc :
gawk '/^-+$$/ { y=tolower(x); gsub("[^a-z0-9]+", "-", y); gsub("-$$", "", y); printf("- [%s](#%s)\n", x, y); } { x=$$0; }' README.md
2015-06-06 20:01:37 +08:00
clean :
2016-04-09 18:51:50 +08:00
rm -rf riscv-gnu-toolchain-riscv32i riscv-gnu-toolchain-riscv32ic \
riscv-gnu-toolchain-riscv32im riscv-gnu-toolchain-riscv32imc
2015-10-15 05:26:04 +08:00
rm -vrf $( FIRMWARE_OBJS) $( TEST_OBJS) check.smt2 check.vcd synth.v synth.log \
2015-07-02 17:01:21 +08:00
firmware/firmware.elf firmware/firmware.bin firmware/firmware.hex firmware/firmware.map \
2016-08-25 20:15:42 +08:00
testbench.vvp testbench_sp.vvp testbench_synth.vvp testbench.vcd testbench.trace
2015-06-06 20:01:37 +08:00
2016-09-03 21:16:24 +08:00
.PHONY : test view test_sp test_axi test_synth download -tools build -tools toc clean
2015-06-06 20:01:37 +08:00