2010-08-31 09:39:37 -05:00
|
|
|
##########################################################
|
|
|
|
### WARNING YOU MUST SET THE VARIABLE XILINX FIRST ##
|
|
|
|
### /install_dir/Xilinx/10.1/ISE/
|
|
|
|
##########################################################
|
2010-04-30 22:21:55 -05:00
|
|
|
DESIGN = plasma
|
2010-04-21 20:01:38 -05:00
|
|
|
PINS = $(DESIGN).ucf
|
2010-05-25 21:49:58 -05:00
|
|
|
DEVICE = xc3s500e-VQ100-4
|
2010-04-21 20:01:38 -05:00
|
|
|
BGFLAGS = -g TdoPin:PULLNONE -g DonePin:PULLUP \
|
|
|
|
-g CRC:enable -g StartUpClk:CCLK
|
2010-08-12 19:51:53 -05:00
|
|
|
|
2010-04-21 20:01:38 -05:00
|
|
|
SIM_CMD = /opt/cad/modeltech/bin/vsim
|
|
|
|
SIM_COMP_SCRIPT = simulation/$(DESIGN)_TB.do
|
|
|
|
SIMGEN_OPTIONS = -p $(FPGA_ARCH) -lang $(LANGUAGE)
|
|
|
|
|
2010-08-12 19:51:53 -05:00
|
|
|
SIMTOP = $(DESIGN)_tb
|
|
|
|
GHDL_SIM_OPT = --stop-time=1ms
|
|
|
|
SIMDIR = simu
|
|
|
|
GHDL_CMD = ghdl
|
|
|
|
GHDL_SIMU_FLAGS = --ieee=synopsys -P$$XILINX/ghdl/unisim --warn-no-vital-generic
|
|
|
|
GHDL_SYNTHESIS_FLAGS = --ieee=synopsys -P$$XILINX/ghdl/unisim --warn-no-vital-generic
|
|
|
|
GHDL_PANDR_FLAGS = --ieee=synopsys -P$$XILINX/ghdl/simprim --warn-no-vital-generic
|
|
|
|
VIEW_CMD = gtkwave
|
|
|
|
TESTBENCH_FILE = $(DESIGN)_TB.vhd
|
|
|
|
SYNT_TESTBENCH_FILE = $(DESIGN)_TB_syn.vhd
|
|
|
|
SYNTHESIS_FILE = simu/$(DESIGN)_synt.vhd
|
|
|
|
LIBRARY_FILE = mlite_pack.vhd
|
|
|
|
|
2010-05-27 21:26:56 -05:00
|
|
|
SRC_HDL = mlite_pack.vhd plasma.vhd ram_image.vhd alu.vhd control.vhd mem_ctrl.vhd mult.vhd shifter.vhd bus_mux.vhd mlite_cpu.vhd pc_next.vhd pipeline.vhd reg_bank.vhd uart.vhd
|
2010-04-21 20:01:38 -05:00
|
|
|
|
|
|
|
all: bits
|
|
|
|
|
|
|
|
remake: clean-build all
|
|
|
|
|
|
|
|
clean:
|
|
|
|
rm -rf *~ */*~ a.out *.log *.key *.edf *.ps trace.dat
|
|
|
|
rm -rf *.bit rm -rf simulation/work simulation/*wlf
|
2010-04-30 22:21:55 -05:00
|
|
|
rm -rf simulation/transcript
|
2010-04-21 20:01:38 -05:00
|
|
|
|
|
|
|
clean-build:
|
|
|
|
rm -rf build
|
|
|
|
|
2010-08-12 19:51:53 -05:00
|
|
|
cleanall: clean clean_ghdl
|
2010-04-21 20:01:38 -05:00
|
|
|
rm -rf build work $(DESIGN).bit
|
|
|
|
|
|
|
|
bits: $(DESIGN).bit
|
|
|
|
|
|
|
|
#
|
|
|
|
# Synthesis
|
|
|
|
#
|
|
|
|
build/project.src:
|
|
|
|
@[ -d build ] || mkdir build
|
|
|
|
@rm -f $@
|
|
|
|
for i in $(SRC); do echo verilog work ../$$i >> $@; done
|
|
|
|
for i in $(SRC_HDL); do echo VHDL work ../$$i >> $@; done
|
|
|
|
|
|
|
|
build/project.xst: build/project.src
|
|
|
|
echo "run" > $@
|
|
|
|
echo "-top $(DESIGN) " >> $@
|
|
|
|
echo "-p $(DEVICE)" >> $@
|
|
|
|
echo "-opt_mode Area" >> $@
|
|
|
|
echo "-opt_level 1" >> $@
|
|
|
|
echo "-ifn project.src" >> $@
|
|
|
|
echo "-ifmt mixed" >> $@
|
|
|
|
echo "-ofn project.ngc" >> $@
|
|
|
|
echo "-ofmt NGC" >> $@
|
|
|
|
echo "-rtlview yes" >> $@
|
|
|
|
|
|
|
|
build/project.ngc: build/project.xst $(SRC)
|
|
|
|
cd build && xst -ifn project.xst -ofn project.log
|
|
|
|
|
2010-05-25 21:49:58 -05:00
|
|
|
build/project.ngd: build/project.ngc $(PINS)
|
|
|
|
cd build && ngdbuild -p $(DEVICE) project.ngc -uc ../$(PINS)
|
2010-04-21 20:01:38 -05:00
|
|
|
|
|
|
|
build/project.ncd: build/project.ngd
|
|
|
|
cd build && map -pr b -p $(DEVICE) project
|
|
|
|
|
|
|
|
build/project_r.ncd: build/project.ncd
|
|
|
|
cd build && par -w project project_r.ncd
|
|
|
|
|
|
|
|
build/project_r.twr: build/project_r.ncd
|
|
|
|
cd build && trce -v 25 project_r.ncd project.pcf
|
|
|
|
|
|
|
|
$(DESIGN).bit: build/project_r.ncd build/project_r.twr
|
|
|
|
cd build && bitgen project_r.ncd -l -w $(BGFLAGS)
|
|
|
|
@mv -f build/project_r.bit $@
|
2010-05-10 14:56:51 -05:00
|
|
|
|
2010-08-12 19:51:53 -05:00
|
|
|
build/project.vhd: build/project.ngc
|
|
|
|
cd build && netgen -w -ofmt vhdl project.ngc project.vhd
|
2010-05-10 14:56:51 -05:00
|
|
|
|
|
|
|
sim:
|
|
|
|
cd simulation; $(SIM_CMD) -do $(DESIGN)_TB.do
|
|
|
|
|
2010-08-12 19:51:53 -05:00
|
|
|
ghdl-simu : ghdl-compil ghdl-run ghdl-view
|
2010-04-21 20:01:38 -05:00
|
|
|
|
2010-08-12 19:51:53 -05:00
|
|
|
ghdl-synthesis : ghdl-compil-synthesis ghdl-run ghdl-view
|
|
|
|
|
|
|
|
ghdl-compil :
|
|
|
|
mkdir -p simu
|
|
|
|
$(GHDL_CMD) -i $(GHDL_SIMU_FLAGS) --workdir=simu --work=work $(TESTBENCH_FILE) $(LIBRARY_FILE) $(SRC_HDL)
|
|
|
|
$(GHDL_CMD) -m $(GHDL_SIMU_FLAGS) -fexplicit --workdir=simu --work=work $(SIMTOP)
|
|
|
|
@mv $(SIMTOP) simu/$(SIMTOP)
|
|
|
|
|
|
|
|
ghdl-compil-synthesis: build/project.vhd
|
|
|
|
mkdir -p simu
|
|
|
|
cp build/project.vhd simu/$(DESIGN)_synt.vhd
|
|
|
|
$(GHDL_CMD) -i $(GHDL_SYNTHESIS_FLAGS) --workdir=simu --work=work $(SYNT_TESTBENCH_FILE) $(SYNTHESIS_FILE)
|
|
|
|
$(GHDL_CMD) -m $(GHDL_SYNTHESIS_FLAGS) --workdir=simu --work=work $(SIMTOP)
|
|
|
|
@mv $(SIMTOP) simu/$(SIMTOP)
|
|
|
|
|
|
|
|
ghdl-run :
|
|
|
|
@$(SIMDIR)/$(SIMTOP) $(GHDL_SIM_OPT) --vcdgz=$(SIMDIR)/$(SIMTOP).vcdgz
|
|
|
|
|
|
|
|
ghdl-view:
|
|
|
|
gunzip --stdout $(SIMDIR)/$(SIMTOP).vcdgz | $(VIEW_CMD) --vcd
|
|
|
|
|
|
|
|
clean_ghdl :
|
|
|
|
$(GHDL_CMD) --clean --workdir=simu
|
|
|
|
-rm -rf simu
|
2010-04-21 20:01:38 -05:00
|
|
|
|