其他分享
首页 > 其他分享> > makefile

makefile

作者:互联网

Makefile
CROSS_COMPILE =
AS		= $(CROSS_COMPILE)as
LD		= $(CROSS_COMPILE)ld
CC		= $(CROSS_COMPILE)gcc
CPP		= $(CC) -E
AR		= $(CROSS_COMPILE)ar
NM		= $(CROSS_COMPILE)nm

STRIP		= $(CROSS_COMPILE)strip
OBJCOPY		= $(CROSS_COMPILE)objcopy
OBJDUMP		= $(CROSS_COMPILE)objdump

export AS LD CC CPP AR NM
export STRIP OBJCOPY OBJDUMP

#获取TOP_PATH
#TOP_PATH = $(shell pwd)
#添加vpath变量
#VPATH = $(TOP_PATH)/DIR
#添加头文件自动搜索路径
#CINCLUDES = -I(TOP_PATH)/DIR

CFLAGS := -Wall -O0 -g   #$(CINCLUDES)
SAVE_TEMPS := -save-temps

LDFLAGS := 

export CFLAGS LDFLAGS

TOPDIR := $(shell pwd)
export TOPDIR
lpthread :=-lpthread
TARGET := test


 obj-y += main.o
 #obj-y += tpool.o
 #obj-y += b/
 #obj-y += cc/

all : 
	make -C ./ -f $(TOPDIR)/Makefile.build
	$(CC)  $(LDFLAGS) -o $(TARGET) built-in.o $(lpthread)


clean:
	rm -f $(shell find -name "*.o")
	rm -f $(shell find -name "*.d")
	rm -f $(shell find -name "*.i*")
	rm -f $(shell find -name "*.s")
	rm -f $(TARGET)
	rm -f $(shell find -name "core")
.PHONY:all clean 


Makefile.build
PHONY := build
build :
obj-y :=
subdir-y :=

include Makefile
__subdir-y	:= $(patsubst %/,%,$(filter %/, $(obj-y)))
subdir-y	+= $(__subdir-y)
subdir_objs := $(foreach f,$(subdir-y),$(f)/built-in.o)
cur_objs := $(filter-out %/, $(obj-y))
dep_files := $(foreach f,$(cur_objs),.$(f).d)

PHONY += $(subdir-y)
build : $(subdir-y) built-in.o
$(subdir-y):
	make -C $@ -f $(TOPDIR)/Makefile.build
built-in.o : $(cur_objs) $(subdir_objs)
	$(LD) -r -o $@ $^
dep_file = .$@.d
%.o : %.c
	$(CC)  $(SAVE_TEMPS) $(CFLAGS) -Wp,-MD,$(dep_file)  -c -o   $@  $< 
.PHONY : $(PHONY)

标签:shell,obj,makefile,CROSS,COMPILE,subdir,build
来源: https://www.cnblogs.com/daocaisheng/p/15513122.html