nt9856x/code/hdal/vendor/isp/drivers/source/ae/Makefile
2023-03-28 15:07:53 +08:00

182 lines
5.6 KiB
Makefile
Executable File

MODULE_NAME = nvt_ae
# DIRs
VOS_DRIVER_DIR = $(NVT_VOS_DIR)/drivers
KDRV_DIR = $(NVT_HDAL_DIR)/drivers/k_driver
KFLOW_DIR = $(NVT_HDAL_DIR)/drivers/k_flow
CURR_DRIVER_DIR = $(NVT_HDAL_DIR)/vendor/isp/drivers
RTOS_OUTPUT_DIR = $(CURR_DRIVER_DIR)/output
PREBUILT_DIR = $(NVT_HDAL_DIR)/vendor/isp/drivers/source/ae
# INCs
VOS_INC_PATH = $(VOS_DRIVER_DIR)/include
KDRV_INC_PATH = $(KDRV_DIR)/include
KFLOW_INC_PATH = $(KFLOW_DIR)/include
CURR_DRIVER_INC_PATH = $(CURR_DRIVER_DIR)/include
ALG_ISP_DRV_INC_PATH=$(NVT_HDAL_DIR)/vendor/alg/isp/drivers
# INC FLAGs
EXTRA_INCLUDE += \
-I$(VOS_INC_PATH) \
-I$(KDRV_INC_PATH) \
-I$(KDRV_INC_PATH)/comm \
-I$(KFLOW_INC_PATH) \
-I$(ALG_ISP_DRV_INC_PATH)/include/ \
-I$(CURR_DRIVER_INC_PATH) \
-I$(ALG_ISP_DRV_INC_PATH)/source/ae/ \
-I$(ALG_ISP_DRV_INC_PATH)/source/ae/ae_lib/ \
-I$(ALG_ISP_DRV_INC_PATH)/source/ae/ae_param/ \
-I$(ALG_ISP_DRV_INC_PATH)/source/ae/ae_task/ \
-I$(ALG_ISP_DRV_INC_PATH)/source/ae/ae_ui/ \
-I$(ALG_ISP_DRV_INC_PATH)/source/ae/ae_nnsc/
.PHONY: modules modules_install clean
###############################################################################
# Linux Makefile #
###############################################################################
ifeq ($(NVT_PRJCFG_CFG),Linux)
# to solve the 'make modules_install' got empty CONFIG_OLD_MCOUNT
ifeq ($(KERNELRELEASE),)
-include $(KERNELDIR)/.config
endif
C_CFLAGS += -D__LINUX -Werror
EXTRA_CFLAGS += $(C_CFLAGS) $(EXTRA_INCLUDE) -Wno-date-time -I$(src)/include -DDEBUG
KBUILD_EXTRA_SYMBOLS = $(shell find $(VOS_DRIVER_DIR) -name Module.symvers) $(shell find $(KDRV_DIR) -name Module.symvers) $(shell find $(KFLOW_DIR) -name Module.symvers) $(shell find $(CURR_DRIVER_DIR) -name Module.symvers)
obj-m += $(MODULE_NAME).o
OBJ := \
ae_dbg.o \
ae_main.o \
ae_proc.o \
ae_version.o \
ae_lib/ae_alg.o \
ae_lib/ae_curve.o \
ae_lib/ae_dciris.o \
ae_lib/ae_afd.o \
ae_lib/ae_flow.o \
ae_lib/aet_api.o \
ae_lib/aet_cfg.o \
ae_lib/aet_dtsi.o \
ae_lib/ae_api.o \
ae_param/ae_param_default.o \
ae_task/ae_task.o \
ae_task/ae_task_id.o \
ae_ui/ae_ui.o \
ae_nnsc/ae_nnsc.o
ifeq ($(CONFIG_FUNCTION_TRACER),y)
$(MODULE_NAME)-objs := $(OBJ)
else
$(MODULE_NAME)-objs := $(OBJ:.o=_no_tracer.o)
EXTRA_CFLAGS += $(shell for n in $(OBJ:.o=); do if [ -f $(src)/$$n.c ]; then ln -sf $$(basename $${n}.c) $(src)/$${n}_no_tracer.c; else rm -f $(src)/$${n}_no_tracer.c; fi done)
endif
ifeq ($(KERNELRELEASE),)
PWD := $(shell pwd)
KERVER ?= $(NVT_LINUX_VER)
KDIR ?= $(KERNELDIR)
MDIR ?= $(KERNELDIR)/_install_modules/lib/modules/$(KERVER)/hdal
MODPATH := $(shell echo $(PWD) | awk -F'source/' '{print $$NF}';)
MODNAME := $(shell echo $(obj-m:.o=.ko))
# variables for clean object
RM_TRACER_OBJ = $(foreach n, $(OBJ:.o=), $(if $(wildcard $(n).c),$(if $(wildcard $(n).o),$(n).o,),))
RM_NO_TRACER_OBJ = $(foreach n, $(OBJ:.o=), $(if $(wildcard $(n).c),$(if $(wildcard $(n)_no_tracer.o),$(n)_no_tracer.o,),))
modules:
@$(MAKE) -C $(KDIR) M=$(PWD) modules
modules_install:
ifeq ($(wildcard $(OBJ:.o=.c)),$(strip $(OBJ:.o=.c)))
@mkdir -p $(PREBUILT_DIR);
@cp --parent -t $(PREBUILT_DIR) $($(MODULE_NAME)-objs) Makefile \
ae_dbg.c ae_dbg.h ae_main.c ae_main.h ae_proc.c ae_proc.h ae_version.c ae_version.h ae_param/ae_param_default.c \
../../include/ae_alg.h ../../include/ae_ui.h ../../include/ae_nnsc.h ../../include/aet_api.h;
endif
@if [ -z $(NVT_MOD_INSTALL) ]; then \
rm -f $(MDIR)/$(MODPATH)/$(MODNAME); \
install -m644 -b -D $(MODNAME) ${MDIR}/$(MODPATH)/$(MODNAME); \
cd $(KDIR)/_install_modules/lib/modules/$(KERVER)/; depmod -b $(KDIR)/_install_modules/ -a $(KERVER); \
else \
mkdir -p $(NVT_MOD_INSTALL)/lib/modules/$(KERVER); \
install -m644 -b -D $(MODNAME) $(NVT_MOD_INSTALL)/lib/modules/$(KERVER)/hdal/$(MODPATH)/$(MODNAME); \
fi
clean:
@rm -rf $(MODULE_NAME).* .$(MODULE_NAME).* $(OBJ:.o=_no_tracer.c) Module.symvers modules.order .tmp_versions
@rm -f `find . -type f -name ".*.cmd" -o -name ".*.d"`
@rm -f $(RM_TRACER_OBJ) $(RM_NO_TRACER_OBJ)
codesize:
@echo $(MODULE_NAME)
@$(OBJDUMP) -t $(MODULE_NAME).o > $(MODULE_NAME).sym && \
$(BUILD_DIR)/nvt-tools/nvt-ld-op -j $(MODULE_NAME).sym
endif
###############################################################################
# rtos Makefile #
###############################################################################
else ifeq ($(NVT_PRJCFG_CFG),rtos)
OUTPUT_NAME = lib$(MODULE_NAME).a
EXTRA_INCLUDE += -I$(KDRV_DIR)/include/plat
C_CFLAGS = $(PLATFORM_CFLAGS) $(EXTRA_INCLUDE)
SRC = \
ae_dbg.c \
ae_sxcmd.c \
ae_version.c \
ae_lib/ae_alg.c \
ae_lib/ae_curve.c \
ae_lib/ae_dciris.c \
ae_lib/ae_afd.c \
ae_lib/ae_flow.c \
ae_lib/aet_api.c \
ae_lib/aet_cfg.c \
ae_lib/aet_dtsi.c \
ae_lib/ae_api.c \
ae_param/ae_param_default.c \
ae_task/ae_task.c \
ae_task/ae_task_id.c \
ae_ui/ae_ui.c \
ae_nnsc/ae_nnsc.c
copy = if [ ! -z "$(1)" -a "$(1)" != " " ]; then cp -avf $(1) $(2); fi
OBJ := $(SRC:.c=.o)
ifneq ($(wildcard $(SRC)),$(strip $(SRC)))
modules:
@echo "nothing to be done for '$(OUTPUT_NAME)'"
clean:
@echo "nothing to be done for '$(OUTPUT_NAME)'"
else
modules : $(OUTPUT_NAME)
%.o:%.c
@echo Compiling $<
@$(CC) $(C_CFLAGS) -c $< -o $@
$(OUTPUT_NAME): $(OBJ)
@echo Creating library $* ...
@$(AR) rcsD $(OUTPUT_NAME) $(OBJ)
@$(BUILD_DIR)/nvt-tools/nvt-ld-op --arc-sha1 $@
clean:
@rm -f $(OBJ) *.a *.so*
endif
modules_install:
ifneq ($(SRC),)
@mkdir -p $(RTOS_OUTPUT_DIR)
@cp -avf *.a $(RTOS_OUTPUT_DIR)
ifeq ($(wildcard $(SRC)),$(strip $(SRC)))
@cp -avf -t $(PREBUILT_DIR) *.a Makefile
endif
else
@echo "nothing to release for '$(OUTPUT_NAME)'"
endif
endif