# # $Id: Makefile.Synthesis 137 2010-02-16 12:35:48Z rosiere $ # # [ Description ] # # Makefile # #-----[ Variables ]---------------------------------------- DIR_VHDL = . WORK_NAME = work DIR_WORK = $(DIR_TMP)/$(WORK_NAME) FPGA_CFG_FILE_LOCAL = mkf.info FPGA_CFG_FILE_GLOBAL_DIR = $(DIR_MORPHEO)/Behavioural FPGA_CFG_FILE_GLOBAL = configure.mkf FPGA_FILES = $(patsubst $(DIR_CFG_GEN)/%.cfg,%,$(wildcard $(DIR_CFG_GEN)/*.cfg)) \ $(patsubst $(DIR_CFG_USER)/%.cfg,%,$(wildcard $(DIR_CFG_USER)/*.cfg)) FPGA_LOG_FILES = $(patsubst $(DIR_CFG_GEN)/%.cfg,$(DIR_LOG)/%.fpga.log,$(wildcard $(DIR_CFG_GEN)/*.cfg)) \ $(patsubst $(DIR_CFG_USER)/%.cfg,$(DIR_LOG)/%.fpga.log,$(wildcard $(DIR_CFG_USER)/*.cfg)) #-----[ Rules ]-------------------------------------------- .PRECIOUS : $(DIR_LOG)/%.vhdl.log $(DIR_LOG)/%.sim.log vhdl : $(EXEC_LOG) @\ $(MAKE) vhdl_package; \ $(MAKE) vhdl_entity; \ $(MAKE) vhdl_testbench vhdl_package : $(DIR_WORK) @\ declare -a vhdl_files=($$($(LS) $(DIR_VHDL)/*_Pack.vhdl)); \ declare -a log_files=($${vhdl_files[*]/%.vhdl/.vhdl.log}); \ if $(TEST) $${#log_files[*]} -ne 0; then $(MAKE) -k $${log_files[*]/#$(DIR_VHDL)/$(DIR_LOG)}; fi; vhdl_testbench : $(DIR_WORK) @\ $(LS) $(DIR_VHDL)/*_Testbench.vhdl &> /dev/null; \ if $(TEST) $$? -eq 0; then \ declare -a vhdl_files=($$($(LS) $(DIR_VHDL)/*_Testbench.vhdl)); \ declare -a log_files=($${vhdl_files[*]/%.vhdl/.vhdl.log}); \ if $(TEST) $${#log_files[*]} -ne 0; then \ $(MAKE) -k $${log_files[*]/#$(DIR_VHDL)/$(DIR_LOG)}; \ fi; \ fi; vhdl_entity : $(DIR_WORK) @\ declare -a vhdl_files=($$($(LS) $(DIR_VHDL)/*.vhdl|$(GREP_NOT) "(_Pack\.|_Testbench\.)")); \ declare -a log_files=($${vhdl_files[*]/%.vhdl/.vhdl.log}); \ if $(TEST) $${#log_files[*]} -ne 0; then $(MAKE) -k $${log_files[*]/#$(DIR_VHDL)/$(DIR_LOG)}; fi; \ #list : # @\ # declare -a vhdl_files=($$($(LS) $(DIR_VHDL)/*.vhdl|$(GREP_NOT) "(_Pack\.|_Testbench\.)")); \ # for file1 in $${vhdl_files[*]}; do \ # declare x=$$(basename $${file1} .vhdl); \ # declare -i count_x=$($(ECHO) $${x} | ${WC} -m); \ # for file2 in $${vhdl_files[*]}; do \ # if $(TEST) "$${file1}" != "$${file2}"; then\ # declare y=$$(basename $${file2} .vhdl); \ # declare -i count_y=$($(ECHO) $${y} | ${WC} -m); \ # if $(TEST) $${count_x} -gt $${count_y}; then \ # break; \ # fi; \ # $(ECHO) $${x}; \ # fi; \ # done; \ # done; sim : vhdl @\ $(LS) $(DIR_VHDL)/*_Testbench.vhdl &> /dev/null; \ if $(TEST) $$? -eq 0; then \ declare -a vhdl_files=($$($(LS) $(DIR_VHDL)/*_Testbench.vhdl)); \ declare -a log_files=($${vhdl_files[*]/%.vhdl/.sim.log}); \ if $(TEST) $${#log_files[*]} -ne 0; then \ $(MAKE) -k $${log_files[*]/#$(DIR_VHDL)/$(DIR_LOG)}; \ fi; \ fi; fpga : sim @\ $(ECHO) -e "" > $(FPGA_CFG_FILE_LOCAL); \ $(ECHO) "files :::::::: $(FPGA_FILES)"; \ for file in $(FPGA_FILES); do \ declare -a files=($$($(LS) $$file*.vhdl|$(GREP_NOT) "(_Testbench\.)")); \ $(ECHO) -e "# $$file" >> $(FPGA_CFG_FILE_LOCAL); \ $(ECHO) -e "target_dep\tall\t$$file.ngc" >> $(FPGA_CFG_FILE_LOCAL); \ $(ECHO) -e "target_dep\t$$file.ngc\t$$file.prj" >> $(FPGA_CFG_FILE_LOCAL); \ $(ECHO) -e "target_dep\t$$file.prj\t$${files[*]}" >> $(FPGA_CFG_FILE_LOCAL); \ $(ECHO) -e "" >> $(FPGA_CFG_FILE_LOCAL); \ done; \ ($(XILINX_ENV); cd $(FPGA_CFG_FILE_GLOBAL_DIR); ./$(FPGA_CFG_FILE_GLOBAL)); \ $(MAKE) -k $(FPGA_LOG_FILES); $(DIR_LOG)/%.fpga.log : @\ $(ECHO) "Synthetis on FPGA : $*"; \ $(XILINX_ENV); $(MAKE) -f Makefile.mkf $*.ngc &> $@; $(DIR_WORK) : @\ $(ECHO) "Create work-space : $@"; \ mkdir -p $@; \ $(MODELTECH_VLIB) $@; \ $(MODELTECH_VMAP) $(XILINX_LIBNAME) $(XILINX_LIBDIR); \ if $(TEST) $${?} -ne 0; then \ $(ECHO) "Xilinx corelib must be compiled to simulation tools"; \ $(ECHO) "Run manualy \"$(XILINX_COMPXLIB)\" with $(XILINX_CORELIB) directory"; \ fi; $(DIR_LOG)/%.sim.log : $(DIR_VHDL)/%.vhdl $(DIR_LOG)/%.vhdl.log @\ $(ECHO) "VHDL's Simulation : $*"; \ $(MODELTECH_VSIM) "$(DIR_WORK).`$(BASENAME) $* |$(UPPERtoLOWER)`" &> $@; \ declare -i count=`$(GREP) -ch "Test OK" $@`; \ if $(TEST) $$count -ne 0; \ then echo " $* ... OK"; \ else echo " $* ... KO"; exit 1; \ fi; $(DIR_LOG)/%.vhdl.log : $(DIR_VHDL)/%.vhdl @\ $(ECHO) "VHDL's Compilation : $*"; \ $(MODELTECH_VCOM) -work $(DIR_WORK) $< &> $@; synthesis_clean : @\ if $(TEST) -f Makefile.mkf; then $(MAKE) -f Makefile.mkf clean; fi; \ $(RM) $(DIR_WORK) transcript Makefile.mkf *wlf* modelsim.ini; synthesis_clean_all : synthesis_clean synthesis_help : @\ $(ECHO) " -----[ Synthesis ]----------------------------------";\ $(ECHO) "";\ $(ECHO) " * vhdl : compile all vhdl's file";\ $(ECHO) " * sim : simulate all testbench's file";\ $(ECHO) " * fpga : synthetis with fpga's tools";\ $(ECHO) "";