xref: /linux/scripts/Makefile.lib (revision 1373411ae4cd0caf2e1a35fb801dd9a00b64dea2)
1f77bf014SSam Ravnborg# Backward compatibility
2f77bf014SSam Ravnborgasflags-y  += $(EXTRA_AFLAGS)
3f77bf014SSam Ravnborgccflags-y  += $(EXTRA_CFLAGS)
4f77bf014SSam Ravnborgcppflags-y += $(EXTRA_CPPFLAGS)
5f77bf014SSam Ravnborgldflags-y  += $(EXTRA_LDFLAGS)
6f77bf014SSam Ravnborg
7720097d8SSam Ravnborg#
8720097d8SSam Ravnborg# flags that take effect in sub directories
9720097d8SSam Ravnborgexport KBUILD_SUBDIR_ASFLAGS := $(KBUILD_SUBDIR_ASFLAGS) $(subdir-asflags-y)
10720097d8SSam Ravnborgexport KBUILD_SUBDIR_CCFLAGS := $(KBUILD_SUBDIR_CCFLAGS) $(subdir-ccflags-y)
11720097d8SSam Ravnborg
121da177e4SLinus Torvalds# Figure out what we need to build from the various variables
131da177e4SLinus Torvalds# ===========================================================================
141da177e4SLinus Torvalds
151da177e4SLinus Torvalds# When an object is listed to be built compiled-in and modular,
161da177e4SLinus Torvalds# only build the compiled-in version
171da177e4SLinus Torvalds
181da177e4SLinus Torvaldsobj-m := $(filter-out $(obj-y),$(obj-m))
191da177e4SLinus Torvalds
201da177e4SLinus Torvalds# Libraries are always collected in one lib file.
211da177e4SLinus Torvalds# Filter out objects already built-in
221da177e4SLinus Torvalds
231da177e4SLinus Torvaldslib-y := $(filter-out $(obj-y), $(sort $(lib-y) $(lib-m)))
241da177e4SLinus Torvalds
251da177e4SLinus Torvalds
261da177e4SLinus Torvalds# Handle objects in subdirs
271da177e4SLinus Torvalds# ---------------------------------------------------------------------------
281da177e4SLinus Torvalds# o if we encounter foo/ in $(obj-y), replace it by foo/built-in.o
291da177e4SLinus Torvalds#   and add the directory to the list of dirs to descend into: $(subdir-y)
301da177e4SLinus Torvalds# o if we encounter foo/ in $(obj-m), remove it from $(obj-m)
311da177e4SLinus Torvalds#   and add the directory to the list of dirs to descend into: $(subdir-m)
321da177e4SLinus Torvalds
33551559e1STejun Heo# Determine modorder.
34551559e1STejun Heo# Unfortunately, we don't have information about ordering between -y
35551559e1STejun Heo# and -m subdirs.  Just put -y's first.
36551559e1STejun Heomodorder	:= $(patsubst %/,%/modules.order, $(filter %/, $(obj-y)) $(obj-m:.o=.ko))
37551559e1STejun Heo
381da177e4SLinus Torvalds__subdir-y	:= $(patsubst %/,%,$(filter %/, $(obj-y)))
391da177e4SLinus Torvaldssubdir-y	+= $(__subdir-y)
401da177e4SLinus Torvalds__subdir-m	:= $(patsubst %/,%,$(filter %/, $(obj-m)))
411da177e4SLinus Torvaldssubdir-m	+= $(__subdir-m)
421da177e4SLinus Torvaldsobj-y		:= $(patsubst %/, %/built-in.o, $(obj-y))
431da177e4SLinus Torvaldsobj-m		:= $(filter-out %/, $(obj-m))
441da177e4SLinus Torvalds
451da177e4SLinus Torvalds# Subdirectories we need to descend into
461da177e4SLinus Torvalds
471da177e4SLinus Torvaldssubdir-ym	:= $(sort $(subdir-y) $(subdir-m))
481da177e4SLinus Torvalds
491da177e4SLinus Torvalds# if $(foo-objs) exists, foo.o is a composite object
501da177e4SLinus Torvaldsmulti-used-y := $(sort $(foreach m,$(obj-y), $(if $(strip $($(m:.o=-objs)) $($(m:.o=-y))), $(m))))
511da177e4SLinus Torvaldsmulti-used-m := $(sort $(foreach m,$(obj-m), $(if $(strip $($(m:.o=-objs)) $($(m:.o=-y))), $(m))))
521da177e4SLinus Torvaldsmulti-used   := $(multi-used-y) $(multi-used-m)
531da177e4SLinus Torvaldssingle-used-m := $(sort $(filter-out $(multi-used-m),$(obj-m)))
541da177e4SLinus Torvalds
551da177e4SLinus Torvalds# Build list of the parts of our composite objects, our composite
561da177e4SLinus Torvalds# objects depend on those (obviously)
571da177e4SLinus Torvaldsmulti-objs-y := $(foreach m, $(multi-used-y), $($(m:.o=-objs)) $($(m:.o=-y)))
581da177e4SLinus Torvaldsmulti-objs-m := $(foreach m, $(multi-used-m), $($(m:.o=-objs)) $($(m:.o=-y)))
591da177e4SLinus Torvaldsmulti-objs   := $(multi-objs-y) $(multi-objs-m)
601da177e4SLinus Torvalds
61f5fb9765SSam Ravnborg# $(subdir-obj-y) is the list of objects in $(obj-y) which uses dir/ to
62f5fb9765SSam Ravnborg# tell kbuild to descend
63f5fb9765SSam Ravnborgsubdir-obj-y := $(filter %/built-in.o, $(obj-y))
641da177e4SLinus Torvalds
651da177e4SLinus Torvalds# $(obj-dirs) is a list of directories that contain object files
661da177e4SLinus Torvaldsobj-dirs := $(dir $(multi-objs) $(subdir-obj-y))
671da177e4SLinus Torvalds
681da177e4SLinus Torvalds# Replace multi-part objects by their individual parts, look at local dir only
691da177e4SLinus Torvaldsreal-objs-y := $(foreach m, $(filter-out $(subdir-obj-y), $(obj-y)), $(if $(strip $($(m:.o=-objs)) $($(m:.o=-y))),$($(m:.o=-objs)) $($(m:.o=-y)),$(m))) $(extra-y)
701da177e4SLinus Torvaldsreal-objs-m := $(foreach m, $(obj-m), $(if $(strip $($(m:.o=-objs)) $($(m:.o=-y))),$($(m:.o=-objs)) $($(m:.o=-y)),$(m)))
711da177e4SLinus Torvalds
721da177e4SLinus Torvalds# Add subdir path
731da177e4SLinus Torvalds
741da177e4SLinus Torvaldsextra-y		:= $(addprefix $(obj)/,$(extra-y))
751da177e4SLinus Torvaldsalways		:= $(addprefix $(obj)/,$(always))
761da177e4SLinus Torvaldstargets		:= $(addprefix $(obj)/,$(targets))
77551559e1STejun Heomodorder	:= $(addprefix $(obj)/,$(modorder))
781da177e4SLinus Torvaldsobj-y		:= $(addprefix $(obj)/,$(obj-y))
791da177e4SLinus Torvaldsobj-m		:= $(addprefix $(obj)/,$(obj-m))
801da177e4SLinus Torvaldslib-y		:= $(addprefix $(obj)/,$(lib-y))
811da177e4SLinus Torvaldssubdir-obj-y	:= $(addprefix $(obj)/,$(subdir-obj-y))
821da177e4SLinus Torvaldsreal-objs-y	:= $(addprefix $(obj)/,$(real-objs-y))
831da177e4SLinus Torvaldsreal-objs-m	:= $(addprefix $(obj)/,$(real-objs-m))
841da177e4SLinus Torvaldssingle-used-m	:= $(addprefix $(obj)/,$(single-used-m))
851da177e4SLinus Torvaldsmulti-used-y	:= $(addprefix $(obj)/,$(multi-used-y))
861da177e4SLinus Torvaldsmulti-used-m	:= $(addprefix $(obj)/,$(multi-used-m))
871da177e4SLinus Torvaldsmulti-objs-y	:= $(addprefix $(obj)/,$(multi-objs-y))
881da177e4SLinus Torvaldsmulti-objs-m	:= $(addprefix $(obj)/,$(multi-objs-m))
891da177e4SLinus Torvaldssubdir-ym	:= $(addprefix $(obj)/,$(subdir-ym))
901da177e4SLinus Torvaldsobj-dirs	:= $(addprefix $(obj)/,$(obj-dirs))
911da177e4SLinus Torvalds
921da177e4SLinus Torvalds# These flags are needed for modversions and compiling, so we define them here
931da177e4SLinus Torvalds# already
941da177e4SLinus Torvalds# $(modname_flags) #defines KBUILD_MODNAME as the name of the module it will
951da177e4SLinus Torvalds# end up in (or would, if it gets compiled in)
961da177e4SLinus Torvalds# Note: It's possible that one object gets potentially linked into more
971da177e4SLinus Torvalds#       than one module. In that case KBUILD_MODNAME will be set to foo_bar,
981da177e4SLinus Torvalds#       where foo and bar are the name of the modules.
99f83b5e32SUstyugov Romanname-fix = $(subst $(comma),_,$(subst -,_,$1))
1005e8d780dSSam Ravnborgbasename_flags = -D"KBUILD_BASENAME=KBUILD_STR($(call name-fix,$(basetarget)))"
101f83b5e32SUstyugov Romanmodname_flags  = $(if $(filter 1,$(words $(modname))),\
102f83b5e32SUstyugov Roman                 -D"KBUILD_MODNAME=KBUILD_STR($(call name-fix,$(modname)))")
1031da177e4SLinus Torvalds
104346e15beSJason Baron#hash values
105e9d376f0SJason Baronifdef CONFIG_DYNAMIC_DEBUG
106346e15beSJason Barondebug_flags = -D"DEBUG_HASH=$(shell ./scripts/basic/hash djb2 $(@D)$(modname))"\
107346e15beSJason Baron              -D"DEBUG_HASH2=$(shell ./scripts/basic/hash r5 $(@D)$(modname))"
108346e15beSJason Baronelse
109346e15beSJason Barondebug_flags =
110346e15beSJason Baronendif
111346e15beSJason Baron
112720097d8SSam Ravnborgorig_c_flags   = $(KBUILD_CPPFLAGS) $(KBUILD_CFLAGS) $(KBUILD_SUBDIR_CCFLAGS) \
113d8672b40SSam Ravnborg                 $(ccflags-y) $(CFLAGS_$(basetarget).o)
114656ee82cSSteven Rostedt_c_flags       = $(filter-out $(CFLAGS_REMOVE_$(basetarget).o), $(orig_c_flags))
115720097d8SSam Ravnborg_a_flags       = $(KBUILD_CPPFLAGS) $(KBUILD_AFLAGS) $(KBUILD_SUBDIR_ASFLAGS) \
116d8672b40SSam Ravnborg                 $(asflags-y) $(AFLAGS_$(basetarget).o)
117f77bf014SSam Ravnborg_cpp_flags     = $(KBUILD_CPPFLAGS) $(cppflags-y) $(CPPFLAGS_$(@F))
1181da177e4SLinus Torvalds
1192521f2c2SPeter Oberparleiter#
1202521f2c2SPeter Oberparleiter# Enable gcov profiling flags for a file, directory or for all files depending
1212521f2c2SPeter Oberparleiter# on variables GCOV_PROFILE_obj.o, GCOV_PROFILE and CONFIG_GCOV_PROFILE_ALL
1222521f2c2SPeter Oberparleiter# (in this order)
1232521f2c2SPeter Oberparleiter#
1242521f2c2SPeter Oberparleiterifeq ($(CONFIG_GCOV_KERNEL),y)
1252521f2c2SPeter Oberparleiter_c_flags += $(if $(patsubst n%,, \
1262521f2c2SPeter Oberparleiter		$(GCOV_PROFILE_$(basetarget).o)$(GCOV_PROFILE)$(CONFIG_GCOV_PROFILE_ALL)), \
1272521f2c2SPeter Oberparleiter		$(CFLAGS_GCOV))
1282521f2c2SPeter Oberparleiterendif
1292521f2c2SPeter Oberparleiter
1309e1b9b80SAlan Jenkinsifdef CONFIG_SYMBOL_PREFIX
1319e1b9b80SAlan Jenkins_cpp_flags += -DSYMBOL_PREFIX=$(patsubst "%",%,$(CONFIG_SYMBOL_PREFIX))
1329e1b9b80SAlan Jenkinsendif
1339e1b9b80SAlan Jenkins
1349e1b9b80SAlan Jenkins
1351da177e4SLinus Torvalds# If building the kernel in a separate objtree expand all occurrences
1361da177e4SLinus Torvalds# of -Idir to -I$(srctree)/dir except for absolute paths (starting with '/').
1371da177e4SLinus Torvalds
1381da177e4SLinus Torvaldsifeq ($(KBUILD_SRC),)
1391da177e4SLinus Torvalds__c_flags	= $(_c_flags)
1401da177e4SLinus Torvalds__a_flags	= $(_a_flags)
1411da177e4SLinus Torvalds__cpp_flags     = $(_cpp_flags)
1421da177e4SLinus Torvaldselse
1431da177e4SLinus Torvalds
1441da177e4SLinus Torvalds# -I$(obj) locates generated .h files
1451da177e4SLinus Torvalds# $(call addtree,-I$(obj)) locates .h files in srctree, from generated .c files
1461da177e4SLinus Torvalds#   and locates generated .h files
1471da177e4SLinus Torvalds# FIXME: Replace both with specific CFLAGS* statements in the makefiles
1481da177e4SLinus Torvalds__c_flags	= $(call addtree,-I$(obj)) $(call flags,_c_flags)
1491da177e4SLinus Torvalds__a_flags	=                          $(call flags,_a_flags)
1501da177e4SLinus Torvalds__cpp_flags     =                          $(call flags,_cpp_flags)
1511da177e4SLinus Torvaldsendif
1521da177e4SLinus Torvalds
153d8672b40SSam Ravnborgc_flags        = -Wp,-MD,$(depfile) $(NOSTDINC_FLAGS) $(LINUXINCLUDE)     \
1541da177e4SLinus Torvalds		 $(__c_flags) $(modkern_cflags)                           \
155346e15beSJason Baron		 -D"KBUILD_STR(s)=\#s" $(basename_flags) $(modname_flags) \
156346e15beSJason Baron		  $(debug_flags)
1571da177e4SLinus Torvalds
158d8672b40SSam Ravnborga_flags        = -Wp,-MD,$(depfile) $(NOSTDINC_FLAGS) $(LINUXINCLUDE)     \
1591da177e4SLinus Torvalds		 $(__a_flags) $(modkern_aflags)
1601da177e4SLinus Torvalds
161d8672b40SSam Ravnborgcpp_flags      = -Wp,-MD,$(depfile) $(NOSTDINC_FLAGS) $(LINUXINCLUDE)     \
162d8672b40SSam Ravnborg		 $(__cpp_flags)
1631da177e4SLinus Torvalds
164f77bf014SSam Ravnborgld_flags       = $(LDFLAGS) $(ldflags-y)
1651da177e4SLinus Torvalds
1661da177e4SLinus Torvalds# Finds the multi-part object the current object will be linked into
1671da177e4SLinus Torvaldsmodname-multi = $(sort $(foreach m,$(multi-used),\
1681da177e4SLinus Torvalds		$(if $(filter $(subst $(obj)/,,$*.o), $($(m:.o=-objs)) $($(m:.o=-y))),$(m:.o=))))
1691da177e4SLinus Torvalds
1701da177e4SLinus Torvalds# Shipped files
1711da177e4SLinus Torvalds# ===========================================================================
1721da177e4SLinus Torvalds
1731da177e4SLinus Torvaldsquiet_cmd_shipped = SHIPPED $@
1741da177e4SLinus Torvaldscmd_shipped = cat $< > $@
1751da177e4SLinus Torvalds
1761da177e4SLinus Torvalds$(obj)/%:: $(src)/%_shipped
1771da177e4SLinus Torvalds	$(call cmd,shipped)
1781da177e4SLinus Torvalds
1791da177e4SLinus Torvalds# Commands useful for building a boot image
1801da177e4SLinus Torvalds# ===========================================================================
1811da177e4SLinus Torvalds#
1821da177e4SLinus Torvalds#	Use as following:
1831da177e4SLinus Torvalds#
1841da177e4SLinus Torvalds#	target: source(s) FORCE
1851da177e4SLinus Torvalds#		$(if_changed,ld/objcopy/gzip)
1861da177e4SLinus Torvalds#
187836caba7SSam Ravnborg#	and add target to extra-y so that we know we have to
1881da177e4SLinus Torvalds#	read in the saved command line
1891da177e4SLinus Torvalds
1901da177e4SLinus Torvalds# Linking
1911da177e4SLinus Torvalds# ---------------------------------------------------------------------------
1921da177e4SLinus Torvalds
1931da177e4SLinus Torvaldsquiet_cmd_ld = LD      $@
194f77bf014SSam Ravnborgcmd_ld = $(LD) $(LDFLAGS) $(ldflags-y) $(LDFLAGS_$(@F)) \
1951da177e4SLinus Torvalds	       $(filter-out FORCE,$^) -o $@
1961da177e4SLinus Torvalds
1971da177e4SLinus Torvalds# Objcopy
1981da177e4SLinus Torvalds# ---------------------------------------------------------------------------
1991da177e4SLinus Torvalds
2001da177e4SLinus Torvaldsquiet_cmd_objcopy = OBJCOPY $@
2011da177e4SLinus Torvaldscmd_objcopy = $(OBJCOPY) $(OBJCOPYFLAGS) $(OBJCOPYFLAGS_$(@F)) $< $@
2021da177e4SLinus Torvalds
2031da177e4SLinus Torvalds# Gzip
2041da177e4SLinus Torvalds# ---------------------------------------------------------------------------
2051da177e4SLinus Torvalds
2061da177e4SLinus Torvaldsquiet_cmd_gzip = GZIP    $@
207d3dd3b5aSH. Peter Anvincmd_gzip = (cat $(filter-out FORCE,$^) | gzip -f -9 > $@) || \
208d3dd3b5aSH. Peter Anvin	(rm -f $@ ; false)
2091da177e4SLinus Torvalds
2101da177e4SLinus Torvalds
211bc22c17eSAlain Knaff# Bzip2
212bc22c17eSAlain Knaff# ---------------------------------------------------------------------------
213bc22c17eSAlain Knaff
214d3dd3b5aSH. Peter Anvin# Bzip2 and LZMA do not include size in file... so we have to fake that;
215d3dd3b5aSH. Peter Anvin# append the size as a 32-bit littleendian number as gzip does.
2164a2ff67cSMichael Tokarevsize_append = printf $(shell						\
217d3dd3b5aSH. Peter Anvindec_size=0;								\
218d3dd3b5aSH. Peter Anvinfor F in $1; do								\
219d3dd3b5aSH. Peter Anvin	fsize=$$(stat -c "%s" $$F);					\
220d3dd3b5aSH. Peter Anvin	dec_size=$$(expr $$dec_size + $$fsize);				\
221d3dd3b5aSH. Peter Anvindone;									\
222*1373411aSJonathan Niederprintf "%08x\n" $$dec_size |						\
223*1373411aSJonathan Nieder	sed 's/\(..\)/\1 /g' | {					\
224*1373411aSJonathan Nieder		read ch0 ch1 ch2 ch3;					\
225*1373411aSJonathan Nieder		for ch in $$ch3 $$ch2 $$ch1 $$ch0; do			\
226*1373411aSJonathan Nieder			printf '%s%03o' '\\' $$((0x$$ch)); 		\
227*1373411aSJonathan Nieder		done;							\
228*1373411aSJonathan Nieder	}								\
229d3dd3b5aSH. Peter Anvin)
230bc22c17eSAlain Knaff
231bc22c17eSAlain Knaffquiet_cmd_bzip2 = BZIP2   $@
232d3dd3b5aSH. Peter Anvincmd_bzip2 = (cat $(filter-out FORCE,$^) | \
233d3dd3b5aSH. Peter Anvin	bzip2 -9 && $(call size_append, $(filter-out FORCE,$^))) > $@ || \
234d3dd3b5aSH. Peter Anvin	(rm -f $@ ; false)
235bc22c17eSAlain Knaff
236bc22c17eSAlain Knaff# Lzma
237bc22c17eSAlain Knaff# ---------------------------------------------------------------------------
238bc22c17eSAlain Knaff
239bc22c17eSAlain Knaffquiet_cmd_lzma = LZMA    $@
240d3dd3b5aSH. Peter Anvincmd_lzma = (cat $(filter-out FORCE,$^) | \
241d3dd3b5aSH. Peter Anvin	lzma -9 && $(call size_append, $(filter-out FORCE,$^))) > $@ || \
242d3dd3b5aSH. Peter Anvin	(rm -f $@ ; false)
2437dd65febSAlbin Tonnerre
2447dd65febSAlbin Tonnerrequiet_cmd_lzo = LZO    $@
2457dd65febSAlbin Tonnerrecmd_lzo = (cat $(filter-out FORCE,$^) | \
2467dd65febSAlbin Tonnerre	lzop -9 && $(call size_append, $(filter-out FORCE,$^))) > $@ || \
2477dd65febSAlbin Tonnerre	(rm -f $@ ; false)
248