-
Notifications
You must be signed in to change notification settings - Fork 559
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #87 from alokgupt/patch-3
Create Makefile
- Loading branch information
Showing
1 changed file
with
335 additions
and
0 deletions.
There are no files selected for viewing
335 changes: 335 additions & 0 deletions
335
AI_Engine_Development/Design_Tutorials/01-aie_lenet_tutorial/Makefile
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,335 @@ | ||
# © Copyright 2020 Xilinx, Inc. | ||
# | ||
# Licensed under the Apache License, Version 2.0 (the "License"); | ||
# you may not use this file except in compliance with the License. | ||
# You may obtain a copy of the License at | ||
# | ||
# http://www.apache.org/licenses/LICENSE-2.0 | ||
# | ||
# Unless required by applicable law or agreed to in writing, software | ||
# distributed under the License is distributed on an "AS IS" BASIS, | ||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
# See the License for the specific language governing permissions and | ||
# limitations under the License. | ||
|
||
%.PHONY: help | ||
help:: | ||
@echo " Makefile Usage:" | ||
@echo "" | ||
@echo " make kernels TARGET=<hw_emu/hw>" | ||
@echo " Command to generate the PL kernels" | ||
@echo " Default TARGET is hw_emu" | ||
@echo "" | ||
@echo " make graph" | ||
@echo " Command to generate the AI Engine graph" | ||
@echo "" | ||
@echo " make xclbin TARGET=<hw_emu/hw>" | ||
@echo " Command to generate the xclbin for specified target" | ||
@echo " Default TARGET is hw_emu" | ||
@echo "" | ||
@echo " make application" | ||
@echo " Command to generate the A72 application" | ||
@echo "" | ||
@echo " make package TARGET=<hw_emu/hw>" | ||
@echo " Command to package design into an sd_card for specified target" | ||
@echo " Default TARGET is hw_emu" | ||
@echo "" | ||
@echo " make clean" | ||
@echo " Command to remove the generated files" | ||
@echo "" | ||
@echo "" | ||
|
||
|
||
EMBEDDED_PACKAGE_OUT=./out_dir | ||
EMBEDDED_EXEC_SCRIPT=./run_script.sh | ||
|
||
#Check environment setup | ||
ifndef PLATFORM_REPO_PATHS | ||
PLATFORM_REPO_PATHS=/proj/xbuilds/${TOOLVERSION}/internal_platforms/ | ||
export PLATFORM_REPO_PATHS | ||
endif | ||
ifndef XILINX_VITIS | ||
XILINX_VITIS = /opt/xilinx/Vitis/$(TOOL_VERSION) | ||
export XILINX_VITIS | ||
endif | ||
ifndef XILINX_XRT | ||
XILINX_XRT = /opt/xilinx/xrt | ||
export XILINX_XRT | ||
endif | ||
|
||
|
||
EMBEDDED_PACKAGE_OUT = $(BUILD_DIR)/$(TARGET)/package | ||
EMBEDDED_EXEC_SCRIPT = run_script.sh | ||
PACKAGE_FILES += $(EMBEDDED_EXEC_SCRIPT) | ||
SD_FILES_WITH_PREFIX = $(foreach sd_file,$(PACKAGE_FILES),--package.sd_file $(sd_file)) | ||
MK_PATH := $(abspath $(lastword $(MAKEFILE_LIST))) | ||
XF_PROJ_ROOT ?= $(shell bash -c 'export MK_PATH=$(MK_PATH); echo $${MK_PATH%/AI_Engine_Development/*}') | ||
PERL ?= /tools/xgs/perl/5.8.5/bin/perl | ||
|
||
RESULT_VAL ?= | ||
RUN_LEVEL ?= 7 | ||
|
||
print-% : ; @echo $* = $($*) | ||
|
||
# ========================================================= | ||
# platform selection | ||
# ========================================================= | ||
PLATFORM := xilinx_vck190_base_202020_1 | ||
|
||
#PLATFORM := xilinx_vck190_base_202030_1 | ||
|
||
# ========================================================= | ||
# TARGET can be set as: | ||
# hw_emu: Hardware Emulation | ||
# hw : Hardware Run | ||
# ========================================================= | ||
TARGET := hw_emu | ||
|
||
# ========================================================= | ||
# Choose the compiler based on the A72 Processor in the | ||
# Versal device | ||
# ========================================================= | ||
#HOST_CXX := aarch64-linux-gnu-g++ | ||
export LD_LIBRARY_PATH := $(XILINX_VIVADO)/tps/lnx64/gcc-6.2.0/lib64:$(LD_LIBRARY_PATH) | ||
CXX := $(XILINX_VITIS)/gnu/aarch64/lin/aarch64-linux/bin/aarch64-linux-gnu-g++ | ||
|
||
# ========================================================= | ||
# Choose the XRT and XAIENGINE | ||
# ========================================================= | ||
|
||
SYSROOT_PATH := $(PLATFORM_REPO_PATHS)/sw/versal/xilinx-versal-common-v2020.2/sysroots/aarch64-xilinx-linux | ||
XRT_PATH := $(SYSROOT_PATH)/usr/include/xrt | ||
|
||
# ========================================================= | ||
# Source directory | ||
# ========================================================= | ||
#relative lenet directory | ||
RELATIVE_PROJECT_DIR := ./ | ||
|
||
#absolute lenet directory = <user path>/Tutorials/AI_Engine/lenet | ||
PROJECT_REPO := $(shell readlink -f $(RELATIVE_PROJECT_DIR)) | ||
|
||
AIE_SRC_REPO := $(PROJECT_REPO)/design/aie_src | ||
PL_SRC_REPO := $(PROJECT_REPO)/design/pl_src | ||
MAKEFILES_REPO := $(PROJECT_REPO) | ||
BUILD_DIR := $(PROJECT_REPO)/build | ||
WORK_DIR := Work | ||
BUILD_TARGET_DIR := $(BUILD_DIR)/$(TARGET) | ||
|
||
# ========================================================== | ||
# Below are the names for SDF graph, application executable, | ||
# kernel executables, and xclbin | ||
# ========================================================== | ||
DMA_KERNEL_XO := dma_hls.$(TARGET) | ||
LIBADF_A := $(BUILD_DIR)/libadf.a | ||
APP_ELF := lenet_xrt.elf | ||
LENET_O := $(BUILD_DIR)/Work/temp/graph.o | ||
LENET_KERNEL_XO := $(PL_SRC_REPO)/lenet_kernel/lenet_kernel.xo | ||
XCLBIN := vck190_aie_lenet.$(TARGET).xclbin | ||
|
||
# ========================================================= | ||
# Kernel Source Files repository | ||
# ========================================================= | ||
DMA_KERNEL_SRC := $(PL_SRC_REPO)/datamover/dma_hls.cpp | ||
|
||
# ========================================================= | ||
# Graph Source files repository | ||
# ======================================================== | ||
GRAPH_SRC_CPP := $(AIE_SRC_REPO)/graph.cpp | ||
|
||
# ========================================================= | ||
# Application Source Files repository | ||
# ========================================================= | ||
APP_SRC_CPP := $(AIE_SRC_REPO)/main.cpp | ||
AIE_CONTROL_CPP := $(BUILD_DIR)/Work/ps/c_rts/aie_control_xrt.cpp | ||
|
||
# ========================================================= | ||
# AIE Compiler Global Settings and Include Libraries | ||
# ========================================================= | ||
#AIE_FLAGS := -include=$(CARDANO_ROOT)/include | ||
AIE_FLAGS += -include=$(AIE_SRC_REPO) | ||
AIE_FLAGS += -include=$(AIE_SRC_REPO)/data | ||
AIE_FLAGS += --verbose | ||
|
||
AIE_FLAGS += --log-level=5 | ||
AIE_FLAGS += --test-iterations=100 | ||
AIE_FLAGS += --dataflow | ||
|
||
AIE_FLAGS += --heapsize=2048 | ||
AIE_FLAGS += --workdir=$(WORK_DIR) | ||
|
||
# ========================================================= | ||
# Application Compiler and Linker Flags | ||
# ========================================================= | ||
GCC_FLAGS := -O | ||
GCC_FLAGS += -c | ||
GCC_FLAGS += -std=c++14 | ||
GCC_FLAGS += -D__linux__ | ||
|
||
GCC_FLAGS += --sysroot=$(SYSROOT_PATH) | ||
GCC_FLAGS += -DXAIE_DEBUG | ||
GCC_FLAGS += -I$(XRT_PATH) | ||
|
||
GCC_FLAGS += -I$(XILINX_VITIS)/aietools/include/ | ||
GCC_FLAGS += -I=$(SYSROOT_PATH)/usr/include | ||
GCC_FLAGS += -I=$(SYSROOT_PATH)/usr/lib | ||
|
||
GCC_LIB := --sysroot=$(SYSROOT_PATH) | ||
|
||
GCC_LIB += -L=$(SYSROOT_PATH)/usr/lib | ||
GCC_LIB += -L$(XILINX_VITIS)/aietools/lib/aarch64.o | ||
GCC_LIB += -L$(XILINX_VITIS)/aietools/lib/lnx64.o | ||
GCC_LIB += -ladf_api_xrt | ||
GCC_LIB += -lxrt_coreutil | ||
|
||
GCC_LIB += -std=c++14 | ||
|
||
# ========================================================= | ||
# Kernel Compiler and Linker Flags | ||
# ======================================================== | ||
VPP_FLAGS := --platform $(PLATFORM) | ||
VPP_FLAGS += --save-temps | ||
VPP_FLAGS += --temp_dir $(BUILD_TARGET_DIR)/_x | ||
VPP_FLAGS += --verbose | ||
VPP_FLAGS += -g | ||
|
||
# ========================================================= | ||
# Step 1. Kernel XO File Generation | ||
# ======================================================== | ||
# This step compiles the HLS C PL kernels. | ||
# Outputs: in build/[hw_emu | hw]/ directory | ||
# dma_hls.[hw_emu | hw].xo | ||
# dma_hls.[hw_emu | hw].xo.compile_summary | ||
# v++_dma_hls.[hw_emu | hw].log | ||
# _x | ||
kernels: $(BUILD_TARGET_DIR)/$(DMA_KERNEL_XO).xo | ||
|
||
$(BUILD_TARGET_DIR)/$(DMA_KERNEL_XO).xo: | ||
mkdir -p $(BUILD_TARGET_DIR); \ | ||
cd $(BUILD_TARGET_DIR); \ | ||
v++ --target $(TARGET) $(VPP_FLAGS) -c -k dma_hls $(DMA_KERNEL_SRC) -o $@ | ||
|
||
# ========================================================= | ||
# Step 2. AI Engine SDF Graph File and Work/ Directory | ||
# (containing the Graph Executable) Generation | ||
# ======================================================== | ||
# This step creates an SDF Graph and the Work/ directory. | ||
# The Work/ directory contains the graph executable | ||
# (lenet.o) which is used in the make xclbin step. | ||
# The aiecompiler is invoked with the -target=hw. | ||
# Outputs: in build/ directory | ||
# libsdf.a | ||
# NOC_Power.xpe | ||
# Work/ | ||
# xnwOut/ | ||
graph: $(BUILD_DIR)/$(LIBADF_A) | ||
|
||
$(BUILD_DIR)/$(LIBADF_A): $(GRAPH_SRC_CPP) | ||
mkdir -p $(BUILD_DIR); \ | ||
cd $(BUILD_DIR); \ | ||
aiecompiler $(AIE_FLAGS) $(GRAPH_SRC_CPP) | ||
|
||
# ========================================================= | ||
# Step 3. XCLBIN File Generation | ||
# ======================================================== | ||
# This step links the graph executable (tx_chain.o) and | ||
# the kernels into a xclbin file. | ||
# Outputs: in build/[hw_emu | hw]/ directory | ||
# vck190_aie_lenet.[hw_emu | hw].xclbin | ||
# vck190_aie_lenet.[hw_emu | hw].xclbin.info | ||
# vck190_aie_lenet.[hw_emu | hw].xclbin.link_summary | ||
# vck190_aie_lenet.[hw_emu | hw].xsa | ||
# vck190_aie_lenet.[hw_emu | hw].log | ||
xclbin: $(BUILD_TARGET_DIR)/$(XCLBIN) | ||
|
||
$(BUILD_TARGET_DIR)/$(XCLBIN): $(BUILD_TARGET_DIR)/$(DMA_KERNEL_XO).xo \ | ||
$(LENET_KERNEL_XO) \ | ||
$(LIBADF_A) | ||
cd $(BUILD_TARGET_DIR); \ | ||
v++ -l $(VPP_FLAGS) --config $(MAKEFILES_REPO)/system.cfg -t $(TARGET) -o $@ \ | ||
$(BUILD_TARGET_DIR)/$(DMA_KERNEL_XO).xo \ | ||
$(LENET_KERNEL_XO) \ | ||
$(LIBADF_A) | ||
|
||
# ========================================================= | ||
# Step 4. A72 Application Executable File Generation | ||
# ======================================================== | ||
# This step compiles the A72 application. This step is the | ||
# same for TARGET=[hw_emu | hw]. Compile the PS code. | ||
# Outputs: in build/ directory | ||
# aie_control.o | ||
# lenet_app.o | ||
# lenet_xrt.elf | ||
application: | ||
$(CXX) $(GCC_FLAGS) $(AIE_CONTROL_CPP) -o $(BUILD_DIR)/app_control.o | ||
$(CXX) $(GCC_FLAGS) $(APP_SRC_CPP) -o $(BUILD_DIR)/lenet_app.o $(GCC_LIB) | ||
$(CXX) $(BUILD_DIR)/app_control.o $(BUILD_DIR)/lenet_app.o $(GCC_LIB) -o $(BUILD_DIR)/$(APP_ELF) | ||
|
||
|
||
# ========================================================= | ||
# Step 5. Package Generation | ||
# ======================================================== | ||
# This step generates the package folder which contains the | ||
# ./launch_hw_emu.sh script to launch hardware emulation | ||
# if TARGET=hw_emu and the sd_card.img file. | ||
# Outputs: in build/[hw_emu | hw]/ directory | ||
# a.xclbin | ||
# package/ directory | ||
# v++.package_summary | ||
# v++_package.log | ||
package: | ||
cp $(MAKEFILES_REPO)/run_script.sh $(BUILD_TARGET_DIR)/ | ||
cd $(BUILD_TARGET_DIR); \ | ||
v++ -p -t $(TARGET) --save-temps --temp_dir $(BUILD_TARGET_DIR)/_x \ | ||
-f $(PLATFORM) \ | ||
--package.sd_dir $(PLATFORM_REPO_PATHS)/sw/versal/xrt \ | ||
--package.rootfs $(PLATFORM_REPO_PATHS)/sw/versal/xilinx-versal-common-v2020.2/rootfs.ext4 \ | ||
--package.kernel_image $(PLATFORM_REPO_PATHS)/sw/versal/xilinx-versal-common-v2020.2/Image \ | ||
--package.boot_mode=sd \ | ||
--package.out_dir $(BUILD_TARGET_DIR)/package \ | ||
--package.sd_dir $(AIE_SRC_REPO)/data \ | ||
--package.image_format=ext4 \ | ||
--package.sd_file $(BUILD_DIR)/$(APP_ELF) $(BUILD_TARGET_DIR)/$(XCLBIN) $(LIBADF_A) $(SD_FILES_WITH_PREFIX) \ | ||
--package.defer_aie_run | ||
|
||
# ========================================================= | ||
# Step 6. Run Hardware Emulation | ||
# ======================================================== | ||
# If the target is for HW_EMU, launch the emulator | ||
# If the target is for HW, you'll have to follow the | ||
# instructions in the README.md | ||
|
||
sd_card: kernels graph xclbin application package | ||
|
||
run_emu: | ||
ifeq ($(TARGET),hw_emu) | ||
cd $(BUILD_TARGET_DIR)/package; \ | ||
$(PERL) $(XF_PROJ_ROOT)/ext/make_utility/embedded_run_emulation.pl "$(EMBEDDED_PACKAGE_OUT)/launch_$(TARGET).sh -no-reboot" "./run_script.sh" "$(RESULT_VAL)" "$(RUN_LEVEL)" | tee embedded_run.log | ||
#./launch_hw_emu.sh | ||
else | ||
@echo "Hardware build, no emulation executed." | ||
endif | ||
########################################################################### | ||
|
||
# ========================================================= | ||
# Primary Build Targets | ||
# ==> build | ||
# ==> run | ||
# ==> clean | ||
# ======================================================== | ||
|
||
#Build the design without running the hardware emulation | ||
build: kernels graph xclbin application package | ||
|
||
#Build the design and then run hardware emulation | ||
run: build run_emu | ||
|
||
#Clean generated files | ||
clean: | ||
rm -rf .Xil/ | ||
rm -rf $(BUILD_DIR)/$(WORK_DIR) | ||
rm -rf $(BUILD_DIR)/hw_emu | ||
rm -rf $(BUILD_DIR)/hw | ||
rm -rf $(BUILD_DIR) | ||
rm -f xcd.log | ||
rm -f xrc.log |