mirror of
git://projects.qi-hardware.com/nn-usb-fpga.git
synced 2025-01-10 15:10:15 +02:00
99 lines
2.8 KiB
Makefile
99 lines
2.8 KiB
Makefile
DESIGN = sram_bus
|
|
PINS = sram_bus.ucf
|
|
DEVICE = xc3s250e-VQ100-4
|
|
BGFLAGS = -g TdoPin:PULLNONE -g DonePin:PULLUP \
|
|
-g CRC:enable -g StartUpClk:CCLK
|
|
|
|
SIM_CMD = /opt/cad/modeltech/bin/vsim
|
|
SIM_COMP_SCRIPT = simulation/$(DESIGN)_TB.do
|
|
SIMGEN_OPTIONS = -p $(FPGA_ARCH) -lang $(LANGUAGE)
|
|
SAKC_IP = 192.168.254.101
|
|
IVERILOG = iverilog
|
|
XILINXCADROOT = /opt/cad/Xilinx/verilog/src
|
|
#XILINXCADROOT = /opt/cad/modeltech/xilinx/verilog/
|
|
|
|
|
|
SRC = sram_bus.v
|
|
|
|
SIM_SRC = $(DESIGN)_TB.v \
|
|
# sim/unisims/BUFG.v \
|
|
# sim/unisims/DCM.v \
|
|
# sim/unisims/FDDRRSE.v \
|
|
# glbl.v
|
|
# sim/unisims/RAMB16_S2_S9.v
|
|
|
|
|
|
all: bits
|
|
|
|
remake: clean-build all
|
|
|
|
clean:
|
|
rm -f *~ */*~ a.out *.log *.key *.edf *.ps trace.dat
|
|
rm *.bit
|
|
|
|
clean-build: clean
|
|
rm -rf build
|
|
|
|
cleanall: clean
|
|
rm -rf build $(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
|
|
|
|
build/project.ngd: build/project.ngc $(PINS)
|
|
cd build && ngdbuild -p $(DEVICE) project.ngc -uc ../$(PINS)
|
|
|
|
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 $@
|
|
|
|
build/project_r.v: build/project_r.ncd
|
|
cd build && netgen -sim -ofmt vhdl project_r.ncd -pcf project.pcf && ngd2ver project.ngd -w project.v
|
|
|
|
modelsim:
|
|
cd simulation; $(SIM_CMD) -do $(DESIGN)_TB.do
|
|
|
|
timesim: build/project_r.v
|
|
cd simulation; $(SIM_CMD) -do $(DESIGN)_TIMING_TB.do
|
|
|
|
iversim:
|
|
$(IVERILOG) -Wall -y $(XILINXCADROOT)/unisims -y $(XILINXCADROOT)/XilinxCoreLib -o simulation/$(DESIGN)_TB.vvp $(VINCDIR) $(SRC) $(SIM_SRC) -s $(DESIGN)_TB
|
|
# $(IVERILOG) -Wall -y $(XILINXCADROOT)/unisims -y $(XILINXCADROOT)/XilinxCoreLib -o simulation/$(DESIGN)_TB.vvp $(VINCDIR) build/project.v $(SIM_SRC) -s $(DESIGN)_TB
|
|
vvp simulation/$(DESIGN)_TB.vvp; mv $(DESIGN)_TB.vcd simulation/
|
|
gtkwave simulation/$(DESIGN)_TB.vcd&
|
|
|
|
upload: $(DESIGN).bit
|
|
scp $(DESIGN).bit root@$(SAKC_IP):
|