203 lines
6.3 KiB
Makefile
Executable File
203 lines
6.3 KiB
Makefile
Executable File
current_mk_abspathname := $(abspath $(lastword $(MAKEFILE_LIST)))
|
|
current_mk_absdir := $(dir $(current_mk_abspathname))../../ai_sdk_env.mk
|
|
ifneq ("$(wildcard $(current_mk_absdir))", "")
|
|
include $(current_mk_absdir)
|
|
endif
|
|
|
|
CUR_PATH := $(shell pwd)
|
|
NVT_KDRV_PATH=$(NVT_HDAL_DIR)/drivers/k_driver
|
|
NVT_KFLOW_PATH=$(NVT_HDAL_DIR)/drivers/k_flow
|
|
|
|
ifeq ("$(wildcard $(OWN_NVT_AI2_PATH))", "")
|
|
NVT_AI_PATH=$(NVT_HDAL_DIR)/vendor/ai
|
|
NVT_AI2_PATH=$(NVT_HDAL_DIR)/vendor/ai2
|
|
NVT_AI_KDRV_PATH=$(NVT_AI_PATH)/drivers/k_driver
|
|
NVT_AI_KFLOW_PATH=$(NVT_AI2_PATH)/drivers/k_flow
|
|
else
|
|
NVT_AI_KFLOW_PATH=$(NVT_AI2_KFLOW_PATH)
|
|
endif
|
|
|
|
NVT_AI_LIB_PATH=$(NVT_AI2_PATH)/source
|
|
OUTPUT_DIR = $(NVT_HDAL_DIR)/vendor/output
|
|
|
|
INCLUDE_PATH += -I$(NVT_VOS_DIR)/drivers/include
|
|
INCLUDE_PATH += -I$(NVT_HDAL_DIR)/include
|
|
INCLUDE_PATH += -I$(NVT_KDRV_PATH)/include -I$(NVT_KDRV_PATH)/source/include/ -I$(NVT_KFLOW_PATH)/include/
|
|
INCLUDE_PATH += -I$(NVT_HDAL_DIR)/vendor/include -I$(NVT_AI_LIB_PATH)/include -I$(NVT_AI2_PATH)/include -I$(NVT_AI_KDRV_PATH)/include -I$(NVT_AI_KFLOW_PATH)/include
|
|
INCLUDE_PATH += -I$(NVT_AI2_PATH)/source_pub
|
|
|
|
ifeq ("$(wildcard $(OWN_NVT_AI2_PATH))", "")
|
|
INCLUDE_PATH += -I$(NVT_HDAL_DIR)/vendor/ai2/source/prebuilt/include -I$(NVT_AI2_PATH)/source
|
|
else
|
|
INCLUDE_PATH += -I$(OWN_NVT_AI2_PATH)/source/prebuilt/include
|
|
endif
|
|
|
|
INCLUDE_PATH += -I$(NVT_HDAL_DIR)/vendor/cv/include -I$(NVT_HDAL_DIR)/vendor/isp/include
|
|
INCLUDE_PATH += -I$(NVT_HDAL_DIR)/vendor/dsp/include
|
|
INCLUDE_PATH += -I$(NVT_HDAL_DIR)/vendor/media/include
|
|
|
|
#COPS = $(INCLUDE_PATH) -D ARM_ASM -O3 -Wall -Werror -finline-functions -msoft-float -fPIC -Wno-aggressive-loop-optimizations
|
|
COPS = $(INCLUDE_PATH) -D ARM_ASM -O3 -Wall -Werror -Werror=sign-compare -finline-functions -fPIC -Wno-aggressive-loop-optimizations -D__LINUX_USER__ -mfpu=neon-fp16
|
|
|
|
ifeq ("$(wildcard $(OWN_NVT_AI2_PATH))", "")
|
|
uclibc=$(shell echo $(CROSS_COMPILE)|grep uclib)
|
|
ifeq ($(uclibc),)
|
|
PREBUILD_LIB=$(NVT_HDAL_DIR)/vendor/ai/source/prebuilt/lib/glibc
|
|
else
|
|
PREBUILD_LIB=$(NVT_HDAL_DIR)/vendor/ai/source/prebuilt/lib/uclibc
|
|
endif
|
|
endif
|
|
|
|
CC=$(CROSS_COMPILE)gcc
|
|
AS=$(CROSS_COMPILE)as
|
|
AR=$(CROSS_COMPILE)ar
|
|
|
|
CSRC += \
|
|
vendor_ai_comm.c \
|
|
vendor_ai_comm_flow.c \
|
|
vendor_ai_net/vendor_ai_op.c \
|
|
vendor_ai_net/vendor_ai_net_gen.c \
|
|
vendor_ai_net/vendor_ai_net_flow.c \
|
|
vendor_ai_net/vendor_ai_net.c \
|
|
vendor_ai_net/vendor_ai_net_mem.c \
|
|
vendor_ai_net/vendor_ai_net_group.c \
|
|
vendor_ai_net/vendor_ai_net_debug.c \
|
|
vendor_ai_net/vendor_ai_net_cmd.c \
|
|
vendor_ai_net/debug_util/graph_debug_core.c \
|
|
vendor_ai_net/debug_util/graph_debug_buffer.c \
|
|
vendor_ai_net/debug_util/graph_debug_schedule.c \
|
|
vendor_ai_net/debug_util/graph_debug_log.c \
|
|
vendor_ai_cpu/vendor_ai_cpu_thread.c \
|
|
vendor_ai_cpu/vendor_ai_cpu_post_accuracy.c \
|
|
vendor_ai_cpu/vendor_ai_cpu_post_softmax.c \
|
|
vendor_ai_dsp/vendor_ai_dsp_thread.c \
|
|
vendor_ai_dla/vendor_ai_dla.c
|
|
|
|
|
|
HDAL_STATIC_LIB = libvendor_ai2.a
|
|
HDAL_DYNAMIC_LIB = libvendor_ai2.so
|
|
|
|
COBJS = ${CSRC:%.c=%.o} ${CPPSRC:%.cpp=%.o}
|
|
|
|
TARGETS := $(HDAL_STATIC_LIB) $(HDAL_DYNAMIC_LIB)
|
|
|
|
.PHONY: $(TARGETS)
|
|
###############################################################################
|
|
# Linux Makefile #
|
|
###############################################################################
|
|
ifeq ($(NVT_PRJCFG_CFG),Linux)
|
|
ifeq ("$(wildcard *.c */*.c)","")
|
|
all:
|
|
@echo "nothing to be done for '$(OUTPUT_NAME)'"
|
|
clean:
|
|
@echo "nothing to be done for '$(OUTPUT_NAME)'"
|
|
codesize:
|
|
@echo "nothing to be done for '$(OUTPUT_NAME)'"
|
|
else
|
|
all: $(TARGETS)
|
|
|
|
$(HDAL_STATIC_LIB) : $(COBJS) $(SOBJS)
|
|
$(AR) -r $@ $(COBJS)
|
|
# mkdir -p ./lib
|
|
# cp $@ ./lib/
|
|
|
|
$(HDAL_DYNAMIC_LIB) : $(COBJS) $(SOBJS)
|
|
$(CC) -shared -s -o $@ $(COBJS)
|
|
# mkdir -p ../lib
|
|
# cp $@ ./lib/
|
|
|
|
%.o: %.c
|
|
$(CC) -c $(COPS) $(CFLAGS) -I. -o $@ $<
|
|
|
|
%.o: %.cpp
|
|
$(CC) -c $(COPS) $(CFLAGS) -I. -o $@ $<
|
|
|
|
clean :
|
|
/bin/rm -f *.o
|
|
/bin/rm -f */*.o
|
|
/bin/rm -f */*/*.o
|
|
/bin/rm -f $(HDAL_STATIC_LIB) $(HDAL_DYNAMIC_LIB)
|
|
endif
|
|
|
|
install:
|
|
# cp *.so *.a $(ROOTFS_DIR)/rootfs/lib
|
|
cp *.so *.a $(OUTPUT_DIR)
|
|
# cp $(PREBUILD_LIB)/*.so $(PREBUILD_LIB)/*.a $(ROOTFS_DIR)/rootfs/lib
|
|
cp $(PREBUILD_LIB)/*.so $(PREBUILD_LIB)/*.a $(OUTPUT_DIR)
|
|
|
|
###############################################################################
|
|
# rtos Makefile #
|
|
###############################################################################
|
|
else ifeq ($(NVT_PRJCFG_CFG),rtos)
|
|
#--------- ENVIRONMENT SETTING --------------------
|
|
# DIRs
|
|
RTOS_KERNEL_DIR = $(KERNELDIR)/lib/FreeRTOS
|
|
RTOS_LIB_DIR = $(KERNELDIR)/lib
|
|
RTOS_CURR_DEMO_DIR = $(KERNELDIR)/demos/novatek/na51089
|
|
RTOS_POSIX_DIR = $(KERNELDIR)/lib/FreeRTOS-Plus-POSIX
|
|
RTOS_POSIX_SRC_DIR = $(RTOS_POSIX_DIR)/source
|
|
|
|
#INCs for C_CFLAGS
|
|
|
|
EXTRA_INCLUDE += \
|
|
-I$(RTOS_LIB_DIR) \
|
|
-I$(RTOS_KERNEL_DIR)/portable/GCC/ARM_CA9 \
|
|
-I$(RTOS_KERNEL_DIR)/include \
|
|
-I$(RTOS_KERNEL_DIR)/include/private \
|
|
-I$(RTOS_CURR_DEMO_DIR)/include \
|
|
-I$(RTOS_POSIX_DIR)/include \
|
|
-I$(RTOS_POSIX_DIR)/include/portable/novatek
|
|
|
|
C_CFLAGS = $(PLATFORM_CFLAGS) $(INCLUDE_PATH) $(EXTRA_INCLUDE) -Wno-format
|
|
#--------- END OF ENVIRONMENT SETTING -------------
|
|
MODULE_NAME = libvendor_ai2
|
|
LIB_NAME = $(MODULE_NAME).a
|
|
PREBUILD_LIB=$(NVT_HDAL_DIR)/vendor/ai/source/prebuilt/lib
|
|
|
|
SRC = \
|
|
vendor_ai_comm.c \
|
|
vendor_ai_comm_flow.c \
|
|
vendor_ai_net/vendor_ai_op.c \
|
|
vendor_ai_net/vendor_ai_net_gen.c \
|
|
vendor_ai_net/vendor_ai_net_flow.c \
|
|
vendor_ai_net/vendor_ai_net.c \
|
|
vendor_ai_net/vendor_ai_net_mem.c \
|
|
vendor_ai_net/vendor_ai_net_group.c \
|
|
vendor_ai_net/vendor_ai_net_debug.c \
|
|
vendor_ai_net/vendor_ai_net_cmd.c \
|
|
vendor_ai_net/debug_util/graph_debug_core.c \
|
|
vendor_ai_net/debug_util/graph_debug_buffer.c \
|
|
vendor_ai_net/debug_util/graph_debug_schedule.c \
|
|
vendor_ai_cpu/vendor_ai_cpu_thread.c \
|
|
vendor_ai_cpu/vendor_ai_cpu_post_accuracy.c \
|
|
vendor_ai_cpu/vendor_ai_cpu_post_softmax.c \
|
|
vendor_ai_dsp/vendor_ai_dsp_thread.c \
|
|
vendor_ai_dla/vendor_ai_dla.c
|
|
|
|
OBJ = $(SRC:.c=.o)
|
|
|
|
|
|
all: $(LIB_NAME)
|
|
|
|
$(LIB_NAME): $(OBJ)
|
|
@echo Creating $@...
|
|
@$(AR) rcsD $@ $(OBJ)
|
|
@$(BUILD_DIR)/nvt-tools/nvt-ld-op --arc-sha1 $@
|
|
|
|
%.o: %.c
|
|
@echo Compiling $<
|
|
@$(CC) $(C_CFLAGS) -c $< -o $@
|
|
|
|
clean:
|
|
@rm -f $(LIB_NAME) $(OBJ) $(LIB_NAME).sym *.o *.a *.so*
|
|
@rm -rf $(OUTPUT_DIR)
|
|
codesize:
|
|
@echo $(MODULE_NAME) no obj
|
|
|
|
install:
|
|
@mkdir -p $(OUTPUT_DIR)
|
|
@cp -avf $(LIB_NAME) $(OUTPUT_DIR)
|
|
@cp -avf $(PREBUILD_LIB)/rtos/*.a $(OUTPUT_DIR)
|
|
|
|
endif
|