2015-10-08 17:58:59 +08:00
|
|
|
TOOLCHAIN_PREFIX = riscv32-unknown-elf-
|
2015-07-19 22:09:19 +08:00
|
|
|
|
2019-01-12 05:14:32 +08:00
|
|
|
# set to 4 for simulation
|
|
|
|
FIRMWARE_COUNTER_BITS=18
|
|
|
|
|
2015-07-19 22:09:19 +08:00
|
|
|
all: example.bin
|
|
|
|
|
2019-01-12 05:44:24 +08:00
|
|
|
## -------------------
|
|
|
|
## firmware generation
|
|
|
|
|
2015-07-19 22:09:19 +08:00
|
|
|
firmware.elf: firmware.S firmware.c firmware.lds
|
2019-01-12 05:14:32 +08:00
|
|
|
$(TOOLCHAIN_PREFIX)gcc \
|
|
|
|
-DSHIFT_COUNTER_BITS=$(FIRMWARE_COUNTER_BITS) \
|
|
|
|
-march=rv32i -Os -ffreestanding -nostdlib \
|
|
|
|
-o $@ firmware.S firmware.c \
|
|
|
|
--std=gnu99 -Wl,-Bstatic,-T,firmware.lds,-Map,firmware.map,--strip-debug -lgcc
|
2019-01-12 04:20:38 +08:00
|
|
|
chmod -x $@
|
2015-07-19 22:09:19 +08:00
|
|
|
|
|
|
|
firmware.bin: firmware.elf
|
2019-01-12 04:20:38 +08:00
|
|
|
$(TOOLCHAIN_PREFIX)objcopy -O binary $< $@
|
|
|
|
chmod -x $@
|
2015-07-19 22:09:19 +08:00
|
|
|
|
|
|
|
firmware.hex: firmware.bin
|
2019-01-12 04:20:38 +08:00
|
|
|
python3 ../../firmware/makehex.py $< 128 > $@
|
2015-07-19 22:09:19 +08:00
|
|
|
|
2019-01-12 05:44:24 +08:00
|
|
|
## ------------------------------
|
|
|
|
## main flow: synth/p&r/bitstream
|
|
|
|
|
2019-01-12 04:32:34 +08:00
|
|
|
synth.json: example.v ../../picorv32.v firmware.hex
|
|
|
|
yosys -v3 -l synth.log -p 'synth_ice40 -top top -json $@; write_verilog -attr2comment synth.v' $(filter %.v, $^)
|
2015-07-19 22:09:19 +08:00
|
|
|
|
2019-01-12 04:32:34 +08:00
|
|
|
example.asc: synth.json example.pcf
|
|
|
|
nextpnr-ice40 --hx8k --package ct256 --json $< --pcf example.pcf --asc $@
|
2015-07-19 22:09:19 +08:00
|
|
|
|
2016-07-14 15:07:52 +08:00
|
|
|
example.bin: example.asc
|
2019-01-12 04:20:38 +08:00
|
|
|
icepack $< $@
|
2015-07-19 22:09:19 +08:00
|
|
|
|
2019-01-12 05:44:24 +08:00
|
|
|
## -----------------
|
|
|
|
## icarus simulation
|
|
|
|
|
2019-01-12 04:20:38 +08:00
|
|
|
example_tb.vvp: example.v example_tb.v ../../picorv32.v firmware.hex
|
|
|
|
iverilog -o $@ -s testbench $(filter %.v, $^)
|
|
|
|
chmod -x $@
|
2015-07-19 22:09:19 +08:00
|
|
|
|
2016-05-04 14:57:16 +08:00
|
|
|
example_sim: example_tb.vvp
|
2019-01-12 04:20:38 +08:00
|
|
|
vvp -N $<
|
2015-07-21 23:43:33 +08:00
|
|
|
|
2016-05-04 14:57:16 +08:00
|
|
|
example_sim_vcd: example_tb.vvp
|
2019-01-12 04:20:38 +08:00
|
|
|
vvp -N $< +vcd
|
2015-07-21 23:43:33 +08:00
|
|
|
|
2019-01-12 05:44:24 +08:00
|
|
|
## ---------------------
|
|
|
|
## post-synth simulation
|
|
|
|
|
2019-01-12 04:32:34 +08:00
|
|
|
synth_tb.vvp: example_tb.v synth.json
|
2019-01-12 04:20:38 +08:00
|
|
|
iverilog -o $@ -s testbench synth.v example_tb.v `yosys-config --datdir/ice40/cells_sim.v`
|
|
|
|
chmod -x $@
|
2015-07-21 23:43:33 +08:00
|
|
|
|
2016-05-04 14:57:16 +08:00
|
|
|
synth_sim: synth_tb.vvp
|
2019-01-12 04:20:38 +08:00
|
|
|
vvp -N $<
|
2015-07-21 23:43:33 +08:00
|
|
|
|
2016-05-04 14:57:16 +08:00
|
|
|
synth_sim_vcd: synth_tb.vvp
|
2019-01-12 04:20:38 +08:00
|
|
|
vvp -N $< +vcd
|
2015-07-21 23:43:33 +08:00
|
|
|
|
2019-01-12 05:44:24 +08:00
|
|
|
## ---------------------
|
|
|
|
## post-route simulation
|
|
|
|
|
2019-01-12 04:20:38 +08:00
|
|
|
route.v: example.asc example.pcf
|
|
|
|
icebox_vlog -L -n top -sp example.pcf $< > $@
|
2015-07-21 23:43:33 +08:00
|
|
|
|
2019-01-12 04:20:38 +08:00
|
|
|
route_tb.vvp: route.v example_tb.v
|
|
|
|
iverilog -o $@ -s testbench $^ `yosys-config --datdir/ice40/cells_sim.v`
|
|
|
|
chmod -x $@
|
2015-07-21 23:43:33 +08:00
|
|
|
|
2016-05-04 14:57:16 +08:00
|
|
|
route_sim: route_tb.vvp
|
2019-01-12 04:20:38 +08:00
|
|
|
vvp -N $<
|
2015-07-21 23:43:33 +08:00
|
|
|
|
2016-05-04 14:57:16 +08:00
|
|
|
route_sim_vcd: route_tb.vvp
|
2019-01-12 04:20:38 +08:00
|
|
|
vvp -N $< +vcd
|
2015-07-19 22:09:19 +08:00
|
|
|
|
2019-01-12 05:44:24 +08:00
|
|
|
## ---------------------
|
|
|
|
## miscellaneous targets
|
|
|
|
|
2019-01-12 04:20:38 +08:00
|
|
|
prog_sram: example.bin
|
|
|
|
iceprog -S $<
|
2015-07-19 22:09:19 +08:00
|
|
|
|
2019-01-12 05:07:49 +08:00
|
|
|
timing: example.asc example.pcf
|
|
|
|
icetime -c 12 -tmd hx8k -P ct256 -p example.pcf -t $<
|
|
|
|
|
2019-01-12 04:20:38 +08:00
|
|
|
view: example.vcd
|
|
|
|
gtkwave $< example.gtkw
|
2015-07-21 23:43:33 +08:00
|
|
|
|
2019-01-12 05:44:24 +08:00
|
|
|
## ------
|
|
|
|
## el fin
|
|
|
|
|
2015-07-19 22:09:19 +08:00
|
|
|
clean:
|
|
|
|
rm -f firmware.elf firmware.map firmware.bin firmware.hex
|
2019-01-12 04:32:34 +08:00
|
|
|
rm -f synth.log synth.v synth.json route.v example.asc example.bin
|
2016-05-04 14:57:16 +08:00
|
|
|
rm -f example_tb.vvp synth_tb.vvp route_tb.vvp example.vcd
|
2015-07-19 22:09:19 +08:00
|
|
|
|
2015-07-21 23:43:33 +08:00
|
|
|
.PHONY: all prog_sram view clean
|
2019-01-12 05:07:49 +08:00
|
|
|
.PHONY: example_sim synth_sim route_sim timing
|
2015-07-21 23:43:33 +08:00
|
|
|
.PHONY: example_sim_vcd synth_sim_vcd route_sim_vcd
|