OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [rtos/] [freertos-6.1.1/] [Demo/] [MicroBlaze/] [system.make] - Rev 588

Go to most recent revision | Compare with Previous | Blame | View Log

#################################################################
# Makefile generated by Xilinx Platform Studio 
# Project:E:\Dev\FreeRTOS\Demo\MicroBlaze\system.xmp
#################################################################

# Name of the Microprocessor system
# The hardware specification of the system is in file :
# E:\Dev\FreeRTOS\Demo\MicroBlaze\system.mhs
# The software specification of the system is in file :
# E:\Dev\FreeRTOS\Demo\MicroBlaze\system.mss

include system_incl.make


#################################################################
# EXTERNAL TARGETS
#################################################################
all:
        @echo "Makefile to build a Microprocessor system :"
        @echo "Run make with any of the following targets"
        @echo " "
        @echo "  netlist  : Generates the netlist for the given MHS "
        @echo "  bits     : Runs Implementation tools to generate the bitstream"
        @echo "  exporttopn:Export to ProjNav"
        @echo " "
        @echo "  libs     : Configures the sw libraries for this system"
        @echo "  program  : Compiles the program sources for all the processor instances"
        @echo " "
        @echo "  init_bram: Initializes bitstream with BRAM data"
        @echo "  ace      : Generate ace file from bitstream and elf"
        @echo "  download : Downloads the bitstream onto the board"
        @echo " "
        @echo "  sim      : Generates HDL simulation models and runs simulator for chosen simulation mode"
        @echo "  simmodel : Generates HDL simulation models for chosen simulation mode"
        @echo "  behavioral_model:Generates behavioral HDL models with BRAM initialization"
        @echo "  structural_model:Generates structural simulation HDL models with BRAM initialization"
        @echo "  timing_model    : Generates timing simulation HDL models with BRAM initialization"
        @echo "  vp       : Generates virtual platform model"
        @echo " "
        @echo "  netlistclean: Deletes netlist"
        @echo "  bitsclean: Deletes bit, ncd, bmm files"
        @echo "  hwclean  : Deletes implementation dir"
        @echo "  libsclean: Deletes sw libraries"
        @echo "  programclean: Deletes compiled ELF files"
        @echo "  swclean  : Deletes sw libraries and ELF files"
        @echo "  simclean : Deletes simulation dir"
        @echo "  vpclean  : Deletes virtualplatform dir"
        @echo "  clean    : Deletes all generated files/directories"
        @echo " "
        @echo "  make <target> : (Default)"
        @echo "      Creates a Microprocessor system using default initializations"
        @echo "      specified for each processor in MSS file"


bits: $(SYSTEM_BIT)

ace: $(SYSTEM_ACE)

netlist: $(POSTSYN_NETLIST)

libs: $(LIBRARIES)

program: $(ALL_USER_ELF_FILES)

download: $(DOWNLOAD_BIT) dummy
        @echo "*********************************************"
        @echo "Downloading Bitstream onto the target board"
        @echo "*********************************************"
        impact -batch etc/download.cmd

init_bram: $(DOWNLOAD_BIT)

sim: $(DEFAULT_SIM_SCRIPT)
        cd simulation/behavioral; \
        $(SIM_CMD)  &

simmodel: $(DEFAULT_SIM_SCRIPT)

behavioral_model: $(BEHAVIORAL_SIM_SCRIPT)

structural_model: $(STRUCTURAL_SIM_SCRIPT)

timing_model: $(TIMING_SIM_SCRIPT)

vp: $(VPEXEC)

clean: hwclean libsclean programclean simclean vpclean
        rm -f _impact.cmd

hwclean: netlistclean bitsclean
        rm -rf implementation synthesis xst hdl
        rm -rf xst.srp $(SYSTEM).srp

netlistclean:
        rm -f $(POSTSYN_NETLIST)
        rm -f $(BMM_FILE)

bitsclean:
        rm -f $(SYSTEM_BIT)
        rm -f implementation/$(SYSTEM).ncd
        rm -f implementation/$(SYSTEM)_bd.bmm 

bitsclean:

simclean: 
        rm -rf simulation/behavioral

swclean: libsclean programclean
        @echo ""

libsclean: $(LIBSCLEAN_TARGETS)

programclean: $(PROGRAMCLEAN_TARGETS)

vpclean:
        rm -rf virtualplatform

#################################################################
# SOFTWARE PLATFORM FLOW
#################################################################


$(LIBRARIES): $(MHSFILE) $(MSSFILE) __xps/libgen.opt
        @echo "*********************************************"
        @echo "Creating software libraries..."
        @echo "*********************************************"
        libgen $(LIBGEN_OPTIONS) $(MSSFILE)


microblaze_0_libsclean:
        rm -rf microblaze_0/lib/

$(MICROBLAZE_0_XMDSTUB): $(LIBRARIES)

#################################################################
# SOFTWARE APPLICATION RTOSDEMO
#################################################################

RTOSDemo_program: $(RTOSDEMO_OUTPUT) 

$(RTOSDEMO_OUTPUT) : $(RTOSDEMO_SOURCES) $(RTOSDEMO_HEADERS) $(RTOSDEMO_LINKER_SCRIPT) \
                    $(LIBRARIES) __xps/rtosdemo_compiler.opt
        @mkdir -p $(RTOSDEMO_OUTPUT_DIR) 
        $(RTOSDEMO_CC) $(RTOSDEMO_CC_OPT) $(RTOSDEMO_SOURCES) -o $(RTOSDEMO_OUTPUT) \
        $(RTOSDEMO_OTHER_CC_FLAGS) $(RTOSDEMO_INCLUDES) $(RTOSDEMO_LIBPATH) \
        -xl-mode-$(RTOSDEMO_MODE)  \
        $(RTOSDEMO_CFLAGS) $(RTOSDEMO_LFLAGS) 
        $(RTOSDEMO_CC_SIZE) $(RTOSDEMO_OUTPUT) 

RTOSDemo_programclean:
        rm -f $(RTOSDEMO_OUTPUT) 

#################################################################
# BOOTLOOP ELF FILES
#################################################################



$(MICROBLAZE_0_BOOTLOOP): $(MICROBLAZE_BOOTLOOP)
        @mkdir -p $(BOOTLOOP_DIR)
        cp -f $(MICROBLAZE_BOOTLOOP) $(MICROBLAZE_0_BOOTLOOP)

#################################################################
# HARDWARE IMPLEMENTATION FLOW
#################################################################


$(BMM_FILE) \
$(WRAPPER_NGC_FILES): $(MHSFILE) __xps/platgen.opt \
                      $(CORE_STATE_DEVELOPMENT_FILES)
        @echo "****************************************************"
        @echo "Creating system netlist for hardware specification.."
        @echo "****************************************************"
        platgen $(PLATGEN_OPTIONS) -st xst $(MHSFILE)

$(POSTSYN_NETLIST): $(WRAPPER_NGC_FILES)
        @echo "Running synthesis..."
        bash -c "cd synthesis; ./synthesis.sh; cd .."

$(SYSTEM_BIT): $(BMM_FILE) $(POSTSYN_NETLIST) __xps/xpsxflow.opt \
               $(UCF_FILE) $(BITGEN_UT_FILE) $(FASTRUNTIME_OPT_FILE)
        @echo "Copying Xilinx Implementation tool scripts.."
        @cp -f $(BITGEN_UT_FILE) implementation/bitgen.ut
        @cp -f $(FASTRUNTIME_OPT_FILE) implementation/fast_runtime.opt
        @cp -f $(UCF_FILE) implementation/$(SYSTEM).ucf
        @echo "*********************************************"
        @echo "Running Xilinx Implementation tools.."
        @echo "*********************************************"
        xflow -wd implementation -p $(DEVICE) -implement fast_runtime.opt $(SYSTEM).ngc
        cd implementation; bitgen -w -f bitgen.ut $(SYSTEM)

exporttopn: 
        @echo "You have chosen XPS for implementation tool flow."
        @echo "Please select ProjNav as your implementation flow in Project Options."
        @echo "In batch mode, use commad xset pnproj <isefile>."

$(DOWNLOAD_BIT): $(SYSTEM_BIT) $(BRAMINIT_ELF_FILES) __xps/bitinit.opt
        @cp -f implementation/$(SYSTEM)_bd.bmm .
        @echo "*********************************************"
        @echo "Initializing BRAM contents of the bitstream"
        @echo "*********************************************"
        bitinit $(MHSFILE) $(SEARCHPATHOPT) $(BRAMINIT_ELF_FILE_ARGS) \
        -bt $(SYSTEM_BIT) -o $(DOWNLOAD_BIT)
        @rm -f $(SYSTEM)_bd.bmm

$(SYSTEM_ACE): $(DOWNLOAD_BIT) $(RTOSDEMO_OUTPUT) 
        @echo "*********************************************"
        @echo "Creating system ace file"
        @echo "*********************************************"
        xmd -tcl genace.tcl -jprog -hw $(DOWNLOAD_BIT) -elf $(RTOSDEMO_OUTPUT)  -ace $(SYSTEM_ACE)

#################################################################
# SIMULATION FLOW
#################################################################


################## BEHAVIORAL SIMULATION ##################

$(BEHAVIORAL_SIM_SCRIPT): $(MHSFILE) __xps/simgen.opt \
                          $(BRAMINIT_ELF_FILES)
        @echo "*********************************************"
        @echo "Creating behavioral simulation models..."
        @echo "*********************************************"
        simgen $(SIMGEN_OPTIONS) -m behavioral $(MHSFILE)

################## STRUCTURAL SIMULATION ##################

$(STRUCTURAL_SIM_SCRIPT): $(WRAPPER_NGC_FILES) __xps/simgen.opt \
                          $(BRAMINIT_ELF_FILES)
        @echo "*********************************************"
        @echo "Creating structural simulation models..."
        @echo "*********************************************"
        simgen $(SIMGEN_OPTIONS) -sd implementation -m structural $(MHSFILE)


################## TIMING SIMULATION ##################

$(TIMING_SIM_SCRIPT): $(SYSTEM_BIT) __xps/simgen.opt \
                      $(BRAMINIT_ELF_FILES)
        @echo "*********************************************"
        @echo "Creating timing simulation models..."
        @echo "*********************************************"
        simgen $(SIMGEN_OPTIONS) -sd implementation -m timing $(MHSFILE)

#################################################################
# VIRTUAL PLATFORM FLOW
#################################################################


$(VPEXEC): $(MHSFILE) __xps/vpgen.opt
        @echo "****************************************************"
        @echo "Creating virtual platform for hardware specification.."
        @echo "****************************************************"
        vpgen $(VPGEN_OPTIONS) $(MHSFILE)

dummy:
        @echo ""

Go to most recent revision | Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.