| [72] | 1 | # $Id: footer.kmk 1148 2007-09-27 18:40:05Z bird $ | 
|---|
|  | 2 | ## @file | 
|---|
|  | 3 | # | 
|---|
|  | 4 | # kBuild - File included at top of makefile. | 
|---|
|  | 5 | # | 
|---|
| [782] | 6 | # Copyright (c) 2004-2007 knut st. osmundsen <bird-kBuild-spam@anduin.net> | 
|---|
| [72] | 7 | # | 
|---|
|  | 8 | # | 
|---|
|  | 9 | # This file is part of kBuild. | 
|---|
|  | 10 | # | 
|---|
|  | 11 | # kBuild is free software; you can redistribute it and/or modify | 
|---|
|  | 12 | # it under the terms of the GNU General Public License as published by | 
|---|
| [106] | 13 | # the Free Software Foundation; either version source of the License, or | 
|---|
| [72] | 14 | # (at your option) any later version. | 
|---|
|  | 15 | # | 
|---|
|  | 16 | # kBuild is distributed in the hope that it will be useful, | 
|---|
|  | 17 | # but WITHOUT ANY WARRANTY; without even the implied warranty of | 
|---|
|  | 18 | # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
|---|
|  | 19 | # GNU General Public License for more details. | 
|---|
|  | 20 | # | 
|---|
|  | 21 | # You should have received a copy of the GNU General Public License | 
|---|
|  | 22 | # along with kBuild; if not, write to the Free Software | 
|---|
| [353] | 23 | # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA | 
|---|
| [72] | 24 | # | 
|---|
|  | 25 | # | 
|---|
|  | 26 |  | 
|---|
|  | 27 | ifndef __footer_kmk__ | 
|---|
|  | 28 | # start-of-file-content | 
|---|
| [988] | 29 | ifdef KBUILD_PROFILE_SELF | 
|---|
|  | 30 | _KBUILD_TS_FOOTER_START := $(nanots ) | 
|---|
|  | 31 | $(info prof: $(int-sub $(_KBUILD_TS_FOOTER_START), $(_KBUILD_TS_HEADER_START)) - $(int-sub $(_KBUILD_TS_FOOTER_START), $(_KBUILD_TS_PREV)) - start of footer.kmk) | 
|---|
|  | 32 | _KBUILD_TS_PREV := $(_KBUILD_TS_FOOTER_START) | 
|---|
|  | 33 | endif | 
|---|
| [72] | 34 |  | 
|---|
|  | 35 | # | 
|---|
|  | 36 | # Variables. | 
|---|
| [73] | 37 | # (Some of these need initialization before including definitions using them.) | 
|---|
| [72] | 38 | # | 
|---|
|  | 39 |  | 
|---|
| [985] | 40 | # All targets of each types. | 
|---|
|  | 41 | _ALL_BLDPROGS    := $(BLDPROGS)    $(BLDPROGS.$(BUILD_PLATFORM))    $(BLDPROGS.$(BUILD_PLATFORM).$(BUILD_PLATFORM_ARCH))    $(BLDPROGS.$(BUILD_PLATFORM_ARCH))  $(BLDPROGS.$(BUILD_PLATFORM_CPU))   $(BLDPROGS.$(BUILD_TYPE)) | 
|---|
|  | 42 | _ALL_LIBRARIES   := $(LIBRARIES)   $(LIBRARIES.$(BUILD_TARGET))     $(LIBRARIES.$(BUILD_TARGET).$(BUILD_TARGET_ARCH))       $(LIBRARIES.$(BUILD_TARGET_ARCH))   $(LIBRARIES.$(BUILD_TARGET_CPU))    $(LIBRARIES.$(BUILD_TYPE)) | 
|---|
|  | 43 | _ALL_IMPORT_LIBS := $(IMPORT_LIBS) $(IMPORT_LIBS.$(BUILD_TARGET))   $(IMPORT_LIBS.$(BUILD_TARGET).$(BUILD_TARGET_ARCH))     $(IMPORT_LIBS.$(BUILD_TARGET_ARCH)) $(IMPORT_LIBS.$(BUILD_TARGET_CPU))  $(IMPORT_LIBS.$(BUILD_TYPE)) | 
|---|
|  | 44 | _ALL_DLLS        := $(DLLS)        $(DLLS.$(BUILD_TARGET))          $(DLLS.$(BUILD_TARGET).$(BUILD_TARGET_ARCH))            $(DLLS.$(BUILD_TARGET_ARCH))        $(DLLS.$(BUILD_TARGET_CPU))         $(DLLS.$(BUILD_TYPE)) | 
|---|
|  | 45 | _ALL_PROGRAMS    := $(PROGRAMS)    $(PROGRAMS.$(BUILD_TARGET))      $(PROGRAMS.$(BUILD_TARGET).$(BUILD_TARGET_ARCH))        $(PROGRAMS.$(BUILD_TARGET_ARCH))    $(PROGRAMS.$(BUILD_TARGET_CPU))     $(PROGRAMS.$(BUILD_TYPE)) | 
|---|
|  | 46 | _ALL_SYSMODS     := $(SYSMODS)     $(SYSMODS.$(BUILD_TARGET))       $(SYSMODS.$(BUILD_TARGET).$(BUILD_TARGET_ARCH))         $(SYSMODS.$(BUILD_TARGET_ARCH))     $(SYSMODS.$(BUILD_TARGET_CPU))      $(SYSMODS.$(BUILD_TYPE)) | 
|---|
|  | 47 | _ALL_OTHERS      := $(OTHERS)      $(OTHERS.$(BUILD_TARGET))        $(OTHERS.$(BUILD_TARGET).$(BUILD_TARGET_ARCH))          $(OTHERS.$(BUILD_TARGET_ARCH))      $(OTHERS.$(BUILD_TARGET_CPU))       $(OTHERS.$(BUILD_TYPE)) | 
|---|
|  | 48 | _ALL_INSTALLS    := $(INSTALLS)    $(INSTALLS.$(BUILD_TARGET))      $(INSTALLS.$(BUILD_TARGET).$(BUILD_TARGET_ARCH))        $(INSTALLS.$(BUILD_TARGET_ARCH))    $(INSTALLS.$(BUILD_TARGET_CPU))     $(INSTALLS.$(BUILD_TYPE)) | 
|---|
|  | 49 | _ALL_FETCHES     := $(FETCHES)     $(FETCHES.$(BUILD_TARGET))       $(FETCHES.$(BUILD_TARGET).$(BUILD_TARGET_ARCH))         $(FETCHES.$(BUILD_TARGET_ARCH))     $(FETCHES.$(BUILD_TARGET_CPU))      $(FETCHES.$(BUILD_TYPE)) | 
|---|
|  | 50 | _ALL_PATCHES     := $(PATCHES)     $(PATCHES.$(BUILD_TARGET))       $(PATCHES.$(BUILD_TARGET).$(BUILD_TARGET_ARCH))         $(PATCHES.$(BUILD_TARGET_ARCH))     $(PATCHES.$(BUILD_TARGET_CPU))      $(PATCHES.$(BUILD_TYPE)) | 
|---|
|  | 51 |  | 
|---|
| [72] | 52 | # all targets. | 
|---|
| [985] | 53 | _ALL_TARGETS = \ | 
|---|
|  | 54 | $(_ALL_FETCHES) \ | 
|---|
|  | 55 | $(_ALL_PATCHES) \ | 
|---|
|  | 56 | $(_ALL_BLDPROGS) \ | 
|---|
|  | 57 | $(_ALL_LIBRARIES) \ | 
|---|
|  | 58 | $(_ALL_IMPORT_LIBS) \ | 
|---|
|  | 59 | $(_ALL_DLLS) \ | 
|---|
|  | 60 | $(_ALL_PROGRAMS) \ | 
|---|
|  | 61 | $(_ALL_SYSMODS) \ | 
|---|
|  | 62 | $(_ALL_INSTALLS) \ | 
|---|
|  | 63 | $(_ALL_OTHERS) | 
|---|
| [72] | 64 |  | 
|---|
| [447] | 65 | # all $(BUILD_TARGET) targets. | 
|---|
| [985] | 66 | _ALL_BUILD_TARGET_TARGETS = \ | 
|---|
|  | 67 | $(_ALL_FETCHES) \ | 
|---|
|  | 68 | $(_ALL_PATCHES) \ | 
|---|
|  | 69 | $(_ALL_LIBRARIES) \ | 
|---|
|  | 70 | $(_ALL_IMPORT_LIBS) \ | 
|---|
|  | 71 | $(_ALL_DLLS) \ | 
|---|
|  | 72 | $(_ALL_PROGRAMS) \ | 
|---|
|  | 73 | $(_ALL_SYSMODS) \ | 
|---|
|  | 74 | $(_ALL_INSTALLS) \ | 
|---|
|  | 75 | $(_ALL_OTHERS) | 
|---|
| [447] | 76 |  | 
|---|
| [985] | 77 | # all $(BUILD_PLATFORM) targets. | 
|---|
|  | 78 | _ALL_BUILD_PLATFORM_TARGETS = \ | 
|---|
|  | 79 | $(_ALL_BLDPROGS) | 
|---|
| [447] | 80 |  | 
|---|
| [640] | 81 | # all targets making use of srcname. | 
|---|
| [985] | 82 | _ALL_SRCNAME_TARGETS = \ | 
|---|
|  | 83 | $(_ALL_FETCHES) \ | 
|---|
|  | 84 | $(_ALL_PATCHES) | 
|---|
| [640] | 85 |  | 
|---|
| [75] | 86 | # dependency files. | 
|---|
|  | 87 | _DEPFILES := | 
|---|
|  | 88 |  | 
|---|
| [380] | 89 | # included dependency files. | 
|---|
|  | 90 | _DEPFILES_INCLUDED := | 
|---|
|  | 91 |  | 
|---|
|  | 92 |  | 
|---|
| [75] | 93 | # All kind of output files except for _OBJS and _DEPFILES. | 
|---|
|  | 94 | # Compiling or linking definition outputting other things that $@ and any | 
|---|
|  | 95 | # required dependency file must add those output files to this variable. | 
|---|
|  | 96 | _OUT_FILES := | 
|---|
|  | 97 |  | 
|---|
| [353] | 98 | # Files which only requires cleaning up. | 
|---|
|  | 99 | _CLEAN_FILES := | 
|---|
|  | 100 |  | 
|---|
| [72] | 101 | # all of a type | 
|---|
| [219] | 102 | _OBJS     := | 
|---|
| [640] | 103 | _FETCHES  := | 
|---|
|  | 104 | _DOWNLOADS:= | 
|---|
|  | 105 | _UNPACKS  := | 
|---|
|  | 106 | _PATCHES  := | 
|---|
| [688] | 107 | _UNFETCHES:= | 
|---|
| [222] | 108 | _BLDPROGS := | 
|---|
| [219] | 109 | _LIBS     := | 
|---|
|  | 110 | _DLLS     := | 
|---|
|  | 111 | _PROGRAMS := | 
|---|
|  | 112 | _SYSMODS  := | 
|---|
| [353] | 113 | _INSTALLS := | 
|---|
| [827] | 114 | _INSTALLS_FILES := | 
|---|
| [380] | 115 | _INSTALLS_DIRS := | 
|---|
| [353] | 116 | _OTHERS   := | 
|---|
| [417] | 117 | _PACKING  := | 
|---|
| [897] | 118 | _DIRS     := $(PATH_TARGET)/ $(PATH_TARGET) $(BLDDIRS) | 
|---|
| [189] | 119 | _IMPORT_LIBS := | 
|---|
| [72] | 120 |  | 
|---|
| [220] | 121 | # misc | 
|---|
|  | 122 | pass_prev := | 
|---|
|  | 123 |  | 
|---|
|  | 124 |  | 
|---|
| [984] | 125 |  | 
|---|
| [72] | 126 | # | 
|---|
| [984] | 127 | # Footer macros | 
|---|
| [73] | 128 | # | 
|---|
|  | 129 |  | 
|---|
| [78] | 130 | ## Figure out the tool for a target. | 
|---|
| [753] | 131 | # @param    $1           normalized target. | 
|---|
|  | 132 | # @param    $2           tooltype. | 
|---|
| [222] | 133 | # @param    bld_trg      build target. | 
|---|
| [481] | 134 | # @param    bld_trg_arch build target architecture. | 
|---|
| [79] | 135 | _TARGET_TOOL = $(strip $(firstword \ | 
|---|
| [753] | 136 | $($(1)_$(2)TOOL.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
|  | 137 | $($(1)_$(2)TOOL.$(bld_trg)) \ | 
|---|
|  | 138 | $($(1)_$(2)TOOL) \ | 
|---|
|  | 139 | $($(1)_TOOL.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
|  | 140 | $($(1)_TOOL.$(bld_trg)) \ | 
|---|
|  | 141 | $($(1)_TOOL) \ | 
|---|
|  | 142 | $($(2)TOOL.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
|  | 143 | $($(2)TOOL.$(bld_trg)) \ | 
|---|
|  | 144 | $($(2)TOOL) \ | 
|---|
| [481] | 145 | $(TOOL.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
| [222] | 146 | $(TOOL.$(bld_trg)) \ | 
|---|
| [106] | 147 | $(TOOL) \ | 
|---|
| [79] | 148 | )) | 
|---|
| [183] | 149 |  | 
|---|
| [353] | 150 | ## Figure out the actual name of an installed file. | 
|---|
|  | 151 | # @param        $1              The file to install. | 
|---|
|  | 152 | # @param        $2              The target name. | 
|---|
|  | 153 | # @param        $3              The _INST value (can be empty). | 
|---|
|  | 154 | # @param        $4              The default directory to use when $3 is empty. | 
|---|
|  | 155 | _INSTALL_FILE = $(patsubst %/,%/$(notdir $(1)),$(if $(3),$(PATH_INS)/$(3),$(4)/)) | 
|---|
|  | 156 |  | 
|---|
|  | 157 |  | 
|---|
| [985] | 158 | ## Inherit one template property in a non-accumulative manner. | 
|---|
|  | 159 | # @param    $(prop)         Property name | 
|---|
|  | 160 | # @param    $(src)          Source (parent) object. | 
|---|
|  | 161 | # @param    $(trg)          Target (child) object. | 
|---|
|  | 162 | # @remark Not all properties has all the variations, but making the correct | 
|---|
|  | 163 | #         exceptions will only complicate matters and probably not gain much speed. | 
|---|
|  | 164 | define def_inherit_one | 
|---|
|  | 165 | ifdef $(src)_$(prop) | 
|---|
|  | 166 | ifndef $(trg)_$(prop) | 
|---|
|  | 167 | $(trg)_$(prop) = $($(src)_$(prop)) | 
|---|
|  | 168 | #$ (warning dbg-inherit: $(trg)_$(prop) = $($(src)_$(prop)) ) | 
|---|
|  | 169 | endif | 
|---|
|  | 170 | endif | 
|---|
|  | 171 | endef # def_inherit_one | 
|---|
| [723] | 172 |  | 
|---|
| [985] | 173 | ## Inherit one template property in a non-accumulative manner. | 
|---|
|  | 174 | # @param    $(prop)         Property name | 
|---|
|  | 175 | # @param    $(src)          Source (parent) object. | 
|---|
|  | 176 | # @param    $(trg)          Target (child) object. | 
|---|
|  | 177 | # @remark Not all properties has all the variations, but making the correct | 
|---|
|  | 178 | #         exceptions will only complicate matters and probably not gain much speed. | 
|---|
|  | 179 | # @todo   Check how/if this differs from def_inherit_one. | 
|---|
|  | 180 | define def_inherit_one_now | 
|---|
|  | 181 | ifdef $(src)_$(prop) | 
|---|
|  | 182 | ifndef $(trg)_$(prop) | 
|---|
|  | 183 | $(trg)_$(prop) := $($(src)_$(prop)) | 
|---|
|  | 184 | #$ (warning dbg-inherit-now: $(trg)_$(prop) = $($(src)_$(prop)) ) | 
|---|
|  | 185 | endif | 
|---|
|  | 186 | endif | 
|---|
|  | 187 | endef # def_inherit_one_now | 
|---|
| [185] | 188 |  | 
|---|
| [985] | 189 | ## Inherit one template property in a non-accumulative manner, deferred expansion. | 
|---|
|  | 190 | # @param    $(prop)         Property name | 
|---|
|  | 191 | # @param    $(src)          Source | 
|---|
|  | 192 | # @param    $(trg)          Target | 
|---|
|  | 193 | # @remark This define relies on double evaluation | 
|---|
|  | 194 | define def_inherit_one_deferred | 
|---|
|  | 195 | ifdef $(src)_$(prop) | 
|---|
|  | 196 | ifndef $(trg)_$(prop) | 
|---|
|  | 197 | $(trg)_$(prop) = $$($(src)_$(prop)) | 
|---|
|  | 198 | #$ (warning dbg-inherit-def: $(trg)_$(prop) = $($(src)_$(prop)) ) | 
|---|
|  | 199 | endif | 
|---|
| [185] | 200 | endif | 
|---|
| [985] | 201 | endef # def_inherit_one_deferred | 
|---|
| [185] | 202 |  | 
|---|
| [985] | 203 | ## Generic inheritance for use with targets templates and tools. | 
|---|
|  | 204 | # @param    trg                 Object to consider for inheriting. | 
|---|
|  | 205 | # @param    src_prefix          What to prefix the value found in EXTENDS with to get the object. | 
|---|
|  | 206 | # @param    properties          List of the properties with straight expansion. | 
|---|
|  | 207 | # @param    properties_now      List of the properties with immediate expansion. | 
|---|
|  | 208 | # @param    properties_deferred List of the properties with deferred expansion (e.g. function). | 
|---|
|  | 209 | define def_inherit | 
|---|
|  | 210 | src := $(strip $($(trg)_EXTENDS)) | 
|---|
|  | 211 | ifneq ($(src),) | 
|---|
|  | 212 | ifndef $(trg)_EXTENDS_STATUS_ | 
|---|
|  | 213 | $(trg)_EXTENDS_STATUS_ := 0 | 
|---|
|  | 214 | src := $(src_prefix)$(src) | 
|---|
| [185] | 215 |  | 
|---|
| [985] | 216 | # Recursivly process the parent (src) if it's inherting from somebody too. | 
|---|
|  | 217 | ifdef $(src)_EXTENDS | 
|---|
|  | 218 | ifneq ($($(src)_EXTENDS_STATUS_),42) | 
|---|
|  | 219 | # 'foreach' will create 'trg' in a new variable context hiding | 
|---|
|  | 220 | # out current variable. 'src' OTOH will be overwritten. | 
|---|
|  | 221 | #$ (warning def_inherit: recursing into $(src) from $(trg)) | 
|---|
|  | 222 | $(foreach trg, $(src), $(eval $(value def_inherit))) | 
|---|
|  | 223 | src := $(src_prefix)$(strip $($(trg)_EXTENDS)) | 
|---|
|  | 224 | endif | 
|---|
|  | 225 | endif | 
|---|
| [984] | 226 |  | 
|---|
| [985] | 227 | # Inherit the properties and mark the trg done. | 
|---|
|  | 228 | #$ (warning def_inherit: trg=$(trg) src=$(src)) | 
|---|
|  | 229 | $(foreach prop, $(properties),          $(eval $(def_inherit_one))) | 
|---|
|  | 230 | $(foreach prop, $(properties_now),      $(eval $(def_inherit_one_now))) | 
|---|
|  | 231 | $(foreach prop, $(properties_deferred), $(eval $(def_inherit_one_deferred))) | 
|---|
|  | 232 | $(trg)_EXTENDS_STATUS_ := 42 | 
|---|
|  | 233 | else | 
|---|
|  | 234 | # Check for inheritance loops. | 
|---|
|  | 235 | ifneq ($(target)_EXTENDS_STATUS_),42) | 
|---|
|  | 236 | $(error kBuild: Target inheritance loop! target=$(target)) | 
|---|
|  | 237 | endif | 
|---|
|  | 238 | endif | 
|---|
|  | 239 | endif | 
|---|
|  | 240 | endef # def_inherit | 
|---|
| [984] | 241 |  | 
|---|
| [985] | 242 |  | 
|---|
| [984] | 243 | # | 
|---|
| [985] | 244 | # Determin all the templates that is being used and make | 
|---|
|  | 245 | # sure they are present. | 
|---|
| [72] | 246 | # | 
|---|
|  | 247 | _TEMPLATES := $(TEMPLATE) | 
|---|
|  | 248 | define def_templates | 
|---|
|  | 249 | ifdef $(target)_TEMPLATE | 
|---|
| [985] | 250 | ifneq ("$($(target)_TEMPLATE)","$(strip $($(target)_TEMPLATE))") | 
|---|
|  | 251 | $$(error kBuild: The template name of target '$(target)' contains tabs ($($(target)_TEMPLATE))). Please remove them) | 
|---|
|  | 252 | endif | 
|---|
|  | 253 | _TEMPLATES += $($(target)_TEMPLATE) | 
|---|
| [72] | 254 | endif | 
|---|
| [985] | 255 | endef # def_templates | 
|---|
| [984] | 256 | $(foreach target, $(_ALL_TARGETS), $(eval $(def_templates))) | 
|---|
| [72] | 257 | _TEMPLATES := $(sort $(_TEMPLATES)) | 
|---|
|  | 258 |  | 
|---|
|  | 259 | define def_templates_include | 
|---|
|  | 260 | ifndef TEMPLATE_$(template) | 
|---|
| [985] | 261 | TEMPLATE_$(template)_INCLUDE_FILE_ := $(firstword $(foreach path, $(TEMPLATE_PATHS) $(PATH_KBUILD)/templates/, $(wildcard $(path)/$(template).kmk))) | 
|---|
|  | 262 | ifneq ($(TEMPLATE_$(template)_INCLUDE_FILE_),) | 
|---|
|  | 263 | include $(TEMPLATE_$(template)_INCLUDE_FILE_) | 
|---|
|  | 264 | else | 
|---|
|  | 265 | $$(error kBuild: Cannot find template '$(template)') | 
|---|
|  | 266 | endif | 
|---|
| [72] | 267 | endif | 
|---|
| [985] | 268 | endef # def_templates_include | 
|---|
| [72] | 269 | $(foreach template, $(_TEMPLATES), $(eval $(def_templates))) | 
|---|
|  | 270 |  | 
|---|
| [985] | 271 | #$ (warning dbg _TEMPLATES := $(_TEMPLATES)) | 
|---|
| [74] | 272 |  | 
|---|
| [985] | 273 |  | 
|---|
| [72] | 274 | # | 
|---|
| [985] | 275 | # Determin the BLD_TRG_* keywords required for correct inherting. | 
|---|
| [412] | 276 | # | 
|---|
| [985] | 277 | # This means walking all the template and target lists in order to | 
|---|
|  | 278 | # pick up all BLD_TRG_* attributes. | 
|---|
|  | 279 | # | 
|---|
|  | 280 | _BLD_TYPES   := $(BUILD_TYPE) | 
|---|
|  | 281 | _BLD_TARGETS := $(BUILD_TARGET) $(BUILD_PLATFORMS) | 
|---|
|  | 282 | _BLD_ARCHES  := $(BUILD_TARGET_ARCH) $(BUILD_PLATFORM_ARCH) | 
|---|
|  | 283 | _BLD_CPUS    := $(BUILD_TARGET_CPU) $(BUILD_PLATFORM_CPU) | 
|---|
|  | 284 |  | 
|---|
|  | 285 | define def_collect_bld_xyz | 
|---|
|  | 286 | ifdef ($(src)_BLD_TYPE) | 
|---|
|  | 287 | _BLD_TYPE += $($(src)_BLD_TYPE) | 
|---|
| [412] | 288 | endif | 
|---|
| [985] | 289 | ifdef ($(src)_BLD_TRG) | 
|---|
|  | 290 | _BLD_TARGETS += $($(src)_BLD_TRG) | 
|---|
|  | 291 | endif | 
|---|
|  | 292 | ifdef ($(src)_BLD_TRG_ARCH) | 
|---|
|  | 293 | _BLD_ARCHES += $($(src)_BLD_TRG_ARCH) | 
|---|
|  | 294 | endif | 
|---|
|  | 295 | ifdef ($(src)_BLD_TRG_CPU) | 
|---|
|  | 296 | _BLD_CPU += $($(src)_BLD_TRG_CPU) | 
|---|
|  | 297 | endif | 
|---|
|  | 298 | endef # def_collect_bld_xyz | 
|---|
|  | 299 | $(foreach src, $(addprefix TEMPLATE_, $(_TEMPLATES)) $(_ALL_TARGETS)\ | 
|---|
|  | 300 | ,$(eval $(def_collect_bld_xyz))) | 
|---|
| [412] | 301 |  | 
|---|
| [985] | 302 | # drop duplicate values | 
|---|
|  | 303 | _BLD_TYPES   := $(sort $(_BLD_TYPES)) | 
|---|
|  | 304 | _BLD_TARGETS := $(sort $(_BLD_TARGETS)) | 
|---|
|  | 305 | _BLD_ARCHES  := $(sort $(_BLD_ARCHES)) | 
|---|
|  | 306 | _BLD_CPUS    := $(sort $(_BLD_CPUS)) | 
|---|
| [552] | 307 |  | 
|---|
| [985] | 308 | # Construct all the possible keywords. | 
|---|
|  | 309 | _KEYWORDS := $(_BLD_TYPES) $(_BLD_TARGETS) $(_BLD_ARCHES) $(_BLD_CPUS) \ | 
|---|
|  | 310 | $(foreach bld_trg,$(_BLD_TARGETS),$(addprefix $(bld_trg).,$(_BLD_ARCHES))) | 
|---|
|  | 311 | # $ (warning dbg _KEYWORDS := $(_KEYWORDS)) | 
|---|
| [412] | 312 |  | 
|---|
| [988] | 313 | ifdef KBUILD_PROFILE_SELF | 
|---|
|  | 314 | _KBUILD_TS_NOW := $(nanots ) | 
|---|
|  | 315 | $(info prof: $(int-sub $(_KBUILD_TS_NOW), $(_KBUILD_TS_HEADER_START)) - $(int-sub $(_KBUILD_TS_NOW), $(_KBUILD_TS_PREV)) - done keywords) | 
|---|
|  | 316 | _KBUILD_TS_PREV := $(_KBUILD_TS_NOW) | 
|---|
|  | 317 | endif | 
|---|
| [552] | 318 |  | 
|---|
| [988] | 319 |  | 
|---|
| [985] | 320 | # | 
|---|
|  | 321 | # Target inheritance. | 
|---|
|  | 322 | # | 
|---|
|  | 323 | # This has to be done on a per target list basis as to avoid adding | 
|---|
|  | 324 | # incorrect properties that will wast memory, time, and may confuse | 
|---|
|  | 325 | # later strictness checks. This also has to be done *before* templates | 
|---|
|  | 326 | # are applied to the targets. Since we're doing that part rather | 
|---|
|  | 327 | # early on, the target inheritance feature is a bit restricted at | 
|---|
|  | 328 | # the moment. However, this will be addressed in a little(?) while. | 
|---|
|  | 329 | # | 
|---|
| [552] | 330 |  | 
|---|
| [985] | 331 | src_prefix := | 
|---|
|  | 332 | ## combines the specified properties $(1) with the $(_KEYWORDS). | 
|---|
|  | 333 | _COMB_KEY_PROP = $(1)  $(foreach keyword,$(_KEYWORDS), $(addsuffix .$(keyword), $(1))) | 
|---|
| [412] | 334 |  | 
|---|
| [985] | 335 | # Fetches. | 
|---|
|  | 336 | properties          := $(call _COMB_KEY_PROP,$(PROPS_FETCHES_SINGLE)) | 
|---|
|  | 337 | properties_now      := $(call _COMB_KEY_PROP,$(PROPS_FETCHES_ACCUMULATE_R) $(PROPS_FETCHES_ACCUMULATE_L)) | 
|---|
|  | 338 | properties_deferred := $(call _COMB_KEY_PROP,$(PROPS_FETCHES_DEFERRED)) | 
|---|
|  | 339 | $(foreach trg, $(_ALL_FETCHES),$(eval $(value def_inherit))) | 
|---|
| [412] | 340 |  | 
|---|
| [985] | 341 | ## Patches. - not implemented yet. | 
|---|
|  | 342 | #properties          := $(call _COMB_KEY_PROP,$(PROPS_PATCHES_SINGLE)) | 
|---|
|  | 343 | #properties_now      := $(call _COMB_KEY_PROP,$(PROPS_PATCHES_ACCUMULATE_R) $(PROPS_PATCHES_ACCUMULATE_L)) | 
|---|
|  | 344 | #properties_deferred := $(call _COMB_KEY_PROP,$(PROPS_PATCHES_DEFERRED)) | 
|---|
|  | 345 | #$(foreach trg, $(_ALL_PATCHES),$(eval $(value def_inherit))) | 
|---|
| [412] | 346 |  | 
|---|
| [985] | 347 | # Programs and build programs. | 
|---|
|  | 348 | properties          := $(call _COMB_KEY_PROP,$(PROPS_PROGRAMS_SINGLE)) | 
|---|
|  | 349 | properties_now      := $(call _COMB_KEY_PROP,$(PROPS_PROGRAMS_ACCUMULATE_R) $(PROPS_PROGRAMS_ACCUMULATE_L)) | 
|---|
|  | 350 | properties_deferred := $(call _COMB_KEY_PROP,$(PROPS_PROGRAMS_DEFERRED)) | 
|---|
|  | 351 | $(foreach trg, $(_ALL_BLDPROGS) $(_ALL_PROGRAMS),$(eval $(value def_inherit))) | 
|---|
|  | 352 |  | 
|---|
|  | 353 | # Libraries and import libraries. | 
|---|
|  | 354 | properties          := $(call _COMB_KEY_PROP,$(PROPS_LIBRARIES_SINGLE)) | 
|---|
|  | 355 | properties_now      := $(call _COMB_KEY_PROP,$(PROPS_LIBRARIES_ACCUMULATE_R) $(PROPS_LIBRARIES_ACCUMULATE_L)) | 
|---|
|  | 356 | properties_deferred := $(call _COMB_KEY_PROP,$(PROPS_LIBRARIES_DEFERRED)) | 
|---|
| [989] | 357 | ifeq ($(filter-out nt os2 win win64 win32,$(BUILD_TARGET)),) | 
|---|
|  | 358 | $(foreach trg, $(_ALL_LIBRARIES) $(_ALL_IMPORT_LIBS),$(eval $(value def_inherit))) | 
|---|
|  | 359 | else | 
|---|
|  | 360 | $(foreach trg, $(_ALL_LIBRARIES),$(eval $(value def_inherit))) | 
|---|
|  | 361 | endif | 
|---|
| [985] | 362 |  | 
|---|
|  | 363 | # DLLs. | 
|---|
|  | 364 | properties          := $(call _COMB_KEY_PROP,$(PROPS_DLLS_SINGLE)) | 
|---|
|  | 365 | properties_now      := $(call _COMB_KEY_PROP,$(PROPS_DLLS_ACCUMULATE_R) $(PROPS_DLLS_ACCUMULATE_L)) | 
|---|
|  | 366 | properties_deferred := $(call _COMB_KEY_PROP,$(PROPS_DLLS_DEFERRED)) | 
|---|
| [989] | 367 | ifeq ($(filter-out nt os2 win win64 win32,$(BUILD_TARGET)),) | 
|---|
|  | 368 | $(foreach trg, $(_ALL_DLLS),$(eval $(value def_inherit))) | 
|---|
|  | 369 | else | 
|---|
|  | 370 | $(foreach trg, $(_ALL_DLLS) $(_ALL_IMPORT_LIBS),$(eval $(value def_inherit))) | 
|---|
|  | 371 | endif | 
|---|
| [985] | 372 |  | 
|---|
| [989] | 373 | # System modules. | 
|---|
|  | 374 | properties          := $(call _COMB_KEY_PROP,$(PROPS_SYSMODS_SINGLE)) | 
|---|
|  | 375 | properties_now      := $(call _COMB_KEY_PROP,$(PROPS_SYSMODS_ACCUMULATE_R) $(PROPS_SYSMODS_ACCUMULATE_L)) | 
|---|
|  | 376 | properties_deferred := $(call _COMB_KEY_PROP,$(PROPS_SYSMODS_DEFERRED)) | 
|---|
|  | 377 | $(foreach trg, $(_ALL_SYSMODS),$(eval $(value def_inherit))) | 
|---|
|  | 378 |  | 
|---|
| [985] | 379 | # Installs. | 
|---|
|  | 380 | properties          := $(call _COMB_KEY_PROP,$(PROPS_INSTALLS_SINGLE)) | 
|---|
|  | 381 | properties_now      := $(call _COMB_KEY_PROP,$(PROPS_INSTALLS_ACCUMULATE_R) $(PROPS_INSTALLS_ACCUMULATE_L)) | 
|---|
|  | 382 | properties_deferred := $(call _COMB_KEY_PROP,$(PROPS_INSTALLS_DEFERRED)) | 
|---|
|  | 383 | $(foreach trg, $(_ALL_INSTALLS),$(eval $(value def_inherit))) | 
|---|
|  | 384 |  | 
|---|
| [988] | 385 | ifdef KBUILD_PROFILE_SELF | 
|---|
|  | 386 | _KBUILD_TS_NOW := $(nanots ) | 
|---|
|  | 387 | $(info prof: $(int-sub $(_KBUILD_TS_NOW), $(_KBUILD_TS_HEADER_START)) - $(int-sub $(_KBUILD_TS_NOW), $(_KBUILD_TS_PREV)) - done target inheritance) | 
|---|
|  | 388 | _KBUILD_TS_PREV := $(_KBUILD_TS_NOW) | 
|---|
|  | 389 | endif | 
|---|
| [985] | 390 |  | 
|---|
| [988] | 391 |  | 
|---|
| [412] | 392 | # | 
|---|
| [985] | 393 | # Template Inheritance. | 
|---|
|  | 394 | # | 
|---|
|  | 395 | # This is much the same as with target inheritance, except we cannot | 
|---|
|  | 396 | # restrict the properties involved since we've got a clue which target | 
|---|
|  | 397 | # types are using them. But, we can drop the instance expansion we're | 
|---|
|  | 398 | # doing for targets since there won't be any more changes to either the | 
|---|
|  | 399 | # source nor the target templates beyond this exercise. | 
|---|
|  | 400 | # | 
|---|
|  | 401 |  | 
|---|
|  | 402 | src_prefix := TEMPLATE_ | 
|---|
|  | 403 | properties := | 
|---|
|  | 404 | properties_now := | 
|---|
|  | 405 | properties_deferred := $(call _COMB_KEY_PROP,$(PROPS_ALL)) | 
|---|
|  | 406 | $(foreach trg, $(addprefix TEMPLATE_,$(_TEMPLATES)),$(eval $(value def_inherit))) | 
|---|
|  | 407 |  | 
|---|
|  | 408 | # done. | 
|---|
|  | 409 | src_prefix := | 
|---|
|  | 410 | properties := | 
|---|
|  | 411 | properties_now := | 
|---|
|  | 412 | properties_deferred := | 
|---|
|  | 413 |  | 
|---|
| [988] | 414 | ifdef KBUILD_PROFILE_SELF | 
|---|
|  | 415 | _KBUILD_TS_NOW := $(nanots ) | 
|---|
|  | 416 | $(info prof: $(int-sub $(_KBUILD_TS_NOW), $(_KBUILD_TS_HEADER_START)) - $(int-sub $(_KBUILD_TS_NOW), $(_KBUILD_TS_PREV)) - done template inheritance) | 
|---|
|  | 417 | _KBUILD_TS_PREV := $(_KBUILD_TS_NOW) | 
|---|
|  | 418 | endif | 
|---|
| [985] | 419 |  | 
|---|
| [988] | 420 |  | 
|---|
| [985] | 421 | # | 
|---|
| [72] | 422 | # Common Inheritance | 
|---|
|  | 423 | # | 
|---|
|  | 424 |  | 
|---|
| [353] | 425 | ## Inherit one template property in a non-accumulative manner. | 
|---|
| [72] | 426 | # @param    $(prop)     Property name | 
|---|
|  | 427 | # @param    $(target)   Target name | 
|---|
| [78] | 428 | # @todo fix the precedence order for some properties. | 
|---|
| [72] | 429 | define def_inherit_template_one | 
|---|
| [78] | 430 | ifdef TEMPLATE_$($(target)_TEMPLATE)_$(prop) | 
|---|
| [72] | 431 | ifndef $(target)_$(prop) | 
|---|
| [353] | 432 | $(target)_$(prop) := $(TEMPLATE_$($(target)_TEMPLATE)_$(prop)) | 
|---|
|  | 433 | #$ (warning dbgtarget: $(target)_$(prop):='$(value $(target)_$(prop))' TEMPLATE_$($(target)_TEMPLATE)_$(prop)) | 
|---|
| [72] | 434 | endif | 
|---|
|  | 435 | endif | 
|---|
| [447] | 436 | ifdef TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg) | 
|---|
|  | 437 | ifndef $(target)_$(prop).$(bld_trg) | 
|---|
|  | 438 | #$ (warning dbgsource: $(target)_$(prop).$(bld_trg)="TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg)" TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg)) | 
|---|
|  | 439 | $(target)_$(prop).$(bld_trg) := $(TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg)) | 
|---|
| [79] | 440 | endif | 
|---|
|  | 441 | endif | 
|---|
| [481] | 442 | ifdef TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg).$(bld_trg_arch) | 
|---|
|  | 443 | ifndef $(target)_$(prop).$(bld_trg).$(bld_trg_arch) | 
|---|
|  | 444 | #$ (warning dbgsource: $(target)_$(prop).$(bld_trg).$(bld_trg_arch)="TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg).$(bld_trg_arch)" TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg).$(bld_trg_arch)) | 
|---|
|  | 445 | $(target)_$(prop).$(bld_trg).$(bld_trg_arch) := $(TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg).$(bld_trg_arch)) | 
|---|
|  | 446 | endif | 
|---|
|  | 447 | endif | 
|---|
| [455] | 448 | ifdef TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg_arch) | 
|---|
|  | 449 | ifndef $(target)_$(prop).$(bld_trg_arch) | 
|---|
|  | 450 | #$ (warning dbgsource: $(target)_$(prop).$(bld_trg_arch)="TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg_arch)" TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg_arch)) | 
|---|
|  | 451 | $(target)_$(prop).$(bld_trg_arch) := $(TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg_arch)) | 
|---|
|  | 452 | endif | 
|---|
|  | 453 | endif | 
|---|
|  | 454 | ifdef TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg_cpu) | 
|---|
|  | 455 | ifndef $(target)_$(prop).$(bld_trg_cpu) | 
|---|
|  | 456 | #$ (warning dbgsource: $(target)_$(prop).$(bld_trg_cpu)="TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg_cpu)" TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg_cpu)) | 
|---|
|  | 457 | $(target)_$(prop).$(bld_trg_cpu) := $(TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg_cpu)) | 
|---|
|  | 458 | endif | 
|---|
|  | 459 | endif | 
|---|
| [72] | 460 | endef | 
|---|
|  | 461 |  | 
|---|
| [353] | 462 | ## Inherit one template property in a non-accumulative manner, deferred expansion. | 
|---|
|  | 463 | # @param    1: $(prop)     Property name | 
|---|
|  | 464 | # @param    2: $(target)        Target name | 
|---|
|  | 465 | # @todo fix the precedence order for some properties. | 
|---|
|  | 466 | # @remark this define relies on double evaluation | 
|---|
|  | 467 | define def_inherit_template_one_deferred | 
|---|
|  | 468 | ifdef TEMPLATE_$($(target)_TEMPLATE)_$(prop) | 
|---|
|  | 469 | ifndef $(target)_$(prop) | 
|---|
|  | 470 | $(target)_$(prop) = $$(TEMPLATE_$($(target)_TEMPLATE)_$(prop)) | 
|---|
|  | 471 | #$ (warning dbgtarget: $(target)_$(prop):='$(value $(target)_$(prop))' TEMPLATE_$($(target)_TEMPLATE)_$(prop)) | 
|---|
|  | 472 | endif | 
|---|
|  | 473 | endif | 
|---|
| [447] | 474 | ifdef TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg) | 
|---|
|  | 475 | ifndef $(target)_$(prop).$(bld_trg) | 
|---|
|  | 476 | #$ (warning dbgsource: $(target)_$(prop).$(bld_trg)="TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg)" TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg)) | 
|---|
|  | 477 | $(target)_$(prop).$(bld_trg) = $$(TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg)) | 
|---|
| [353] | 478 | endif | 
|---|
|  | 479 | endif | 
|---|
| [481] | 480 | ifdef TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg).$(bld_trg_arch) | 
|---|
|  | 481 | ifndef $(target)_$(prop).$(bld_trg).$(bld_trg_arch) | 
|---|
|  | 482 | #$ (warning dbgsource: $(target)_$(prop).$(bld_trg).$(bld_trg_arch)="TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg).$(bld_trg_arch)" TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg).$(bld_trg_arch)) | 
|---|
|  | 483 | $(target)_$(prop).$(bld_trg).$(bld_trg_arch) = $$(TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg).$(bld_trg_arch)) | 
|---|
|  | 484 | endif | 
|---|
|  | 485 | endif | 
|---|
| [455] | 486 | ifdef TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg_arch) | 
|---|
|  | 487 | ifndef $(target)_$(prop).$(bld_trg_arch) | 
|---|
|  | 488 | #$ (warning dbgsource: $(target)_$(prop).$(bld_trg_arch)="TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg_arch)" TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg_arch)) | 
|---|
|  | 489 | $(target)_$(prop).$(bld_trg_arch) = $$(TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg_arch)) | 
|---|
|  | 490 | endif | 
|---|
|  | 491 | endif | 
|---|
|  | 492 | ifdef TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg_cpu) | 
|---|
|  | 493 | ifndef $(target)_$(prop).$(bld_trg_cpu) | 
|---|
|  | 494 | #$ (warning dbgsource: $(target)_$(prop).$(bld_trg_cpu)="TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg_cpu)" TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg_cpu)) | 
|---|
|  | 495 | $(target)_$(prop).$(bld_trg_cpu) = $$(TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg_cpu)) | 
|---|
|  | 496 | endif | 
|---|
|  | 497 | endif | 
|---|
| [353] | 498 | endef | 
|---|
|  | 499 |  | 
|---|
| [660] | 500 | ## Inherit one acculumlative template property where the 'most significant' items are at the left end. | 
|---|
| [78] | 501 | # @param    $(prop)     Property name | 
|---|
|  | 502 | # @param    $(target)   Target name | 
|---|
| [660] | 503 | define def_inherit_template_one_accumulate_l | 
|---|
| [78] | 504 | ifdef TEMPLATE_$($(target)_TEMPLATE)_$(prop) | 
|---|
| [353] | 505 | #$ (warning dbgtype: TEMPLATE_$($(target)_TEMPLATE)_$(prop) $(target)_$(prop)=$($(target)_$(prop)) $(TEMPLATE_$($(target)_TEMPLATE)_$(prop))) | 
|---|
| [659] | 506 | $(target)_$(prop) += $$(TEMPLATE_$($(target)_TEMPLATE)_$(prop)) | 
|---|
| [442] | 507 | #$ (warning dbgtype: $(target)_$(prop)=$($(target)_$(prop))) | 
|---|
| [78] | 508 | endif | 
|---|
| [243] | 509 | ifdef TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(BUILD_TYPE) | 
|---|
| [353] | 510 | #$ (warning dbg4: TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(BUILD_TYPE)) | 
|---|
| [659] | 511 | $(target)_$(prop).$(BUILD_TYPE) += $$(TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(BUILD_TYPE)) | 
|---|
| [243] | 512 | endif | 
|---|
| [447] | 513 | ifdef TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg) | 
|---|
| [659] | 514 | #$ (warning dbg5: TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg)) | 
|---|
|  | 515 | $(target)_$(prop).$(bld_trg) += $$(TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg)) | 
|---|
| [79] | 516 | endif | 
|---|
| [481] | 517 | ifdef TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg).$(bld_trg_arch) | 
|---|
|  | 518 | #$ (warning dbg4: TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg).$(bld_trg_arch)) | 
|---|
| [659] | 519 | $(target)_$(prop).$(bld_trg).$(bld_trg_arch) += $$(TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg).$(bld_trg_arch)) | 
|---|
| [481] | 520 | endif | 
|---|
| [447] | 521 | ifdef TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg_cpu) | 
|---|
|  | 522 | #$ (warning dbg5: TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg_cpu)) | 
|---|
| [659] | 523 | $(target)_$(prop).$(bld_trg_cpu) += $$(TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg_cpu)) | 
|---|
| [79] | 524 | endif | 
|---|
| [447] | 525 | ifdef TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg_arch) | 
|---|
|  | 526 | #$ (warning dbg6: TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg_arch)) | 
|---|
| [659] | 527 | $(target)_$(prop).$(bld_trg_arch) += $$(TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg_arch)) | 
|---|
| [79] | 528 | endif | 
|---|
| [78] | 529 | endef | 
|---|
|  | 530 |  | 
|---|
| [660] | 531 | ## Inherit one acculumlative template property where the 'most significant' items are at the right end. | 
|---|
|  | 532 | # @param    $(prop)     Property name | 
|---|
|  | 533 | # @param    $(target)   Target name | 
|---|
| [981] | 534 | define def_inherit_template_one_accumulate_r | 
|---|
| [660] | 535 | ifdef TEMPLATE_$($(target)_TEMPLATE)_$(prop) | 
|---|
| [981] | 536 | #$ (warning dbgtype: TEMPLATE_$($(target)_TEMPLATE)_$(prop) $(target)_$(prop)=$($(target)_$(prop)) $(TEMPLATE_$($(target)_TEMPLATE)_$(prop))) | 
|---|
|  | 537 | $(target)_$(prop) <=$$(TEMPLATE_$($(target)_TEMPLATE)_$(prop)) | 
|---|
|  | 538 | #$ (warning dbgtype: $(target)_$(prop)=$($(target)_$(prop))) | 
|---|
| [660] | 539 | endif | 
|---|
|  | 540 | ifdef TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(BUILD_TYPE) | 
|---|
| [981] | 541 | #$ (warning dbg4: TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(BUILD_TYPE)) | 
|---|
|  | 542 | $(target)_$(prop).$(BUILD_TYPE) <=$$(TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(BUILD_TYPE)) | 
|---|
| [660] | 543 | endif | 
|---|
|  | 544 | ifdef TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg) | 
|---|
| [981] | 545 | #$ (warning dbg5: TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg)) | 
|---|
|  | 546 | $(target)_$(prop).$(bld_trg) <=$$(TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg)) | 
|---|
| [660] | 547 | endif | 
|---|
|  | 548 | ifdef TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg).$(bld_trg_arch) | 
|---|
| [981] | 549 | #$ (warning dbg4: TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg).$(bld_trg_arch)) | 
|---|
|  | 550 | $(target)_$(prop).$(bld_trg).$(bld_trg_arch) <=$$(TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg).$(bld_trg_arch)) | 
|---|
| [660] | 551 | endif | 
|---|
|  | 552 | ifdef TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg_cpu) | 
|---|
| [981] | 553 | #$ (warning dbg5: TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg_cpu)) | 
|---|
|  | 554 | $(target)_$(prop).$(bld_trg_cpu) <=$$(TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg_cpu)) | 
|---|
| [660] | 555 | endif | 
|---|
|  | 556 | ifdef TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg_arch) | 
|---|
| [981] | 557 | #$ (warning dbg6: TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg_arch)) | 
|---|
|  | 558 | $(target)_$(prop).$(bld_trg_arch) <=$$(TEMPLATE_$($(target)_TEMPLATE)_$(prop).$(bld_trg_arch)) | 
|---|
| [660] | 559 | endif | 
|---|
|  | 560 | endef | 
|---|
|  | 561 |  | 
|---|
|  | 562 |  | 
|---|
| [72] | 563 | ## Inherit template properties for on target. | 
|---|
|  | 564 | # @param    $(target)    Target name. | 
|---|
|  | 565 | define def_inherit_template | 
|---|
| [745] | 566 | # sanity check. | 
|---|
|  | 567 | ifdef _$(target)_ALREADY_PROCESSED | 
|---|
|  | 568 | $(error kBuild: The target $(target) appears more than once in the target lists! Please correct the makefile(s)) | 
|---|
|  | 569 | endif | 
|---|
|  | 570 | _$(target)_ALREADY_PROCESSED := 1 | 
|---|
|  | 571 |  | 
|---|
| [447] | 572 | # Inherit any default template. | 
|---|
|  | 573 | ifdef TEMPLATE | 
|---|
|  | 574 | ifeq ($($(target)_TEMPLATE),) | 
|---|
|  | 575 | $(eval $(target)_TEMPLATE:=$(TEMPLATE)) | 
|---|
|  | 576 | endif | 
|---|
|  | 577 | endif | 
|---|
|  | 578 | # Expand the template if specified. | 
|---|
|  | 579 | ifneq ($($(target)_TEMPLATE),) | 
|---|
| [353] | 580 | $(foreach prop,$(PROPS_SINGLE),$(eval $(value def_inherit_template_one))) | 
|---|
|  | 581 | $(foreach prop,$(PROPS_DEFERRED),$(eval $(def_inherit_template_one_deferred))) # exploits the 2 evaluation, so no value! | 
|---|
| [981] | 582 | $(foreach prop,$(PROPS_ACCUMULATE_L),$(eval $(def_inherit_template_one_accumulate_l))) # += works fine without value | 
|---|
|  | 583 | $(foreach prop,$(PROPS_ACCUMULATE_R),$(eval $(def_inherit_template_one_accumulate_r))) # use <= (kmk addition) | 
|---|
| [447] | 584 | endif | 
|---|
| [72] | 585 | endef | 
|---|
| [353] | 586 |  | 
|---|
| [72] | 587 | # Inherit template properties | 
|---|
| [447] | 588 | bld_trg := $(BUILD_TARGET) | 
|---|
|  | 589 | bld_trg_arch := $(BUILD_TARGET_ARCH) | 
|---|
|  | 590 | bld_trg_cpu := $(BUILD_TARGET_CPU) | 
|---|
|  | 591 | $(foreach target, $(_ALL_BUILD_TARGET_TARGETS),$(eval $(value def_inherit_template))) | 
|---|
| [72] | 592 |  | 
|---|
| [447] | 593 | bld_trg := $(BUILD_PLATFORM) | 
|---|
|  | 594 | bld_trg_arch := $(BUILD_PLATFORM_ARCH) | 
|---|
|  | 595 | bld_trg_cpu := $(BUILD_PLATFORM_CPU) | 
|---|
|  | 596 | $(foreach target, $(_ALL_BUILD_PLATFORM_TARGETS),$(eval $(value def_inherit_template))) | 
|---|
| [72] | 597 |  | 
|---|
| [988] | 598 | ifdef KBUILD_PROFILE_SELF | 
|---|
|  | 599 | _KBUILD_TS_NOW := $(nanots ) | 
|---|
|  | 600 | $(info prof: $(int-sub $(_KBUILD_TS_NOW), $(_KBUILD_TS_HEADER_START)) - $(int-sub $(_KBUILD_TS_NOW), $(_KBUILD_TS_PREV)) - done common inheritance) | 
|---|
|  | 601 | _KBUILD_TS_PREV := $(_KBUILD_TS_NOW) | 
|---|
|  | 602 | endif | 
|---|
| [447] | 603 |  | 
|---|
| [988] | 604 |  | 
|---|
| [72] | 605 | # | 
|---|
| [460] | 606 | # Include tools & sdks | 
|---|
| [183] | 607 | # | 
|---|
| [985] | 608 | # The first part of this exercise is to figure out which TOOLS and SDKS | 
|---|
|  | 609 | # that should be included. | 
|---|
|  | 610 | # | 
|---|
| [592] | 611 | _TOOLS := $(TOOL.$(BUILD_TARGET))   $(TOOL.$(BUILD_TARGET_ARCH))   $(TOOL.$(BUILD_TARGET).$(BUILD_TARGET_ARCH)) \ | 
|---|
|  | 612 | $(TOOL.$(BUILD_PLATFORM)) $(TOOL.$(BUILD_PLATFORM_ARCH)) $(TOOL.$(BUILD_PLATFORM).$(BUILD_PLATFORM_ARCH)) \ | 
|---|
|  | 613 | $(TOOL) | 
|---|
|  | 614 | _SDKS  := $(SDKS.$(BUILD_TARGET))   $(SDKS.$(BUILD_TARGET_ARCH))   $(SDKS.$(BUILD_TARGET).$(BUILD_TARGET_ARCH)) \ | 
|---|
|  | 615 | $(SDKS.$(BUILD_PLATFORM)) $(SDKS.$(BUILD_PLATFORM_ARCH)) $(SDKS.$(BUILD_PLATFORM).$(BUILD_PLATFORM_ARCH)) \ | 
|---|
|  | 616 | $(SDKS.$(BUILD_TYPE)) \ | 
|---|
|  | 617 | $(SDKS) | 
|---|
| [460] | 618 | define def_tools_sdks_target_source | 
|---|
| [353] | 619 | $(eval _TOOLS += $(foreach prop, $(PROPS_TOOLS), \ | 
|---|
| [460] | 620 | $($(source)_$(prop).$(_bld_trg)) \ | 
|---|
|  | 621 | $($(target)_$(source)_$(prop).$(_bld_trg)) \ | 
|---|
| [481] | 622 | $($(source)_$(prop).$(_bld_trg).$(_bld_trg_arch)) \ | 
|---|
|  | 623 | $($(target)_$(source)_$(prop).$(_bld_trg).$(_bld_trg_arch)) \ | 
|---|
| [460] | 624 | $($(source)_$(prop).$(_bld_trg_arch)) \ | 
|---|
|  | 625 | $($(target)_$(source)_$(prop).$(_bld_trg_arch)) \ | 
|---|
| [353] | 626 | $($(source)_$(prop)) \ | 
|---|
|  | 627 | $($(target)_$(source)_$(prop)))) | 
|---|
| [460] | 628 | $(eval _SDKS += \ | 
|---|
|  | 629 | $($(source)_SDKS.$(_bld_trg)) \ | 
|---|
|  | 630 | $($(target)_$(source)_SDKS.$(_bld_trg)) \ | 
|---|
| [481] | 631 | $($(source)_SDKS.$(_bld_trg).$(_bld_trg_arch)) \ | 
|---|
|  | 632 | $($(target)_$(source)_SDKS.$(_bld_trg).$(_bld_trg_arch)) \ | 
|---|
| [460] | 633 | $($(source)_SDKS.$(_bld_trg_arch)) \ | 
|---|
|  | 634 | $($(target)_$(source)_SDKS.$(_bld_trg_arch)) \ | 
|---|
| [592] | 635 | $($(source)_SDKS.$(BUILD_TYPE)) \ | 
|---|
|  | 636 | $($(target)_$(source)_SDKS.$(BUILD_TYPE)) \ | 
|---|
| [460] | 637 | $($(source)_SDKS) \ | 
|---|
|  | 638 | $($(target)_$(source)_SDKS)) | 
|---|
| [985] | 639 | endef # def_tools_sdks_target_source | 
|---|
| [353] | 640 |  | 
|---|
| [460] | 641 | define def_tools_sdks_target | 
|---|
| [985] | 642 | _bld_type := $(firstword $($(target)_BLD_TYPE) $(BUILD_TYPE)) | 
|---|
| [460] | 643 | _bld_trg := $(firstword $($(target)_BLD_TRG) $(bld_trg)) | 
|---|
|  | 644 | _bld_trg_arch := $(firstword $($(target)_BLD_TRG_ARCH) $(bld_trg_arch)) | 
|---|
|  | 645 | _bld_trg_cpu := $(firstword $($(target)_BLD_TRG_CPU) $(bld_trg_cpu)) | 
|---|
|  | 646 |  | 
|---|
| [353] | 647 | $(eval _TOOLS += $(foreach prop, $(PROPS_TOOLS), \ | 
|---|
| [460] | 648 | $($(target)_$(prop).$(_bld_trg)) \ | 
|---|
|  | 649 | $($(target)_$(prop).$(_bld_trg_arch)) \ | 
|---|
| [481] | 650 | $($(target)_$(prop).$(_bld_trg).$(_bld_trg_arch)) \ | 
|---|
| [353] | 651 | $($(target)_$(prop)))) | 
|---|
| [460] | 652 | $(eval _SDKS += \ | 
|---|
|  | 653 | $($(target)_SDKS.$(_bld_trg)) \ | 
|---|
|  | 654 | $($(target)_SDKS.$(_bld_trg_arch)) \ | 
|---|
| [481] | 655 | $($(target)_SDKS.$(_bld_trg).$(_bld_trg_arch)) \ | 
|---|
| [460] | 656 | $($(target)_SDKS)) | 
|---|
| [353] | 657 | $(foreach source, \ | 
|---|
| [460] | 658 | $($(target)_SOURCES.$(_bld_trg)) \ | 
|---|
|  | 659 | $($(target)_SOURCES.$(_bld_trg_arch)) \ | 
|---|
| [481] | 660 | $($(target)_SOURCES.$(_bld_trg).$(_bld_trg_arch)) \ | 
|---|
| [460] | 661 | $($(target)_SOURCES.$(_bld_trg_cpu)) \ | 
|---|
| [985] | 662 | $($(target)_SOURCES.$(_bld_type)) \ | 
|---|
| [353] | 663 | $($(target)_SOURCES) \ | 
|---|
| [460] | 664 | , $(eval $(value def_tools_sdks_target_source))) | 
|---|
| [985] | 665 | endef # def_tools_sdks_target | 
|---|
| [353] | 666 |  | 
|---|
| [640] | 667 | define def_tools_srcname_target | 
|---|
| [985] | 668 | _bld_type := $(firstword $($(target)_BLD_TYPE) $(BUILD_TYPE)) | 
|---|
| [640] | 669 | _bld_trg := $(firstword $($(target)_BLD_TRG) $(bld_trg)) | 
|---|
|  | 670 | _bld_trg_arch := $(firstword $($(target)_BLD_TRG_ARCH) $(bld_trg_arch)) | 
|---|
|  | 671 | _bld_trg_cpu := $(firstword $($(target)_BLD_TRG_CPU) $(bld_trg_cpu)) | 
|---|
|  | 672 |  | 
|---|
|  | 673 | $(foreach source, $(notdir\ | 
|---|
|  | 674 | $($(target)_SOURCES.$(_bld_trg)) \ | 
|---|
|  | 675 | $($(target)_SOURCES.$(_bld_trg_arch)) \ | 
|---|
|  | 676 | $($(target)_SOURCES.$(_bld_trg).$(_bld_trg_arch)) \ | 
|---|
|  | 677 | $($(target)_SOURCES.$(_bld_trg_cpu)) \ | 
|---|
| [985] | 678 | $($(target)_SOURCES.$(_bld_type)) \ | 
|---|
| [640] | 679 | $($(target)_SOURCES) \ | 
|---|
|  | 680 | ), $(eval $(value def_tools_sdks_target_source))) | 
|---|
| [985] | 681 | endef # def_tools_srcname_target | 
|---|
| [640] | 682 |  | 
|---|
| [460] | 683 | bld_trg := $(BUILD_TARGET) | 
|---|
|  | 684 | bld_trg_arch := $(BUILD_TARGET_ARCH) | 
|---|
|  | 685 | bld_trg_cpu := $(BUILD_TARGET_CPU) | 
|---|
|  | 686 | $(foreach target, $(_ALL_BUILD_TARGET_TARGETS), $(eval $(value def_tools_sdks_target))) | 
|---|
| [640] | 687 | $(foreach target, $(_ALL_SRCNAME_TARGETS), $(eval $(value def_tools_srcname_target))) | 
|---|
| [72] | 688 |  | 
|---|
| [460] | 689 | bld_trg := $(BUILD_PLATFORM) | 
|---|
|  | 690 | bld_trg_arch := $(BUILD_PLATFORM_ARCH) | 
|---|
|  | 691 | bld_trg_cpu := $(BUILD_PLATFORM_CPU) | 
|---|
|  | 692 | $(foreach target, $(_ALL_BUILD_PLATFORM_TARGETS), $(eval $(value def_tools_sdks_target))) | 
|---|
|  | 693 |  | 
|---|
|  | 694 |  | 
|---|
|  | 695 | # include TOOLS | 
|---|
| [72] | 696 | define def_tools_include | 
|---|
|  | 697 | ifndef TOOL_$(tool) | 
|---|
| [985] | 698 | TOOL_$(tool)_KMK_FILE := $(firstword $(foreach path, $(TOOL_PATHS) $(PATH_KBUILD)/tools, $(wildcard $(path)/$(tool).kmk))) | 
|---|
|  | 699 | ifeq ($(TOOL_$(tool)_KMK_FILE),) | 
|---|
|  | 700 | $(error kBuild: Cannot find include file for the tool '$(tool)'! Searched: $(TOOL_PATHS) $(PATH_KBUILD)/tools) | 
|---|
|  | 701 | endif | 
|---|
|  | 702 | include $(TOOL_$(tool)_KMK_FILE) | 
|---|
|  | 703 | ifndef TOOL_$(tool) | 
|---|
|  | 704 | $(warning kBuild: TOOL_$(tool) was not by $(TOOL_$(tool)_KMK_FILE)!) | 
|---|
|  | 705 | endif | 
|---|
| [72] | 706 | endif | 
|---|
| [985] | 707 | endef # def_tools_include | 
|---|
| [460] | 708 |  | 
|---|
|  | 709 | _TOOLS := $(sort $(_TOOLS)) | 
|---|
| [353] | 710 | $(foreach tool, $(_TOOLS), $(eval $(value def_tools_include))) | 
|---|
| [72] | 711 |  | 
|---|
|  | 712 |  | 
|---|
| [460] | 713 | # include SDKS | 
|---|
| [122] | 714 | define def_sdks_include_one | 
|---|
| [72] | 715 | ifndef SDK_$(sdk) | 
|---|
| [985] | 716 | SDK_$(sdk)_KMK_FILE := $(firstword $(foreach path, $(SDK_PATHS) $(PATH_KBUILD)/sdks, $(wildcard $(path)/$(sdk).kmk))) | 
|---|
|  | 717 | ifeq ($(SDK_$(sdk)_KMK_FILE),) | 
|---|
|  | 718 | $(error kBuild: Cannot find include file for the SDK '$(sdk)'! Searched: $(SDK_PATHS) $(PATH_KBUILD)/sdks) | 
|---|
|  | 719 | endif | 
|---|
|  | 720 | include $(SDK_$(sdk)_KMK_FILE) | 
|---|
|  | 721 | ifndef SDK_$(sdk) | 
|---|
|  | 722 | $(warning kBuild: SDK_$(sdk) was not defined by $(SDK_$(sdk)_KMK_FILE)!) | 
|---|
|  | 723 | endif | 
|---|
| [72] | 724 | endif | 
|---|
| [985] | 725 | endef # def_sdks_include_one | 
|---|
| [460] | 726 |  | 
|---|
| [859] | 727 | _SDKS := $(sort $(_SDKS)) | 
|---|
| [353] | 728 | $(foreach sdk, $(_SDKS), $(eval $(value def_sdks_include_one))) | 
|---|
| [72] | 729 |  | 
|---|
| [985] | 730 | ## @todo Execute SDKS and TOOL inhertiance. | 
|---|
| [380] | 731 |  | 
|---|
| [988] | 732 | ifdef KBUILD_PROFILE_SELF | 
|---|
|  | 733 | _KBUILD_TS_NOW := $(nanots ) | 
|---|
|  | 734 | $(info prof: $(int-sub $(_KBUILD_TS_NOW), $(_KBUILD_TS_HEADER_START)) - $(int-sub $(_KBUILD_TS_NOW), $(_KBUILD_TS_PREV)) - done tools and sdks) | 
|---|
|  | 735 | _KBUILD_TS_PREV := $(_KBUILD_TS_NOW) | 
|---|
|  | 736 | endif | 
|---|
| [640] | 737 |  | 
|---|
| [988] | 738 |  | 
|---|
| [828] | 739 | # | 
|---|
|  | 740 | # | 
|---|
|  | 741 | # Target lists - Pass 1 | 
|---|
|  | 742 | # | 
|---|
|  | 743 | #       This pass is for defining variables that might be referenced in | 
|---|
|  | 744 | #       properties of other targets. | 
|---|
|  | 745 | # | 
|---|
|  | 746 | # | 
|---|
|  | 747 |  | 
|---|
|  | 748 | # Don't do anything for fetch targets (yet). | 
|---|
|  | 749 |  | 
|---|
|  | 750 | ## | 
|---|
|  | 751 | # Link prolog for Pass 1. | 
|---|
|  | 752 | # | 
|---|
|  | 753 | # @param    $(target)           Normalized target name. | 
|---|
|  | 754 | # @param    $(EXT)              EXE,DLL,SYS,LIB. | 
|---|
|  | 755 | # @param    $(EXTPRE)           HOST or nothing. | 
|---|
|  | 756 | # @param    $(definst)          The default _INST value. | 
|---|
|  | 757 | # @param    $(tool_prefix)      LD or AR. | 
|---|
|  | 758 | # @param    $(bld_trg_base_var) TARGET or PLATFORM. | 
|---|
|  | 759 | define def_pass1_link_common | 
|---|
|  | 760 |  | 
|---|
|  | 761 | bld_type    := $(firstword $($(target)_BLD_TYPE)     $(BUILD_TYPE)) | 
|---|
|  | 762 | bld_trg     := $(firstword $($(target)_BLD_TRG)      $(BUILD_$(bld_trg_base_var))) | 
|---|
|  | 763 | bld_trg_arch:= $(firstword $($(target)_BLD_TRG_ARCH) $(BUILD_$(bld_trg_base_var)_ARCH)) | 
|---|
|  | 764 | bld_trg_cpu := $(firstword $($(target)_BLD_TRG_CPU)  $(BUILD_$(bld_trg_base_var)_CPU)) | 
|---|
|  | 765 |  | 
|---|
| [889] | 766 | tool        := $(call _TARGET_TOOL,$(target),$(tool_prefix)) | 
|---|
|  | 767 | name        := $(firstword\ | 
|---|
|  | 768 | $($(target)_NAME.$(bld_trg).$(bld_trg_arch))\ | 
|---|
|  | 769 | $($(target)_NAME.$(bld_trg_arch))\ | 
|---|
|  | 770 | $($(target)_NAME.$(bld_trg))\ | 
|---|
|  | 771 | $($(target)_NAME.$(bld_type))\ | 
|---|
|  | 772 | $($(target)_NAME)\ | 
|---|
|  | 773 | $(target)) | 
|---|
|  | 774 | outbase     := $(call TARGET_BASE,$(name),$(target)) | 
|---|
| [828] | 775 | ifndef PATH_$(target) | 
|---|
|  | 776 | PATH_$(target) := $(patsubst %/,%,$(dir $(outbase))) | 
|---|
|  | 777 | else ifneq ($(PATH_$(target)),$(patsubst %/,%,$(dir $(outbase)))) | 
|---|
|  | 778 | $(error kBuild internal error: PATH_$(target)=$(PATH_$(target)) expected $(patsubst %/,%,$(dir $(outbase)))) | 
|---|
|  | 779 | endif | 
|---|
|  | 780 | ifeq ($(tool_prefix),AR) ## @todo fix this mess! | 
|---|
|  | 781 | suff := $(firstword\ | 
|---|
|  | 782 | $($(target)_$(EXT)SUFF.$(bld_trg).$(bld_trg_arch))\ | 
|---|
|  | 783 | $($(target)_$(EXT)SUFF.$(bld_trg))\ | 
|---|
|  | 784 | $($(target)_$(EXT)SUFF)\ | 
|---|
|  | 785 | $(TOOL_$(tool)_$(tool_prefix)$(EXT)SUFF.$(bld_trg).$(bld_trg_arch))\ | 
|---|
|  | 786 | $(TOOL_$(tool)_$(tool_prefix)$(EXT)SUFF.$(bld_trg))\ | 
|---|
|  | 787 | $(TOOL_$(tool)_$(tool_prefix)$(EXT)SUFF)\ | 
|---|
|  | 788 | $(SUFF_LIB)) | 
|---|
|  | 789 | else | 
|---|
|  | 790 | suff := $(firstword \ | 
|---|
|  | 791 | $($(target)_$(EXT)SUFF) \ | 
|---|
|  | 792 | $($(target)_$(EXT)SUFF) \ | 
|---|
|  | 793 | $(TOOL_$(tool)_$(tool_prefix)$(EXT)SUFF) \ | 
|---|
|  | 794 | $($(EXTPRE)SUFF_$(EXT))) | 
|---|
|  | 795 | endif | 
|---|
|  | 796 | out := $(outbase)$(suff) | 
|---|
|  | 797 |  | 
|---|
|  | 798 | # TARGET_* | 
|---|
|  | 799 | TARGET_$(target) := $(out) | 
|---|
|  | 800 |  | 
|---|
|  | 801 | # INSTARGET_* | 
|---|
|  | 802 | ifndef $(target)_NOINST | 
|---|
|  | 803 | INSTARGET_$(target) := $(patsubst %/,%/$(notdir $(out)), \ | 
|---|
|  | 804 | $(if $($(target)_INST), $(addprefix $(PATH_INS)/,$($(target)_INST)), $(definst)/)) | 
|---|
|  | 805 |  | 
|---|
|  | 806 | else # NOINST | 
|---|
|  | 807 | INSTARGET_$(target) := | 
|---|
|  | 808 | endif # NOINST | 
|---|
|  | 809 |  | 
|---|
|  | 810 | endef | 
|---|
|  | 811 |  | 
|---|
|  | 812 |  | 
|---|
|  | 813 | # | 
|---|
|  | 814 | # BLDPROGS (Pass 1) | 
|---|
|  | 815 | # | 
|---|
|  | 816 | define def_pass1_bldprog | 
|---|
|  | 817 | # set NOINST if not forced installation before doing the usual stuff. | 
|---|
|  | 818 | ifndef $(target)_INST | 
|---|
|  | 819 | $(target)_NOINST := 1 | 
|---|
|  | 820 | endif | 
|---|
|  | 821 | $(eval $(value def_pass1_link_common)) | 
|---|
|  | 822 | endef | 
|---|
|  | 823 |  | 
|---|
|  | 824 | EXT     := EXE | 
|---|
|  | 825 | EXTPRE  := HOST | 
|---|
|  | 826 | definst := $(PATH_BIN) | 
|---|
|  | 827 | tool_prefix := LD | 
|---|
|  | 828 | bld_trg_base_var := PLATFORM | 
|---|
|  | 829 | $(foreach target, $(BLDPROGS) $(BLDPROGS.$(BUILD_PLATFORM)) $(BLDPROGS.$(BUILD_PLATFORM).$(BUILD_PLATFORM_ARCH)), \ | 
|---|
|  | 830 | $(eval $(value def_pass1_bldprog))) | 
|---|
|  | 831 |  | 
|---|
|  | 832 |  | 
|---|
|  | 833 | # | 
|---|
|  | 834 | # LIBRARIES (Pass 1) | 
|---|
|  | 835 | # | 
|---|
|  | 836 | EXT     := LIB | 
|---|
|  | 837 | EXTPRE  := | 
|---|
|  | 838 | definst := $(PATH_LIB) | 
|---|
|  | 839 | tool_prefix := AR | 
|---|
|  | 840 | bld_trg_base_var := TARGET | 
|---|
|  | 841 | $(foreach target, $(LIBRARIES) $(LIBRARIES.$(BUILD_TARGET)) $(LIBRARIES.$(BUILD_TARGET).$(BUILD_TARGET_ARCH)), \ | 
|---|
|  | 842 | $(eval $(value def_pass1_link_common))) | 
|---|
|  | 843 |  | 
|---|
|  | 844 |  | 
|---|
|  | 845 | # | 
|---|
|  | 846 | # DLLS  (Pass 1) | 
|---|
|  | 847 | # | 
|---|
|  | 848 | EXT     := DLL | 
|---|
|  | 849 | EXTPRE  := | 
|---|
|  | 850 | definst := $(PATH_DLL) | 
|---|
|  | 851 | tool_prefix := LD | 
|---|
|  | 852 | bld_trg_base_var := TARGET | 
|---|
|  | 853 | $(foreach target, $(DLLS) $(DLLS.$(BUILD_TARGET)) $(DLLS.$(BUILD_TARGET).$(BUILD_TARGET_ARCH)), \ | 
|---|
|  | 854 | $(eval $(value def_pass1_link_common))) | 
|---|
|  | 855 |  | 
|---|
|  | 856 |  | 
|---|
|  | 857 | # | 
|---|
|  | 858 | # IMPORT LIBRARIES (Pass 1) | 
|---|
|  | 859 | # | 
|---|
|  | 860 | #   - On OS/2 and windows these are libraries. | 
|---|
|  | 861 | #   - On other platforms they are fake DLLs. | 
|---|
|  | 862 | # | 
|---|
|  | 863 | ifeq ($(filter-out nt os2 win win64 win32,$(BUILD_TARGET)),) | 
|---|
|  | 864 | EXT     := LIB | 
|---|
|  | 865 | EXTPRE  := | 
|---|
|  | 866 | definst := $(PATH_LIB) | 
|---|
|  | 867 | tool_prefix := AR | 
|---|
|  | 868 | bld_trg_base_var := TARGET | 
|---|
|  | 869 | $(foreach target, $(IMPORT_LIBS) $(IMPORT_LIBS.$(BUILD_TARGET)) $(IMPORT_LIBS.$(BUILD_TARGET).$(BUILD_TARGET_ARCH)), \ | 
|---|
|  | 870 | $(eval $(value def_pass1_lib))) | 
|---|
|  | 871 | else | 
|---|
|  | 872 | EXT     := DLL | 
|---|
|  | 873 | EXTPRE  := | 
|---|
|  | 874 | definst := $(PATH_DLL) | 
|---|
|  | 875 | tool_prefix := LD | 
|---|
|  | 876 | bld_trg_base_var := TARGET | 
|---|
|  | 877 | $(foreach target, $(IMPORT_LIBS) $(IMPORT_LIBS.$(BUILD_TARGET)) $(IMPORT_LIBS.$(BUILD_TARGET).$(BUILD_TARGET_ARCH)), \ | 
|---|
|  | 878 | $(eval $(value def_pass1_link_common))) | 
|---|
|  | 879 | endif | 
|---|
|  | 880 |  | 
|---|
|  | 881 |  | 
|---|
|  | 882 | # | 
|---|
|  | 883 | # PROGRAMS (Pass 1) | 
|---|
|  | 884 | # | 
|---|
|  | 885 | EXT     := EXE | 
|---|
|  | 886 | EXTPRE  := | 
|---|
|  | 887 | definst := $(PATH_BIN) | 
|---|
|  | 888 | tool_prefix := LD | 
|---|
|  | 889 | bld_trg_base_var := TARGET | 
|---|
|  | 890 | $(foreach target, $(PROGRAMS) $(PROGRAMS.$(BUILD_TARGET)) $(PROGRAMS.$(BUILD_TARGET).$(BUILD_TARGET_ARCH)), \ | 
|---|
|  | 891 | $(eval $(value def_pass1_link_common))) | 
|---|
|  | 892 |  | 
|---|
|  | 893 |  | 
|---|
|  | 894 | # | 
|---|
|  | 895 | # SYSMODS (Pass 1) | 
|---|
|  | 896 | # | 
|---|
|  | 897 | EXT     := SYS | 
|---|
|  | 898 | EXTPRE  := | 
|---|
|  | 899 | definst := $(PATH_SYS) | 
|---|
|  | 900 | tool_prefix := LD | 
|---|
|  | 901 | bld_trg_base_var := TARGET | 
|---|
|  | 902 | $(foreach target, $(SYSMODS) $(SYSMODS.$(BUILD_TARGET)) $(SYSMODS.$(BUILD_TARGET).$(BUILD_TARGET_ARCH)), \ | 
|---|
|  | 903 | $(eval $(value def_pass1_link_common))) | 
|---|
|  | 904 |  | 
|---|
|  | 905 |  | 
|---|
|  | 906 | # | 
|---|
|  | 907 | # INSTALLS (Pass 1) | 
|---|
|  | 908 | #       Note! INSTARGET_* for INSTALLS aren't available until later. | 
|---|
|  | 909 | # | 
|---|
|  | 910 | define def_pass1_install | 
|---|
| [985] | 911 | bld_type    := $(firstword $($(target)_BLD_TYPE)     $(BUILD_TYPE)) | 
|---|
|  | 912 | bld_trg     := $(firstword $($(target)_BLD_TRG)      $(BUILD_TARGET)) | 
|---|
| [828] | 913 | bld_trg_arch:= $(firstword $($(target)_BLD_TRG_ARCH) $(BUILD_TARGET_ARCH)) | 
|---|
|  | 914 | bld_trg_cpu := $(firstword $($(target)_BLD_TRG_CPU)  $(BUILD_TARGET_CPU)) | 
|---|
|  | 915 | # TARGET_* | 
|---|
|  | 916 | TARGET_$(target) := $(PATH_TARGET)/$(target).ins | 
|---|
|  | 917 | # INSTARGET_ later. | 
|---|
|  | 918 | endef | 
|---|
|  | 919 | $(foreach target, $(INSTALLS) $(INSTALLS.$(BUILD_TARGET)) $(INSTALLS.$(BUILD_TARGET).$(BUILD_TARGET_ARCH)), \ | 
|---|
|  | 920 | $(eval $(value def_pass1_install))) | 
|---|
|  | 921 |  | 
|---|
| [988] | 922 | ifdef KBUILD_PROFILE_SELF | 
|---|
|  | 923 | _KBUILD_TS_NOW := $(nanots ) | 
|---|
|  | 924 | $(info prof: $(int-sub $(_KBUILD_TS_NOW), $(_KBUILD_TS_HEADER_START)) - $(int-sub $(_KBUILD_TS_NOW), $(_KBUILD_TS_PREV)) - done pass 1) | 
|---|
|  | 925 | _KBUILD_TS_PREV := $(_KBUILD_TS_NOW) | 
|---|
|  | 926 | endif | 
|---|
| [828] | 927 |  | 
|---|
|  | 928 |  | 
|---|
|  | 929 |  | 
|---|
| [988] | 930 |  | 
|---|
| [828] | 931 | # | 
|---|
|  | 932 | # | 
|---|
|  | 933 | # Target lists - Pass 2 | 
|---|
|  | 934 | # | 
|---|
|  | 935 | # | 
|---|
|  | 936 |  | 
|---|
|  | 937 |  | 
|---|
| [688] | 938 | ## @page pg_fetches     Fetching Tools, Sources and Similar. | 
|---|
| [73] | 939 | # | 
|---|
| [688] | 940 | # The targets listed in the the FETCHES target list have the following attributes: | 
|---|
|  | 941 | #       SOURCES | 
|---|
|  | 942 | #       INST | 
|---|
|  | 943 | #   FETCHTOOL | 
|---|
|  | 944 | #   FETCHFLAGS | 
|---|
|  | 945 | #   FETCHDIR | 
|---|
|  | 946 | #   UNPACKTOOL | 
|---|
|  | 947 | #   UNPACKFLAGS | 
|---|
| [640] | 948 | # | 
|---|
| [719] | 949 | # As usual the target name is an alias for 'creating' the target. Other | 
|---|
| [688] | 950 | # aliases are: | 
|---|
|  | 951 | #       pass_fetches | 
|---|
|  | 952 | #       fetch | 
|---|
|  | 953 | #       unfetch | 
|---|
|  | 954 | #       download | 
|---|
|  | 955 | #       unpack | 
|---|
|  | 956 | # | 
|---|
|  | 957 | # @remark | 
|---|
|  | 958 | # | 
|---|
|  | 959 | #   This is a little bit complex because we must guarantee that if a source file | 
|---|
| [719] | 960 | #   changes only sligtly we must refetch it and to a proper unpacking of it. It | 
|---|
|  | 961 | #   is also a desire that fetched archives and unpacked files can be deleted to | 
|---|
| [688] | 962 | #   save space. | 
|---|
|  | 963 | # | 
|---|
| [719] | 964 | #   Thus, we must be able to cleanup what we've unpacked should any of the | 
|---|
| [688] | 965 | #   sources be removed. We do this by maintaining a file listing the files | 
|---|
|  | 966 | #   and directories that was unpacked. This operation is named 'unfetch'. | 
|---|
|  | 967 | # | 
|---|
| [719] | 968 | #   We make use of the SIZE and MD5 attributes for each of the sources to | 
|---|
| [689] | 969 | #   create a digest that is stored in the primary target file. Subsequent | 
|---|
|  | 970 | #   runswill compare their digest with it to decide if a refetch is required. | 
|---|
| [719] | 971 | #   When a refetch is found necessary, an 'unfetch' is performed first to | 
|---|
| [689] | 972 | #       clean out old files and directores. Note even changes in source order | 
|---|
| [719] | 973 | #   will cause a refetch due to the way the digest is constructed and | 
|---|
| [689] | 974 | #   evaluated. | 
|---|
| [688] | 975 | # | 
|---|
|  | 976 | #   By not depending directly on the archives (nor on any unpacked files) | 
|---|
|  | 977 | #       but on a goal made up from the archive name, size and md5, we allow | 
|---|
|  | 978 | #   the user to delete the archives. Naturally, this means we'll have to | 
|---|
|  | 979 | #   check and fetch missing archives before attempting to unpack them. | 
|---|
| [689] | 980 | # | 
|---|
|  | 981 | # @remark | 
|---|
|  | 982 | # | 
|---|
| [719] | 983 | #       This feature will *NOT* work correctly with vanilla GNU make becuase | 
|---|
| [689] | 984 | #   it makes use of includedep to avoid too many unnecessary files. | 
|---|
| [719] | 985 | # | 
|---|
| [689] | 986 | # @todo | 
|---|
| [688] | 987 | #       1. Port md5sum or some equivalent tool and include it in kBuild. | 
|---|
|  | 988 | #   2. Download corruption / continuation. | 
|---|
|  | 989 | #   3. It's quite possible that there is one too many indirect dependency now... | 
|---|
|  | 990 | # | 
|---|
|  | 991 |  | 
|---|
|  | 992 | ## @todo move this! | 
|---|
| [640] | 993 | MD5SUM := md5sum | 
|---|
|  | 994 |  | 
|---|
|  | 995 | ## generates the fetch rule | 
|---|
|  | 996 | define def_fetch_src_fetch_rule | 
|---|
|  | 997 | # Indirect goal for downloading something. | 
|---|
| [682] | 998 | .PRECIOUS: $(out) | 
|---|
| [1030] | 999 | $(out) + $($(target)_$(srcname)_FETCH_OUTPUT_) +| $($(target)_$(srcname)_FETCH_OUTPUT_MAYBE_)  : \ | 
|---|
|  | 1000 | | $($(target)_$(srcname)_FETCH_DEPORD_) | 
|---|
| [776] | 1001 | $$(call MSG_FETCH_DL,$(target),$(source),$(out)) | 
|---|
| [696] | 1002 | @## @todo do fancy stuff like download continuation. | 
|---|
|  | 1003 | $$(QUIET)$$(RM) -f $(out) $(out).md5 | 
|---|
| [640] | 1004 | $($(target)_$(srcname)_FETCH_CMDS_) | 
|---|
| [696] | 1005 | $$(QUIET2)$(if $(md5),$$(APPEND) $(out).md5 "$(md5) *$(out)") | 
|---|
|  | 1006 | $$(QUIET)$(if $(md5),$$(MD5SUM) -c $(out).md5) | 
|---|
| [640] | 1007 |  | 
|---|
|  | 1008 |  | 
|---|
| [682] | 1009 |  | 
|---|
| [640] | 1010 | # Intermediate goal for making sure the md5 and size matches. it will (re) fetch the archive if necessary. | 
|---|
|  | 1011 | $(out).checked_$(md5)_$(size): $($(target)_$(srcname)_FETCH_DEPEND_) | $($(target)_$(srcname)_FETCH_DEPORD_) | 
|---|
| [776] | 1012 | $$(call MSG_FETCH_CHK,$(target),$(source),$(out)) | 
|---|
| [696] | 1013 | $$(QUIET)$$(RM) -f $$@ $(out).md5 | 
|---|
| [640] | 1014 | @# creates the .md5 we pass to md5sum. | 
|---|
| [696] | 1015 | $$(QUIET2)$(if $(md5),$$(APPEND) $(out).md5 "$(md5) *$(out)") | 
|---|
| [688] | 1016 | @# (re)fetch the file if it doesn't exist or if it doesn't matches the md5. | 
|---|
| [696] | 1017 | @## @todo do fancy stuff like download continuation. | 
|---|
|  | 1018 | $$(QUIET)( test -f $(out) && $(if $(md5),$$(MD5SUM) -c $(out).md5, true) ) \ | 
|---|
|  | 1019 | || (   $$(RM_EXT) -f $(out) \ | 
|---|
|  | 1020 | && $$(MAKE)      $(out) -f $(MAKEFILE) --no-print-directory ) | 
|---|
|  | 1021 | $$(QUIET2)$$(APPEND) $$@ | 
|---|
| [640] | 1022 |  | 
|---|
| [719] | 1023 | _TARGET_$(target)_FETCHED += $(out) $(out).checked_$(md5)_$(size) | 
|---|
| [640] | 1024 |  | 
|---|
| [688] | 1025 | # Just a little precaution. | 
|---|
|  | 1026 | .NOTPARALLEL: $(out) $(out).checked_$(md5)_$(size) | 
|---|
|  | 1027 |  | 
|---|
| [640] | 1028 | endef | 
|---|
|  | 1029 |  | 
|---|
|  | 1030 | ## generates the unpack rule | 
|---|
|  | 1031 | define def_fetch_src_unpack_rule | 
|---|
|  | 1032 | # This is the unpack rule. it has an order-only dependency on the download check. | 
|---|
| [1030] | 1033 | $(out) + $($(target)_$(srcname)_UNPACK_OUTPUT_) +| $($(target)_$(srcname)_UNPACK_OUTPUT_MAYBE_) : \ | 
|---|
|  | 1034 | $($(target)_$(srcname)_UNPACK_DEPEND_) \ | 
|---|
| [640] | 1035 | | $($(target)_$(srcname)_UNPACK_DEPORD_) $(archive).checked_$(md5)_$(size) | 
|---|
| [776] | 1036 | $$(call MSG_FETCH_UP,$(target),$(archive),$(inst)) | 
|---|
| [696] | 1037 | $$(QUIET)$$(RM) -f $(out) | 
|---|
| [688] | 1038 | @# if the source archive doesn't exist fetch it (can have been deleted to save space). | 
|---|
| [696] | 1039 | $$(QUIET)test -f $(archive) \ | 
|---|
|  | 1040 | || (   $$(RM_EXT) -f $(archive).checked_$(md5)_$(size) \ | 
|---|
|  | 1041 | && $$(MAKE)      $(archive).checked_$(md5)_$(size) -f $(MAKEFILE) --no-print-directory ) | 
|---|
| [640] | 1042 | $($(target)_$(srcname)_UNPACK_CMDS_) | 
|---|
| [696] | 1043 | $$(QUIET2)$$(APPEND) $(out) $(notdir $(archive).checked_$(md5)_$(size)) | 
|---|
|  | 1044 | $$(QUIET2)$$(APPEND) $(out) $(notdir $(out)) | 
|---|
| [640] | 1045 |  | 
|---|
|  | 1046 | $(eval _TARGET_$(target)_UNPACKED += $(out)) | 
|---|
|  | 1047 | _TARGET_$(target)_DIGEST := $(_TARGET_$(target)_DIGEST)-$(srcname)_$(md5)_$(size) | 
|---|
|  | 1048 |  | 
|---|
| [688] | 1049 | .NOTPARALLEL: $(out) | 
|---|
|  | 1050 |  | 
|---|
| [719] | 1051 | endef | 
|---|
| [640] | 1052 |  | 
|---|
|  | 1053 | ## Processes a fetch source | 
|---|
|  | 1054 | # | 
|---|
|  | 1055 | define def_fetch_src | 
|---|
|  | 1056 | #$ (warning dbg: def_fetch_src: source='$(source)' target='$(target)') | 
|---|
|  | 1057 |  | 
|---|
|  | 1058 | # common | 
|---|
|  | 1059 | srcname := $(notdir $(source)) | 
|---|
|  | 1060 | inst := $(firstword \ | 
|---|
|  | 1061 | $($(target)_$(source)_INST)\ | 
|---|
|  | 1062 | $($(target)_$(srcname)_INST)\ | 
|---|
|  | 1063 | $($(source)_INST)\ | 
|---|
|  | 1064 | $($(srcname)_INST)\ | 
|---|
|  | 1065 | $($(target)_INST)\ | 
|---|
|  | 1066 | ) | 
|---|
|  | 1067 | ifneq ($(patsubst %/,ok,$(inst)),ok) | 
|---|
|  | 1068 | $(error kBuild: Bad or missing INST property for source '$(source)' in target '$(target)': $(inst)) | 
|---|
|  | 1069 | endif | 
|---|
|  | 1070 | INSTARGET_$(target)_$(srcname) := $(inst) | 
|---|
|  | 1071 | fetchdir := $(firstword \ | 
|---|
|  | 1072 | $($(target)_$(source)_FETCHDIR)\ | 
|---|
|  | 1073 | $($(target)_$(srcname)_FETCHDIR)\ | 
|---|
|  | 1074 | $($(source)_FETCHDIR)\ | 
|---|
|  | 1075 | $($(srcname)_FETCHDIR)\ | 
|---|
|  | 1076 | $($(target)_FETCHDIR)\ | 
|---|
|  | 1077 | $(FETCHDIR)\ | 
|---|
|  | 1078 | $(PATH_TARGET)\ | 
|---|
|  | 1079 | ) | 
|---|
|  | 1080 | deps := \ | 
|---|
|  | 1081 | $($(target)_$(source)_DEPS)\ | 
|---|
|  | 1082 | $($(target)_$(srcname)_DEPS)\ | 
|---|
|  | 1083 | $($(source)_DEPS)\ | 
|---|
|  | 1084 | $($(srcname)_DEPS)\ | 
|---|
|  | 1085 | $($(target)_DEPS) | 
|---|
| [827] | 1086 | orderdeps := \ | 
|---|
|  | 1087 | $($(target)_$(source)_ORDERDEPS)\ | 
|---|
|  | 1088 | $($(target)_$(srcname)_ORDERDEPS)\ | 
|---|
|  | 1089 | $($(source)_ORDERDEPS)\ | 
|---|
|  | 1090 | $($(srcname)_ORDERDEPS)\ | 
|---|
|  | 1091 | $($(target)_ORDERDEPS) | 
|---|
| [640] | 1092 | md5 := $(firstword \ | 
|---|
|  | 1093 | $($(target)_$(source)_MD5)\ | 
|---|
|  | 1094 | $($(target)_$(srcname)_MD5)\ | 
|---|
|  | 1095 | $($(source)_MD5)\ | 
|---|
|  | 1096 | $($(srcname)_MD5)\ | 
|---|
|  | 1097 | $($(target)_MD5)\ | 
|---|
|  | 1098 | ) | 
|---|
|  | 1099 | size := $(firstword \ | 
|---|
|  | 1100 | $($(target)_$(source)_SIZE)\ | 
|---|
|  | 1101 | $($(target)_$(srcname)_SIZE)\ | 
|---|
|  | 1102 | $($(source)_SIZE)\ | 
|---|
|  | 1103 | $($(srcname)_SIZE)\ | 
|---|
|  | 1104 | $($(target)_SIZE)\ | 
|---|
|  | 1105 | ) | 
|---|
|  | 1106 | dep := # not legal for fetch and unpack tools | 
|---|
|  | 1107 |  | 
|---|
|  | 1108 |  | 
|---|
|  | 1109 | # | 
|---|
|  | 1110 | # The fetching. | 
|---|
|  | 1111 | # | 
|---|
|  | 1112 | out := $(fetchdir)/$(srcname) | 
|---|
|  | 1113 | archive := $(out) | 
|---|
|  | 1114 | TARGET_$(target)_$(srcname) := $(out) | 
|---|
|  | 1115 | dirdep := $(call DIRDEP,$(fetchdir)) | 
|---|
|  | 1116 | tool := $(firstword \ | 
|---|
|  | 1117 | $($(target)_$(source)_FETCHTOOL)\ | 
|---|
|  | 1118 | $($(target)_$(srcname)_FETCHTOOL)\ | 
|---|
|  | 1119 | $($(target)_$(source)_TOOL)\ | 
|---|
|  | 1120 | $($(target)_$(srcname)_TOOL)\ | 
|---|
|  | 1121 | $($(source)_FETCHTOOL)\ | 
|---|
|  | 1122 | $($(srcname)_FETCHTOOL)\ | 
|---|
|  | 1123 | $($(source)_TOOL)\ | 
|---|
|  | 1124 | $($(srcname)_TOOL)\ | 
|---|
|  | 1125 | $($(target)_FETCHTOOL)\ | 
|---|
|  | 1126 | $($(target)_TOOL)\ | 
|---|
|  | 1127 | ) | 
|---|
|  | 1128 | flags :=\ | 
|---|
|  | 1129 | $(TOOL_$(tool)_FETCHFLAGS)\ | 
|---|
|  | 1130 | $(FETCHFLAGS)\ | 
|---|
|  | 1131 | $($(target)_FETCHFLAGS)\ | 
|---|
|  | 1132 | $($(srcname)_FETCHFLAGS)\ | 
|---|
|  | 1133 | $($(source)_FETCHFLAGS)\ | 
|---|
|  | 1134 | $($(target)_$(srcname)_FETCHFLAGS)\ | 
|---|
|  | 1135 | $($(target)_$(source)_FETCHFLAGS) | 
|---|
|  | 1136 |  | 
|---|
|  | 1137 | #$ (warning dbg: target=$(target) source=$(source) $(srcname)=$(srcname) tool=$(tool) out=$(out) flags=$(flags) dirdep=$(dirdep) fetchdir=$(fetchdir) md5=$(md5) size=$(size)) | 
|---|
|  | 1138 |  | 
|---|
|  | 1139 | ifndef TOOL_$(tool)_FETCH_CMDS | 
|---|
|  | 1140 | $(warning kBuild: tools: \ | 
|---|
|  | 1141 | 1 $($(target)_$(source)_FETCHTOOL)\ | 
|---|
|  | 1142 | 2 $($(target)_$(srcname)_FETCHTOOL)\ | 
|---|
|  | 1143 | 3 $($(target)_$(source)_TOOL)\ | 
|---|
|  | 1144 | 4 $($(target)_$(srcname)_TOOL)\ | 
|---|
|  | 1145 | 5 $($(source)_FETCHTOOL)\ | 
|---|
|  | 1146 | 6 $($(srcname)_FETCHTOOL)\ | 
|---|
|  | 1147 | 7 $($(source)_TOOL)\ | 
|---|
|  | 1148 | 8 $($(srcname)_TOOL)\ | 
|---|
|  | 1149 | 9 $($(target)_FETCHTOOL)\ | 
|---|
|  | 1150 | 10 $($(target)_TOOL) ) | 
|---|
|  | 1151 | $(error kBuild: TOOL_$(tool)_FETCH_CMDS is not defined. source=$(source) target=$(target) ) | 
|---|
|  | 1152 | endif | 
|---|
|  | 1153 |  | 
|---|
|  | 1154 | # call the tool | 
|---|
|  | 1155 | $(target)_$(srcname)_FETCH_CMDS_   := $(TOOL_$(tool)_FETCH_CMDS) | 
|---|
|  | 1156 | $(target)_$(srcname)_FETCH_OUTPUT_ := $(TOOL_$(tool)_FETCH_OUTPUT) | 
|---|
| [1030] | 1157 | $(target)_$(srcname)_FETCH_OUTPUT_MAYBE_ := $(TOOL_$(tool)_FETCH_OUTPUT_MAYBE) | 
|---|
| [640] | 1158 | $(target)_$(srcname)_FETCH_DEPEND_ := $(TOOL_$(tool)_FETCH_DEPEND) $(deps) | 
|---|
| [827] | 1159 | $(target)_$(srcname)_FETCH_DEPORD_ := $(TOOL_$(tool)_FETCH_DEPORD) $(dirdep) $(orderdeps) | 
|---|
| [640] | 1160 |  | 
|---|
|  | 1161 | # generate the fetch rule. | 
|---|
|  | 1162 | $(eval $(def_fetch_src_fetch_rule)) | 
|---|
|  | 1163 |  | 
|---|
|  | 1164 |  | 
|---|
|  | 1165 | # | 
|---|
|  | 1166 | # The unpacking / installing. | 
|---|
|  | 1167 | # | 
|---|
|  | 1168 | out := $(inst)_kBuild_$(target)_$(srcname)_unpacked.lst | 
|---|
|  | 1169 | dirdep := $(call DIRDEP,$(inst)) | 
|---|
|  | 1170 | tool := $(firstword \ | 
|---|
|  | 1171 | $($(target)_$(source)_UNPACKTOOL)\ | 
|---|
|  | 1172 | $($(target)_$(srcname)_UNPACKTOOL)\ | 
|---|
|  | 1173 | $($(target)_$(source)_TOOL)\ | 
|---|
|  | 1174 | $($(target)_$(srcname)_TOOL)\ | 
|---|
|  | 1175 | $($(source)_UNPACKTOOL)\ | 
|---|
|  | 1176 | $($(srcname)_UNPACKTOOL)\ | 
|---|
|  | 1177 | $($(source)_TOOL)\ | 
|---|
|  | 1178 | $($(srcname)_TOOL)\ | 
|---|
|  | 1179 | $($(target)_UNPACKTOOL)\ | 
|---|
|  | 1180 | $($(target)_TOOL) \ | 
|---|
|  | 1181 | ) | 
|---|
|  | 1182 | ifeq ($(tool),) | 
|---|
|  | 1183 | tool := $(toupper $(subst .,,$(suffix $(subst tar.,TAR,$(srcname))))) | 
|---|
|  | 1184 | $(eval $(value def_tools_include)) | 
|---|
|  | 1185 | endif | 
|---|
|  | 1186 | flags :=\ | 
|---|
|  | 1187 | $(TOOL_$(tool)_UNPACKFLAGS)\ | 
|---|
|  | 1188 | $(UNPACKFLAGS)\ | 
|---|
|  | 1189 | $($(target)_UNPACKFLAGS)\ | 
|---|
|  | 1190 | $($(srcname)_UNPACKFLAGS)\ | 
|---|
|  | 1191 | $($(source)_UNPACKFLAGS)\ | 
|---|
|  | 1192 | $($(target)_$(srcname)_UNPACKFLAGS)\ | 
|---|
|  | 1193 | $($(target)_$(source)_UNPACKFLAGS) | 
|---|
|  | 1194 |  | 
|---|
|  | 1195 | #$ (warning dbg: target=$(target) source=$(source) $(srcname)=$(srcname) tool=$(tool) out=$(out) flags=$(flags) dirdep=$(dirdep) inst=$(inst) md5=$(md5) size=$(size)) | 
|---|
|  | 1196 | ifndef TOOL_$(tool)_UNPACK_CMDS | 
|---|
|  | 1197 | $(warning kBuild: tools: \ | 
|---|
|  | 1198 | 1 $($(target)_$(source)_UNPACKTOOL)\ | 
|---|
|  | 1199 | 2 $($(target)_$(srcname)_UNPACKTOOL)\ | 
|---|
|  | 1200 | 3 $($(target)_$(source)_TOOL)\ | 
|---|
|  | 1201 | 4 $($(target)_$(srcname)_TOOL)\ | 
|---|
|  | 1202 | 5 $($(source)_UNPACKTOOL)\ | 
|---|
|  | 1203 | 6 $($(srcname)_UNPACKTOOL)\ | 
|---|
|  | 1204 | 7 $($(source)_TOOL)\ | 
|---|
|  | 1205 | 8 $($(srcname)_TOOL)\ | 
|---|
|  | 1206 | 9 $($(target)_UNPACKTOOL)\ | 
|---|
|  | 1207 | 10 $($(target)_TOOL) \ | 
|---|
|  | 1208 | 11 $(toupper $(subst tar.,TAR,$(ext $(srcname)))) \ | 
|---|
|  | 1209 | ) | 
|---|
|  | 1210 | $(error kBuild: TOOL_$(tool)_UNPACK_CMDS is not defined. source=$(source) target=$(target) ) | 
|---|
|  | 1211 | endif | 
|---|
|  | 1212 |  | 
|---|
|  | 1213 | # call the tool | 
|---|
|  | 1214 | $(target)_$(srcname)_UNPACK_CMDS_   := $(TOOL_$(tool)_UNPACK_CMDS) | 
|---|
|  | 1215 | $(target)_$(srcname)_UNPACK_OUTPUT_ := $(TOOL_$(tool)_UNPACK_OUTPUT) | 
|---|
| [1030] | 1216 | $(target)_$(srcname)_UNPACK_OUTPUT_MAYBE_ := $(TOOL_$(tool)_UNPACK_OUTPUT_MAYBE) | 
|---|
| [640] | 1217 | $(target)_$(srcname)_UNPACK_DEPEND_ := $(TOOL_$(tool)_UNPACK_DEPEND) $(deps) | 
|---|
| [827] | 1218 | $(target)_$(srcname)_UNPACK_DEPORD_ := $(TOOL_$(tool)_UNPACK_DEPORD) $(dirdep) $(orderdeps) | 
|---|
| [640] | 1219 |  | 
|---|
|  | 1220 | # generate the fetch rule. | 
|---|
|  | 1221 | $(eval $(def_fetch_src_unpack_rule)) | 
|---|
|  | 1222 |  | 
|---|
|  | 1223 | _DIRS += $(inst) $(fetchdir) | 
|---|
|  | 1224 |  | 
|---|
|  | 1225 | endef | 
|---|
|  | 1226 |  | 
|---|
|  | 1227 |  | 
|---|
|  | 1228 | ## | 
|---|
|  | 1229 | # Define the target level rules for a fetch. | 
|---|
|  | 1230 | # @param        target | 
|---|
|  | 1231 | # @param        out | 
|---|
|  | 1232 | # @param        inst | 
|---|
| [688] | 1233 | # @param        _TARGET_$(target)_UNPACKED | 
|---|
|  | 1234 | # @param        _TARGET_$(target)_DIGEST | 
|---|
| [640] | 1235 | # @param        bld_trg | 
|---|
|  | 1236 | # @param        bld_trg_arch | 
|---|
|  | 1237 | define def_fetch_rules | 
|---|
|  | 1238 |  | 
|---|
| [689] | 1239 | $(out).lst: $(_TARGET_$(target)_UNPACKED) | $(call DIRDEP,$(inst)) | 
|---|
| [776] | 1240 | $$(call MSG_FETCH_OK,$(target)) | 
|---|
| [696] | 1241 | $$(QUIET)$$(RM) -f $$@ $$@.tmp | 
|---|
|  | 1242 | $$(QUIET2)$$(APPEND) $$@.tmp "$(notdir $(out))" | 
|---|
|  | 1243 | $$(QUIET)$(if $(_TARGET_$(target)_UNPACKED),$$(CAT_EXT) $(_TARGET_$(target)_UNPACKED) >> $$@.tmp) | 
|---|
|  | 1244 | $$(QUIET)$$(MV) -f $$@.tmp $$@ | 
|---|
| [640] | 1245 |  | 
|---|
|  | 1246 | $(out)_unfetched: | 
|---|
| [776] | 1247 | $$(call MSG_UNFETCH,$(target)) | 
|---|
| [696] | 1248 | $$(QUIET)$$(RM) -f $$(addprefix $(inst),$$(shell $$(CAT_EXT) $(out).lst 2> /dev/null | $$(SED) -e '/\/$$$$/d')) | 
|---|
|  | 1249 | $$(QUIET)$$(RMDIR) -p --ignore-fail-on-non-empty --ignore-fail-on-not-exist $$(dir $$@) \ | 
|---|
| [689] | 1250 | $$(addprefix $(inst),$$(sort $$(dir $$(shell $$(CAT_EXT) $(out).lst 2> /dev/null)))) | 
|---|
| [696] | 1251 | $$(QUIET)$$(RM) -f $(out).lst $(out) | 
|---|
|  | 1252 | $$(QUIET)$$(RMDIR) -p --ignore-fail-on-non-empty --ignore-fail-on-not-exist $$(dir $$@) | 
|---|
| [640] | 1253 |  | 
|---|
| [689] | 1254 | $(out): $(comp-vars _TARGET_$(target)_DIGEST_PREV,_TARGET_$(target)_DIGEST,FORCE) | $(call DIRDEP,$(inst)) | 
|---|
| [696] | 1255 | $$(QUIET)$$(RM) -f $$@ | 
|---|
| [776] | 1256 | $$(if $$(_TARGET_$(target)_DIGEST),$$(if $$(wildcard $(out).lst)\ | 
|---|
|  | 1257 | ,$$(call MSG_REFETCH,$(target)),$$(call MSG_FETCH,$(target))),$$(call MSG_UNFETCH,$(target))) | 
|---|
| [696] | 1258 | $$(QUIET)$$(if $$(wildcard $(out).lst      ),$$(MAKE) -f $(MAKEFILE) --no-print-directory $(out)_unfetched) | 
|---|
| [701] | 1259 | $$(QUIET)$$(if  $$(_TARGET_$(target)_DIGEST),$$(MAKE) -f $(MAKEFILE) --no-print-directory $(out).lst,$$(RMDIR) -p --ignore-fail-on-non-empty --ignore-fail-on-not-exist $$(dir $$@)) | 
|---|
| [696] | 1260 | $$(QUIET2)$$(if $$(_TARGET_$(target)_DIGEST),$$(APPEND) $$@ "_TARGET_$(target)_DIGEST_PREV := $(_TARGET_$(target)_DIGEST)") | 
|---|
| [760] | 1261 |  | 
|---|
| [689] | 1262 | .NOTPARALLEL: $(out).lst $(out)_unfetched $(out) | 
|---|
| [688] | 1263 |  | 
|---|
| [640] | 1264 | endef | 
|---|
|  | 1265 |  | 
|---|
|  | 1266 |  | 
|---|
|  | 1267 | ## | 
|---|
|  | 1268 | # Deal with one fetch target. | 
|---|
|  | 1269 | # @param        target | 
|---|
|  | 1270 | # @param        bld_trg | 
|---|
|  | 1271 | # @param        bld_trg_arch | 
|---|
|  | 1272 | define def_fetch | 
|---|
|  | 1273 | # common | 
|---|
|  | 1274 | INSTARGET_$(target) := $($(target)_INST) | 
|---|
|  | 1275 | ifneq ($(patsubst %/,ok,$(INSTARGET_$(target))),ok) | 
|---|
| [679] | 1276 | $(error kBuild: Bad or missing INST property for target '$(target)'. \ | 
|---|
|  | 1277 | $(target)_INST='$($(target)_INST)' ($(origin $(target)_INST))) | 
|---|
| [640] | 1278 | endif | 
|---|
|  | 1279 | _TARGET_$(target)_FETCHED := | 
|---|
|  | 1280 | _TARGET_$(target)_UNPACKED := | 
|---|
|  | 1281 | _TARGET_$(target)_DIGEST := | 
|---|
|  | 1282 |  | 
|---|
|  | 1283 | # The 'sources'. | 
|---|
|  | 1284 | #$ (warning dbg fetch: target=$(target) sources=$($(target)_SOURCES) $($(target)_SOURCES.$(BUILD_TYPE)) $($(target)_SOURCES.$(BUILD_TARGET)) $($(target)_SOURCES.$(BUILD_TARGET_ARCH)) $($(target)_SOURCES.$(BUILD_TARGET).$(BUILD_TARGET_ARCH))) | 
|---|
|  | 1285 | $(foreach source,$($(target)_SOURCES) $($(target)_SOURCES.$(BUILD_TYPE)) $($(target)_SOURCES.$(BUILD_TARGET)) $($(target)_SOURCES.$(BUILD_TARGET_ARCH)) $($(target)_SOURCES.$(BUILD_TARGET).$(BUILD_TARGET_ARCH)),\ | 
|---|
|  | 1286 | $(eval $(value def_fetch_src))) | 
|---|
|  | 1287 |  | 
|---|
|  | 1288 | # The target. | 
|---|
|  | 1289 | inst := $(INSTARGET_$(target)) | 
|---|
|  | 1290 | out := $(inst)_kBuild_fetch_$(target) | 
|---|
|  | 1291 |  | 
|---|
| [689] | 1292 | $(eval includedep $(out)) | 
|---|
| [690] | 1293 |  | 
|---|
| [640] | 1294 | $(eval $(def_fetch_rules)) | 
|---|
|  | 1295 |  | 
|---|
| [690] | 1296 | # Define the aliases here (doesn't work if defined in def_fetch_rules, just like includedep). | 
|---|
| [749] | 1297 | $(target): $(out) | 
|---|
|  | 1298 | $(target)_unfetch: $(out)_unfetched | 
|---|
| [690] | 1299 |  | 
|---|
| [689] | 1300 | _FETCHES += $(out) | 
|---|
| [640] | 1301 | _DOWNLOADS += $(_TARGET_$(target)_FETCHED) | 
|---|
|  | 1302 | _UNPACKS += $(_TARGET_$(target)_UNPACKED) | 
|---|
|  | 1303 | _UNFETCHES += $(out)_unfetched | 
|---|
|  | 1304 | _DIRS += $(inst) | 
|---|
|  | 1305 |  | 
|---|
|  | 1306 | endef | 
|---|
|  | 1307 |  | 
|---|
|  | 1308 | # Walk the FETCH target lists. | 
|---|
|  | 1309 | bld_trg := $(BUILD_TARGET) | 
|---|
|  | 1310 | bld_trg_arch := $(BUILD_TARGET_ARCH) | 
|---|
|  | 1311 | $(foreach target, $(FETCHES) $(FETCHES.$(BUILD_TARGET)) $(FETCHES.$(BUILD_TARGET).$(BUILD_TARGET_ARCH)), \ | 
|---|
|  | 1312 | $(eval $(value def_fetch))) | 
|---|
|  | 1313 |  | 
|---|
|  | 1314 | # some aliases. | 
|---|
|  | 1315 | download: $(_DOWNLOADS) | 
|---|
| [688] | 1316 | unpack: $(_UNPACKS) | 
|---|
|  | 1317 | fetch: $(_FETCHES) | 
|---|
|  | 1318 | unfetch: $(_UNFETCHES) | 
|---|
| [640] | 1319 |  | 
|---|
| [988] | 1320 | ifdef KBUILD_PROFILE_SELF | 
|---|
|  | 1321 | _KBUILD_TS_NOW := $(nanots ) | 
|---|
|  | 1322 | $(info prof: $(int-sub $(_KBUILD_TS_NOW), $(_KBUILD_TS_HEADER_START)) - $(int-sub $(_KBUILD_TS_NOW), $(_KBUILD_TS_PREV)) - done fetching targets) | 
|---|
|  | 1323 | _KBUILD_TS_PREV := $(_KBUILD_TS_NOW) | 
|---|
|  | 1324 | endif | 
|---|
| [640] | 1325 |  | 
|---|
|  | 1326 |  | 
|---|
| [988] | 1327 |  | 
|---|
| [640] | 1328 | ## | 
|---|
|  | 1329 | ## Patching. | 
|---|
|  | 1330 | ## | 
|---|
|  | 1331 | ## | 
|---|
| [688] | 1332 | #define def_patch_src | 
|---|
| [640] | 1333 | # | 
|---|
|  | 1334 | #endef | 
|---|
|  | 1335 | # | 
|---|
|  | 1336 | # | 
|---|
|  | 1337 | ## Deal with one patch target. | 
|---|
|  | 1338 | #define def_patch | 
|---|
|  | 1339 | # | 
|---|
|  | 1340 | #$(foreach source,$($(target)_SOURCES) $($(target)_SOURCES.$(BUILD_TYPE)) $($(target)_SOURCES.$(BUILD_TARGET)) $($(target)_SOURCES.$(BUILD_TARGET_ARCH)) $($(target)_SOURCES.$(BUILD_TARGET).$(BUILD_TARGET_ARCH)),\ | 
|---|
| [688] | 1341 | #       $(eval $(value def_patch_src))) | 
|---|
| [640] | 1342 | # | 
|---|
| [719] | 1343 | #_PATCHES += | 
|---|
| [640] | 1344 | #endef | 
|---|
|  | 1345 | # | 
|---|
|  | 1346 | #$(foreach target, $(PATCHES) $(PATCHES.$(BUILD_TARGET)) $(PATCHES.$(BUILD_TARGET).$(BUILD_TARGET_ARCH)), \ | 
|---|
|  | 1347 | #       $(eval $(value def_patch))) | 
|---|
|  | 1348 | # | 
|---|
|  | 1349 |  | 
|---|
|  | 1350 |  | 
|---|
|  | 1351 | # | 
|---|
| [73] | 1352 | # Object processing. | 
|---|
|  | 1353 | # | 
|---|
| [72] | 1354 |  | 
|---|
| [380] | 1355 | ## wrapper the compile command dependency check. | 
|---|
|  | 1356 | ifndef NO_COMPILE_CMDS_DEPS | 
|---|
| [741] | 1357 | _DEP_COMPILE_CMDS = $(comp-cmds $(target)_$(source)_CMDS_PREV_,$(target)_$(source)_CMDS_,FORCE) | 
|---|
| [380] | 1358 | else | 
|---|
| [730] | 1359 | _DEP_COMPILE_CMDS = | 
|---|
| [380] | 1360 | endif | 
|---|
|  | 1361 |  | 
|---|
| [749] | 1362 | ## Generates the rules for building a specific object, and the aliases | 
|---|
| [380] | 1363 | # for building a source file. | 
|---|
| [353] | 1364 | # @param    $(obj)    The object file. | 
|---|
| [380] | 1365 | define def_target_source_rule | 
|---|
| [1025] | 1366 |  | 
|---|
| [1012] | 1367 | ifdef TOOL_$(tool)_COMPILE_$(type)_USES_KOBJCACHE | 
|---|
| [1030] | 1368 | $(outbase).koc +| $(obj) $($(target)_$(source)_OUTPUT_) $($(target)_$(source)_OUTPUT_MAYBE_) : \ | 
|---|
| [1007] | 1369 | $($(target)_$(source)_DEPEND_) \ | 
|---|
|  | 1370 | $(_DEP_COMPILE_CMDS) \ | 
|---|
|  | 1371 | | \ | 
|---|
|  | 1372 | $($(target)_$(source)_DEPORD_) | 
|---|
|  | 1373 | $$(call MSG_COMPILE,$(target),$(source),$$@,$(type)) | 
|---|
|  | 1374 | else | 
|---|
| [1030] | 1375 | $(obj) + $($(target)_$(source)_OUTPUT_) +| $($(target)_$(source)_OUTPUT_MAYBE_) : \ | 
|---|
| [380] | 1376 | $($(target)_$(source)_DEPEND_) \ | 
|---|
|  | 1377 | $(_DEP_COMPILE_CMDS) \ | 
|---|
|  | 1378 | | \ | 
|---|
|  | 1379 | $($(target)_$(source)_DEPORD_) | 
|---|
| [776] | 1380 | $$(call MSG_COMPILE,$(target),$(source),$$@,$(type)) | 
|---|
| [1012] | 1381 | ifdef TOOL_$(tool)_COMPILE_$(type)_DONT_PURGE_OUTPUT | 
|---|
| [1030] | 1382 | $$(QUIET)$$(RM) -f $(dep) $(obj) $($(target)_$(source)_OUTPUT_) $($(target)_OUTPUT_MAYBE_) | 
|---|
| [1007] | 1383 | endif | 
|---|
| [1012] | 1384 | endif | 
|---|
| [412] | 1385 |  | 
|---|
| [380] | 1386 | $($(target)_$(source)_CMDS_) | 
|---|
|  | 1387 |  | 
|---|
|  | 1388 | ifndef NO_COMPILE_CMDS_DEPS | 
|---|
| [696] | 1389 | $$(QUIET2)$$(APPEND) "$(dep)" | 
|---|
|  | 1390 | $$(QUIET2)$$(APPEND) "$(dep)" 'define $(target)_$(source)_CMDS_PREV_' | 
|---|
| [770] | 1391 | ifeq ($(filter append-dash-n,$(KMK_FEATURES)),append-dash-n) | 
|---|
|  | 1392 | $$(QUIET2)$$(APPEND) -v "$(dep)" '$(target)_$(source)_CMDS_' | 
|---|
|  | 1393 | else | 
|---|
| [696] | 1394 | $$(QUIET2)$$(APPEND) "$(dep)" '$(subst $(NL),'$(NL)$(TAB)@$(APPEND) "$(dep)" ',$($(target)_$(source)_CMDS_))' | 
|---|
| [770] | 1395 | endif | 
|---|
| [696] | 1396 | $$(QUIET2)$$(APPEND) "$(dep)" 'endef' | 
|---|
| [412] | 1397 | endif | 
|---|
| [380] | 1398 |  | 
|---|
| [749] | 1399 | $(basename $(notdir $(obj))).o: $(obj) | 
|---|
|  | 1400 | $(basename $(notdir $(obj))).obj: $(obj) | 
|---|
| [353] | 1401 | endef | 
|---|
| [205] | 1402 |  | 
|---|
| [353] | 1403 |  | 
|---|
| [380] | 1404 | ## wrapper the link command dependency check. | 
|---|
|  | 1405 | ifndef NO_COMPILE_CMDS_DEPS | 
|---|
| [741] | 1406 | _DEP_LINK_CMDS = $(comp-cmds $(target)_CMDS_PREV_,$(target)_CMDS_,FORCE) | 
|---|
| [380] | 1407 | else | 
|---|
| [730] | 1408 | _DEP_LINK_CMDS = | 
|---|
| [380] | 1409 | endif | 
|---|
|  | 1410 |  | 
|---|
|  | 1411 | ## Generate the link rule for a target. | 
|---|
|  | 1412 | # @param    $(target)               The normalized target name. | 
|---|
|  | 1413 | # @param    $(dirdep)               Directories we depend upon begin created before linking. | 
|---|
|  | 1414 | # @param    $(dep)                  The name of the dependency file. | 
|---|
|  | 1415 | # @param    $(out) | 
|---|
|  | 1416 | # @param    $($(target)_OUTPUT_)    Output files from the link. | 
|---|
| [1030] | 1417 | # @param    $($(target)_OUTPUT_MAYBE_)  Output files that the link may perhaps create. | 
|---|
| [380] | 1418 | # @param    $($(target)_DEPEND_)        Dependencies. | 
|---|
|  | 1419 | # @param    $($(target)_DEPORD_)    Dependencies which should only affect build order. | 
|---|
|  | 1420 | # @param    $($(target)_CMDS_)      The link commands. | 
|---|
|  | 1421 | # @param    $($(target)_CMDS_PREV_) The link commands from the previous run. | 
|---|
|  | 1422 | define def_link_rule | 
|---|
| [1030] | 1423 | $(out) + $($(target)_OUTPUT_) +| $($(target)_OUTPUT_MAYBE_) : \ | 
|---|
| [380] | 1424 | $($(target)_DEPEND_) \ | 
|---|
|  | 1425 | $(_DEP_LINK_CMDS) \ | 
|---|
|  | 1426 | | \ | 
|---|
|  | 1427 | $($(target)_DEPORD_) | 
|---|
| [776] | 1428 | $$(call MSG_LINK,$(target),$$@,$(tool_do)) | 
|---|
| [1030] | 1429 | $$(QUIET)$$(RM) -f $(dep) $(out) $($(target)_OUTPUT_) $($(target)_OUTPUT_MAYBE_) | 
|---|
| [412] | 1430 |  | 
|---|
| [380] | 1431 | $($(target)_CMDS_) | 
|---|
|  | 1432 |  | 
|---|
| [524] | 1433 | ifndef NO_LINK_CMDS_DEPS | 
|---|
| [696] | 1434 | $$(QUIET2)$$(APPEND) "$(dep)" 'define $(target)_CMDS_PREV_' | 
|---|
| [770] | 1435 | ifeq ($(filter append-dash-n,$(KMK_FEATURES)),append-dash-n) | 
|---|
|  | 1436 | $$(QUIET2)$$(APPEND) -v "$(dep)" '$(target)_CMDS_' | 
|---|
|  | 1437 | else | 
|---|
| [696] | 1438 | $$(QUIET2)$$(APPEND) "$(dep)" '$(subst $(NL),'$(NL)$(TAB)@$(APPEND) "$(dep)" ',$($(target)_CMDS_))' | 
|---|
| [770] | 1439 | endif | 
|---|
| [696] | 1440 | $$(QUIET2)$$(APPEND) "$(dep)" 'endef' | 
|---|
| [412] | 1441 | endif | 
|---|
| [380] | 1442 |  | 
|---|
| [749] | 1443 | $(basename $(notdir $(out))): $(out) | 
|---|
| [719] | 1444 |  | 
|---|
| [380] | 1445 | endef | 
|---|
|  | 1446 |  | 
|---|
|  | 1447 |  | 
|---|
|  | 1448 | ## Generate the link & lib install rule | 
|---|
|  | 1449 | # @param    $(target)   Normalized target name. | 
|---|
|  | 1450 | # @param    $(out)      The build target. | 
|---|
|  | 1451 | # @param    $(INSTARGET_$(target))  The installation targets. | 
|---|
|  | 1452 | # @param    $(mode)     The file mode (optional) | 
|---|
|  | 1453 | define def_link_install_rule | 
|---|
|  | 1454 | $(INSTARGET_$(target)) : $(out) | $(call DIRDEP,$(dir $(INSTARGET_$(target)))) | 
|---|
| [776] | 1455 | $$(call MSG_INST_TRG,$(target),$(out),$$@) | 
|---|
| [696] | 1456 | $$(QUIET)$$(INSTALL) $$(if $(mode),-m $(mode)) $(out) $$@ | 
|---|
| [719] | 1457 |  | 
|---|
|  | 1458 | ifdef KBUILD_DO_AUTO_INSTALL | 
|---|
| [749] | 1459 | $(basename $(notdir $(out))): $(INSTARGET_$(target)) | 
|---|
| [719] | 1460 | endif | 
|---|
| [380] | 1461 | endef | 
|---|
|  | 1462 |  | 
|---|
|  | 1463 |  | 
|---|
| [73] | 1464 | ## Generic macro for processing C, C++ and Assembly sources. | 
|---|
|  | 1465 | # @param    $(target)     Normalized target name. | 
|---|
|  | 1466 | # @param    $(source)     Source file name. | 
|---|
|  | 1467 | # @param    $(type)       Source type. {C,CXX,AS} | 
|---|
| [221] | 1468 | # @param    bld_type      Build type. | 
|---|
|  | 1469 | # @param    bld_trg       Build target. | 
|---|
|  | 1470 | # @param    bld_trg_arch  Build target arch. | 
|---|
|  | 1471 | # @param    bld_trg_cpu   Build target cpu. | 
|---|
| [729] | 1472 | def_target_source_c_cpp_asm_rc_new = $(kb-src-one ) | 
|---|
| [741] | 1473 | ifdef KMK_VERSION | 
|---|
| [723] | 1474 | def_target_source_c_cpp_asm_rc_var = def_target_source_c_cpp_asm_rc_new | 
|---|
| [530] | 1475 | else | 
|---|
| [723] | 1476 | def_target_source_c_cpp_asm_rc_var = def_target_source_c_cpp_asm_rc_old | 
|---|
| [530] | 1477 | endif | 
|---|
|  | 1478 |  | 
|---|
| [73] | 1479 | ## Generic macro for processing all target sources. | 
|---|
| [74] | 1480 | # @param    $(target)   Normalized target name. | 
|---|
| [725] | 1481 | # @param    $(defpath) | 
|---|
|  | 1482 | # @param    much-more... | 
|---|
| [73] | 1483 | define def_target_sources | 
|---|
|  | 1484 | #$ (warning def_target_sources) | 
|---|
|  | 1485 | # C sources | 
|---|
| [353] | 1486 | type := C | 
|---|
| [481] | 1487 | $(foreach source, $(filter %.c             , $($(target)_SOURCES) $($(target)_SOURCES.$(bld_trg)) $($(target)_SOURCES.$(bld_trg).$(bld_trg_arch)) $($(target)_SOURCES.$(bld_trg_arch)) $($(target)_SOURCES.$(bld_trg_cpu)) $($(target)_SOURCES.$(bld_type)))\ | 
|---|
| [641] | 1488 | ,$(eval $(value $(def_target_source_c_cpp_asm_rc_var))) ) | 
|---|
| [73] | 1489 |  | 
|---|
|  | 1490 | # C++ sources | 
|---|
| [353] | 1491 | type := CXX | 
|---|
| [481] | 1492 | $(foreach source, $(filter %.cpp %.cxx %.xx, $($(target)_SOURCES) $($(target)_SOURCES.$(bld_trg)) $($(target)_SOURCES.$(bld_trg).$(bld_trg_arch)) $($(target)_SOURCES.$(bld_trg_arch)) $($(target)_SOURCES.$(bld_trg_cpu)) $($(target)_SOURCES.$(bld_type)))\ | 
|---|
| [641] | 1493 | ,$(eval $(value $(def_target_source_c_cpp_asm_rc_var))) ) | 
|---|
| [73] | 1494 |  | 
|---|
|  | 1495 | # ASM sources | 
|---|
| [353] | 1496 | type := AS | 
|---|
| [481] | 1497 | $(foreach source, $(filter %.asm %.s %.S   , $($(target)_SOURCES) $($(target)_SOURCES.$(bld_trg)) $($(target)_SOURCES.$(bld_trg).$(bld_trg_arch)) $($(target)_SOURCES.$(bld_trg_arch)) $($(target)_SOURCES.$(bld_trg_cpu)) $($(target)_SOURCES.$(bld_type)))\ | 
|---|
| [641] | 1498 | ,$(eval $(value $(def_target_source_c_cpp_asm_rc_var))) ) | 
|---|
| [353] | 1499 |  | 
|---|
| [641] | 1500 | # Resource sources | 
|---|
|  | 1501 | type := RC | 
|---|
|  | 1502 | $(foreach source, $(filter %.rc            , $($(target)_SOURCES) $($(target)_SOURCES.$(bld_trg)) $($(target)_SOURCES.$(bld_trg).$(bld_trg_arch)) $($(target)_SOURCES.$(bld_trg_arch)) $($(target)_SOURCES.$(bld_trg_cpu)) $($(target)_SOURCES.$(bld_type)))\ | 
|---|
|  | 1503 | ,$(eval $(value $(def_target_source_c_cpp_asm_rc_var))) ) | 
|---|
|  | 1504 |  | 
|---|
| [73] | 1505 | endef | 
|---|
|  | 1506 |  | 
|---|
|  | 1507 |  | 
|---|
| [219] | 1508 |  | 
|---|
| [353] | 1509 | ## Generic macro for generating the install rule(s) for a target | 
|---|
|  | 1510 | # and update the globals with default out. | 
|---|
| [219] | 1511 | # | 
|---|
| [353] | 1512 | # @param        $(target)   Normalized target name. | 
|---|
|  | 1513 | # @param        $(out)      The output file. | 
|---|
|  | 1514 | # @param        $(definst)  The default _INST value. | 
|---|
|  | 1515 | # @param        $(typevar)  The name of the variable with all the root targets of its type. | 
|---|
| [729] | 1516 | # @remark   Only library uses this now. | 
|---|
| [353] | 1517 | define def_target_install_pluss | 
|---|
|  | 1518 | ifndef $(target)_NOINST | 
|---|
|  | 1519 | INSTARGET_$(target) := $(patsubst %/,%/$(notdir $(out)), \ | 
|---|
|  | 1520 | $(if $($(target)_INST), $(addprefix $(PATH_INS)/,$($(target)_INST)), $(definst)/)) | 
|---|
| [219] | 1521 |  | 
|---|
| [353] | 1522 | $(eval $(def_link_install_rule)) | 
|---|
| [239] | 1523 |  | 
|---|
| [827] | 1524 | _INSTALLS_FILES += $(INSTARGET_$(target)) | 
|---|
| [272] | 1525 |  | 
|---|
| [353] | 1526 | ifdef KBUILD_DO_AUTO_INSTALL | 
|---|
| [579] | 1527 | $(typevar) += $(INSTARGET_$(target)) | 
|---|
| [219] | 1528 | else | 
|---|
| [579] | 1529 | $(typevar) += $(out) | 
|---|
| [219] | 1530 | endif | 
|---|
| [353] | 1531 | else # _NOINST | 
|---|
| [579] | 1532 | $(typevar) += $(out) | 
|---|
| [353] | 1533 | endif | 
|---|
|  | 1534 |  | 
|---|
| [1030] | 1535 | _OUT_FILES += $($(target)_OUTPUT_) $($(target)_OUTPUT_MAYBE_) $(out) | 
|---|
| [905] | 1536 | _CLEAN_FILES += $($(target)_CLEAN) $($(target)_CLEAN.$(bld_trg)) $($(target)_CLEAN.$(bld_trg).$(bld_trg_arch)) $($(target)_CLEAN.$(bld_trg_arch)) $($(target)_CLEAN.$(bld_trg_cpu)) $($(target)_CLEAN.$(bld_type)) | 
|---|
|  | 1537 | _DIRS += $($(target)_BLDDIRS) $($(target)_BLDDIRS.$(bld_trg)) $($(target)_BLDDIRS.$(bld_trg).$(bld_trg_arch)) $($(target)_BLDDIRS.$(bld_trg_arch)) $($(target)_BLDDIRS.$(bld_trg_cpu)) $($(target)_BLDDIRS.$(bld_type)) | 
|---|
| [353] | 1538 | _OBJS += $($(target)_OBJS_) | 
|---|
|  | 1539 |  | 
|---|
| [219] | 1540 | endef | 
|---|
|  | 1541 |  | 
|---|
|  | 1542 |  | 
|---|
|  | 1543 |  | 
|---|
|  | 1544 | # | 
|---|
| [72] | 1545 | # LIBRARIES | 
|---|
| [73] | 1546 | # | 
|---|
| [72] | 1547 |  | 
|---|
|  | 1548 | ## Library (one). | 
|---|
| [74] | 1549 | # @param    $(target)   Normalized library (target) name. | 
|---|
| [72] | 1550 | define def_lib | 
|---|
| [145] | 1551 | # library basics | 
|---|
| [222] | 1552 | ## @todo prefix | 
|---|
| [353] | 1553 | bld_type    := $(firstword $($(target)_BLD_TYPE)     $(BUILD_TYPE)) | 
|---|
|  | 1554 | bld_trg     := $(firstword $($(target)_BLD_TRG)      $(BUILD_TARGET)) | 
|---|
|  | 1555 | bld_trg_arch:= $(firstword $($(target)_BLD_TRG_ARCH) $(BUILD_TARGET_ARCH)) | 
|---|
|  | 1556 | bld_trg_cpu := $(firstword $($(target)_BLD_TRG_CPU)  $(BUILD_TARGET_CPU)) | 
|---|
|  | 1557 | tool        := $(call _TARGET_TOOL,$(target),AR) | 
|---|
| [78] | 1558 | ifeq ($(tool),) | 
|---|
| [353] | 1559 | $(error kBuild: Library target $(target) does not have a tool defined!) | 
|---|
| [78] | 1560 | endif | 
|---|
| [889] | 1561 | name        := $(firstword\ | 
|---|
|  | 1562 | $($(target)_NAME.$(bld_trg).$(bld_trg_arch))\ | 
|---|
|  | 1563 | $($(target)_NAME.$(bld_trg_arch))\ | 
|---|
|  | 1564 | $($(target)_NAME.$(bld_trg))\ | 
|---|
|  | 1565 | $($(target)_NAME.$(bld_type))\ | 
|---|
|  | 1566 | $($(target)_NAME)\ | 
|---|
|  | 1567 | $(target)) | 
|---|
|  | 1568 | outbase     := $(call TARGET_BASE,$(name),$(target)) | 
|---|
| [743] | 1569 | ifndef PATH_$(target) | 
|---|
|  | 1570 | PATH_$(target) := $(patsubst %/,%,$(dir $(outbase))) | 
|---|
|  | 1571 | else | 
|---|
|  | 1572 | ifneq ($(PATH_$(target)),$(patsubst %/,%,$(dir $(outbase)))) | 
|---|
|  | 1573 | $(error kBuild internal error: PATH_$(target)=$(PATH_$(target)) expected $(patsubst %/,%,$(dir $(outbase)))) | 
|---|
|  | 1574 | endif | 
|---|
|  | 1575 | endif | 
|---|
| [353] | 1576 | suff        := $(firstword\ | 
|---|
| [481] | 1577 | $($(target)_LIBSUFF.$(bld_trg).$(bld_trg_arch))\ | 
|---|
| [221] | 1578 | $($(target)_LIBSUFF.$(bld_trg))\ | 
|---|
| [126] | 1579 | $($(target)_LIBSUFF)\ | 
|---|
| [481] | 1580 | $(TOOL_$(tool)_ARLIBSUFF.$(bld_trg).$(bld_trg_arch))\ | 
|---|
| [221] | 1581 | $(TOOL_$(tool)_ARLIBSUFF.$(bld_trg))\ | 
|---|
| [126] | 1582 | $(TOOL_$(tool)_ARLIBSUFF)\ | 
|---|
| [353] | 1583 | $(SUFF_LIB)) | 
|---|
|  | 1584 | out         := $(outbase)$(suff) | 
|---|
|  | 1585 | TARGET_$(target) := $(out) | 
|---|
| [719] | 1586 | $(target)_OBJS_ := | 
|---|
| [725] | 1587 | defpath := $($(target)_PATH) | 
|---|
| [145] | 1588 |  | 
|---|
|  | 1589 | # source -> object | 
|---|
| [353] | 1590 | $(eval $(value def_target_sources)) | 
|---|
| [145] | 1591 |  | 
|---|
|  | 1592 | # library linking | 
|---|
| [353] | 1593 | tool        := $(call _TARGET_TOOL,$(target),AR) | 
|---|
| [889] | 1594 | name        := $(firstword\ | 
|---|
|  | 1595 | $($(target)_NAME.$(bld_trg).$(bld_trg_arch))\ | 
|---|
|  | 1596 | $($(target)_NAME.$(bld_trg_arch))\ | 
|---|
|  | 1597 | $($(target)_NAME.$(bld_trg))\ | 
|---|
|  | 1598 | $($(target)_NAME.$(bld_type))\ | 
|---|
|  | 1599 | $($(target)_NAME)\ | 
|---|
|  | 1600 | $(target)) | 
|---|
|  | 1601 | outbase     := $(call TARGET_BASE,$(name),$(target)) | 
|---|
| [353] | 1602 | flags       :=\ | 
|---|
| [74] | 1603 | $(TOOL_$(tool)_ARFLAGS)\ | 
|---|
| [221] | 1604 | $(TOOL_$(tool)_ARFLAGS.$(bld_type))\ | 
|---|
| [74] | 1605 | $(ARFLAGS)\ | 
|---|
| [221] | 1606 | $(ARFLAGS.$(bld_type))\ | 
|---|
| [74] | 1607 | $($(target)_ARFLAGS)\ | 
|---|
| [481] | 1608 | $($(target)_ARFLAGS.$(bld_type)) \ | 
|---|
|  | 1609 | $($(target)_ARFLAGS.$(bld_trg)) \ | 
|---|
|  | 1610 | $($(target)_ARFLAGS.$(bld_trg_arch)) \ | 
|---|
|  | 1611 | $($(target)_ARFLAGS.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
|  | 1612 | $($(target)_ARFLAGS.$(bld_trg_cpu)) | 
|---|
| [1148] | 1613 | othersrc    := $(filter-out %.c %.cpp %.cxx %.cc %.s %.S %.asm %.rc %.o %.obj %.res,\ | 
|---|
| [353] | 1614 | $($(target)_SOURCES) \ | 
|---|
|  | 1615 | $($(target)_SOURCES.$(bld_trg)) \ | 
|---|
|  | 1616 | $($(target)_SOURCES.$(bld_trg_arch)) \ | 
|---|
| [481] | 1617 | $($(target)_SOURCES.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
| [353] | 1618 | $($(target)_SOURCES.$(bld_trg_cpu)) \ | 
|---|
|  | 1619 | $($(target)_SOURCES.$(bld_type))) | 
|---|
| [1148] | 1620 | objs         = $(filter %.o %.obj %.res, \ | 
|---|
| [643] | 1621 | $($(target)_SOURCES) \ | 
|---|
|  | 1622 | $($(target)_SOURCES.$(bld_trg)) \ | 
|---|
|  | 1623 | $($(target)_SOURCES.$(bld_trg_arch)) \ | 
|---|
|  | 1624 | $($(target)_SOURCES.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
|  | 1625 | $($(target)_SOURCES.$(bld_trg_cpu)) \ | 
|---|
|  | 1626 | $($(target)_SOURCES.$(bld_type))) \ | 
|---|
|  | 1627 | $($(target)_OBJS_) | 
|---|
| [353] | 1628 | dirdep      := $(call DIRDEP,$(dir $(out))) | 
|---|
|  | 1629 | deps        := $($(target)_DEPS) | 
|---|
| [827] | 1630 | orderdeps   := $($(target)_ORDERDEPS) | 
|---|
| [72] | 1631 |  | 
|---|
| [725] | 1632 | # Adjust paths if we got a default path. | 
|---|
|  | 1633 | ifneq ($(defpath),) | 
|---|
| [979] | 1634 | objs := $(abspathex $(objs),$(defpath)) | 
|---|
|  | 1635 | deps := $(abspathex $(deps),$(defpath)) | 
|---|
|  | 1636 | orderdeps := $(abspathex $(orderdeps),$(defpath)) | 
|---|
|  | 1637 | othersrc := $(abspathex $(othersrc),$(defpath)) | 
|---|
| [725] | 1638 | endif | 
|---|
|  | 1639 |  | 
|---|
| [859] | 1640 |  | 
|---|
|  | 1641 | # Custom pre-link actions. | 
|---|
|  | 1642 | ifdef $(target)_PRE_CMDS.$(bld_trg).$(bld_trg_arch).$(bld_type) | 
|---|
|  | 1643 | pre_cmds := $($(target)_PRE_CMDS.$(bld_trg).$(bld_trg_arch).$(bld_type)) | 
|---|
|  | 1644 | else ifdef $(target)_PRE_CMDS.$(bld_trg).$(bld_trg_arch) | 
|---|
|  | 1645 | pre_cmds := $($(target)_PRE_CMDS.$(bld_trg).$(bld_trg_arch)) | 
|---|
|  | 1646 | else ifdef $(target)_PRE_CMDS.$(bld_trg).$(bld_type) | 
|---|
|  | 1647 | pre_cmds := $($(target)_PRE_CMDS.$(bld_trg).$(bld_type)) | 
|---|
|  | 1648 | else ifdef $(target)_PRE_CMDS.$(bld_trg_arch) | 
|---|
|  | 1649 | pre_cmds := $($(target)_PRE_CMDS.$(bld_trg_arch)) | 
|---|
|  | 1650 | else ifdef $(target)_PRE_CMDS.$(bld_trg) | 
|---|
|  | 1651 | pre_cmds := $($(target)_PRE_CMDS.$(bld_trg)) | 
|---|
|  | 1652 | else ifdef $(target)_PRE_CMDS.$(bld_type) | 
|---|
|  | 1653 | pre_cmds := $($(target)_PRE_CMDS.$(bld_type)) | 
|---|
|  | 1654 | else ifdef $(target)_PRE_CMDS | 
|---|
|  | 1655 | pre_cmds := $($(target)_PRE_CMDS) | 
|---|
|  | 1656 | else ifdef PRE_CMDS.$(bld_trg).$(bld_trg_arch).$(bld_type) | 
|---|
|  | 1657 | pre_cmds := $(PRE_CMDS.$(bld_trg).$(bld_trg_arch).$(bld_type)) | 
|---|
|  | 1658 | else ifdef PRE_CMDS.$(bld_trg).$(bld_trg_arch) | 
|---|
|  | 1659 | pre_cmds := $(PRE_CMDS.$(bld_trg).$(bld_trg_arch)) | 
|---|
|  | 1660 | else ifdef PRE_CMDS.$(bld_trg).$(bld_type) | 
|---|
|  | 1661 | pre_cmds := $(PRE_CMDS.$(bld_trg).$(bld_type)) | 
|---|
|  | 1662 | else ifdef PRE_CMDS.$(bld_trg_arch) | 
|---|
|  | 1663 | pre_cmds := $(PRE_CMDS.$(bld_trg_arch)) | 
|---|
|  | 1664 | else ifdef PRE_CMDS.$(bld_trg) | 
|---|
|  | 1665 | pre_cmds := $(PRE_CMDS.$(bld_trg)) | 
|---|
|  | 1666 | else ifdef PRE_CMDS.$(bld_type) | 
|---|
|  | 1667 | pre_cmds := $(PRE_CMDS.$(bld_type)) | 
|---|
|  | 1668 | else | 
|---|
|  | 1669 | pre_cmds := $(PRE_CMDS) | 
|---|
|  | 1670 | endif | 
|---|
|  | 1671 |  | 
|---|
|  | 1672 | # Custom post-link actions. | 
|---|
|  | 1673 | ifdef $(target)_POST_CMDS.$(bld_trg).$(bld_trg_arch).$(bld_type) | 
|---|
|  | 1674 | post_cmds := $($(target)_POST_CMDS.$(bld_trg).$(bld_trg_arch).$(bld_type)) | 
|---|
|  | 1675 | else ifdef $(target)_POST_CMDS.$(bld_trg).$(bld_trg_arch) | 
|---|
|  | 1676 | post_cmds := $($(target)_POST_CMDS.$(bld_trg).$(bld_trg_arch)) | 
|---|
|  | 1677 | else ifdef $(target)_POST_CMDS.$(bld_trg).$(bld_type) | 
|---|
|  | 1678 | post_cmds := $($(target)_POST_CMDS.$(bld_trg).$(bld_type)) | 
|---|
|  | 1679 | else ifdef $(target)_POST_CMDS.$(bld_trg_arch) | 
|---|
|  | 1680 | post_cmds := $($(target)_POST_CMDS.$(bld_trg_arch)) | 
|---|
|  | 1681 | else ifdef $(target)_POST_CMDS.$(bld_trg) | 
|---|
|  | 1682 | post_cmds := $($(target)_POST_CMDS.$(bld_trg)) | 
|---|
|  | 1683 | else ifdef $(target)_POST_CMDS.$(bld_type) | 
|---|
|  | 1684 | post_cmds := $($(target)_POST_CMDS.$(bld_type)) | 
|---|
|  | 1685 | else ifdef $(target)_POST_CMDS | 
|---|
|  | 1686 | post_cmds := $($(target)_POST_CMDS) | 
|---|
|  | 1687 | else ifdef POST_CMDS.$(bld_trg).$(bld_trg_arch).$(bld_type) | 
|---|
|  | 1688 | post_cmds := $(POST_CMDS.$(bld_trg).$(bld_trg_arch).$(bld_type)) | 
|---|
|  | 1689 | else ifdef POST_CMDS.$(bld_trg).$(bld_trg_arch) | 
|---|
|  | 1690 | post_cmds := $(POST_CMDS.$(bld_trg).$(bld_trg_arch)) | 
|---|
|  | 1691 | else ifdef POST_CMDS.$(bld_trg).$(bld_type) | 
|---|
|  | 1692 | post_cmds := $(POST_CMDS.$(bld_trg).$(bld_type)) | 
|---|
|  | 1693 | else ifdef POST_CMDS.$(bld_trg_arch) | 
|---|
|  | 1694 | post_cmds := $(POST_CMDS.$(bld_trg_arch)) | 
|---|
|  | 1695 | else ifdef POST_CMDS.$(bld_trg) | 
|---|
|  | 1696 | post_cmds := $(POST_CMDS.$(bld_trg)) | 
|---|
|  | 1697 | else ifdef POST_CMDS.$(bld_type) | 
|---|
|  | 1698 | post_cmds := $(POST_CMDS.$(bld_type)) | 
|---|
|  | 1699 | else | 
|---|
|  | 1700 | post_cmds := $(POST_CMDS) | 
|---|
|  | 1701 | endif | 
|---|
|  | 1702 |  | 
|---|
| [380] | 1703 | # dependency file | 
|---|
|  | 1704 | dep := $(out)$(SUFF_DEP) | 
|---|
| [524] | 1705 | ifndef NO_LINK_CMDS_DEPS | 
|---|
| [893] | 1706 | _DEPFILES_INCLUDED += $(dep) | 
|---|
|  | 1707 | $(eval includedep $(dep)) | 
|---|
| [380] | 1708 | endif | 
|---|
| [72] | 1709 |  | 
|---|
| [380] | 1710 | # check that the tool is defined. | 
|---|
|  | 1711 | ifndef TOOL_$(tool)_LINK_LIBRARY_CMDS | 
|---|
|  | 1712 | $(warning kBuild: tools: \ | 
|---|
| [481] | 1713 | 1 $($(target)_$(source)TOOL.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
|  | 1714 | 2 $($(target)_$(source)TOOL.$(bld_trg)) \ | 
|---|
|  | 1715 | 3 $($(target)_$(source)TOOL) \ | 
|---|
|  | 1716 | 4 $($(target)_TOOL.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
|  | 1717 | 5 $($(target)_TOOL.$(bld_trg)) \ | 
|---|
|  | 1718 | 6 $($(target)_TOOL) \ | 
|---|
|  | 1719 | 7 $($(source)TOOL) \ | 
|---|
|  | 1720 | 8 $($(source)TOOL.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
|  | 1721 | 9 $($(source)TOOL.$(bld_trg)) \ | 
|---|
|  | 1722 | 10 $(TOOL.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
|  | 1723 | 11 $(TOOL.$(bld_trg)) \ | 
|---|
|  | 1724 | 12 $(TOOL) ) | 
|---|
| [380] | 1725 | $(error kBuild: TOOL_$(tool)_LINK_LIBRARY_CMDS isn't defined! target=$(target) ) | 
|---|
|  | 1726 | endif | 
|---|
|  | 1727 |  | 
|---|
|  | 1728 | # call the tool | 
|---|
|  | 1729 | $(target)_CMDS_   := $(TOOL_$(tool)_LINK_LIBRARY_CMDS) | 
|---|
| [859] | 1730 | ifneq ($(pre_cmds),) | 
|---|
|  | 1731 | $(target)_CMDS_  := $(TAB)$(pre_cmds)$(NL)$(TAB)$($(target)_CMDS_) | 
|---|
|  | 1732 | endif | 
|---|
|  | 1733 | ifneq ($(post_cmds),) | 
|---|
|  | 1734 | $(target)_CMDS_  := $($(target)_CMDS_)$(NL)$(TAB)$(post_cmds) | 
|---|
|  | 1735 | endif | 
|---|
| [380] | 1736 | $(target)_OUTPUT_ := $(TOOL_$(tool)_LINK_LIBRARY_OUTPUT) | 
|---|
| [1030] | 1737 | $(target)_OUTPUT_MAYBE_ := $(TOOL_$(tool)_LINK_LIBRARY_OUTPUT_MAYBE) | 
|---|
| [380] | 1738 | $(target)_DEPEND_ := $(TOOL_$(tool)_LINK_LIBRARY_DEPEND) $(deps) $(objs) | 
|---|
| [827] | 1739 | $(target)_DEPORD_ := $(TOOL_$(tool)_LINK_LIBRARY_DEPORD) $(dirdep) $(orderdeps) | 
|---|
| [380] | 1740 |  | 
|---|
| [412] | 1741 | # generate the link rule. | 
|---|
| [380] | 1742 | $(eval $(def_link_rule)) | 
|---|
|  | 1743 |  | 
|---|
| [353] | 1744 | # installing and globals | 
|---|
|  | 1745 | $(eval $(value def_target_install_pluss)) | 
|---|
| [72] | 1746 | endef | 
|---|
|  | 1747 |  | 
|---|
|  | 1748 | # Process libraries | 
|---|
| [859] | 1749 | definst := $(PATH_LIB) | 
|---|
|  | 1750 | typevar := _LIBS | 
|---|
| [776] | 1751 | tool_do := LINK_LIBRARY | 
|---|
| [380] | 1752 | mode := 0644 | 
|---|
| [481] | 1753 | $(foreach target, $(LIBRARIES) $(LIBRARIES.$(BUILD_TARGET)) $(LIBRARIES.$(BUILD_TARGET).$(BUILD_TARGET_ARCH)), $(eval $(value def_lib))) | 
|---|
| [72] | 1754 |  | 
|---|
| [988] | 1755 | ifdef KBUILD_PROFILE_SELF | 
|---|
|  | 1756 | _KBUILD_TS_NOW := $(nanots ) | 
|---|
|  | 1757 | $(info prof: $(int-sub $(_KBUILD_TS_NOW), $(_KBUILD_TS_HEADER_START)) - $(int-sub $(_KBUILD_TS_NOW), $(_KBUILD_TS_PREV)) - done library targets) | 
|---|
|  | 1758 | _KBUILD_TS_PREV := $(_KBUILD_TS_NOW) | 
|---|
|  | 1759 | endif | 
|---|
| [72] | 1760 |  | 
|---|
| [988] | 1761 |  | 
|---|
| [72] | 1762 | # | 
|---|
| [353] | 1763 | # Link operations. | 
|---|
| [72] | 1764 | # | 
|---|
|  | 1765 |  | 
|---|
| [353] | 1766 | ## | 
|---|
|  | 1767 | # Link prolog | 
|---|
|  | 1768 | # | 
|---|
|  | 1769 | # @param    $(target)   Normalized target name. | 
|---|
|  | 1770 | # @param    $(EXT)      EXE,DLL,SYS. | 
|---|
|  | 1771 | # @param    $(definst)  The default _INST value. | 
|---|
|  | 1772 | # @param    $(typevar)  The name of the variable with all the root targets of its type. | 
|---|
| [380] | 1773 | define def_link_common | 
|---|
| [353] | 1774 | # basics | 
|---|
|  | 1775 | bld_type    := $(firstword $($(target)_BLD_TYPE)     $(BUILD_TYPE)) | 
|---|
|  | 1776 | bld_trg     := $(firstword $($(target)_BLD_TRG)      $(BUILD_$(bld_trg_base_var))) | 
|---|
|  | 1777 | bld_trg_arch:= $(firstword $($(target)_BLD_TRG_ARCH) $(BUILD_$(bld_trg_base_var)_ARCH)) | 
|---|
|  | 1778 | bld_trg_cpu := $(firstword $($(target)_BLD_TRG_CPU)  $(BUILD_$(bld_trg_base_var)_CPU)) | 
|---|
| [145] | 1779 |  | 
|---|
| [353] | 1780 | tool        := $(call _TARGET_TOOL,$(target),LD) | 
|---|
| [889] | 1781 | name        := $(firstword\ | 
|---|
|  | 1782 | $($(target)_NAME.$(bld_trg).$(bld_trg_arch))\ | 
|---|
|  | 1783 | $($(target)_NAME.$(bld_trg_arch))\ | 
|---|
|  | 1784 | $($(target)_NAME.$(bld_trg))\ | 
|---|
|  | 1785 | $($(target)_NAME.$(bld_type))\ | 
|---|
|  | 1786 | $($(target)_NAME)\ | 
|---|
|  | 1787 | $(target)) | 
|---|
|  | 1788 | outbase     := $(call TARGET_BASE,$(name),$(target)) | 
|---|
| [743] | 1789 | ifndef PATH_$(target) | 
|---|
|  | 1790 | PATH_$(target) := $(patsubst %/,%,$(dir $(outbase))) | 
|---|
|  | 1791 | else | 
|---|
|  | 1792 | ifneq ($(PATH_$(target)),$(patsubst %/,%,$(dir $(outbase)))) | 
|---|
|  | 1793 | $(error kBuild internal error: PATH_$(target)=$(PATH_$(target)) expected $(patsubst %/,%,$(dir $(outbase)))) | 
|---|
|  | 1794 | endif | 
|---|
|  | 1795 | endif | 
|---|
| [353] | 1796 | suff        := $(firstword \ | 
|---|
|  | 1797 | $($(target)_$(EXT)SUFF) \ | 
|---|
|  | 1798 | $($(target)_$(EXT)SUFF) \ | 
|---|
|  | 1799 | $(TOOL_$(tool)_LD$(EXT)SUFF) \ | 
|---|
|  | 1800 | $($(EXTPRE)SUFF_$(EXT))) | 
|---|
|  | 1801 | out         := $(outbase)$(suff) | 
|---|
|  | 1802 | TARGET_$(target) := $(out) | 
|---|
| [719] | 1803 | $(target)_OBJS_  := | 
|---|
| [725] | 1804 | defpath := $($(target)_PATH) | 
|---|
| [353] | 1805 |  | 
|---|
| [145] | 1806 | # source -> object | 
|---|
| [353] | 1807 | $(eval $(value def_target_sources)) | 
|---|
| [145] | 1808 |  | 
|---|
| [744] | 1809 | # more link stuff. | 
|---|
| [353] | 1810 | tool        := $(call _TARGET_TOOL,$(target),LD) | 
|---|
| [889] | 1811 | name        := $(firstword\ | 
|---|
|  | 1812 | $($(target)_NAME.$(bld_trg).$(bld_trg_arch))\ | 
|---|
|  | 1813 | $($(target)_NAME.$(bld_trg_arch))\ | 
|---|
|  | 1814 | $($(target)_NAME.$(bld_trg))\ | 
|---|
|  | 1815 | $($(target)_NAME.$(bld_type))\ | 
|---|
|  | 1816 | $($(target)_NAME)\ | 
|---|
|  | 1817 | $(target)) | 
|---|
|  | 1818 | outbase     := $(call TARGET_BASE,$(name),$(target)) | 
|---|
| [353] | 1819 | flags       :=\ | 
|---|
| [74] | 1820 | $(TOOL_$(tool)_LDFLAGS)\ | 
|---|
| [221] | 1821 | $(TOOL_$(tool)_LDFLAGS.$(bld_type))\ | 
|---|
|  | 1822 | $(TOOL_$(tool)_LDFLAGS.$(bld_trg))\ | 
|---|
|  | 1823 | $(TOOL_$(tool)_LDFLAGS.$(bld_trg_arch))\ | 
|---|
| [481] | 1824 | $(TOOL_$(tool)_LDFLAGS.$(bld_trg).$(bld_trg_arch))\ | 
|---|
| [221] | 1825 | $(TOOL_$(tool)_LDFLAGS.$(bld_trg_cpu))\ | 
|---|
| [74] | 1826 | $(LDFLAGS)\ | 
|---|
| [221] | 1827 | $(LDFLAGS.$(bld_type))\ | 
|---|
|  | 1828 | $(LDFLAGS.$(bld_trg))\ | 
|---|
|  | 1829 | $(LDFLAGS.$(bld_trg_arch))\ | 
|---|
| [481] | 1830 | $(LDFLAGS.$(bld_trg).$(bld_trg_arch))\ | 
|---|
| [221] | 1831 | $(LDFLAGS.$(bld_trg_cpu))\ | 
|---|
| [74] | 1832 | $($(target)_LDFLAGS)\ | 
|---|
| [221] | 1833 | $($(target)_LDFLAGS.$(bld_type))\ | 
|---|
|  | 1834 | $($(target)_LDFLAGS.$(bld_trg))\ | 
|---|
|  | 1835 | $($(target)_LDFLAGS.$(bld_trg_arch))\ | 
|---|
| [481] | 1836 | $($(target)_LDFLAGS.$(bld_trg).$(bld_trg_arch))\ | 
|---|
| [353] | 1837 | $($(target)_LDFLAGS.$(bld_trg_cpu)) | 
|---|
| [1148] | 1838 | othersrc    := $(filter-out %.c %.cpp %.cxx %.cc %.s %.S %.asm %.rc %.o %.obj %.res,\ | 
|---|
| [353] | 1839 | $($(target)_SOURCES)\ | 
|---|
|  | 1840 | $($(target)_SOURCES.$(bld_trg)) \ | 
|---|
|  | 1841 | $($(target)_SOURCES.$(bld_trg_arch)) \ | 
|---|
| [481] | 1842 | $($(target)_SOURCES.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
| [353] | 1843 | $($(target)_SOURCES.$(bld_trg_cpu)) \ | 
|---|
|  | 1844 | $($(target)_SOURCES.$(bld_type))) | 
|---|
| [1148] | 1845 | objs         = $(filter %.o %.obj %.res, \ | 
|---|
| [643] | 1846 | $($(target)_SOURCES) \ | 
|---|
|  | 1847 | $($(target)_SOURCES.$(bld_trg)) \ | 
|---|
|  | 1848 | $($(target)_SOURCES.$(bld_trg_arch)) \ | 
|---|
|  | 1849 | $($(target)_SOURCES.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
|  | 1850 | $($(target)_SOURCES.$(bld_trg_cpu)) \ | 
|---|
|  | 1851 | $($(target)_SOURCES.$(bld_type))) \ | 
|---|
|  | 1852 | $($(target)_OBJS_) | 
|---|
| [353] | 1853 | libs        :=\ | 
|---|
| [221] | 1854 | $($(target)_LIBS.$(bld_trg_cpu))\ | 
|---|
| [481] | 1855 | $($(target)_LIBS.$(bld_trg).$(bld_trg_arch))\ | 
|---|
| [221] | 1856 | $($(target)_LIBS.$(bld_trg_arch))\ | 
|---|
|  | 1857 | $($(target)_LIBS.$(bld_trg))\ | 
|---|
|  | 1858 | $($(target)_LIBS.$(bld_type))\ | 
|---|
| [74] | 1859 | $($(target)_LIBS)\ | 
|---|
| [592] | 1860 | $(foreach sdk, $($(target)_SDKS.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
|  | 1861 | $($(target)_SDKS.$(bld_trg_arch)) \ | 
|---|
|  | 1862 | $($(target)_SDKS.$(bld_trg)) \ | 
|---|
|  | 1863 | $($(target)_SDKS.$(bld_type)) \ | 
|---|
|  | 1864 | $($(target)_SDKS),\ | 
|---|
| [353] | 1865 | $(SDK_$(sdk)_LIBS.$(bld_trg_cpu))\ | 
|---|
| [481] | 1866 | $(SDK_$(sdk)_LIBS.$(bld_trg).$(bld_trg_arch))\ | 
|---|
| [353] | 1867 | $(SDK_$(sdk)_LIBS.$(bld_trg_arch))\ | 
|---|
|  | 1868 | $(SDK_$(sdk)_LIBS.$(bld_trg))\ | 
|---|
|  | 1869 | $(SDK_$(sdk)_LIBS.$(bld_type))\ | 
|---|
|  | 1870 | $(SDK_$(sdk)_LIBS))\ | 
|---|
| [221] | 1871 | $(LIBS.$(bld_trg_cpu))\ | 
|---|
| [481] | 1872 | $(LIBS.$(bld_trg).$(bld_trg_arch))\ | 
|---|
| [221] | 1873 | $(LIBS.$(bld_trg_arch))\ | 
|---|
|  | 1874 | $(LIBS.$(bld_trg))\ | 
|---|
|  | 1875 | $(LIBS.$(bld_type))\ | 
|---|
| [74] | 1876 | $(LIBS)\ | 
|---|
| [592] | 1877 | $(foreach sdk, $(SDKS.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
|  | 1878 | $(SDKS.$(bld_trg_arch)) \ | 
|---|
|  | 1879 | $(SDKS.$(bld_trg)) \ | 
|---|
|  | 1880 | $(SDKS.$(bld_type)) \ | 
|---|
|  | 1881 | $(SDKS),\ | 
|---|
| [353] | 1882 | $(SDK_$(sdk)_LIBS.$(bld_trg_cpu))\ | 
|---|
| [481] | 1883 | $(SDK_$(sdk)_LIBS.$(bld_trg).$(bld_trg_arch))\ | 
|---|
| [353] | 1884 | $(SDK_$(sdk)_LIBS.$(bld_trg_arch))\ | 
|---|
|  | 1885 | $(SDK_$(sdk)_LIBS.$(bld_trg))\ | 
|---|
|  | 1886 | $(SDK_$(sdk)_LIBS.$(bld_type))\ | 
|---|
|  | 1887 | $(SDK_$(sdk)_LIBS))\ | 
|---|
| [221] | 1888 | $(TOOL_$(tool)_LIBS.$(bld_trg_cpu))\ | 
|---|
| [481] | 1889 | $(TOOL_$(tool)_LIBS.$(bld_trg).$(bld_trg_arch))\ | 
|---|
| [221] | 1890 | $(TOOL_$(tool)_LIBS.$(bld_trg_arch))\ | 
|---|
|  | 1891 | $(TOOL_$(tool)_LIBS.$(bld_trg))\ | 
|---|
|  | 1892 | $(TOOL_$(tool)_LIBS.$(bld_type))\ | 
|---|
| [353] | 1893 | $(TOOL_$(tool)_LIBS) | 
|---|
|  | 1894 | libpath    :=\ | 
|---|
| [221] | 1895 | $($(target)_LIBPATH.$(bld_trg_cpu))\ | 
|---|
| [481] | 1896 | $($(target)_LIBPATH.$(bld_trg).$(bld_trg_arch))\ | 
|---|
| [221] | 1897 | $($(target)_LIBPATH.$(bld_trg_arch))\ | 
|---|
|  | 1898 | $($(target)_LIBPATH.$(bld_trg))\ | 
|---|
|  | 1899 | $($(target)_LIBPATH.$(bld_type))\ | 
|---|
| [74] | 1900 | $($(target)_LIBPATH)\ | 
|---|
| [592] | 1901 | $(foreach sdk, $($(target)_SDKS.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
|  | 1902 | $($(target)_SDKS.$(bld_trg_arch)) \ | 
|---|
|  | 1903 | $($(target)_SDKS.$(bld_trg)) \ | 
|---|
|  | 1904 | $($(target)_SDKS.$(bld_type)) \ | 
|---|
|  | 1905 | $($(target)_SDKS),\ | 
|---|
| [353] | 1906 | $(SDK_$(sdk)_LIBPATH.$(bld_trg_cpu))\ | 
|---|
| [481] | 1907 | $(SDK_$(sdk)_LIBPATH.$(bld_trg).$(bld_trg_arch))\ | 
|---|
| [353] | 1908 | $(SDK_$(sdk)_LIBPATH.$(bld_trg_arch))\ | 
|---|
|  | 1909 | $(SDK_$(sdk)_LIBPATH.$(bld_trg))\ | 
|---|
|  | 1910 | $(SDK_$(sdk)_LIBPATH.$(bld_type))\ | 
|---|
|  | 1911 | $(SDK_$(sdk)_LIBPATH))\ | 
|---|
| [221] | 1912 | $(LIBPATH.$(bld_trg_cpu))\ | 
|---|
| [481] | 1913 | $(LIBPATH.$(bld_trg).$(bld_trg_arch))\ | 
|---|
| [221] | 1914 | $(LIBPATH.$(bld_trg_arch))\ | 
|---|
|  | 1915 | $(LIBPATH.$(bld_trg))\ | 
|---|
|  | 1916 | $(LIBPATH.$(bld_type))\ | 
|---|
| [74] | 1917 | $(LIBPATH)\ | 
|---|
| [592] | 1918 | $(foreach sdk, $(SDKS.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
|  | 1919 | $(SDKS.$(bld_trg_arch)) \ | 
|---|
|  | 1920 | $(SDKS.$(bld_trg)) \ | 
|---|
|  | 1921 | $(SDKS.$(bld_type)) \ | 
|---|
|  | 1922 | $(SDKS),\ | 
|---|
| [353] | 1923 | $(SDK_$(sdk)_LIBPATH.$(bld_trg_cpu))\ | 
|---|
| [481] | 1924 | $(SDK_$(sdk)_LIBPATH.$(bld_trg).$(bld_trg_arch))\ | 
|---|
| [353] | 1925 | $(SDK_$(sdk)_LIBPATH.$(bld_trg_arch))\ | 
|---|
|  | 1926 | $(SDK_$(sdk)_LIBPATH.$(bld_trg))\ | 
|---|
|  | 1927 | $(SDK_$(sdk)_LIBPATH.$(bld_type))\ | 
|---|
|  | 1928 | $(SDK_$(sdk)_LIBPATH))\ | 
|---|
| [221] | 1929 | $(TOOL_$(tool)_LIBPATH.$(bld_trg_cpu))\ | 
|---|
| [481] | 1930 | $(TOOL_$(tool)_LIBPATH.$(bld_trg).$(bld_trg_arch))\ | 
|---|
| [221] | 1931 | $(TOOL_$(tool)_LIBPATH.$(bld_trg_arch))\ | 
|---|
|  | 1932 | $(TOOL_$(tool)_LIBPATH.$(bld_trg))\ | 
|---|
|  | 1933 | $(TOOL_$(tool)_LIBPATH.$(bld_type))\ | 
|---|
| [353] | 1934 | $(TOOL_$(tool)_LIBPATH) | 
|---|
|  | 1935 | dirdep      := $(call DIRDEP,$(dir $(out))) | 
|---|
|  | 1936 | deps        := $($(target)_DEPS) | 
|---|
| [827] | 1937 | orderdeps   := $($(target)_ORDERDEPS) | 
|---|
| [353] | 1938 |  | 
|---|
| [725] | 1939 | # Adjust paths if we got a default path. | 
|---|
|  | 1940 | ifneq ($(defpath),) | 
|---|
| [979] | 1941 | libpath := $(abspathex $(libpath),$(defpath)) | 
|---|
|  | 1942 | objs := $(abspathex $(objs),$(defpath)) | 
|---|
|  | 1943 | deps := $(abspathex $(deps),$(defpath)) | 
|---|
|  | 1944 | orderdeps := $(abspathex $(orderdeps),$(defpath)) | 
|---|
|  | 1945 | othersrc := $(abspathex $(othersrc),$(defpath)) | 
|---|
| [725] | 1946 | # libs are not subject to this because of the the -l<lib> stuff. Use $(<target>_PATH)/lib if relative to current dir! | 
|---|
|  | 1947 | endif | 
|---|
|  | 1948 |  | 
|---|
| [859] | 1949 | # Custom pre-link actions. | 
|---|
|  | 1950 | ifdef $(target)_PRE_CMDS.$(bld_trg).$(bld_trg_arch).$(bld_type) | 
|---|
|  | 1951 | pre_cmds := $($(target)_PRE_CMDS.$(bld_trg).$(bld_trg_arch).$(bld_type)) | 
|---|
|  | 1952 | else ifdef $(target)_PRE_CMDS.$(bld_trg).$(bld_trg_arch) | 
|---|
|  | 1953 | pre_cmds := $($(target)_PRE_CMDS.$(bld_trg).$(bld_trg_arch)) | 
|---|
|  | 1954 | else ifdef $(target)_PRE_CMDS.$(bld_trg).$(bld_type) | 
|---|
|  | 1955 | pre_cmds := $($(target)_PRE_CMDS.$(bld_trg).$(bld_type)) | 
|---|
|  | 1956 | else ifdef $(target)_PRE_CMDS.$(bld_trg_arch) | 
|---|
|  | 1957 | pre_cmds := $($(target)_PRE_CMDS.$(bld_trg_arch)) | 
|---|
|  | 1958 | else ifdef $(target)_PRE_CMDS.$(bld_trg) | 
|---|
|  | 1959 | pre_cmds := $($(target)_PRE_CMDS.$(bld_trg)) | 
|---|
|  | 1960 | else ifdef $(target)_PRE_CMDS.$(bld_type) | 
|---|
|  | 1961 | pre_cmds := $($(target)_PRE_CMDS.$(bld_type)) | 
|---|
|  | 1962 | else ifdef $(target)_PRE_CMDS | 
|---|
|  | 1963 | pre_cmds := $($(target)_PRE_CMDS) | 
|---|
|  | 1964 | else ifdef PRE_CMDS.$(bld_trg).$(bld_trg_arch).$(bld_type) | 
|---|
|  | 1965 | pre_cmds := $(PRE_CMDS.$(bld_trg).$(bld_trg_arch).$(bld_type)) | 
|---|
|  | 1966 | else ifdef PRE_CMDS.$(bld_trg).$(bld_trg_arch) | 
|---|
|  | 1967 | pre_cmds := $(PRE_CMDS.$(bld_trg).$(bld_trg_arch)) | 
|---|
|  | 1968 | else ifdef PRE_CMDS.$(bld_trg).$(bld_type) | 
|---|
|  | 1969 | pre_cmds := $(PRE_CMDS.$(bld_trg).$(bld_type)) | 
|---|
|  | 1970 | else ifdef PRE_CMDS.$(bld_trg_arch) | 
|---|
|  | 1971 | pre_cmds := $(PRE_CMDS.$(bld_trg_arch)) | 
|---|
|  | 1972 | else ifdef PRE_CMDS.$(bld_trg) | 
|---|
|  | 1973 | pre_cmds := $(PRE_CMDS.$(bld_trg)) | 
|---|
|  | 1974 | else ifdef PRE_CMDS.$(bld_type) | 
|---|
|  | 1975 | pre_cmds := $(PRE_CMDS.$(bld_type)) | 
|---|
|  | 1976 | else | 
|---|
|  | 1977 | pre_cmds := $(PRE_CMDS) | 
|---|
|  | 1978 | endif | 
|---|
| [72] | 1979 |  | 
|---|
| [859] | 1980 | # Custom post-link actions. | 
|---|
|  | 1981 | ifdef $(target)_POST_CMDS.$(bld_trg).$(bld_trg_arch).$(bld_type) | 
|---|
|  | 1982 | post_cmds := $($(target)_POST_CMDS.$(bld_trg).$(bld_trg_arch).$(bld_type)) | 
|---|
|  | 1983 | else ifdef $(target)_POST_CMDS.$(bld_trg).$(bld_trg_arch) | 
|---|
|  | 1984 | post_cmds := $($(target)_POST_CMDS.$(bld_trg).$(bld_trg_arch)) | 
|---|
|  | 1985 | else ifdef $(target)_POST_CMDS.$(bld_trg).$(bld_type) | 
|---|
|  | 1986 | post_cmds := $($(target)_POST_CMDS.$(bld_trg).$(bld_type)) | 
|---|
|  | 1987 | else ifdef $(target)_POST_CMDS.$(bld_trg_arch) | 
|---|
|  | 1988 | post_cmds := $($(target)_POST_CMDS.$(bld_trg_arch)) | 
|---|
|  | 1989 | else ifdef $(target)_POST_CMDS.$(bld_trg) | 
|---|
|  | 1990 | post_cmds := $($(target)_POST_CMDS.$(bld_trg)) | 
|---|
|  | 1991 | else ifdef $(target)_POST_CMDS.$(bld_type) | 
|---|
|  | 1992 | post_cmds := $($(target)_POST_CMDS.$(bld_type)) | 
|---|
|  | 1993 | else ifdef $(target)_POST_CMDS | 
|---|
|  | 1994 | post_cmds := $($(target)_POST_CMDS) | 
|---|
|  | 1995 | else ifdef POST_CMDS.$(bld_trg).$(bld_trg_arch).$(bld_type) | 
|---|
|  | 1996 | post_cmds := $(POST_CMDS.$(bld_trg).$(bld_trg_arch).$(bld_type)) | 
|---|
|  | 1997 | else ifdef POST_CMDS.$(bld_trg).$(bld_trg_arch) | 
|---|
|  | 1998 | post_cmds := $(POST_CMDS.$(bld_trg).$(bld_trg_arch)) | 
|---|
|  | 1999 | else ifdef POST_CMDS.$(bld_trg).$(bld_type) | 
|---|
|  | 2000 | post_cmds := $(POST_CMDS.$(bld_trg).$(bld_type)) | 
|---|
|  | 2001 | else ifdef POST_CMDS.$(bld_trg_arch) | 
|---|
|  | 2002 | post_cmds := $(POST_CMDS.$(bld_trg_arch)) | 
|---|
|  | 2003 | else ifdef POST_CMDS.$(bld_trg) | 
|---|
|  | 2004 | post_cmds := $(POST_CMDS.$(bld_trg)) | 
|---|
|  | 2005 | else ifdef POST_CMDS.$(bld_type) | 
|---|
|  | 2006 | post_cmds := $(POST_CMDS.$(bld_type)) | 
|---|
|  | 2007 | else | 
|---|
|  | 2008 | post_cmds := $(POST_CMDS) | 
|---|
|  | 2009 | endif | 
|---|
|  | 2010 |  | 
|---|
| [353] | 2011 | # installation targets | 
|---|
|  | 2012 | ifndef $(target)_NOINST | 
|---|
|  | 2013 | INSTARGET_$(target) := $(patsubst %/,%/$(notdir $(out)), \ | 
|---|
|  | 2014 | $(if $($(target)_INST), $(addprefix $(PATH_INS)/,$($(target)_INST)), $(definst)/)) | 
|---|
|  | 2015 | ifdef KBUILD_DO_AUTO_INSTALL | 
|---|
|  | 2016 | $(typevar)  += $(INSTARGET_$(target)) | 
|---|
|  | 2017 | else | 
|---|
|  | 2018 | $(typevar)  += $(out) | 
|---|
|  | 2019 | endif | 
|---|
|  | 2020 | # generate the install rule | 
|---|
|  | 2021 | $(eval $(def_link_install_rule)) | 
|---|
|  | 2022 |  | 
|---|
|  | 2023 | else # NOINST | 
|---|
|  | 2024 | INSTARGET_$(target) := | 
|---|
|  | 2025 | $(typevar)  += $(out) | 
|---|
|  | 2026 | endif # NOINST | 
|---|
|  | 2027 |  | 
|---|
| [380] | 2028 | # dependency file | 
|---|
|  | 2029 | dep := $(outbase)$(SUFF_DEP) | 
|---|
| [524] | 2030 | ifndef NO_LINK_CMDS_DEPS | 
|---|
| [893] | 2031 | _DEPFILES_INCLUDED += $(dep) | 
|---|
|  | 2032 | $(eval includedep $(dep)) | 
|---|
| [380] | 2033 | endif | 
|---|
| [353] | 2034 |  | 
|---|
| [380] | 2035 | # check that the tool is defined. | 
|---|
|  | 2036 | ifndef TOOL_$(tool)_$(tool_do)_CMDS | 
|---|
|  | 2037 | $(warning kBuild: tools: \ | 
|---|
| [481] | 2038 | 1 $($(target)_$(source)TOOL.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
|  | 2039 | 2 $($(target)_$(source)TOOL.$(bld_trg)) \ | 
|---|
|  | 2040 | 3 $($(target)_$(source)TOOL) \ | 
|---|
|  | 2041 | 4 $($(target)_TOOL.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
|  | 2042 | 5 $($(target)_TOOL.$(bld_trg)) \ | 
|---|
|  | 2043 | 6 $($(target)_TOOL) \ | 
|---|
|  | 2044 | 7 $($(source)TOOL.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
|  | 2045 | 8 $($(source)TOOL.$(bld_trg)) \ | 
|---|
|  | 2046 | 9 $($(source)TOOL) \ | 
|---|
|  | 2047 | 10 $(TOOL.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
|  | 2048 | 11 $(TOOL.$(bld_trg)) \ | 
|---|
|  | 2049 | 12 $(TOOL) ) | 
|---|
| [380] | 2050 | $(error kBuild: TOOL_$(tool)_$(tool_do)_CMDS isn't defined! target=$(target) ) | 
|---|
|  | 2051 | endif | 
|---|
| [353] | 2052 |  | 
|---|
| [380] | 2053 | # call the tool | 
|---|
|  | 2054 | $(target)_CMDS_   := $(TOOL_$(tool)_$(tool_do)_CMDS) | 
|---|
| [859] | 2055 | ifneq ($(pre_cmds),) | 
|---|
|  | 2056 | $(target)_CMDS_  := $(TAB)$(pre_cmds)$(NL)$(TAB)$($(target)_CMDS_) | 
|---|
|  | 2057 | endif | 
|---|
|  | 2058 | ifneq ($(post_cmds),) | 
|---|
|  | 2059 | $(target)_CMDS_  := $($(target)_CMDS_)$(NL)$(TAB)$(post_cmds) | 
|---|
|  | 2060 | endif | 
|---|
| [380] | 2061 | $(target)_OUTPUT_ := $(TOOL_$(tool)_$(tool_do)_OUTPUT) | 
|---|
| [1030] | 2062 | $(target)_OUTPUT_MAYBE_ := $(TOOL_$(tool)_$(tool_do)_OUTPUT_MAYBE) | 
|---|
| [380] | 2063 | $(target)_DEPEND_ := $(TOOL_$(tool)_$(tool_do)_DEPEND) $(deps) $(objs) | 
|---|
| [827] | 2064 | $(target)_DEPORD_ := $(TOOL_$(tool)_$(tool_do)_DEPORD) $(dirdep) $(orderdeps) | 
|---|
| [353] | 2065 |  | 
|---|
| [412] | 2066 | # generate the link rule. | 
|---|
| [380] | 2067 | $(eval $(def_link_rule)) | 
|---|
|  | 2068 |  | 
|---|
| [412] | 2069 |  | 
|---|
| [380] | 2070 | # Update globals. | 
|---|
| [579] | 2071 | _OBJS += $($(target)_OBJS_) | 
|---|
|  | 2072 | _OUT_FILES += $($(target)_OUTPUT_) $(out) | 
|---|
| [905] | 2073 | _CLEAN_FILES += $($(target)_CLEAN) $($(target)_CLEAN.$(bld_trg)) $($(target)_CLEAN.$(bld_trg).$(bld_trg_arch)) $($(target)_CLEAN.$(bld_trg_arch)) $($(target)_CLEAN.$(bld_trg_cpu)) $($(target)_CLEAN.$(bld_type)) | 
|---|
|  | 2074 | _DIRS += $($(target)_BLDDIRS) $($(target)_BLDDIRS.$(bld_trg)) $($(target)_BLDDIRS.$(bld_trg).$(bld_trg_arch)) $($(target)_BLDDIRS.$(bld_trg_arch)) $($(target)_BLDDIRS.$(bld_trg_cpu)) $($(target)_BLDDIRS.$(bld_type)) | 
|---|
| [827] | 2075 | _INSTALLS_FILES += $(INSTARGET_$(target)) | 
|---|
| [353] | 2076 |  | 
|---|
|  | 2077 | endef | 
|---|
|  | 2078 |  | 
|---|
|  | 2079 |  | 
|---|
|  | 2080 | # | 
|---|
|  | 2081 | # BLDPROGS | 
|---|
|  | 2082 | # | 
|---|
|  | 2083 |  | 
|---|
|  | 2084 | ## Build program (one). | 
|---|
|  | 2085 | # @param    $(target)   Normalized target (program) name. | 
|---|
|  | 2086 | define def_bldprog | 
|---|
|  | 2087 |  | 
|---|
|  | 2088 | # set NOINST if not forced installation. | 
|---|
|  | 2089 | ifndef $(target)_INST | 
|---|
|  | 2090 | $(target)_NOINST := 1 | 
|---|
|  | 2091 | endif | 
|---|
|  | 2092 |  | 
|---|
| [380] | 2093 | # do the usual stuff. | 
|---|
|  | 2094 | $(eval $(value def_link_common)) | 
|---|
| [353] | 2095 |  | 
|---|
|  | 2096 | endef | 
|---|
|  | 2097 |  | 
|---|
|  | 2098 | # Process build programs. | 
|---|
|  | 2099 | EXT     := EXE | 
|---|
|  | 2100 | EXTPRE  := HOST | 
|---|
| [380] | 2101 | tool_do := LINK_PROGRAM | 
|---|
| [353] | 2102 | definst := $(PATH_BIN) | 
|---|
|  | 2103 | typevar := _BLDPROGS | 
|---|
| [380] | 2104 | mode    := 0755 | 
|---|
| [353] | 2105 | bld_trg_base_var := PLATFORM | 
|---|
| [481] | 2106 | $(foreach target, $(BLDPROGS) $(BLDPROGS.$(BUILD_PLATFORM)) $(BLDPROGS.$(BUILD_PLATFORM).$(BUILD_PLATFORM_ARCH)), $(eval $(value def_bldprog))) | 
|---|
| [353] | 2107 |  | 
|---|
| [988] | 2108 | ifdef KBUILD_PROFILE_SELF | 
|---|
|  | 2109 | _KBUILD_TS_NOW := $(nanots ) | 
|---|
|  | 2110 | $(info prof: $(int-sub $(_KBUILD_TS_NOW), $(_KBUILD_TS_HEADER_START)) - $(int-sub $(_KBUILD_TS_NOW), $(_KBUILD_TS_PREV)) - done build program targets) | 
|---|
|  | 2111 | _KBUILD_TS_PREV := $(_KBUILD_TS_NOW) | 
|---|
|  | 2112 | endif | 
|---|
| [353] | 2113 |  | 
|---|
|  | 2114 |  | 
|---|
|  | 2115 | # | 
|---|
|  | 2116 | # DLLS | 
|---|
|  | 2117 | # | 
|---|
|  | 2118 |  | 
|---|
| [189] | 2119 | # Process dlls | 
|---|
| [353] | 2120 | EXT     := DLL | 
|---|
|  | 2121 | EXTPRE  := | 
|---|
| [380] | 2122 | tool_do := LINK_DLL | 
|---|
| [353] | 2123 | definst := $(PATH_DLL) | 
|---|
|  | 2124 | typevar := _DLLS | 
|---|
| [830] | 2125 | mode    := 0644 | 
|---|
| [353] | 2126 | bld_trg_base_var := TARGET | 
|---|
| [481] | 2127 | $(foreach target, $(DLLS) $(DLLS.$(BUILD_TARGET)) $(DLLS.$(BUILD_TARGET).$(BUILD_TARGET_ARCH)), $(eval $(value def_link_common))) | 
|---|
| [74] | 2128 |  | 
|---|
| [988] | 2129 | ifdef KBUILD_PROFILE_SELF | 
|---|
|  | 2130 | _KBUILD_TS_NOW := $(nanots ) | 
|---|
|  | 2131 | $(info prof: $(int-sub $(_KBUILD_TS_NOW), $(_KBUILD_TS_HEADER_START)) - $(int-sub $(_KBUILD_TS_NOW), $(_KBUILD_TS_PREV)) - done dll targets) | 
|---|
|  | 2132 | _KBUILD_TS_PREV := $(_KBUILD_TS_NOW) | 
|---|
|  | 2133 | endif | 
|---|
| [74] | 2134 |  | 
|---|
| [988] | 2135 |  | 
|---|
| [72] | 2136 | # | 
|---|
| [830] | 2137 | # IMPORT LIBRARIES | 
|---|
| [72] | 2138 | # | 
|---|
| [219] | 2139 | #   - On OS/2 and windows these are libraries. | 
|---|
| [189] | 2140 | #   - On other platforms they are fake DLLs. | 
|---|
| [830] | 2141 | # | 
|---|
|  | 2142 | EXTPRE  := | 
|---|
|  | 2143 | typevar := _IMPORT_LIBS | 
|---|
|  | 2144 | mode    := 0644 | 
|---|
|  | 2145 | bld_trg_base_var := TARGET | 
|---|
| [481] | 2146 | ifeq ($(filter-out nt os2 win win64 win32,$(BUILD_TARGET)),) | 
|---|
| [830] | 2147 | EXT     := LIB | 
|---|
|  | 2148 | tool_do := LINK_LIBRARY | 
|---|
|  | 2149 | definst := $(PATH_LIB) | 
|---|
|  | 2150 | $(foreach target, $(IMPORT_LIBS) $(IMPORT_LIBS.$(BUILD_TARGET)) $(IMPORT_LIBS.$(BUILD_TARGET).$(BUILD_TARGET_ARCH)), $(eval $(value def_lib))) | 
|---|
| [189] | 2151 | else | 
|---|
| [830] | 2152 | EXT     := DLL | 
|---|
|  | 2153 | tool_do := LINK_DLL | 
|---|
|  | 2154 | definst := $(PATH_DLL) | 
|---|
|  | 2155 | $(foreach target, $(IMPORT_LIBS) $(IMPORT_LIBS.$(BUILD_TARGET)) $(IMPORT_LIBS.$(BUILD_TARGET).$(BUILD_TARGET_ARCH)), $(eval $(value def_link_common))) | 
|---|
| [189] | 2156 | endif | 
|---|
| [72] | 2157 |  | 
|---|
| [988] | 2158 | ifdef KBUILD_PROFILE_SELF | 
|---|
|  | 2159 | _KBUILD_TS_NOW := $(nanots ) | 
|---|
|  | 2160 | $(info prof: $(int-sub $(_KBUILD_TS_NOW), $(_KBUILD_TS_HEADER_START)) - $(int-sub $(_KBUILD_TS_NOW), $(_KBUILD_TS_PREV)) - done import library targets) | 
|---|
|  | 2161 | _KBUILD_TS_PREV := $(_KBUILD_TS_NOW) | 
|---|
|  | 2162 | endif | 
|---|
| [189] | 2163 |  | 
|---|
| [988] | 2164 |  | 
|---|
| [189] | 2165 | # | 
|---|
|  | 2166 | # PROGRAMS | 
|---|
|  | 2167 | # | 
|---|
|  | 2168 |  | 
|---|
| [353] | 2169 | # Process programs | 
|---|
|  | 2170 | EXT     := EXE | 
|---|
|  | 2171 | EXTPRE  := | 
|---|
| [380] | 2172 | tool_do := LINK_PROGRAM | 
|---|
| [353] | 2173 | definst := $(PATH_BIN) | 
|---|
|  | 2174 | typevar := _PROGRAMS | 
|---|
| [380] | 2175 | mode    := 0755 | 
|---|
| [353] | 2176 | bld_trg_base_var := TARGET | 
|---|
| [481] | 2177 | $(foreach target, $(PROGRAMS) $(PROGRAMS.$(BUILD_TARGET)) $(PROGRAMS.$(BUILD_TARGET).$(BUILD_TARGET_ARCH)), $(eval $(value def_link_common))) | 
|---|
| [130] | 2178 |  | 
|---|
| [988] | 2179 | ifdef KBUILD_PROFILE_SELF | 
|---|
|  | 2180 | _KBUILD_TS_NOW := $(nanots ) | 
|---|
|  | 2181 | $(info prof: $(int-sub $(_KBUILD_TS_NOW), $(_KBUILD_TS_HEADER_START)) - $(int-sub $(_KBUILD_TS_NOW), $(_KBUILD_TS_PREV)) - done program targets) | 
|---|
|  | 2182 | _KBUILD_TS_PREV := $(_KBUILD_TS_NOW) | 
|---|
|  | 2183 | endif | 
|---|
| [130] | 2184 |  | 
|---|
| [189] | 2185 |  | 
|---|
| [72] | 2186 | # | 
|---|
| [83] | 2187 | # SYSMODS | 
|---|
| [72] | 2188 | # | 
|---|
|  | 2189 |  | 
|---|
| [130] | 2190 | # Process sysmods | 
|---|
| [353] | 2191 | EXT     := SYS | 
|---|
|  | 2192 | EXTPRE  := | 
|---|
| [380] | 2193 | tool_do := LINK_SYSMOD | 
|---|
| [353] | 2194 | definst := $(PATH_SYS) | 
|---|
|  | 2195 | typevar := _SYSMODS | 
|---|
| [380] | 2196 | mode    := 0644 | 
|---|
| [353] | 2197 | bld_trg_base_var := TARGET | 
|---|
| [481] | 2198 | $(foreach target, $(SYSMODS) $(SYSMODS.$(BUILD_TARGET)) $(SYSMODS.$(BUILD_TARGET).$(BUILD_TARGET_ARCH)), $(eval $(value def_link_common))) | 
|---|
| [83] | 2199 |  | 
|---|
| [988] | 2200 | ifdef KBUILD_PROFILE_SELF | 
|---|
|  | 2201 | _KBUILD_TS_NOW := $(nanots ) | 
|---|
|  | 2202 | $(info prof: $(int-sub $(_KBUILD_TS_NOW), $(_KBUILD_TS_HEADER_START)) - $(int-sub $(_KBUILD_TS_NOW), $(_KBUILD_TS_PREV)) - done sysmod targets) | 
|---|
|  | 2203 | _KBUILD_TS_PREV := $(_KBUILD_TS_NOW) | 
|---|
|  | 2204 | endif | 
|---|
| [83] | 2205 |  | 
|---|
| [988] | 2206 |  | 
|---|
| [72] | 2207 | # | 
|---|
|  | 2208 | # OTHERS | 
|---|
|  | 2209 | # | 
|---|
| [481] | 2210 | _OTHERS = $(OTHERS) $(OTHERS.$(BUILD_TARGET)) $(OTHERS.$(BUILD_TARGET).$(BUILD_TARGET_ARCH)) | 
|---|
| [72] | 2211 |  | 
|---|
|  | 2212 |  | 
|---|
| [353] | 2213 | # | 
|---|
|  | 2214 | # INSTALLS | 
|---|
|  | 2215 | # | 
|---|
| [72] | 2216 |  | 
|---|
| [353] | 2217 | ## generate the install rule | 
|---|
|  | 2218 | define def_install_src_rule | 
|---|
|  | 2219 | # the install rule | 
|---|
|  | 2220 | $(insdst) : $(srcsrc) | $(call DIRDEP,$(dir $(insdst))) | 
|---|
| [776] | 2221 | $$(call MSG_INST_FILE,$(srcsrc),$(insdst)) | 
|---|
| [696] | 2222 | $$(QUIET)$(inscmd) | 
|---|
| [353] | 2223 | endef | 
|---|
|  | 2224 |  | 
|---|
|  | 2225 | ## install one file | 
|---|
|  | 2226 | define def_install_src | 
|---|
|  | 2227 |  | 
|---|
|  | 2228 | # deal with '=>' in the source file name. | 
|---|
|  | 2229 | srcdst := $(subst =>, ,$(src)) | 
|---|
|  | 2230 | srcsrc := $(firstword $(srcdst)) | 
|---|
| [424] | 2231 | srcdstdir := $(dir $(word 2,$(srcdst))) | 
|---|
| [353] | 2232 | srcdst := $(word $(words $(srcdst)),$(srcdst)) | 
|---|
|  | 2233 |  | 
|---|
|  | 2234 | # _INSTFUN | 
|---|
|  | 2235 | ifdef $(srcsrc)_INSTFUN | 
|---|
| [725] | 2236 | instfun := $(srcsrc)_INSTFUN | 
|---|
| [353] | 2237 | else | 
|---|
| [725] | 2238 | ifdef $(target)_INSTFUN | 
|---|
|  | 2239 | instfun := $(target)_INSTFUN | 
|---|
|  | 2240 | else | 
|---|
|  | 2241 | instfun := _INSTALL_FILE | 
|---|
|  | 2242 | endif | 
|---|
| [353] | 2243 | endif | 
|---|
|  | 2244 |  | 
|---|
|  | 2245 | # _INST | 
|---|
|  | 2246 | ifdef $(srcsrc)_INST | 
|---|
| [725] | 2247 | inst := $(patsubst %/,%,$($(srcsrc)_INST))/$(dir $(srcdstdir)) | 
|---|
| [353] | 2248 | else | 
|---|
| [725] | 2249 | ifdef $(target)_INST | 
|---|
|  | 2250 | inst := $(patsubst %/,%,$($(target)_INST))/$(dir $(srcdstdir)) | 
|---|
|  | 2251 | else | 
|---|
|  | 2252 | inst := $(dir $(srcdstdir)) | 
|---|
|  | 2253 | endif | 
|---|
| [353] | 2254 | endif | 
|---|
|  | 2255 |  | 
|---|
|  | 2256 | # calc target | 
|---|
| [380] | 2257 | insdst := $(call $(instfun),$(srcdst),$(target),$(inst),$(PATH_INS)) | 
|---|
| [424] | 2258 | #$(warning instfun=$(instfun) srcdst=$(srcdst) target=$(target) inst=$(inst) => insdst=$(insdst)) | 
|---|
| [353] | 2259 |  | 
|---|
| [414] | 2260 | # mode, uid and gid | 
|---|
|  | 2261 | mode := $(firstword \ | 
|---|
| [481] | 2262 | $($(target)_$(srcsrc)_MODE.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
| [414] | 2263 | $($(target)_$(srcsrc)_MODE.$(bld_trg)) \ | 
|---|
|  | 2264 | $($(target)_$(srcsrc)_MODE) \ | 
|---|
| [481] | 2265 | $($(target)_$(srcdst)_MODE.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
| [414] | 2266 | $($(target)_$(srcdst)_MODE.$(bld_trg)) \ | 
|---|
|  | 2267 | $($(target)_$(srcdst)_MODE) \ | 
|---|
| [481] | 2268 | $($(srcsrc)_MODE.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
| [414] | 2269 | $($(srcsrc)_MODE.$(bld_trg)) \ | 
|---|
|  | 2270 | $($(srcsrc)_MODE) \ | 
|---|
| [481] | 2271 | $($(srcdst)_MODE.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
| [414] | 2272 | $($(srcdst)_MODE.$(bld_trg)) \ | 
|---|
|  | 2273 | $($(srcdst)_MODE) \ | 
|---|
| [481] | 2274 | $($(target)_MODE.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
| [414] | 2275 | $($(target)_MODE.$(bld_trg)) \ | 
|---|
|  | 2276 | $($(target)_MODE)) | 
|---|
|  | 2277 | uid := $(firstword \ | 
|---|
| [481] | 2278 | $($(target)_$(srcsrc)_UID.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
| [414] | 2279 | $($(target)_$(srcsrc)_UID.$(bld_trg)) \ | 
|---|
|  | 2280 | $($(target)_$(srcsrc)_UID) \ | 
|---|
| [481] | 2281 | $($(target)_$(srcdst)_UID.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
| [414] | 2282 | $($(target)_$(srcdst)_UID.$(bld_trg)) \ | 
|---|
|  | 2283 | $($(target)_$(srcdst)_UID) \ | 
|---|
| [481] | 2284 | $($(srcsrc)_UID.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
| [414] | 2285 | $($(srcsrc)_UID.$(bld_trg)) \ | 
|---|
|  | 2286 | $($(srcsrc)_UID) \ | 
|---|
| [481] | 2287 | $($(srcdst)_UID.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
| [414] | 2288 | $($(srcdst)_UID.$(bld_trg)) \ | 
|---|
|  | 2289 | $($(srcdst)_UID) \ | 
|---|
| [481] | 2290 | $($(target)_UID.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
| [414] | 2291 | $($(target)_UID.$(bld_trg)) \ | 
|---|
|  | 2292 | $($(target)_UID)) | 
|---|
|  | 2293 | gid := $(firstword \ | 
|---|
| [481] | 2294 | $($(target)_$(srcsrc)_GID.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
| [414] | 2295 | $($(target)_$(srcsrc)_GID.$(bld_trg)) \ | 
|---|
|  | 2296 | $($(target)_$(srcsrc)_GID) \ | 
|---|
| [481] | 2297 | $($(target)_$(srcdst)_GID.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
| [414] | 2298 | $($(target)_$(srcdst)_GID.$(bld_trg)) \ | 
|---|
|  | 2299 | $($(target)_$(srcdst)_GID) \ | 
|---|
| [481] | 2300 | $($(srcsrc)_GID.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
| [414] | 2301 | $($(srcsrc)_GID.$(bld_trg)) \ | 
|---|
|  | 2302 | $($(srcsrc)_GID) \ | 
|---|
| [481] | 2303 | $($(srcdst)_GID.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
| [414] | 2304 | $($(srcdst)_GID.$(bld_trg)) \ | 
|---|
|  | 2305 | $($(srcdst)_GID) \ | 
|---|
| [481] | 2306 | $($(target)_GID.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
| [414] | 2307 | $($(target)_GID.$(bld_trg)) \ | 
|---|
|  | 2308 | $($(target)_GID)) | 
|---|
| [830] | 2309 | flags := \ | 
|---|
|  | 2310 | $($(target)_IFFLAGS) \ | 
|---|
|  | 2311 | $($(target)_IFFLAGS.$(bld_trg)) \ | 
|---|
|  | 2312 | $($(target)_IFFLAGS.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
|  | 2313 | $($(srcdst)_IFFLAGS) \ | 
|---|
|  | 2314 | $($(srcdst)_IFFLAGS.$(bld_trg)) \ | 
|---|
|  | 2315 | $($(srcdst)_IFFLAGS.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
|  | 2316 | $($(srcsrc)_IFFLAGS) \ | 
|---|
|  | 2317 | $($(srcsrc)_IFFLAGS.$(bld_trg)) \ | 
|---|
|  | 2318 | $($(srcsrc)_IFFLAGS.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
|  | 2319 | $($(target)_$(srcdst)_IFFLAGS) \ | 
|---|
|  | 2320 | $($(target)_$(srcdst)_IFFLAGS.$(bld_trg)) \ | 
|---|
|  | 2321 | $($(target)_$(srcdst)_IFFLAGS.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
|  | 2322 | $($(target)_$(srcsrc)_IFFLAGS) \ | 
|---|
|  | 2323 | $($(target)_$(srcsrc)_IFFLAGS.$(bld_trg)) \ | 
|---|
|  | 2324 | $($(target)_$(srcsrc)_IFFLAGS.$(bld_trg).$(bld_trg_arch)) | 
|---|
| [414] | 2325 |  | 
|---|
| [725] | 2326 |  | 
|---|
|  | 2327 | # Adjust the source if we got a default PATH. (This must be done this late!) | 
|---|
|  | 2328 | ifdef $(target)_PATH | 
|---|
| [979] | 2329 | srcsrc := $(abspathex $(srcsrc),$($(target)_PATH)) | 
|---|
| [725] | 2330 | endif | 
|---|
|  | 2331 |  | 
|---|
| [353] | 2332 | # create the command | 
|---|
|  | 2333 | ifdef $(srcsrc)_INSTALLER | 
|---|
| [830] | 2334 | inscmd := $(call $(srcsrc)_INSTALLER,$(srcsrc),$(insdst),$(target),$(flags)) | 
|---|
|  | 2335 | else ifdef $(target)_INSTALLER | 
|---|
|  | 2336 | inscmd := $(call $(target)_INSTALLER,$(srcsrc),$(insdst),$(target),$(flags)) | 
|---|
| [353] | 2337 | else | 
|---|
| [830] | 2338 | inscmd := $$(INSTALL)\ | 
|---|
| [414] | 2339 | $(if $(uid),-o $(uid))\ | 
|---|
|  | 2340 | $(if $(gid),-g $(gid))\ | 
|---|
|  | 2341 | $(if $(mode),-m $(mode))\ | 
|---|
| [830] | 2342 | $(flags)\ | 
|---|
| [414] | 2343 | $(srcsrc) $(insdst) | 
|---|
| [353] | 2344 | endif | 
|---|
|  | 2345 |  | 
|---|
|  | 2346 | # generate the rule (need double evaluation here) | 
|---|
|  | 2347 | $(eval $(def_install_src_rule)) | 
|---|
|  | 2348 |  | 
|---|
|  | 2349 | INSTARGET_$(target) += $(insdst) | 
|---|
|  | 2350 | endef | 
|---|
|  | 2351 |  | 
|---|
|  | 2352 |  | 
|---|
|  | 2353 | ## generate the symlink rule | 
|---|
|  | 2354 | define def_install_symlink_rule | 
|---|
|  | 2355 | # the install rule | 
|---|
|  | 2356 | $(insdst) : | $(call DIRDEP,$(dir $(insdst))) | 
|---|
| [776] | 2357 | $$(call MSG_INST_SYM,$(insdst),$(symdst)) | 
|---|
| [696] | 2358 | $$(QUIET)$$(RM) -f $$@ | 
|---|
|  | 2359 | $$(QUIET)$$(LN_SYMLINK) $(symdst) $(insdst) | 
|---|
| [353] | 2360 | endef | 
|---|
|  | 2361 |  | 
|---|
|  | 2362 | ## create one symlink | 
|---|
|  | 2363 | define def_install_symlink | 
|---|
|  | 2364 |  | 
|---|
|  | 2365 | # deal with '=>' in the source file name. | 
|---|
| [380] | 2366 | symdst := $(subst =>, ,$(src)) | 
|---|
|  | 2367 | symlnk := $(firstword $(symdst)) | 
|---|
|  | 2368 | symdst := $(word $(words $(symdst)),$(symdst)) | 
|---|
| [353] | 2369 |  | 
|---|
|  | 2370 | # _INSTFUN | 
|---|
| [380] | 2371 | ifdef $(symlnk)_INSTFUN | 
|---|
| [827] | 2372 | instfun := $(symlnk)_INSTFUN | 
|---|
|  | 2373 | else ifdef $(target)_INSTFUN | 
|---|
| [830] | 2374 | instfun := $(target)_INSTFUN | 
|---|
| [353] | 2375 | else | 
|---|
| [827] | 2376 | instfun := _INSTALL_FILE | 
|---|
| [353] | 2377 | endif | 
|---|
|  | 2378 |  | 
|---|
|  | 2379 | # _INST | 
|---|
| [380] | 2380 | ifdef $(symlnk)_INST | 
|---|
| [725] | 2381 | inst := $(patsubst %/,%,$($(symlnk)_INST))/$(dir $(symlnk)) | 
|---|
| [827] | 2382 | else ifdef $(target)_INST | 
|---|
|  | 2383 | inst := $(patsubst %/,%,$($(target)_INST))/$(dir $(symlnk)) | 
|---|
| [353] | 2384 | else | 
|---|
| [827] | 2385 | inst := $(dir $(symlnk)) | 
|---|
| [353] | 2386 | endif | 
|---|
|  | 2387 |  | 
|---|
|  | 2388 | # calc target | 
|---|
| [380] | 2389 | insdst := $(call $(instfun),$(symlnk),$(target),$(inst),$(PATH_INS)) | 
|---|
|  | 2390 | #$(warning symlnk=$(symlnk) symdst=$(symdst) insdst=$(insdst) instfun=$(instfun) inst='$(inst)') | 
|---|
| [353] | 2391 |  | 
|---|
|  | 2392 | # generate the rule (need double evaluation here) | 
|---|
|  | 2393 | $(eval $(def_install_symlink_rule)) | 
|---|
|  | 2394 |  | 
|---|
|  | 2395 | INSTARGET_$(target) += $(insdst) | 
|---|
|  | 2396 | endef | 
|---|
|  | 2397 |  | 
|---|
| [412] | 2398 |  | 
|---|
| [380] | 2399 | ## generate the install rule | 
|---|
|  | 2400 | define def_install_directory_rule | 
|---|
|  | 2401 | # the install rule | 
|---|
|  | 2402 | $(insdst): | 
|---|
| [776] | 2403 | $$(call MSG_INST_DIR,$(insdst)) | 
|---|
| [696] | 2404 | $$(QUIET)$$(INSTALL) -d \ | 
|---|
| [380] | 2405 | $(if $(uid),-o $(uid))\ | 
|---|
|  | 2406 | $(if $(gid),-g $(gid))\ | 
|---|
|  | 2407 | $(if $(mode),-m $(mode))\ | 
|---|
| [830] | 2408 | $(flags)\ | 
|---|
| [380] | 2409 | $(insdst) | 
|---|
| [412] | 2410 |  | 
|---|
|  | 2411 | .NOTPARALLEL: $(insdst) | 
|---|
| [380] | 2412 | endef | 
|---|
|  | 2413 |  | 
|---|
| [412] | 2414 |  | 
|---|
| [380] | 2415 | ## create one directory | 
|---|
|  | 2416 | define def_install_directory | 
|---|
|  | 2417 |  | 
|---|
|  | 2418 | # _INST | 
|---|
|  | 2419 | ifdef $(directory)_INST | 
|---|
| [725] | 2420 | inst := $(PATH_INS)/$(patsubst %/,%,$($(directory)_INST)) | 
|---|
| [827] | 2421 | else ifdef $(target)_INST | 
|---|
|  | 2422 | inst := $(PATH_INS)/$(patsubst %/,%,$($(target)_INST)) | 
|---|
| [380] | 2423 | else | 
|---|
| [827] | 2424 | inst := $(PATH_INS) | 
|---|
| [380] | 2425 | endif | 
|---|
|  | 2426 |  | 
|---|
|  | 2427 | mode := $(firstword \ | 
|---|
| [481] | 2428 | $($(target)_$(directory)_MODE.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
| [380] | 2429 | $($(target)_$(directory)_MODE.$(bld_trg)) \ | 
|---|
|  | 2430 | $($(target)_$(directory)_MODE) \ | 
|---|
| [481] | 2431 | $($(directory)_MODE.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
| [380] | 2432 | $($(directory)_MODE.$(bld_trg)) \ | 
|---|
|  | 2433 | $($(directory)_MODE) \ | 
|---|
| [481] | 2434 | $($(target)_MODE.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
| [380] | 2435 | $($(target)_MODE.$(bld_trg)) \ | 
|---|
|  | 2436 | $($(target)_MODE)) | 
|---|
|  | 2437 | uid := $(firstword \ | 
|---|
| [481] | 2438 | $($(target)_$(directory)_UID.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
| [380] | 2439 | $($(target)_$(directory)_UID.$(bld_trg)) \ | 
|---|
|  | 2440 | $($(target)_$(directory)_UID) \ | 
|---|
| [481] | 2441 | $($(directory)_UID.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
| [380] | 2442 | $($(directory)_UID.$(bld_trg)) \ | 
|---|
|  | 2443 | $($(directory)_UID) \ | 
|---|
| [481] | 2444 | $($(target)_UID.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
| [380] | 2445 | $($(target)_UID.$(bld_trg)) \ | 
|---|
|  | 2446 | $($(target)_UID)) | 
|---|
|  | 2447 | gid := $(firstword \ | 
|---|
| [481] | 2448 | $($(target)_$(directory)_GID.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
| [380] | 2449 | $($(target)_$(directory)_GID.$(bld_trg)) \ | 
|---|
|  | 2450 | $($(target)_$(directory)_GID) \ | 
|---|
| [481] | 2451 | $($(directory)_GID.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
| [380] | 2452 | $($(directory)_GID.$(bld_trg)) \ | 
|---|
|  | 2453 | $($(directory)_GID) \ | 
|---|
| [481] | 2454 | $($(target)_GID.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
| [380] | 2455 | $($(target)_GID.$(bld_trg)) \ | 
|---|
|  | 2456 | $($(target)_GID)) | 
|---|
| [830] | 2457 | flags := \ | 
|---|
|  | 2458 | $($(target)_IDFLAGS)\ | 
|---|
|  | 2459 | $($(target)_IDFLAGS.$(bld_trg)) \ | 
|---|
|  | 2460 | $($(target)_IDFLAGS.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
|  | 2461 | $($(directory)_IDFLAGS) \ | 
|---|
|  | 2462 | $($(directory)_IDFLAGS.$(bld_trg)) \ | 
|---|
|  | 2463 | $($(directory)_IDFLAGS.$(bld_trg).$(bld_trg_arch)) \ | 
|---|
|  | 2464 | $($(target)_$(directory)_IDFLAGS) \ | 
|---|
|  | 2465 | $($(target)_$(directory)_IDFLAGS.$(bld_trg)) \ | 
|---|
|  | 2466 | $($(target)_$(directory)_IDFLAGS.$(bld_trg).$(bld_trg_arch)) | 
|---|
| [380] | 2467 |  | 
|---|
|  | 2468 | insdst := $(inst)/$(directory)/ | 
|---|
|  | 2469 | #$(warning directory=$(directory) inst=$(inst) insdst=$(insdst) mode=$(mode) gid=$(gid) uid=$(uid)) | 
|---|
|  | 2470 |  | 
|---|
|  | 2471 | # generate the rule (need double evaluation here) | 
|---|
|  | 2472 | $(eval $(def_install_directory_rule)) | 
|---|
|  | 2473 |  | 
|---|
|  | 2474 | INSTARGET_DIRS_$(target) += $(insdst) | 
|---|
|  | 2475 | endef | 
|---|
|  | 2476 |  | 
|---|
|  | 2477 |  | 
|---|
| [353] | 2478 | ## process one install target. | 
|---|
|  | 2479 | define def_install | 
|---|
| [744] | 2480 | # the basics. | 
|---|
| [353] | 2481 | bld_type  := $(firstword $($(target)_BLD_TYPE)     $(BUILD_TYPE)) | 
|---|
|  | 2482 | bld_trg   := $(firstword $($(target)_BLD_TRG)      $(BUILD_TARGET)) | 
|---|
|  | 2483 | bld_trg_arch:= $(firstword $($(target)_BLD_TRG_ARCH) $(BUILD_TARGET_ARCH)) | 
|---|
|  | 2484 | bld_trg_cpu := $(firstword $($(target)_BLD_TRG_CPU)  $(BUILD_TARGET_CPU)) | 
|---|
|  | 2485 |  | 
|---|
| [827] | 2486 | INSTARGET_$(target) := $($(target)_GOALS) | 
|---|
| [380] | 2487 | INSTARGET_DIRS_$(target) := | 
|---|
|  | 2488 |  | 
|---|
| [481] | 2489 | $(foreach directory,$($(target)_DIRS) $($(target)_DIRS.$(bld_trg)) $($(target)_DIRS.$(bld_trg).$(bld_trg_arch)) $($(target)_DIRS.$(bld_trg_arch)) $($(target)_DIRS.$(bld_trg_cpu)) $($(target)_DIRS.$(bld_type)), \ | 
|---|
| [380] | 2490 | $(eval $(value def_install_directory))) | 
|---|
|  | 2491 |  | 
|---|
| [481] | 2492 | $(foreach src,$($(target)_SOURCES) $($(target)_SOURCES.$(bld_trg)) $($(target)_SOURCES.$(bld_trg).$(bld_trg_arch)) $($(target)_SOURCES.$(bld_trg_arch)) $($(target)_SOURCES.$(bld_trg_cpu)) $($(target)_SOURCES.$(bld_type)), \ | 
|---|
| [353] | 2493 | $(eval $(value def_install_src))) | 
|---|
|  | 2494 |  | 
|---|
| [481] | 2495 | $(foreach src,$($(target)_SYMLINKS) $($(target)_SYMLINKS.$(bld_trg)) $($(target)_SYMLINKS.$(bld_trg).$(bld_trg_arch)) $($(target)_SYMLINKS.$(bld_trg_arch)) $($(target)_SYMLINKS.$(bld_trg_cpu)) $($(target)_SYMLINKS.$(bld_type)), \ | 
|---|
| [353] | 2496 | $(eval $(value def_install_symlink))) | 
|---|
|  | 2497 |  | 
|---|
| [827] | 2498 | # the collection target | 
|---|
|  | 2499 | TARGET_$(target) := $(PATH_TARGET)/$(target).ins | 
|---|
| [838] | 2500 | $(TARGET_$(target)): $(INSTARGET_$(target)) | $(INSTARGET_DIRS_$(target)) $(call DIRDEP,$(PATH_TARGET)) | 
|---|
| [827] | 2501 | @$(QUIET2)$(APPEND) $@ | 
|---|
|  | 2502 |  | 
|---|
|  | 2503 | $(target): $(TARGET_$(target)) | 
|---|
|  | 2504 |  | 
|---|
|  | 2505 | _INSTALLS += $(TARGET_$(target)) | 
|---|
|  | 2506 | _INSTALLS_FILES += $(INSTARGET_$(target)) | 
|---|
| [380] | 2507 | _INSTALLS_DIRS += $(INSTARGET_DIRS_$(target)) | 
|---|
| [905] | 2508 | _CLEAN_FILES += $($(target)_CLEAN) $($(target)_CLEAN.$(bld_trg)) $($(target)_CLEAN.$(bld_trg).$(bld_trg_arch)) $($(target)_CLEAN.$(bld_trg_arch)) $($(target)_CLEAN.$(bld_trg_cpu)) $($(target)_CLEAN.$(bld_type)) | 
|---|
|  | 2509 | _DIRS += $($(target)_BLDDIRS) $($(target)_BLDDIRS.$(bld_trg)) $($(target)_BLDDIRS.$(bld_trg).$(bld_trg_arch)) $($(target)_BLDDIRS.$(bld_trg_arch)) $($(target)_BLDDIRS.$(bld_trg_cpu)) $($(target)_BLDDIRS.$(bld_type)) | 
|---|
| [353] | 2510 | endef | 
|---|
|  | 2511 |  | 
|---|
|  | 2512 | ## process all install targets | 
|---|
| [481] | 2513 | $(foreach target, $(INSTALLS) $(INSTALLS.$(BUILD_TARGET)) $(INSTALLS.$(BUILD_TARGET).$(BUILD_TARGET_ARCH)), \ | 
|---|
| [353] | 2514 | $(eval $(value def_install))) | 
|---|
|  | 2515 |  | 
|---|
| [988] | 2516 | ifdef KBUILD_PROFILE_SELF | 
|---|
|  | 2517 | _KBUILD_TS_NOW := $(nanots ) | 
|---|
|  | 2518 | $(info prof: $(int-sub $(_KBUILD_TS_NOW), $(_KBUILD_TS_HEADER_START)) - $(int-sub $(_KBUILD_TS_NOW), $(_KBUILD_TS_PREV)) - done install targets) | 
|---|
|  | 2519 | _KBUILD_TS_PREV := $(_KBUILD_TS_NOW) | 
|---|
|  | 2520 | endif | 
|---|
| [353] | 2521 |  | 
|---|
| [988] | 2522 |  | 
|---|
| [72] | 2523 | # | 
|---|
| [417] | 2524 | # PACKING | 
|---|
|  | 2525 | # | 
|---|
| [481] | 2526 | _PACKING += $(PACKING) $(PACKING.$(BUILD_TARGET)) $(PACKING.$(BUILD_TARGET).$(BUILD_TARGET_ARCH)) | 
|---|
| [417] | 2527 |  | 
|---|
|  | 2528 |  | 
|---|
|  | 2529 | # | 
|---|
| [72] | 2530 | # DOCS | 
|---|
|  | 2531 | # | 
|---|
|  | 2532 |  | 
|---|
|  | 2533 |  | 
|---|
|  | 2534 | # | 
|---|
| [353] | 2535 | # DIRECTORIES | 
|---|
|  | 2536 | # | 
|---|
| [827] | 2537 | _DIR_ALL := $(sort $(addsuffix /,$(patsubst %/,%,$(_DIRS))) $(dir $(_OUT_FILES) $(_OBJS) $(_INSTALLS_FILES))) | 
|---|
| [380] | 2538 | $(foreach directory,$(_INSTALLS_DIRS), $(eval _DIR_ALL := $(filter-out $(directory),$(_DIR_ALL)))) | 
|---|
| [353] | 2539 |  | 
|---|
| [380] | 2540 |  | 
|---|
| [353] | 2541 | define def_mkdir_rule | 
|---|
|  | 2542 | $(directory): | 
|---|
| [776] | 2543 | $$(call MSG_MKDIR,$$@) | 
|---|
| [696] | 2544 | $$(QUIET)$$(MKDIR) -p $$@ | 
|---|
| [72] | 2545 | endef | 
|---|
|  | 2546 |  | 
|---|
| [353] | 2547 | $(foreach directory,$(_DIR_ALL),$(eval $(def_mkdir_rule))) | 
|---|
| [72] | 2548 |  | 
|---|
| [988] | 2549 | ifdef KBUILD_PROFILE_SELF | 
|---|
|  | 2550 | _KBUILD_TS_NOW := $(nanots ) | 
|---|
|  | 2551 | $(info prof: $(int-sub $(_KBUILD_TS_NOW), $(_KBUILD_TS_HEADER_START)) - $(int-sub $(_KBUILD_TS_NOW), $(_KBUILD_TS_PREV)) - done directories) | 
|---|
|  | 2552 | _KBUILD_TS_PREV := $(_KBUILD_TS_NOW) | 
|---|
|  | 2553 | endif | 
|---|
| [183] | 2554 |  | 
|---|
| [988] | 2555 |  | 
|---|
| [72] | 2556 | # | 
|---|
| [353] | 2557 | # NOTHING | 
|---|
| [72] | 2558 | # | 
|---|
| [353] | 2559 | do-nothing: | 
|---|
| [988] | 2560 | ifdef KBUILD_PROFILE_SELF | 
|---|
|  | 2561 | @$(ECHO) 'prof: $(int-sub $(nanots ), $(_KBUILD_TS_HEADER_START)) - $(int-sub $(nanots ), $(_KBUILD_TS_PREV)) - executing $@' | 
|---|
|  | 2562 | endif | 
|---|
| [776] | 2563 | $(call MSG_NOTHING) | 
|---|
| [72] | 2564 |  | 
|---|
| [183] | 2565 |  | 
|---|
| [75] | 2566 | # | 
|---|
| [353] | 2567 | # CLEAN UP | 
|---|
| [75] | 2568 | # | 
|---|
| [353] | 2569 | do-clean: | 
|---|
| [776] | 2570 | $(call MSG_CLEAN) | 
|---|
| [701] | 2571 | $(QUIET)$(RM) -f $(_OUT_FILES) $(_OBJS) $(_DEPFILES) $(_DEPFILES_INCLUDED) $(_CLEAN_FILES) $(OTHER_CLEAN) | 
|---|
| [966] | 2572 | $(QUIET)$(RMDIR) -p --ignore-fail-on-non-empty --ignore-fail-on-not-exist $(rsort $(dir $(_OUT_FILES) $(_OBJS) $(_DEPFILES) $(_DEPFILES_INCLUDED) $(_CLEAN_FILES) $(OTHER_CLEAN))) | 
|---|
| [72] | 2573 |  | 
|---|
| [98] | 2574 |  | 
|---|
| [897] | 2575 |  | 
|---|
| [353] | 2576 | # | 
|---|
|  | 2577 | # PASSES (including directory and makefile walking) | 
|---|
|  | 2578 | # | 
|---|
| [221] | 2579 |  | 
|---|
| [75] | 2580 | ## Subdir | 
|---|
|  | 2581 | # @param        $(pass)         Lowercase pass name. | 
|---|
|  | 2582 | # @param        $(PASS)         Uppercase pass name. | 
|---|
|  | 2583 | # @param        $(subdir)       Subdirectory | 
|---|
|  | 2584 | # @param        $(tag)          tag to attach to the rule name. | 
|---|
|  | 2585 | define def_pass_subdir | 
|---|
| [219] | 2586 | pass_$(pass)$(tag):: $(dep) | 
|---|
| [696] | 2587 | + $$(QUIET)$$(MAKE) -C $(subdir) -f $$(notdir $$(firstword $$(wildcard $$(addprefix $(subdir)/,$$(DEFAULT_MAKEFILE))))) pass_$(pass) | 
|---|
| [75] | 2588 | endef | 
|---|
| [72] | 2589 |  | 
|---|
| [75] | 2590 | ## Submakefile | 
|---|
|  | 2591 | # @param        $(pass)         Lowercase pass name. | 
|---|
|  | 2592 | # @param        $(PASS)         Uppercase pass name. | 
|---|
|  | 2593 | # @param        $(makefile) Makefile. | 
|---|
|  | 2594 | # @param        $(tag)          tag to attach to the rule name. | 
|---|
|  | 2595 | define def_pass_makefile | 
|---|
| [219] | 2596 | pass_$(pass)$(tag):: $(dep) | 
|---|
| [696] | 2597 | + $$(QUIET)$$(MAKE) -C $(patsubst %/,%,$(dir $(makefile))) -f $(notdir $(makefile)) pass_$(pass) | 
|---|
| [75] | 2598 | endef | 
|---|
| [73] | 2599 |  | 
|---|
| [75] | 2600 | ## Execute a pass. | 
|---|
|  | 2601 | # @param        $(pass)         Lowercase pass name. | 
|---|
|  | 2602 | # @param        $(PASS)         Uppercase pass name. | 
|---|
| [353] | 2603 | define def_pass_old | 
|---|
| [481] | 2604 | $(eval SUBDIRS_$(PASS)          ?= $(SUBDIRS)          $(SUBDIRS.$(BUILD_TARGET))           $(SUBDIRS.$(BUILD_TARGET).$(BUILD_TARGET_ARCH))          ) | 
|---|
|  | 2605 | $(eval SUBDIRS_AFTER_$(PASS)    ?= $(SUBDIRS_AFTER)    $(SUBDIRS_AFTER.$(BUILD_TARGET))     $(SUBDIRS_AFTER.$(BUILD_TARGET).$(BUILD_TARGET_ARCH))    ) | 
|---|
|  | 2606 | $(eval MAKEFILES_BEFORE_$(PASS) ?= $(MAKEFILES_BEFORE) $(MAKEFILES_BEFORE.$(BUILD_TARGET))  $(MAKEFILES_BEFORE.$(BUILD_TARGET).$(BUILD_TARGET_ARCH)) ) | 
|---|
|  | 2607 | $(eval MAKEFILES_AFTER_$(PASS)  ?= $(MAKEFILES_AFTER)  $(MAKEFILES_AFTER.$(BUILD_TARGET))   $(MAKEFILES_AFTER.$(BUILD_TARGET).$(BUILD_TARGET_ARCH))  ) | 
|---|
| [75] | 2608 |  | 
|---|
|  | 2609 | $(eval tag:=_before) | 
|---|
| [219] | 2610 | $(eval dep:=) | 
|---|
| [481] | 2611 | $(foreach subdir,$(SUBDIRS_$(PASS))            $(SUBDIRS_$(PASS).$(BUILD_TARGET))           $(SUBDIRS_$(PASS).$(BUILD_TARGET).$(BUILD_TARGET_ARCH))         ,$(eval $(def_pass_subdir))) | 
|---|
|  | 2612 | $(foreach makefile,$(MAKEFILES_BEFORE_$(PASS)) $(MAKEFILES_BEFORE_$(PASS).$(BUILD_TARGET))  $(MAKEFILES_BEFORE_$(PASS).$(BUILD_TARGET).$(BUILD_TARGET_ARCH)),$(eval $(def_pass_makefile))) | 
|---|
| [75] | 2613 |  | 
|---|
|  | 2614 | $(eval tag:=_after) | 
|---|
| [219] | 2615 | $(eval dep:=pass_$(pass)_doit) | 
|---|
| [481] | 2616 | $(foreach subdir,$(SUBDIRS_AFTER_$(PASS))      $(SUBDIRS_AFTER_$(PASS).$(BUILD_TARGET))     $(SUBDIRS_AFTER_$(PASS).$(BUILD_TARGET).$(BUILD_TARGET_ARCH))   ,$(eval $(def_pass_subdir))) | 
|---|
|  | 2617 | $(foreach makefile,$(MAKEFILES_AFTER_$(PASS))  $(MAKEFILES_AFTER_$(PASS).$(BUILD_TARGET))   $(MAKEFILES_AFTER_$(PASS).$(BUILD_TARGET).$(BUILD_TARGET_ARCH)) ,$(eval $(def_pass_makefile))) | 
|---|
| [75] | 2618 |  | 
|---|
|  | 2619 | .NOTPARALLEL: pass_$(pass)_before pass_$(pass)_after | 
|---|
|  | 2620 | .PHONY: pass_$(pass) pass_$(pass)_before pass_$(pass)_doit pass_$(pass)_after | 
|---|
| [353] | 2621 | pass_$(pass)_doit:      $(PASS_$(PASS)_trgs) $(foreach var,$(PASS_$(PASS)_vars),$(var)) | 
|---|
| [272] | 2622 | pass_$(pass)_this:      pass_$(pass)_before | 
|---|
| [696] | 2623 | + $$(QUIET)$$(MAKE) -f $$(MAKEFILE) pass_$(pass)_doit | 
|---|
| [220] | 2624 | pass_$(pass)_after::    pass_$(pass)_this | 
|---|
| [219] | 2625 | pass_$(pass):           pass_$(pass)_after | 
|---|
| [75] | 2626 |  | 
|---|
| [183] | 2627 | endef | 
|---|
|  | 2628 |  | 
|---|
| [353] | 2629 | define def_pass | 
|---|
| [481] | 2630 | $(eval SUBDIRS_$(PASS)          ?= $(SUBDIRS)          $(SUBDIRS.$(BUILD_TARGET))          $(SUBDIRS.$(BUILD_TARGET.$(BUILD_TARGET_ARCH)))          ) | 
|---|
|  | 2631 | $(eval SUBDIRS_AFTER_$(PASS)    ?= $(SUBDIRS_AFTER)    $(SUBDIRS_AFTER.$(BUILD_TARGET))    $(SUBDIRS_AFTER.$(BUILD_TARGET).$(BUILD_TARGET_ARCH))    ) | 
|---|
|  | 2632 | $(eval MAKEFILES_BEFORE_$(PASS) ?= $(MAKEFILES_BEFORE) $(MAKEFILES_BEFORE.$(BUILD_TARGET)) $(MAKEFILES_BEFORE.$(BUILD_TARGET).$(BUILD_TARGET_ARCH)) ) | 
|---|
|  | 2633 | $(eval MAKEFILES_AFTER_$(PASS)  ?= $(MAKEFILES_AFTER)  $(MAKEFILES_AFTER.$(BUILD_TARGET))  $(MAKEFILES_AFTER.$(BUILD_TARGET).$(BUILD_TARGET_ARCH))  ) | 
|---|
| [183] | 2634 |  | 
|---|
| [353] | 2635 | $(eval tag:=_before) | 
|---|
|  | 2636 | $(eval dep:=) | 
|---|
| [481] | 2637 | $(foreach subdir,$(SUBDIRS_$(PASS))            $(SUBDIRS_$(PASS).$(BUILD_TARGET))          $(SUBDIRS_$(PASS).$(BUILD_TARGET).$(BUILD_TARGET_ARCH))         ,$(eval $(def_pass_subdir))) | 
|---|
|  | 2638 | $(foreach makefile,$(MAKEFILES_BEFORE_$(PASS)) $(MAKEFILES_BEFORE_$(PASS).$(BUILD_TARGET)) $(MAKEFILES_BEFORE_$(PASS).$(BUILD_TARGET).$(BUILD_TARGET_ARCH)),$(eval $(def_pass_makefile))) | 
|---|
| [75] | 2639 |  | 
|---|
| [353] | 2640 | $(eval tag:=_after) | 
|---|
|  | 2641 | $(eval dep:=pass_$(pass)_doit) | 
|---|
| [481] | 2642 | $(foreach subdir,$(SUBDIRS_AFTER_$(PASS))      $(SUBDIRS_AFTER_$(PASS).$(BUILD_TARGET))    $(SUBDIRS_AFTER_$(PASS).$(BUILD_TARGET).$(BUILD_TARGET_ARCH))   ,$(eval $(def_pass_subdir))) | 
|---|
|  | 2643 | $(foreach makefile,$(MAKEFILES_AFTER_$(PASS))  $(MAKEFILES_AFTER_$(PASS).$(BUILD_TARGET))  $(MAKEFILES_AFTER_$(PASS).$(BUILD_TARGET).$(BUILD_TARGET_ARCH)) ,$(eval $(def_pass_makefile))) | 
|---|
| [75] | 2644 |  | 
|---|
| [380] | 2645 | ifdef KBUILD_SAFE_PARALLEL | 
|---|
| [353] | 2646 | .NOTPARALLEL: pass_$(pass) pass_$(pass)_before pass_$(pass)_after pass_$(pass)_this | 
|---|
|  | 2647 | .PHONY:       pass_$(pass) pass_$(pass)_before pass_$(pass)_after pass_$(pass)_this pass_$(pass)_doit | 
|---|
|  | 2648 | pass_$(pass)_doit:          $(PASS_$(PASS)_trgs) $(foreach var,$(PASS_$(PASS)_vars),$(var)) | 
|---|
|  | 2649 | pass_$(pass)_this:      pass_$(pass)_before | 
|---|
| [696] | 2650 | + $$(QUIET)$$(MAKE) -f $$(MAKEFILE) pass_$(pass)_doit | 
|---|
| [353] | 2651 | pass_$(pass)_after::    pass_$(pass)_this | 
|---|
|  | 2652 | pass_$(pass):           pass_$(pass)_after | 
|---|
|  | 2653 | else | 
|---|
| [388] | 2654 | .NOTPARALLEL: pass_$(pass) pass_$(pass)_before pass_$(pass)_after pass_$(pass)_doit | 
|---|
| [353] | 2655 | .PHONY:       pass_$(pass) pass_$(pass)_before pass_$(pass)_after pass_$(pass)_doit | 
|---|
|  | 2656 | pass_$(pass)_doit: pass_$(pass)_before \ | 
|---|
|  | 2657 | $(PASS_$(PASS)_trgs) $(foreach var,$(PASS_$(PASS)_vars),$($(var))) | 
|---|
|  | 2658 | pass_$(pass): \ | 
|---|
|  | 2659 | pass_$(pass)_before \ | 
|---|
|  | 2660 | pass_$(pass)_doit \ | 
|---|
| [388] | 2661 | pass_$(pass)_after | 
|---|
| [353] | 2662 | endif | 
|---|
| [189] | 2663 |  | 
|---|
| [353] | 2664 | #$ (warning pass=$(pass) PASS=$(PASS): $(PASS_$(PASS)_trgs) $(PASS_$(PASS)_trgs) $(foreach var,$(PASS_$(PASS)_vars),$($(var)))) | 
|---|
|  | 2665 | endef | 
|---|
| [75] | 2666 |  | 
|---|
| [353] | 2667 | # Generate the defined passes. | 
|---|
|  | 2668 | $(foreach PASS, $(PASSES), \ | 
|---|
|  | 2669 | $(eval pass := $(PASS_$(PASS)_pass)) \ | 
|---|
|  | 2670 | $(eval $(def_pass))) | 
|---|
| [75] | 2671 |  | 
|---|
| [219] | 2672 | ## Pass order | 
|---|
|  | 2673 | # @param        $(pass)         Current pass name. | 
|---|
|  | 2674 | # @param        $(prev_pass)    The previous pass name. | 
|---|
|  | 2675 | define def_pass_order | 
|---|
| [380] | 2676 | ifdef KBUILD_SAFE_PARALLEL | 
|---|
| [353] | 2677 | .NOTPARALLEL: pass_$(pass)_order | 
|---|
|  | 2678 | .PHONY: pass_$(pass)_order | 
|---|
| [219] | 2679 | pass_$(pass)_order: $(pass_prev) | 
|---|
| [776] | 2680 | $$(call MSG_PASS,$$(if $$(PASS_$(PASS)),$$(PASS_$(PASS)),$(pass))) | 
|---|
| [696] | 2681 | + $$(QUIET)$$(MAKE) -f $$(MAKEFILE) pass_$(pass) | 
|---|
| [353] | 2682 | else | 
|---|
|  | 2683 | .NOTPARALLEL: pass_$(pass)_order pass_$(pass)_banner | 
|---|
| [388] | 2684 | .PHONY:       pass_$(pass)_order pass_$(pass)_banner | 
|---|
| [353] | 2685 | pass_$(pass)_banner: | 
|---|
| [776] | 2686 | $$(call MSG_PASS,$$(if $$(PASS_$(PASS)),$$(PASS_$(PASS)),$(pass))) | 
|---|
| [353] | 2687 | pass_$(pass)_order: \ | 
|---|
|  | 2688 | $(pass_prev) \ | 
|---|
|  | 2689 | pass_$(pass)_banner \ | 
|---|
|  | 2690 | pass_$(pass) | 
|---|
|  | 2691 | endif | 
|---|
| [219] | 2692 | $(eval pass_prev := pass_$(pass)_order) | 
|---|
|  | 2693 | endef | 
|---|
| [183] | 2694 |  | 
|---|
| [219] | 2695 | ## PASS: order | 
|---|
|  | 2696 | # Use dependencies to ensure correct pass order. | 
|---|
|  | 2697 | pass_prev := | 
|---|
| [353] | 2698 | $(foreach PASS,$(DEFAULT_PASSES),\ | 
|---|
|  | 2699 | $(eval pass := $(PASS_$(PASS)_pass)) \ | 
|---|
|  | 2700 | $(eval $(def_pass_order))) | 
|---|
| [219] | 2701 |  | 
|---|
| [988] | 2702 | ifdef KBUILD_PROFILE_SELF | 
|---|
|  | 2703 | _KBUILD_TS_NOW := $(nanots ) | 
|---|
|  | 2704 | $(info prof: $(int-sub $(_KBUILD_TS_NOW), $(_KBUILD_TS_HEADER_START)) - $(int-sub $(_KBUILD_TS_NOW), $(_KBUILD_TS_PREV)) - done passes) | 
|---|
|  | 2705 | _KBUILD_TS_PREV := $(_KBUILD_TS_NOW) | 
|---|
|  | 2706 | endif | 
|---|
| [272] | 2707 |  | 
|---|
| [897] | 2708 |  | 
|---|
| [75] | 2709 | # | 
|---|
|  | 2710 | # THE MAIN RULES | 
|---|
|  | 2711 | # | 
|---|
| [219] | 2712 | all_recursive: $(pass_prev) | 
|---|
| [75] | 2713 |  | 
|---|
| [130] | 2714 | rebuild: clean | 
|---|
| [219] | 2715 | + $(MAKE) -f $(firstword $(MAKEFILE_LIST)) all_recursive | 
|---|
| [78] | 2716 |  | 
|---|
| [412] | 2717 | # @todo make this a non-default pass! | 
|---|
| [353] | 2718 | uninstall: | 
|---|
| [827] | 2719 | $(RM) -f $(_INSTALLS_FILES) | 
|---|
| [412] | 2720 |  | 
|---|
| [380] | 2721 | install: pass_installs | 
|---|
| [78] | 2722 |  | 
|---|
| [75] | 2723 | # misc shortcuts. | 
|---|
| [380] | 2724 | targets:   bldprogs libraries dlls programs sysmods others installs | 
|---|
| [75] | 2725 | objects:   $(_OBJS) | 
|---|
| [222] | 2726 | bldprogs:  $(_BLDPROGS) | 
|---|
| [189] | 2727 | libraries: $(_LIBS) $(_IMPORT_LIBS) $(_OTHER_LIBRARIES) | 
|---|
| [205] | 2728 | dlls:      $(_DLLS) | 
|---|
| [219] | 2729 | programs:  $(_PROGRAMS) | 
|---|
| [205] | 2730 | sysmods:   $(_SYSMODS) | 
|---|
| [353] | 2731 | others:    $(_OTHERS) | 
|---|
| [854] | 2732 | installs:  $(_INSTALLS) $(_INSTALLS_DIRS) $(_INSTALLS_FILES) | 
|---|
| [75] | 2733 |  | 
|---|
|  | 2734 |  | 
|---|
| [897] | 2735 |  | 
|---|
| [353] | 2736 | # | 
|---|
|  | 2737 | # kBuild debugging stuff. | 
|---|
|  | 2738 | # | 
|---|
|  | 2739 | show_targets: | 
|---|
| [984] | 2740 | @$(foreach target, $(_ALL_TARGETS),\ | 
|---|
| [353] | 2741 | @$(ECHO) "target: $(target)" $(NLTAB)\ | 
|---|
|  | 2742 | @$(ECHO) "  PATH_$(target)=$(PATH_$(target))" $(NLTAB)\ | 
|---|
|  | 2743 | @$(ECHO) "  TARGET_$(target)=$(TARGET_$(target))" $(NLTAB)\ | 
|---|
|  | 2744 | @$(ECHO) "  INSTARGET_$(target)=$(INSTARGET_$(target))" $(NLTAB)\ | 
|---|
| [660] | 2745 | $(foreach prop,$(PROPS_SINGLE) $(PROPS_ACCUMULATE_L) $(PROPS_ACCUMULATE_R) OBJS_ CLEAN, \ | 
|---|
| [353] | 2746 | $(eval _tmp:=$(firstword $($(target)_BLD_TRG) $(BUILD_TARGET))) \ | 
|---|
|  | 2747 | $(if $($(target)_$(prop).$(_tmp)),\ | 
|---|
|  | 2748 | @$(ECHO) "  $(target)_$(prop).$(_tmp)=$($(target)_$(prop).$(_tmp))" $(NLTAB)) \ | 
|---|
|  | 2749 | $(if $($(target)_$(prop)), $(NLTAB)@$(ECHO) "  $(target)_$(prop)=$($(target)_$(prop))" $(NLTAB)) \ | 
|---|
|  | 2750 | )\ | 
|---|
|  | 2751 | $(foreach prop,$(PROPS_DEFERRED), \ | 
|---|
|  | 2752 | $(eval _tmp:=$(firstword $($(target)_BLD_TRG) $(BUILD_TARGET))) \ | 
|---|
|  | 2753 | $(if $(value $(target)_$(prop).$(_tmp)),\ | 
|---|
|  | 2754 | @$(ECHO) '  $(target)_$(prop).$(_tmp)=$(value $(TARGET)_$(prop).$(_tmp))' $(NLTAB)) \ | 
|---|
|  | 2755 | $(if $(value $(target)_$(prop)), $(NLTAB)@$(ECHO) '  $(target)_$(prop)=$(value $(target)_$(prop))' $(NLTAB)) \ | 
|---|
|  | 2756 | )) | 
|---|
|  | 2757 |  | 
|---|
|  | 2758 |  | 
|---|
|  | 2759 |  | 
|---|
|  | 2760 | # | 
|---|
|  | 2761 | # Include dependency files. | 
|---|
|  | 2762 | # | 
|---|
| [893] | 2763 | ifneq ($(_DEPFILES),) | 
|---|
|  | 2764 | includedep $(_DEPFILES) | 
|---|
|  | 2765 | endif | 
|---|
| [353] | 2766 |  | 
|---|
|  | 2767 |  | 
|---|
| [988] | 2768 | ifdef KBUILD_PROFILE_SELF | 
|---|
|  | 2769 | _KBUILD_TS_FOOTER_END := $(nanots ) | 
|---|
|  | 2770 | $(info prof: $(int-sub $(_KBUILD_TS_FOOTER_END), $(_KBUILD_TS_HEADER_START)) - $(int-sub $(_KBUILD_TS_FOOTER_END), $(_KBUILD_TS_PREV)) - end of footer.kmk) | 
|---|
|  | 2771 | $(info prof: footer.kmk: $(int-sub $(_KBUILD_TS_FOOTER_END), $(_KBUILD_TS_FOOTER_START))) | 
|---|
|  | 2772 | _KBUILD_TS_PREV := $(_KBUILD_TS_FOOTER_END) | 
|---|
|  | 2773 | endif | 
|---|
|  | 2774 |  | 
|---|
| [72] | 2775 | # end-of-file-content | 
|---|
| [106] | 2776 | __footer_kmk__ := target | 
|---|
| [72] | 2777 | endif # __footer_kmk__ | 
|---|
| [438] | 2778 |  | 
|---|