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 -rf *.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 && 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):