mirror of
https://gitlab.com/brendanhaines/cpu.git
synced 2024-12-26 19:16:48 -07:00
shift to iverilog + gtkwave for simulation
This commit is contained in:
parent
82283f01f4
commit
180f05fb0a
187
Makefile
187
Makefile
|
@ -1,187 +0,0 @@
|
||||||
###########################################################################
|
|
||||||
## Xilinx ISE Makefile
|
|
||||||
##
|
|
||||||
## To the extent possible under law, the author(s) have dedicated all copyright
|
|
||||||
## and related and neighboring rights to this software to the public domain
|
|
||||||
## worldwide. This software is distributed without any warranty.
|
|
||||||
###########################################################################
|
|
||||||
|
|
||||||
include project.cfg
|
|
||||||
|
|
||||||
|
|
||||||
###########################################################################
|
|
||||||
# Default values
|
|
||||||
###########################################################################
|
|
||||||
|
|
||||||
ifndef XILINX
|
|
||||||
$(error XILINX must be defined)
|
|
||||||
endif
|
|
||||||
|
|
||||||
ifndef PROJECT
|
|
||||||
$(error PROJECT must be defined)
|
|
||||||
endif
|
|
||||||
|
|
||||||
ifndef TARGET_PART
|
|
||||||
$(error TARGET_PART must be defined)
|
|
||||||
endif
|
|
||||||
|
|
||||||
TOPLEVEL ?= $(PROJECT)
|
|
||||||
CONSTRAINTS ?= $(PROJECT).ucf
|
|
||||||
BITFILE ?= build/$(PROJECT).bit
|
|
||||||
|
|
||||||
COMMON_OPTS ?= -intstyle xflow
|
|
||||||
XST_OPTS ?=
|
|
||||||
NGDBUILD_OPTS ?=
|
|
||||||
MAP_OPTS ?=
|
|
||||||
PAR_OPTS ?=
|
|
||||||
BITGEN_OPTS ?=
|
|
||||||
TRACE_OPTS ?=
|
|
||||||
FUSE_OPTS ?= -incremental
|
|
||||||
|
|
||||||
PROGRAMMER ?= none
|
|
||||||
|
|
||||||
IMPACT_OPTS ?= -batch impact.cmd
|
|
||||||
|
|
||||||
DJTG_EXE ?= djtgcfg
|
|
||||||
DJTG_DEVICE ?= DJTG_DEVICE-NOT-SET
|
|
||||||
DJTG_INDEX ?= 0
|
|
||||||
|
|
||||||
XC3SPROG_EXE ?= xc3sprog
|
|
||||||
XC3SPROG_CABLE ?= none
|
|
||||||
XC3SPROG_OPTS ?=
|
|
||||||
|
|
||||||
|
|
||||||
###########################################################################
|
|
||||||
# Internal variables, platform-specific definitions, and macros
|
|
||||||
###########################################################################
|
|
||||||
|
|
||||||
ifeq ($(OS),Windows_NT)
|
|
||||||
XILINX := $(shell cygpath -m $(XILINX))
|
|
||||||
CYG_XILINX := $(shell cygpath $(XILINX))
|
|
||||||
EXE := .exe
|
|
||||||
XILINX_PLATFORM ?= nt64
|
|
||||||
PATH := $(PATH):$(CYG_XILINX)/bin/$(XILINX_PLATFORM)
|
|
||||||
else
|
|
||||||
EXE :=
|
|
||||||
XILINX_PLATFORM ?= lin64
|
|
||||||
PATH := $(PATH):$(XILINX)/bin/$(XILINX_PLATFORM)
|
|
||||||
endif
|
|
||||||
|
|
||||||
TEST_NAMES = $(foreach file,$(VTEST) $(VHDTEST),$(basename $(file)))
|
|
||||||
TEST_EXES = $(foreach test,$(TEST_NAMES),build/isim_$(test)$(EXE))
|
|
||||||
|
|
||||||
RUN = @echo -ne "\n\n\e[1;33m======== $(1) ========\e[m\n\n"; \
|
|
||||||
cd build && $(XILINX)/bin/$(XILINX_PLATFORM)/$(1)
|
|
||||||
|
|
||||||
# isim executables don't work without this
|
|
||||||
export XILINX
|
|
||||||
|
|
||||||
|
|
||||||
###########################################################################
|
|
||||||
# Default build
|
|
||||||
###########################################################################
|
|
||||||
|
|
||||||
default: $(BITFILE)
|
|
||||||
|
|
||||||
clean:
|
|
||||||
rm -rf build
|
|
||||||
|
|
||||||
build/$(PROJECT).prj: project.cfg
|
|
||||||
@echo "Updating $@"
|
|
||||||
@mkdir -p build
|
|
||||||
@rm -f $@
|
|
||||||
@$(foreach file,$(VSOURCE),echo "verilog work \"../$(file)\"" >> $@;)
|
|
||||||
@$(foreach file,$(VHDSOURCE),echo "vhdl work \"../$(file)\"" >> $@;)
|
|
||||||
|
|
||||||
build/$(PROJECT)_sim.prj: build/$(PROJECT).prj
|
|
||||||
@cp build/$(PROJECT).prj $@
|
|
||||||
@$(foreach file,$(VTEST),echo "verilog work \"../$(file)\"" >> $@;)
|
|
||||||
@$(foreach file,$(VHDTEST),echo "vhdl work \"../$(file)\"" >> $@;)
|
|
||||||
@echo "verilog work $(XILINX)/verilog/src/glbl.v" >> $@
|
|
||||||
|
|
||||||
build/$(PROJECT).scr: project.cfg
|
|
||||||
@echo "Updating $@"
|
|
||||||
@mkdir -p build
|
|
||||||
@rm -f $@
|
|
||||||
@echo "run" \
|
|
||||||
"-ifn $(PROJECT).prj" \
|
|
||||||
"-ofn $(PROJECT).ngc" \
|
|
||||||
"-ifmt mixed" \
|
|
||||||
"$(XST_OPTS)" \
|
|
||||||
"-top $(TOPLEVEL)" \
|
|
||||||
"-ofmt NGC" \
|
|
||||||
"-p $(TARGET_PART)" \
|
|
||||||
> build/$(PROJECT).scr
|
|
||||||
|
|
||||||
$(BITFILE): project.cfg $(VSOURCE) $(CONSTRAINTS) build/$(PROJECT).prj build/$(PROJECT).scr
|
|
||||||
@mkdir -p build
|
|
||||||
$(call RUN,xst) $(COMMON_OPTS) \
|
|
||||||
-ifn $(PROJECT).scr
|
|
||||||
$(call RUN,ngdbuild) $(COMMON_OPTS) $(NGDBUILD_OPTS) \
|
|
||||||
-p $(TARGET_PART) -uc ../$(CONSTRAINTS) \
|
|
||||||
$(PROJECT).ngc $(PROJECT).ngd
|
|
||||||
$(call RUN,map) $(COMMON_OPTS) $(MAP_OPTS) \
|
|
||||||
-p $(TARGET_PART) \
|
|
||||||
-w $(PROJECT).ngd -o $(PROJECT).map.ncd $(PROJECT).pcf
|
|
||||||
$(call RUN,par) $(COMMON_OPTS) $(PAR_OPTS) \
|
|
||||||
-w $(PROJECT).map.ncd $(PROJECT).ncd $(PROJECT).pcf
|
|
||||||
$(call RUN,bitgen) $(COMMON_OPTS) $(BITGEN_OPTS) \
|
|
||||||
-w $(PROJECT).ncd $(PROJECT).bit
|
|
||||||
@echo -ne "\e[1;32m======== OK ========\e[m\n"
|
|
||||||
|
|
||||||
|
|
||||||
###########################################################################
|
|
||||||
# Testing (work in progress)
|
|
||||||
###########################################################################
|
|
||||||
|
|
||||||
trace: project.cfg $(BITFILE)
|
|
||||||
$(call RUN,trce) $(COMMON_OPTS) $(TRACE_OPTS) \
|
|
||||||
$(PROJECT).ncd $(PROJECT).pcf
|
|
||||||
|
|
||||||
test: $(TEST_EXES)
|
|
||||||
|
|
||||||
build/isim_%$(EXE): build/$(PROJECT)_sim.prj $(VSOURCE) $(VHDSOURCE) $(VTEST) $(VHDTEST)
|
|
||||||
$(call RUN,fuse) $(COMMON_OPTS) $(FUSE_OPTS) \
|
|
||||||
-prj $(PROJECT)_sim.prj \
|
|
||||||
-o isim_$*$(EXE) \
|
|
||||||
work.$* work.glbl
|
|
||||||
|
|
||||||
isim: build/isim_$(TB)$(EXE)
|
|
||||||
@grep --no-filename --no-messages 'ISIM:' $(TB).{v,vhd} | cut -d: -f2 > build/isim_$(TB).cmd
|
|
||||||
@echo "run all" >> build/isim_$(TB).cmd
|
|
||||||
cd build ; ./isim_$(TB)$(EXE) -tclbatch isim_$(TB).cmd
|
|
||||||
|
|
||||||
isimgui: build/isim_$(TB)$(EXE)
|
|
||||||
@grep --no-filename --no-messages 'ISIM:' $(TB).{v,vhd} | cut -d: -f2 > build/isim_$(TB).cmd
|
|
||||||
@echo "run all" >> build/isim_$(TB).cmd
|
|
||||||
cd build ; ./isim_$(TB)$(EXE) -gui -tclbatch isim_$(TB).cmd
|
|
||||||
|
|
||||||
|
|
||||||
###########################################################################
|
|
||||||
# Programming
|
|
||||||
###########################################################################
|
|
||||||
|
|
||||||
ifeq ($(PROGRAMMER), impact)
|
|
||||||
prog: $(BITFILE)
|
|
||||||
$(XILINX)/bin/$(XILINX_PLATFORM)/impact $(IMPACT_OPTS)
|
|
||||||
endif
|
|
||||||
|
|
||||||
ifeq ($(PROGRAMMER), digilent)
|
|
||||||
prog: $(BITFILE)
|
|
||||||
$(DJTG_EXE) prog -d $(DJTG_DEVICE) -i $(DJTG_INDEX) -f $(BITFILE)
|
|
||||||
endif
|
|
||||||
|
|
||||||
ifeq ($(PROGRAMMER), xc3sprog)
|
|
||||||
prog: $(BITFILE)
|
|
||||||
$(XC3SPROG_EXE) -c $(XC3SPROG_CABLE) $(XC3SPROG_OPTS) $(BITFILE)
|
|
||||||
endif
|
|
||||||
|
|
||||||
ifeq ($(PROGRAMMER), none)
|
|
||||||
prog:
|
|
||||||
$(error PROGRAMMER must be set to use 'make prog')
|
|
||||||
endif
|
|
||||||
|
|
||||||
|
|
||||||
###########################################################################
|
|
||||||
|
|
||||||
# vim: set filetype=make: #
|
|
2
hdl/.gitignore
vendored
Normal file
2
hdl/.gitignore
vendored
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
*.out
|
||||||
|
*.vcd
|
19
hdl/Makefile
Normal file
19
hdl/Makefile
Normal file
|
@ -0,0 +1,19 @@
|
||||||
|
# SOURCE_V = $(wildcard *.v)
|
||||||
|
# TESTBENCH_V = $(wildcard tb/*.v)
|
||||||
|
|
||||||
|
SOURCE_V = core.v
|
||||||
|
TESTBENCH_V = tb/core_tb.v
|
||||||
|
|
||||||
|
all: sim
|
||||||
|
|
||||||
|
tb.out: $(SOURCE_V) $(TESTBENCH_V)
|
||||||
|
iverilog $^ -o $@
|
||||||
|
|
||||||
|
sim: tb.out
|
||||||
|
./tb.out
|
||||||
|
|
||||||
|
clean:
|
||||||
|
rm -rf tb.out tb.vcd
|
||||||
|
|
||||||
|
.SECONDARY:
|
||||||
|
.PHONY: all clean sim
|
22
hdl/tb/core_tb.gtkw
Normal file
22
hdl/tb/core_tb.gtkw
Normal file
|
@ -0,0 +1,22 @@
|
||||||
|
[*]
|
||||||
|
[*] GTKWave Analyzer v3.3.86 (w)1999-2017 BSI
|
||||||
|
[*] Fri Jul 2 06:48:14 2021
|
||||||
|
[*]
|
||||||
|
[dumpfile] "/home/brendan/Documents/Projects/0039_cpu/hdl/core_tb.vcd"
|
||||||
|
[dumpfile_mtime] "Fri Jul 2 06:46:26 2021"
|
||||||
|
[dumpfile_size] 667859
|
||||||
|
[savefile] "/home/brendan/Documents/Projects/0039_cpu/hdl/tb/core_tb.gtkw"
|
||||||
|
[timestart] 0
|
||||||
|
[size] 1871 1025
|
||||||
|
[pos] -1900 -2
|
||||||
|
*0.000000 2 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1
|
||||||
|
[treeopen] core_tb.
|
||||||
|
[sst_width] 289
|
||||||
|
[signals_width] 199
|
||||||
|
[sst_expanded] 1
|
||||||
|
[sst_vpaned_height] 301
|
||||||
|
@28
|
||||||
|
core_tb.clk
|
||||||
|
core_tb.reset
|
||||||
|
[pattern_trace] 1
|
||||||
|
[pattern_trace] 0
|
|
@ -1,8 +1,12 @@
|
||||||
`timescale 500 ps / 1 ps
|
`timescale 1ns/1ps
|
||||||
|
|
||||||
module core_tb();
|
module core_tb();
|
||||||
|
|
||||||
initial $timeformat(-9, 2, " ns", 20);
|
initial $timeformat(-9, 2, " ns", 20);
|
||||||
|
initial begin
|
||||||
|
$dumpfile("core_tb.vcd");
|
||||||
|
$dumpvars(0);
|
||||||
|
end
|
||||||
|
|
||||||
wire dummy_out;
|
wire dummy_out;
|
||||||
|
|
||||||
|
@ -57,7 +61,7 @@ initial begin
|
||||||
|
|
||||||
#5000
|
#5000
|
||||||
reset = 1;
|
reset = 1;
|
||||||
$stop;
|
$finish;
|
||||||
end
|
end
|
||||||
|
|
||||||
always #2 clk = !clk;
|
always #2 clk = !clk;
|
||||||
|
|
Loading…
Reference in New Issue
Block a user