117 lines
3.6 KiB
Makefile
Executable File
117 lines
3.6 KiB
Makefile
Executable File
|
|
|
|
include ../../config.mk
|
|
include ../../../Makefile.inc
|
|
################################################################################
|
|
## set flags for golobal compile and link setting.
|
|
################################################################################
|
|
|
|
CONFIG_FOR_COMPILE = $(CFLAGS) $(LOCAL_CFLAGS) -Werror
|
|
CONFIG_FOR_LINK =
|
|
|
|
|
|
################################################################################
|
|
|
|
BuildPath = ./build
|
|
ObjectPath = $(BuildPath)/obj
|
|
OutputPath = ./
|
|
DependFilePath = $(BuildPath)/dep
|
|
Target = $(OutputPath)/libcdx_base.so ## output target.
|
|
|
|
ifneq ($(BuildPath),wildcard($(BuildPath)))
|
|
a := $(shell mkdir -p $(BuildPath))
|
|
endif
|
|
ifneq ($(ObjectPath),wildcard($(ObjectPath)))
|
|
a := $(shell mkdir -p $(ObjectPath))
|
|
endif
|
|
ifneq ($(DependFilePath),wildcard($(DependFilePath)))
|
|
a := $(shell mkdir -p $(DependFilePath))
|
|
endif
|
|
|
|
|
|
################################################################################
|
|
## set the source files, object files and dependency files
|
|
################################################################################
|
|
## set the source path to VPATH.
|
|
SourcePath = $(shell find ./ -type d)
|
|
SvnPath = $(shell find ./ -type d | grep ".svn")
|
|
SourcePath := $(filter-out $(SvnPath) $(BuildPath) $(ObjectPath) $(DependFilePath), $(SourcePath))
|
|
VPATH := $(SourcePath)
|
|
|
|
## set the source files.
|
|
SourceFiles = $(foreach dir,$(SourcePath),$(shell find $(dir) -maxdepth 1 -name "*.c"))
|
|
|
|
## set the object files.
|
|
ObjectFiles = $(addprefix $(ObjectPath)/, $(addsuffix .o ,$(basename $(notdir $(SourceFiles)))))
|
|
|
|
## set the dependency files.
|
|
DependFiles = $(addprefix $(DependFilePath)/, $(addsuffix .d ,$(notdir $(basename $(SourceFiles)))))
|
|
|
|
|
|
################################################################################
|
|
## set flags for compile and link
|
|
################################################################################
|
|
|
|
## set the include path for compile flags.
|
|
SourceIncludePath = $(foreach dir,$(SourcePath),-I$(dir)) -I../../
|
|
|
|
## set compile flags
|
|
ifeq ($(CONFIG_CC),$(OPTION_CC_LINUX_MUSLGNUEABI64))
|
|
CompileFlags = $(CONFIG_FOR_COMPILE) $(SourceIncludePath) -O1 -fPIC -ldl
|
|
else
|
|
CompileFlags = $(CONFIG_FOR_COMPILE) $(SourceIncludePath) -mfpu=neon -O1 -fPIC -ldl
|
|
endif
|
|
## set link flags
|
|
LoadFlags = $(CONFIG_FOR_LINK) -lpthread -ldl -shared
|
|
|
|
|
|
################################################################################
|
|
## make commands, all/clean/cleanall
|
|
################################################################################
|
|
|
|
## define commands for make, sush as all, clean
|
|
.PHONY: all clean cleantarget cleanall
|
|
all:$(Target)
|
|
|
|
clean:
|
|
-rm -f $(ObjectPath)/*
|
|
-rm -rf $(Target)
|
|
|
|
cleanall: clean
|
|
-rm -f $(DependFilePath)/*
|
|
-rm -rf $(BuildPath)
|
|
|
|
|
|
|
|
################################################################################
|
|
## define target dependencies.
|
|
################################################################################
|
|
|
|
## compile source files to object files.
|
|
#$(ObjectPath)/%.o:%.c
|
|
# $(CC) $(CompileFlags) -o $@ -c $<
|
|
$(ObjectFiles):$(ObjectPath)/%.o:%.c
|
|
@$(CC) $(CompileFlags) -o $@ -c $<
|
|
@echo "CC $<"
|
|
|
|
## link object files to the target share library.
|
|
$(Target):$(ObjectFiles)
|
|
@$(LD) -o $@ $^ $(LoadFlags)
|
|
@echo "LD $@"
|
|
|
|
## set rules to generate .d files.
|
|
$(DependFilePath)/%.d:%.c
|
|
@set -e; rm -f $@; \
|
|
$(CC) -MM $(CompileFlags) $< > $@.$$$$; \
|
|
sed 's,\($*\)\.o[:]*,$(ObjectPath)/\1.o $@: ,g' < $@.$$$$ > $@; \
|
|
rm -f $@.$$$$
|
|
|
|
## include the .d files to set dependency rules.
|
|
ifneq ($(MAKECMDGOALS),clean)
|
|
ifneq ($(MAKECMDGOALS),cleantarget)
|
|
ifneq ($(MAKECMDGOALS),cleanall)
|
|
-include $(DependFiles)
|
|
endif
|
|
endif
|
|
endif
|