205 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			Makefile
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			205 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			Makefile
		
	
	
		
			Executable File
		
	
	
	
	
| MODULE_NAME = kdrv_comm
 | |
| # DIRs
 | |
| VOS_DRIVER_DIR = $(NVT_VOS_DIR)/drivers
 | |
| KDRV_DIR = $(NVT_HDAL_DIR)/drivers/k_driver
 | |
| CURR_DRIVER_DIR = $(KDRV_DIR)
 | |
| RTOS_OUTPUT_DIR = $(CURR_DRIVER_DIR)/output
 | |
| EXTRA_INCLUDE += \
 | |
| 	-I$(VOS_DRIVER_DIR)/include \
 | |
| 	-I$(KDRV_DIR)/include \
 | |
| 	-I$(KDRV_DIR)/include/plat \
 | |
| 	-I$(CURR_DRIVER_DIR)/source/include \
 | |
| 	-I$(CURR_DRIVER_DIR)/source/comm/ddr_arb/include \
 | |
| 	-I$(CURR_DRIVER_DIR)/source/comm/drv_sys/include \
 | |
| 	-I$(CURR_DRIVER_DIR)/source/comm/pwm/include \
 | |
| 	-I$(CURR_DRIVER_DIR)/source/comm/sif/include \
 | |
| 	-I$(KDRV_DIR)/include/comm \
 | |
| 
 | |
| .PHONY: modules modules_install clean
 | |
| ###############################################################################
 | |
| # Linux Makefile                                                              #
 | |
| ###############################################################################
 | |
| ifeq ($(NVT_PRJCFG_CFG),Linux)
 | |
| C_CFLAGS  += -D_ARCH_ARM_=1 -D_ARCH_MIPS_=0 -D_ARCH_=$(_ARCH_ARM_)
 | |
| C_CFLAGS  += -D__LINUX -Werror
 | |
| EXTRA_CFLAGS += $(C_CFLAGS) $(EXTRA_INCLUDE) -Wno-date-time -Wno-sign-compare -D__SOC_680_PLATFORM__ -DDEBUG -D_GROUP_KO_
 | |
| KBUILD_EXTRA_SYMBOLS = $(shell find $(NVT_HDAL_DIR)/drivers -name Module.symvers)
 | |
| ccflags-y  := $(EXTRA_CFLAGS)
 | |
| 
 | |
| ifeq ($(CONFIG_NVT_HDAL_KDRV_COMM),y)
 | |
| obj-y += $(MODULE_NAME).o
 | |
| else
 | |
| obj-m += $(MODULE_NAME).o
 | |
| endif
 | |
| 
 | |
| OBJ := \
 | |
| 	kdrv_comm_main.o \
 | |
| 	drv_sys/timer_main.o \
 | |
| 	drv_sys/timer_proc.o \
 | |
| 	drv_sys/timer_drv.o \
 | |
| 	drv_sys/timer_api.o \
 | |
| 	drv_sys/timer_platform.o \
 | |
| 	drv_sys/timer.o \
 | |
| 	drv_sys/timer_ioctl.o \
 | |
| 	drv_sys/timer_export.o \
 | |
| 	drv_sys/hwclock.o \
 | |
| 	drv_sys/heavyload.o \
 | |
| 	drv_sys/heavyload_proc.o \
 | |
| 	ddr_arb/ddr_arb_main.o \
 | |
| 	ddr_arb/ddr_arb_proc.o \
 | |
| 	ddr_arb/ddr_arb_drv.o \
 | |
| 	ddr_arb/ddr_arb_api.o \
 | |
| 	ddr_arb/ddr_arb_platform.o \
 | |
| 	ddr_arb/arb.o \
 | |
| 	ddr_arb/emu_arb.o \
 | |
| 	ddr_arb/arb_ver.o \
 | |
| 	ddr_arb/ddr_arb_export.o \
 | |
| 	pwm/pwm_main.o \
 | |
| 	pwm/pwm_proc.o \
 | |
| 	pwm/pwm_drv.o \
 | |
| 	pwm/pwm_api.o \
 | |
| 	pwm/pwm_platform.o \
 | |
| 	pwm/pwm.o \
 | |
| 	pwm/pwm_ver.o \
 | |
| 	pwm/pwm_export.o \
 | |
| 	kdrv_log/vg_log_pif.o \
 | |
| 	kdrv_log/vg_log_core.o \
 | |
| 	kdrv_log/vg_log_linux.o \
 | |
| 	kdrv_log/vg_log_pub.o \
 | |
| 	sif/sif_main.o \
 | |
| 	sif/sif_proc.o \
 | |
| 	sif/sif_drv.o \
 | |
| 	sif/sif_api.o \
 | |
| 	sif/sif.o \
 | |
| 	sif/sif_export.o \
 | |
| 	fdt/fdt.o \
 | |
| 	fdt/fdt_ro.o \
 | |
| 	fdt/fdt_wip.o \
 | |
| 	fdt/fdt_sw.o \
 | |
| 	fdt/fdt_rw.o \
 | |
| 	fdt/fdt_strerror.o \
 | |
| 	fdt/fdt_empty_tree.o \
 | |
| 	fdt/fdt_addresses.o \
 | |
| 	fdt/fdt_overlay.o \
 | |
| 	fdt/fdt_export.o \
 | |
| 	ddr_arb/arb_protected.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'linux-driver/' '{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) $(NVT_KGCOV) modules
 | |
| 
 | |
| modules_install:
 | |
| 	@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)
 | |
| include $(NVT_PRJCFG_MODEL_CFG)
 | |
| OUTPUT_NAME = lib$(MODULE_NAME).a
 | |
| EXTRA_INCLUDE += -I$(KDRV_DIR)/include/plat
 | |
| C_CFLAGS = $(PLATFORM_CFLAGS) $(EXTRA_INCLUDE) -Wno-sign-compare -DDEBUG -D_$(CPU2_TYPE)_
 | |
| 
 | |
| SRC = \
 | |
| 	kdrv_comm_main.c \
 | |
| 	drv_sys/dummy_core.c \
 | |
| 	drv_sys/timer_platform.c \
 | |
| 	drv_sys/timer.c \
 | |
| 	drv_sys/timer_drv.c \
 | |
| 	drv_sys/hwclock.c \
 | |
| 	drv_sys/hwclock_freertos.c \
 | |
| 	drv_sys/delay.c \
 | |
| 	drv_sys/heavyload.o \
 | |
| 	ddr_arb/arb.c\
 | |
| 	ddr_arb/ddr_arb_platform.c\
 | |
| 	ddr_arb/arb_ver.c \
 | |
| 	pwm/pwm.c \
 | |
| 	pwm/pwm_platform.c \
 | |
| 	pwm/pwm_ver.c \
 | |
| 	kdrv_log/vg_log_pif.c \
 | |
| 	kdrv_log/vg_log_core.c \
 | |
| 	kdrv_log/vg_log_pub.c \
 | |
| 	kdrv_log/vg_log_rtos.c \
 | |
| 	fdt/fdt.c \
 | |
| 	fdt/fdt_ro.c \
 | |
| 	fdt/fdt_wip.c \
 | |
| 	fdt/fdt_sw.c \
 | |
| 	fdt/fdt_rw.c \
 | |
| 	fdt/fdt_strerror.c \
 | |
| 	fdt/fdt_empty_tree.c \
 | |
| 	fdt/fdt_addresses.c \
 | |
| 	fdt/fdt_overlay.c \
 | |
| 	drvdump/nvt_drvdump.c
 | |
| 
 | |
| copy = if [ ! -z "$(1)" -a "$(1)" != " " ]; then cp -avf $(1) $(2); fi
 | |
| 
 | |
| OBJ = $(SRC:.c=.o)
 | |
| 
 | |
| # variables for clean object
 | |
| RM_TRACER_OBJ = $(foreach n, $(OBJ:.o=), $(if $(wildcard $(n).c),$(if $(wildcard $(n).o),$(n).o,),))
 | |
| 
 | |
| ifeq ("$(wildcard *.c */*.c */*/*.c)","")
 | |
| modules:
 | |
| 	@echo "nothing to be done for '$(MODULE_NAME)'"
 | |
| 
 | |
| clean:
 | |
| 	@echo "nothing to be done for '$(MODULE_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 $(RM_TRACER_OBJ) *.a *.so*
 | |
| endif
 | |
| 
 | |
| modules_install:
 | |
| 	@mkdir -p $(RTOS_OUTPUT_DIR)
 | |
| 	@cp -avf *.a $(RTOS_OUTPUT_DIR)
 | |
| 
 | |
| endif
 | 
