]> git.saurik.com Git - apple/xnu.git/blame_incremental - makedefs/MakeInc.rule
xnu-4570.1.46.tar.gz
[apple/xnu.git] / makedefs / MakeInc.rule
... / ...
CommitLineData
1# -*- mode: makefile;-*-
2#
3# Copyright (C) 1999-2016 Apple Inc. All rights reserved.
4#
5# MakeInc.rule defines the targets and rules for
6# leaf directories once MakeInc.dir has recursed
7# into them. "do_XXX" may be double-colon rules
8# to allow the Makefile in the source directory
9# to augment the actions that will be performed.
10#
11
12#
13# Generic Install rules
14#
15
16ifndef INSTALL_KF_MI_LCL_LIST
17 INSTALL_KF_MI_LCL_LIST = $(EXPORT_MI_LIST)
18endif
19
20ifndef INSTALL_KF_MI_LCL_GEN_LIST
21 INSTALL_KF_MI_LCL_GEN_LIST = $(EXPORT_MI_GEN_LIST)
22endif
23
24ifndef INSTALL_KF_MD_LCL_LIST
25 INSTALL_KF_MD_LCL_LIST = $(EXPORT_MD_LIST)
26endif
27
28ifndef INSTALL_KF_MD_LCL_GEN_LIST
29 INSTALL_KF_MD_LCL_GEN_LIST = $(EXPORT_MD_GEN_LIST)
30endif
31
32ifndef INSTALL_KF_MI_LIST
33 INSTALL_KF_MI_LIST = $(EXPORT_MI_LIST)
34endif
35
36ifndef INSTALL_KF_MI_GEN_LIST
37 INSTALL_KF_MI_GEN_LIST = $(EXPORT_MI_GEN_LIST)
38endif
39
40ifndef INSTALL_KF_MD_LIST
41 INSTALL_KF_MD_LIST = $(EXPORT_MD_LIST)
42endif
43
44ifndef INSTALL_KF_MD_GEN_LIST
45 INSTALL_KF_MD_GEN_LIST = $(EXPORT_MD_GEN_LIST)
46endif
47
48ifeq (${XNU_LOGCOLORS},y)
49 LOGCOLORS ?= y
50endif
51
52ifeq ($(LOGCOLORS),y)
53 # Get a nice list of device code names associated with the build platform
54 ifndef CDevs
55 #ifdef EMBEDDED_DEVICE_MAP
56 # export CDevs := $(shell $(EMBEDDED_DEVICE_MAP) -db $(EDM_DBPATH) -query "SELECT DISTINCT TargetType FROM Targets WHERE KernelPlatform = '$(CURRENT_MACHINE_CONFIG_LC)'" | tr '[\r\n]' ':' | sed 's,:$$,,')
57 #endif
58 endif
59 ifndef CMD_MC
60 export _MACHINE := $(CURRENT_MACHINE_CONFIG_LC)
61 ifeq ($(CURRENT_MACHINE_CONFIG),NONE)
62 export _MACHINE := $(subst Mac,,$(PLATFORM))
63 endif
64 export CMD_MC := \\033[1m$(shell __A="$(CURRENT_ARCH_CONFIG_LC)"; \
65 __As=$$((6-$${\#__A})); \
66 printf "%-.6s%*.*s %9.9s" \
67 "$${__A}" \
68 $${__As} $${__As} " " \
69 "$(_MACHINE)")\\033[m
70 endif
71 # Turn off colored output
72 Color0=\\033[m
73 # Start a host command: bold, underlined pink text
74 ColorH=\\033[1;4;35m
75 # Start a compilation-related command: bold, underlined blue text
76 ColorC=[$(CMD_MC)] \\033[1;4;34m
77 # Start a MIG command: bold, green text on light grey background
78 ColorM=[$(CMD_MC)] \\033[1;32;40m
79 # Start a linking command: bold, white text on blue background
80 ColorL=[$(CMD_MC)] \\033[1;37;44m
81 # Start a filename: bold, white text
82 ColorF=\\033[1;37m
83 # Start a linked file name: yellow text on light grey background
84 ColorLF=\\033[1;33;40m
85 # Error strings: underlined bold white text on red background
86 ColorErr=\033[1;4;37;41m
87endif
88
89.PHONY: ALWAYS
90
91ALWAYS:
92
93# $(1) is the list of install paths
94# $(2) is "1" if it's a "GEN"-style rule that looks locally, or else $(SOURCE)
95# $(3) is the local temp directory for processing
96# $(4) is the unifdef flags
97#
98# $$$$$$$$ is a double-escaped "$$" to represent the current pid
99# of the shell process for creating uniquely named temporary files
100
101define INSTALLHDRS_RULE_template
102
103.PHONY: $(3)_MKDIR
104
105$(3)_MKDIR:
106 $$(_v)$$(MKDIR) ./$(3)
107 $$(_v)$$(MKDIR) $(dir $(firstword $(1)))
108
109# Rebuild if unifdef flags change
110$(1): $(3)/.UNIFDEF_FLAGS
111$(3)/.UNIFDEF_FLAGS: ALWAYS | $(3)_MKDIR
112 $$(_v)$$(REPLACECONTENTS) $$@ $$(UNIFDEF) $(4)
113
114$(1): $(dir $(firstword $(1)))% : $(if $(2),%,$$(SOURCE)/%) | $(3)_MKDIR
115 @echo "$$(ColorH)INSTALLHDR$(Color0) $$(ColorF)$$*$$(Color0)"
116 $$(_v)$$(UNIFDEF) $(4) $$< > ./$(3)/$$*.unifdef.$$$$$$$$; \
117 if [ $$$$? -eq 2 ]; then \
118 echo Parse failure for $$<; \
119 exit 1; \
120 fi; \
121 $$(DECOMMENT) ./$(3)/$$*.unifdef.$$$$$$$$ r > \
122 ./$(3)/$$*.strip.$$$$$$$$ || exit 1; \
123 if [ -s ./$(3)/$$*.strip.$$$$$$$$ ]; then \
124 $$(INSTALL) $$(INSTALL_FLAGS) ./$(3)/$$*.unifdef.$$$$$$$$ $$@ || exit 1; \
125 fi; \
126 $$(RM) ./$(3)/$$*.unifdef.$$$$$$$$ ./$(3)/$$*.strip.$$$$$$$$
127endef
128
129#
130# Machine-independent (public) files
131#
132
133INSTALL_MI_INC_FILES = $(addprefix $(DSTROOT)/$(INCDIR)/$(INSTALL_MI_DIR)/, $(INSTALL_MI_LIST))
134INSTALL_MI_INC_GEN_FILES = $(addprefix $(DSTROOT)/$(INCDIR)/$(INSTALL_MI_DIR)/, $(INSTALL_MI_GEN_LIST))
135
136$(eval $(call INSTALLHDRS_RULE_template,$(INSTALL_MI_INC_FILES),,incmidir,$(SINCFRAME_UNIFDEF)))
137$(eval $(call INSTALLHDRS_RULE_template,$(INSTALL_MI_INC_GEN_FILES),1,incmigendir,$(SINCFRAME_UNIFDEF)))
138
139INSTALL_KF_MI_FILES = $(addprefix $(DSTROOT)/$(KINCDIR)/$(EXPORT_MI_DIR)/, $(INSTALL_KF_MI_LIST))
140INSTALL_KF_MI_GEN_FILES = $(addprefix $(DSTROOT)/$(KINCDIR)/$(EXPORT_MI_DIR)/, $(INSTALL_KF_MI_GEN_LIST))
141
142$(eval $(call INSTALLHDRS_RULE_template,$(INSTALL_KF_MI_FILES),,kincmidir,$(KINCFRAME_UNIFDEF)))
143$(eval $(call INSTALLHDRS_RULE_template,$(INSTALL_KF_MI_GEN_FILES),1,kincmigendir,$(KINCFRAME_UNIFDEF)))
144
145#
146# Machine-independent local (private) files
147#
148
149INSTALL_MI_LCL_FILES = $(addprefix $(DSTROOT)/$(LCLDIR)/$(INSTALL_MI_DIR)/, $(sort $(INSTALL_MI_LCL_LIST) $(INSTALL_MI_LIST)))
150INSTALL_MI_LCL_GEN_FILES = $(addprefix $(DSTROOT)/$(LCLDIR)/$(INSTALL_MI_DIR)/, $(sort $(INSTALL_MI_LCL_GEN_LIST) $(INSTALL_MI_GEN_LIST)))
151
152$(eval $(call INSTALLHDRS_RULE_template,$(INSTALL_MI_LCL_FILES),,pincmidir,$(SPINCFRAME_UNIFDEF)))
153$(eval $(call INSTALLHDRS_RULE_template,$(INSTALL_MI_LCL_GEN_FILES),1,pincmigendir,$(SPINCFRAME_UNIFDEF)))
154
155INSTALL_KF_MI_LCL_FILES = $(addprefix $(DSTROOT)/$(KPINCDIR)/$(EXPORT_MI_DIR)/, $(INSTALL_KF_MI_LCL_LIST))
156INSTALL_KF_MI_LCL_GEN_FILES = $(addprefix $(DSTROOT)/$(KPINCDIR)/$(EXPORT_MI_DIR)/, $(INSTALL_KF_MI_LCL_GEN_LIST))
157
158$(eval $(call INSTALLHDRS_RULE_template,$(INSTALL_KF_MI_LCL_FILES),,kpincmidir,$(KPINCFRAME_UNIFDEF)))
159$(eval $(call INSTALLHDRS_RULE_template,$(INSTALL_KF_MI_LCL_GEN_FILES),1,kpincmigendir,$(KPINCFRAME_UNIFDEF)))
160
161#
162# Machine-dependent (public) files
163#
164
165INSTALL_MD_INC_FILES = $(addprefix $(DSTROOT)/$(INCDIR)/$(INSTALL_MD_DIR)/, $(INSTALL_MD_LIST))
166INSTALL_MD_INC_GEN_FILES = $(addprefix $(DSTROOT)/$(INCDIR)/$(INSTALL_MD_DIR)/, $(INSTALL_MD_GEN_LIST))
167
168$(eval $(call INSTALLHDRS_RULE_template,$(INSTALL_MD_INC_FILES),,incdir,$(SINCFRAME_UNIFDEF)))
169$(eval $(call INSTALLHDRS_RULE_template,$(INSTALL_MD_INC_GEN_FILES),1,incgendir,$(SINCFRAME_UNIFDEF)))
170
171INSTALL_KF_MD_FILES = $(addprefix $(DSTROOT)/$(KINCDIR)/$(EXPORT_MD_DIR)/, $(INSTALL_KF_MD_LIST))
172INSTALL_KF_MD_GEN_FILES = $(addprefix $(DSTROOT)/$(KINCDIR)/$(EXPORT_MD_DIR)/, $(INSTALL_KF_MD_GEN_LIST))
173
174$(eval $(call INSTALLHDRS_RULE_template,$(INSTALL_KF_MD_FILES),,kincdir,$(KINCFRAME_UNIFDEF)))
175$(eval $(call INSTALLHDRS_RULE_template,$(INSTALL_KF_MD_GEN_FILES),1,kincgendir,$(KINCFRAME_UNIFDEF)))
176
177#
178# Machine-dependent local (private) files
179#
180
181INSTALL_MD_LCL_FILES = $(addprefix $(DSTROOT)/$(LCLDIR)/$(INSTALL_MD_DIR)/, $(sort $(INSTALL_MD_LCL_LIST) $(INSTALL_MD_LIST)))
182INSTALL_MD_LCL_GEN_FILES = $(addprefix $(DSTROOT)/$(LCLDIR)/$(INSTALL_MD_DIR)/, $(sort $(INSTALL_MD_LCL_GEN_LIST) $(INSTALL_MD_GEN_LIST)))
183
184$(eval $(call INSTALLHDRS_RULE_template,$(INSTALL_MD_LCL_FILES),,pincdir,$(SPINCFRAME_UNIFDEF)))
185$(eval $(call INSTALLHDRS_RULE_template,$(INSTALL_MD_LCL_GEN_FILES),1,pincgendir,$(SPINCFRAME_UNIFDEF)))
186
187INSTALL_KF_MD_LCL_FILES = $(addprefix $(DSTROOT)/$(KPINCDIR)/$(EXPORT_MD_DIR)/, $(INSTALL_KF_MD_LCL_LIST))
188INSTALL_KF_MD_LCL_GEN_FILES = $(addprefix $(DSTROOT)/$(KPINCDIR)/$(EXPORT_MD_DIR)/, $(INSTALL_KF_MD_LCL_GEN_LIST))
189
190$(eval $(call INSTALLHDRS_RULE_template,$(INSTALL_KF_MD_LCL_FILES),,kpincdir,$(KPINCFRAME_UNIFDEF)))
191$(eval $(call INSTALLHDRS_RULE_template,$(INSTALL_KF_MD_LCL_GEN_FILES),1,kpincgendir,$(KPINCFRAME_UNIFDEF)))
192
193.PHONY: do_installhdrs_mi
194
195# Double-colon rule so that MakeInc.kernel can add custom behaviors
196do_installhdrs_mi:: $(INSTALL_MI_INC_FILES) $(INSTALL_MI_INC_GEN_FILES) $(INSTALL_KF_MI_FILES) $(INSTALL_KF_MI_GEN_FILES) \
197 $(INSTALL_MI_LCL_FILES) $(INSTALL_MI_LCL_GEN_FILES) $(INSTALL_KF_MI_LCL_FILES) $(INSTALL_KF_MI_LCL_GEN_FILES)
198 @:
199
200.PHONY: do_installhdrs_md
201
202do_installhdrs_md: $(INSTALL_MD_INC_FILES) $(INSTALL_MD_INC_GEN_FILES) $(INSTALL_KF_MD_FILES) $(INSTALL_KF_MD_GEN_FILES) \
203 $(INSTALL_MD_LCL_FILES) $(INSTALL_MD_LCL_GEN_FILES) $(INSTALL_KF_MD_LCL_FILES) $(INSTALL_KF_MD_LCL_GEN_FILES)
204 @:
205
206#
207# Generic Export rules
208#
209EXPORT_MI_INC_FILES = $(addprefix $(OBJROOT)/$(EXPDIR)/$(EXPORT_MI_DIR)/, $(EXPORT_MI_LIST))
210EXPORT_MI_GEN_INC_FILES = $(addprefix $(OBJROOT)/$(EXPDIR)/$(EXPORT_MI_DIR)/, $(EXPORT_MI_GEN_LIST))
211
212.PHONY: EXP_MI_INC_DIR
213
214EXP_MI_INC_DIR:
215 $(_v)$(MKDIR) $(OBJROOT)/$(EXPDIR)/$(EXPORT_MI_DIR)
216
217$(EXPORT_MI_GEN_INC_FILES): $(OBJROOT)/$(EXPDIR)/$(EXPORT_MI_DIR)/% : % | EXP_MI_INC_DIR
218 $(_v)$(INSTALL) $(DATA_INSTALL_FLAGS) $< $@
219
220$(EXPORT_MI_INC_FILES): $(OBJROOT)/$(EXPDIR)/$(EXPORT_MI_DIR)/% : $(SOURCE)/% | EXP_MI_INC_DIR
221 $(_v)$(INSTALL) $(DATA_INSTALL_FLAGS) $< $@
222
223EXPORT_MD_INC_FILES = $(addprefix $(OBJROOT)/$(EXPDIR)/$(EXPORT_MD_DIR)/, $(EXPORT_MD_LIST))
224EXPORT_MD_GEN_INC_FILES = $(addprefix $(OBJROOT)/$(EXPDIR)/$(EXPORT_MD_DIR)/, $(EXPORT_MD_GEN_LIST))
225
226.PHONY: EXP_MD_INC_DIR
227
228EXP_MD_INC_DIR:
229 $(_v)$(MKDIR) $(OBJROOT)/$(EXPDIR)/$(EXPORT_MD_DIR)
230
231$(EXPORT_MD_GEN_INC_FILES): $(OBJROOT)/$(EXPDIR)/$(EXPORT_MD_DIR)/% : % | EXP_MD_INC_DIR
232 $(_v)$(INSTALL) $(DATA_INSTALL_FLAGS) $< $@
233
234$(EXPORT_MD_INC_FILES): $(OBJROOT)/$(EXPDIR)/$(EXPORT_MD_DIR)/% : $(SOURCE)/% | EXP_MD_INC_DIR
235 $(_v)$(INSTALL) $(DATA_INSTALL_FLAGS) $< $@
236
237.PHONY: do_exporthdrs_mi
238
239do_exporthdrs_mi: $(EXPORT_MI_GEN_INC_FILES) $(EXPORT_MI_INC_FILES)
240 @:
241
242.PHONY: do_exporthdrs_md
243
244do_exporthdrs_md: $(EXPORT_MD_GEN_INC_FILES) $(EXPORT_MD_INC_FILES)
245 @:
246
247#
248# Generic Compilation rules
249#
250
251#
252# Compilation rules to generate .o from .s
253#
254
255S_RULE_0=@echo "$(ColorC)AS$(Color0) $(ColorF)$@$(Color0)"
256S_RULE_1A=$(_v)${S_KCC} -c ${SFLAGS} -MD -MF $(@:o=d) -MP ${$@_SFLAGS_ADD} ${INCFLAGS} ${$@_INCFLAGS}
257S_RULE_1B=$(<F)
258S_RULE_2=
259
260#
261# Compilation rules to generate .o from .c for normal files
262#
263C_RULE_0=@echo "$(ColorC)CC$(Color0) $(ColorF)$@$(Color0)"
264C_RULE_1A=$(_v)${KCC} -c ${filter-out ${$@_CFLAGS_RM}, ${CFLAGS} ${CWARNFLAGS}} -MD -MF $(@:o=d) -MP ${$@_CFLAGS_ADD} ${$@_CWARNFLAGS_ADD} ${INCFLAGS} ${$@_INCFLAGS}
265C_RULE_1B=$(<F)
266ifeq ($(BUILD_MACHO_OBJ),0)
267C_RULE_2=
268else ifeq ($(DO_CTFCONVERT),1)
269C_RULE_2=$(_v)if [ -z "${$@_SKIP_CTFCONVERT}" ]; then \
270 ctferr=`${CTFCONVERT} -l xnu -v -o $@.ctf $@ 2>&1 > /dev/null || true`; \
271 if [ ! -z "$${ctferr}" ]; then \
272 echo "[$(CMD_MC)] $(ColorErr)$@$(Color0) $(ColorErr)$${ctferr}$(Color0)"; \
273 fi; \
274 fi
275else
276C_RULE_2=
277endif
278ifeq ($(DO_CTFMACHO), 1)
279C_CTFRULE_1A=$(_v)${KCC} -o $@.non_lto -c ${filter-out ${$@_CFLAGS_RM}, ${CFLAGS} ${CWARNFLAGS}} ${$@_CFLAGS_ADD} ${$@_CWARNFLAGS_ADD} ${INCFLAGS} $(CFLAGS_NOLTO_FLAG) ${$@_INCFLAGS}
280C_CTFRULE_1B=$(<F)
281C_CTFRULE_2=$(_v)if [ -z "${$@_SKIP_CTFCONVERT}" ]; then \
282 ctferr=`${CTFCONVERT} -l xnu -v -o $@.non_lto.ctf $@.non_lto 2>&1 > /dev/null || true`; \
283 if [ ! -z "$${ctferr}" ]; then \
284 echo "[$(CMD_MC)] $(ColorErr)$@$(Color0) $(ColorErr)$${ctferr}$(Color0)"; \
285 fi; \
286 fi
287else
288C_CTFRULE_1A=@true
289C_CTFRULE_1B=
290C_CTFRULE_2=@true
291endif
292
293C_RULE_3=@true
294C_RULE_4A=@true
295C_RULE_4B=
296
297#
298# Compilation rules to generate .o from .c for driver files
299#
300C_RULE_0_D=${C_RULE_0}
301C_RULE_1A_D=${C_RULE_1A}
302C_RULE_1B_D=${C_RULE_1B}
303C_RULE_2_D=${C_RULE_2}
304C_RULE_3_D=${C_RULE_3}
305C_RULE_4A_D=${C_RULE_4A}
306C_RULE_4B_D=${C_RULE_4B}
307C_CTFRULE_1A_D=${C_CTFRULE_1A}
308C_CTFRULE_1B_D=${C_CTFRULE_1B}
309C_CTFRULE_2_D=${C_CTFRULE_2}
310C_CTFRULE_3_D=${C_CTFRULE_3}
311
312#
313# Compilation rules to generate .co from .cp or .cpo from .cpp
314# The config tool slickly changes the last source filename char to 'o'
315# for the object filename.
316P_RULE_0=@echo "$(ColorC)C++$(Color0) $(ColorF)$@$(Color0)"
317P_RULE_1A=$(_v)${KC++} -o $@ -c ${CXXFLAGS} ${filter-out ${$@_CFLAGS_RM}, ${CFLAGS} ${CXXWARNFLAGS}} -MD -MF $(@:o=d) -MP ${$@_CFLAGS_ADD} ${$@_CXXWARNFLAGS_ADD} ${INCFLAGS} ${$@_INCFLAGS}
318P_RULE_1B=$(<F)
319P_RULE_2=
320P_CTFRULE_1A=@true
321P_CTFRULE_1B=
322P_CTFRULE_2=@true
323
324P_RULE_3=@true
325P_RULE_4A=@true
326P_RULE_4B=
327
328#
329# This isn't the right place to put this, but we need to := override some settings
330# in Makefiles that include the generic helper fragments (like this file)
331#
332ifeq ($(BUILD_JSON_COMPILATION_DATABASE),1)
333HIB_FILES :=
334LAST_FILES :=
335KLD_FILES :=
336endif
337
338.PHONY: do_build_all
339
340# Do-nothing rule, since not all levels of the recursive hierarchy might implement this
341# in their local Makefiles. Those that do will use a "::" rule to augment this.
342do_build_all::
343 @:
344
345.PHONY: do_build_install_primary
346
347# Do-nothing rule, since not all levels of the recursive hierarchy might implement this
348# in their local Makefiles. Those that do will use a "::" rule to augment this.
349do_build_install_primary::
350 @:
351
352.PHONY: do_build_install_non_primary
353
354# Do-nothing rule, since not all levels of the recursive hierarchy might implement this
355# in their local Makefiles. Those that do will use a "::" rule to augment this.
356do_build_install_non_primary::
357 @:
358
359INSTALL_MAN_FILES = $(addprefix $(DSTROOT)/$(MANDIR)/$(INSTALL_MAN_DIR)/, $(INSTALL_MAN_LIST))
360
361.PHONY: INSTALL_MAN_DIR
362
363INSTALL_MAN_DIR:
364 $(_v)$(MKDIR) $(DSTROOT)/$(MANDIR)/$(INSTALL_MAN_DIR)
365
366$(INSTALL_MAN_FILES): $(DSTROOT)/$(MANDIR)/$(INSTALL_MAN_DIR)/% : % | INSTALL_MAN_DIR
367 @echo "$(ColorH)MAN$(Color0) $(ColorF)$*$(Color0)"
368 $(_v)$(INSTALL) $(INSTALL_FLAGS) $< $@
369
370define MAN_LINKS_RULE_template
371$$(DSTROOT)/$$(MANDIR)/$$(INSTALL_MAN_DIR)/$(2): $$(DSTROOT)/$$(MANDIR)/$$(INSTALL_MAN_DIR)/$(1)
372 @echo "$$(ColorH)MANLINK$$(Color0) $$(ColorF)$(2)$$(Color0)"
373 $(_v)ln -f $$< $$@
374endef
375
376function_generate_man_links_rules = $(if $(word 1,$(1)),$(eval $(call MAN_LINKS_RULE_template,$(word 1,$(1)),$(word 2,$(1)))) $(DSTROOT)/$(MANDIR)/$(INSTALL_MAN_DIR)/$(word 2,$(1)) $(call function_generate_man_links_rules,$(wordlist 3,$(words $(1)),$(1))))
377
378INSTALL_MAN_FILES_LINKS = $(call function_generate_man_links_rules,$(INSTALL_MAN_LINKS))
379
380.PHONY: do_installman
381
382do_installman: $(INSTALL_MAN_FILES) $(INSTALL_MAN_FILES_LINKS)
383 @:
384
385.PHONY: do_textfiles_install
386
387# Do-nothing rule, since not all levels of the recursive hierarchy might implement this
388# in their local Makefiles. Those that do will use a "::" rule to augment this.
389do_textfiles_install:: do_installman
390 @:
391
392.PHONY: do_build_setup
393
394# Do-nothing rule, since not all levels of the recursive hierarchy might implement this
395# in their local Makefiles. Those that do will use a "::" rule to augment this.
396do_build_setup::
397 @:
398
399.PHONY: do_config_all
400
401# Do-nothing rule, since not all levels of the recursive hierarchy might implement this
402# in their local Makefiles. Those that do will use a "::" rule to augment this.
403do_config_all::
404 @:
405
406.PHONY: do_config_install
407
408# Do-nothing rule, since not all levels of the recursive hierarchy might implement this
409# in their local Makefiles. Those that do will use a "::" rule to augment this.
410do_config_install::
411 @:
412
413# vim: set ft=make: