xref: /xnu-11215.61.5/makedefs/MakeInc.kernel (revision 4f1223e81cd707a65cc109d0b8ad6653699da3c4)
1*4f1223e8SApple OSS Distributions# -*- mode: makefile;-*-
2*4f1223e8SApple OSS Distributions#
3*4f1223e8SApple OSS Distributions# Copyright (C) 1999-2020 Apple Inc. All rights reserved.
4*4f1223e8SApple OSS Distributions#
5*4f1223e8SApple OSS Distributions# MakeInc.kernel augments the single-architecture
6*4f1223e8SApple OSS Distributions# recursive build system with rules specific
7*4f1223e8SApple OSS Distributions# to assembling and linking a kernel.
8*4f1223e8SApple OSS Distributions#
9*4f1223e8SApple OSS Distributions
10*4f1223e8SApple OSS Distributions#
11*4f1223e8SApple OSS Distributions# Validate configuration options
12*4f1223e8SApple OSS Distributions#
13*4f1223e8SApple OSS Distributionsifeq ($(filter $(CURRENT_ARCH_CONFIG),$(SUPPORTED_ARCH_CONFIGS)),)
14*4f1223e8SApple OSS Distributions$(error Unsupported CURRENT_ARCH_CONFIG $(CURRENT_ARCH_CONFIG))
15*4f1223e8SApple OSS Distributionsendif
16*4f1223e8SApple OSS Distributions
17*4f1223e8SApple OSS Distributionsifeq ($(filter $(CURRENT_KERNEL_CONFIG),$(SUPPORTED_KERNEL_CONFIGS)),)
18*4f1223e8SApple OSS Distributions$(error Unsupported CURRENT_KERNEL_CONFIG $(CURRENT_KERNEL_CONFIG))
19*4f1223e8SApple OSS Distributionsendif
20*4f1223e8SApple OSS Distributions
21*4f1223e8SApple OSS Distributionsifeq ($(filter $(CURRENT_MACHINE_CONFIG),$(SUPPORTED_$(CURRENT_ARCH_CONFIG)_MACHINE_CONFIGS)),)
22*4f1223e8SApple OSS Distributions$(error Unsupported CURRENT_MACHINE_CONFIG $(CURRENT_MACHINE_CONFIG))
23*4f1223e8SApple OSS Distributionsendif
24*4f1223e8SApple OSS Distributions
25*4f1223e8SApple OSS Distributionsifeq ($(filter $(PLATFORM),$(SUPPORTED_PLATFORMS)),)
26*4f1223e8SApple OSS Distributions$(error Unsupported PLATFORM $(PLATFORM))
27*4f1223e8SApple OSS Distributionsendif
28*4f1223e8SApple OSS Distributions
29*4f1223e8SApple OSS Distributions# Generate xnu version file early (from build environment or SDK/KDK)
30*4f1223e8SApple OSS Distributionsdo_build_setup:: $(XNU_VERSION)
31*4f1223e8SApple OSS Distributions
32*4f1223e8SApple OSS Distributionsifeq ($(BUILD_STATIC_LINK),1)
33*4f1223e8SApple OSS Distributionsifeq ($(USE_LTO),1)
34*4f1223e8SApple OSS Distributions# <rdar://problem/46252406>
35*4f1223e8SApple OSS Distributions# To run LTO in the xnu project while linking the final result in KCB, without losing debugging info,
36*4f1223e8SApple OSS Distributions# run ld -r on only the LTO bitcode object files to produce one mach-o for KCB to use, which is added
37*4f1223e8SApple OSS Distributions# to the static link archive, along with the non-LTO objects (not linked, since ld -r on mach-o objects
38*4f1223e8SApple OSS Distributions# does not preserve DWARF.)
39*4f1223e8SApple OSS DistributionsPRE_LTO=1
40*4f1223e8SApple OSS Distributionsendif
41*4f1223e8SApple OSS Distributionsendif
42*4f1223e8SApple OSS Distributions
43*4f1223e8SApple OSS Distributions#
44*4f1223e8SApple OSS Distributions# Rules for the highly parallel "build" phase, where each build configuration
45*4f1223e8SApple OSS Distributions# writes into their own $(TARGET) independent of other build configs
46*4f1223e8SApple OSS Distributions#
47*4f1223e8SApple OSS Distributions# There are 5 primary build outputs:
48*4f1223e8SApple OSS Distributions# 1) $(KERNEL_FILE_NAME).unstripped    (raw linked kernel, unstripped)
49*4f1223e8SApple OSS Distributions# 2) $(KERNEL_FILE_NAME)               (stripped kernel, with optional CTF data)
50*4f1223e8SApple OSS Distributions# 3) $(KERNEL_FILE_NAME).dSYM          (dSYM)
51*4f1223e8SApple OSS Distributions# 4) $(KERNEL_FILE_NAME).link          (bits for static linking)
52*4f1223e8SApple OSS Distributions# 5) lib$(KERNEL_FILE_NAME).a          (static archive for testing)
53*4f1223e8SApple OSS Distributions
54*4f1223e8SApple OSS Distributionsifeq ($(BUILD_STATIC_LINK),1)
55*4f1223e8SApple OSS Distributionsifeq ($(BUILD_XNU_LIBRARY),1)
56*4f1223e8SApple OSS Distributions
57*4f1223e8SApple OSS DistributionsKERNEL_STATIC_LINK_TARGETS = \
58*4f1223e8SApple OSS Distributions	$(TARGET)/lib$(KERNEL_FILE_NAME).a
59*4f1223e8SApple OSS DistributionsKERNEL_STATIC_LINK_DST = \
60*4f1223e8SApple OSS Distributions	$(DSTROOT)/$(INSTALL_KERNEL_DIR)/lib$(KERNEL_FILE_NAME).a
61*4f1223e8SApple OSS Distributions
62*4f1223e8SApple OSS Distributionselse
63*4f1223e8SApple OSS Distributions
64*4f1223e8SApple OSS DistributionsKERNEL_STATIC_LINK_TARGETS = \
65*4f1223e8SApple OSS Distributions	$(TARGET)/$(KERNEL_FILE_NAME).link/$(KERNEL_FILE_NAME).a
66*4f1223e8SApple OSS Distributions
67*4f1223e8SApple OSS DistributionsKERNEL_STATIC_LINK_DST = \
68*4f1223e8SApple OSS Distributions			$(DSTROOT)/$(INSTALL_KERNEL_DIR)/$(KERNEL_FILE_NAME).link/$(KERNEL_FILE_NAME).a             \
69*4f1223e8SApple OSS Distributions			$(DSTROOT)/$(INSTALL_KERNEL_DIR)/$(KERNEL_FILE_NAME).link/$(KERNEL_FILE_NAME).linkarguments \
70*4f1223e8SApple OSS Distributions			$(DSTROOT)/$(INSTALL_KERNEL_DIR)/$(KERNEL_FILE_NAME).link/$(KERNEL_FILE_NAME).linkarchives  \
71*4f1223e8SApple OSS Distributions			$(DSTROOT)/$(INSTALL_KERNEL_DIR)/$(KERNEL_FILE_NAME).link/$(KERNEL_FILE_NAME).exp           \
72*4f1223e8SApple OSS Distributions			$(DSTROOT)/$(INSTALL_KERNEL_DIR)/$(KERNEL_FILE_NAME).link/$(KERNEL_FILE_NAME).alias.exp     \
73*4f1223e8SApple OSS Distributions			$(DSTROOT)/$(INSTALL_KERNEL_DIR)/$(KERNEL_FILE_NAME).link/$(KERNEL_FILE_NAME).dSYM/$(DSYMLLDBMACROSDIR)/lldbmacros                   \
74*4f1223e8SApple OSS Distributions			$(DSTROOT)/$(INSTALL_KERNEL_DIR)/$(KERNEL_FILE_NAME).link/$(KERNEL_FILE_NAME).dSYM/$(DSYMLLDBMACROSDIR)/$(KERNEL_LLDBBOOTSTRAP_NAME)
75*4f1223e8SApple OSS Distributions
76*4f1223e8SApple OSS Distributionsendif
77*4f1223e8SApple OSS Distributionsendif
78*4f1223e8SApple OSS Distributions
79*4f1223e8SApple OSS Distributionsdo_build_all:: do_build_kernel
80*4f1223e8SApple OSS Distributions
81*4f1223e8SApple OSS Distributions.PHONY: do_build_kernel
82*4f1223e8SApple OSS Distributions
83*4f1223e8SApple OSS Distributionsifeq ($(BUILD_XNU_LIBRARY),1)
84*4f1223e8SApple OSS Distributionsdo_build_kernel: $(KERNEL_STATIC_LINK_TARGETS)
85*4f1223e8SApple OSS Distributions
86*4f1223e8SApple OSS Distributionselse
87*4f1223e8SApple OSS Distributions
88*4f1223e8SApple OSS Distributionsdo_build_kernel: $(TARGET)/$(KERNEL_FILE_NAME) $(TARGET)/$(KERNEL_FILE_NAME).unstripped $(KERNEL_STATIC_LINK_TARGETS)
89*4f1223e8SApple OSS Distributions	@:
90*4f1223e8SApple OSS Distributions
91*4f1223e8SApple OSS Distributionsifeq ($(BUILD_DSYM),1)
92*4f1223e8SApple OSS Distributionsdo_build_all:: do_build_kernel_dSYM
93*4f1223e8SApple OSS Distributionsendif
94*4f1223e8SApple OSS Distributions
95*4f1223e8SApple OSS Distributions.PHONY: do_build_kernel_dSYM
96*4f1223e8SApple OSS Distributions
97*4f1223e8SApple OSS Distributionsdo_build_kernel_dSYM: $(TARGET)/$(KERNEL_FILE_NAME).dSYM
98*4f1223e8SApple OSS Distributions	@:
99*4f1223e8SApple OSS Distributions
100*4f1223e8SApple OSS Distributionsendif
101*4f1223e8SApple OSS Distributions
102*4f1223e8SApple OSS Distributionsdo_build_all:: do_build_compile_commands_json
103*4f1223e8SApple OSS Distributions
104*4f1223e8SApple OSS Distributions.PHONY: do_build_compile_commands_json
105*4f1223e8SApple OSS Distributions
106*4f1223e8SApple OSS Distributionsdo_build_compile_commands_json: $(TARGET)/compile_commands.json
107*4f1223e8SApple OSS Distributions	@:
108*4f1223e8SApple OSS Distributions
109*4f1223e8SApple OSS Distributions.LDFLAGS: ALWAYS
110*4f1223e8SApple OSS Distributions	$(_v)$(REPLACECONTENTS) $@ $(LD) $(LDFLAGS_KERNEL) $(LDFLAGS_KERNEL_ONLY) $(LD_KERNEL_LIBS)
111*4f1223e8SApple OSS Distributions.CFLAGS: ALWAYS
112*4f1223e8SApple OSS Distributions	$(_v)$(REPLACECONTENTS) $@ $(KCC) $(CFLAGS) $(INCFLAGS)
113*4f1223e8SApple OSS Distributions
114*4f1223e8SApple OSS Distributions
115*4f1223e8SApple OSS Distributions#
116*4f1223e8SApple OSS Distributions# CTF generation requires the following files:
117*4f1223e8SApple OSS Distributions
118*4f1223e8SApple OSS Distributions#     kernel.unstripped.noctf  Unstripped kernel with no CTF
119*4f1223e8SApple OSS Distributions#     kernel.ctf               CTF from the dSYM associated with kernel.unstripped.noctf
120*4f1223e8SApple OSS Distributions#     kernel.unstripped        kernel.unstripped.noctf merged with kernel.ctf (Debug Rich Executable)
121*4f1223e8SApple OSS Distributions#     kernel                   Stripped kernel.unstripped.noctf merged with kernel.ctf (Final Kernel)
122*4f1223e8SApple OSS Distributions
123*4f1223e8SApple OSS Distributions# Note: "kernel" here is a placeholder for the actual name of the kernel which
124*4f1223e8SApple OSS Distributions# varies.
125*4f1223e8SApple OSS Distributions#
126*4f1223e8SApple OSS Distributions
127*4f1223e8SApple OSS Distributions
128*4f1223e8SApple OSS Distributions# Convert DWARF to CTF
129*4f1223e8SApple OSS Distributions$(TARGET)/$(KERNEL_FILE_NAME).ctf: $(TARGET)/$(KERNEL_FILE_NAME).dSYM $(TARGET)/$(KERNEL_FILE_NAME).unstripped.noctf
130*4f1223e8SApple OSS Distributionsifeq ($(DO_CTFMERGE),1)
131*4f1223e8SApple OSS Distributions	@$(LOG_CTFCONVERT) "$(@F)"
132*4f1223e8SApple OSS Distributions	$(_v)$(CTFCONVERT) -c -l xnu -u xnu -o $@ $(TARGET)/$(KERNEL_FILE_NAME).dSYM/Contents/Resources/DWARF/$(KERNEL_FILE_NAME)
133*4f1223e8SApple OSS Distributionsendif
134*4f1223e8SApple OSS Distributions
135*4f1223e8SApple OSS Distributions# Strip the kernel and merge in the CTF
136*4f1223e8SApple OSS Distributions$(TARGET)/$(KERNEL_FILE_NAME): $(TARGET)/$(KERNEL_FILE_NAME).unstripped.noctf $(TARGET)/$(KERNEL_FILE_NAME).dSYM $(TARGET)/$(KERNEL_FILE_NAME).ctf
137*4f1223e8SApple OSS Distributions	@$(LOG_STRIP) "$(@F)"
138*4f1223e8SApple OSS Distributions	$(_v)$(STRIP) $(STRIP_FLAGS) $< -o $@
139*4f1223e8SApple OSS Distributions	@echo "built kernel at $@"
140*4f1223e8SApple OSS Distributions	$(_v)$(RM) [email protected]
141*4f1223e8SApple OSS Distributionsifeq ($(DO_CTFMERGE),1)
142*4f1223e8SApple OSS Distributions	@$(LOG_CTFMERGE) "$(@F)"
143*4f1223e8SApple OSS Distributions	$(_v)$(CTFMERGE) -l xnu -o $@ -Z [email protected] [email protected]
144*4f1223e8SApple OSS Distributions	$(_v)if [ -s [email protected] ]; then                          \
145*4f1223e8SApple OSS Distributions		$(LOG_CTFINSERT) "$(@F)";                            \
146*4f1223e8SApple OSS Distributions		$(CTFINSERT) $@	$(ARCH_FLAGS_$(CURRENT_ARCH_CONFIG)) \
147*4f1223e8SApple OSS Distributions			     [email protected] -o $@;                           \
148*4f1223e8SApple OSS Distributions	else                                                     \
149*4f1223e8SApple OSS Distributions	    exit 1;                                              \
150*4f1223e8SApple OSS Distributions	fi;
151*4f1223e8SApple OSS Distributions	-$(_v)$(CTFDUMP) -S $@ $(_vstdout) $(_vstderr)
152*4f1223e8SApple OSS Distributionsendif
153*4f1223e8SApple OSS Distributions	$(_v)$(LN) $(call function_convert_build_config_to_objdir,$(CURRENT_BUILD_CONFIG))/$(KERNEL_FILE_NAME) $(OBJROOT)/$(KERNEL_FILE_NAME)
154*4f1223e8SApple OSS Distributions
155*4f1223e8SApple OSS Distributions# Merge the CTF into the unstripped kernel (Debug Rich Executable)
156*4f1223e8SApple OSS Distributions$(TARGET)/$(KERNEL_FILE_NAME).unstripped: $(TARGET)/$(KERNEL_FILE_NAME).ctf $(TARGET)/$(KERNEL_FILE_NAME).unstripped.noctf
157*4f1223e8SApple OSS Distributions	$(_v)$(CP) $(TARGET)/$(KERNEL_FILE_NAME).unstripped.noctf $(TARGET)/$(KERNEL_FILE_NAME).unstripped
158*4f1223e8SApple OSS Distributions	$(_v)$(RM) [email protected]
159*4f1223e8SApple OSS Distributionsifeq ($(DO_CTFMERGE),1)
160*4f1223e8SApple OSS Distributions	@$(LOG_CTFMERGE) "$(@F)"
161*4f1223e8SApple OSS Distributions	$(_v)$(CTFMERGE) -l xnu -o $@ -Z [email protected] $(TARGET)/$(KERNEL_FILE_NAME).ctf
162*4f1223e8SApple OSS Distributions	$(_v)if [ -s [email protected] ]; then                          \
163*4f1223e8SApple OSS Distributions		$(LOG_CTFINSERT) "$(@F)";                            \
164*4f1223e8SApple OSS Distributions		$(CTFINSERT) $@	$(ARCH_FLAGS_$(CURRENT_ARCH_CONFIG)) \
165*4f1223e8SApple OSS Distributions			     [email protected] -o $@;                           \
166*4f1223e8SApple OSS Distributions	else                                                     \
167*4f1223e8SApple OSS Distributions	    exit 1;                                              \
168*4f1223e8SApple OSS Distributions	fi;
169*4f1223e8SApple OSS Distributions	-$(_v)$(CTFDUMP) -S $@ $(_vstdout) $(_vstderr)
170*4f1223e8SApple OSS Distributionsendif
171*4f1223e8SApple OSS Distributions
172*4f1223e8SApple OSS Distributions$(TARGET)/$(KERNEL_FILE_NAME).dSYM: $(TARGET)/$(KERNEL_FILE_NAME).unstripped.noctf
173*4f1223e8SApple OSS Distributionsifeq ($(BUILD_DSYM),1)
174*4f1223e8SApple OSS Distributions	@$(LOG_DSYMUTIL) "$(@F)"
175*4f1223e8SApple OSS Distributions	$(_v)$(BASH) -c "$(DSYMUTIL) $(DSYMUTIL_FLAGS) $< -o $@ $(_vstdout) 2> >(grep -v '^warning:.*could not find object file symbol for symbol' 1>&2)"
176*4f1223e8SApple OSS Distributions	$(_v)$(MV) $@/$(DSYMDWARFDIR)/$(KERNEL_FILE_NAME).unstripped.noctf $@/$(DSYMDWARFDIR)/$(KERNEL_FILE_NAME)
177*4f1223e8SApple OSS Distributionselse
178*4f1223e8SApple OSS Distributions	$(_v)$(MKDIR) $@
179*4f1223e8SApple OSS Distributionsendif
180*4f1223e8SApple OSS Distributions	$(_v)$(TOUCH) $@
181*4f1223e8SApple OSS Distributions
182*4f1223e8SApple OSS Distributionsifeq ($(BUILD_XNU_LIBRARY),1)
183*4f1223e8SApple OSS Distributions$(TARGET)/lib$(KERNEL_FILE_NAME).a: $(addprefix $(TARGET)/,$(foreach component,$(COMPONENT_LIST),$(component)/$(CURRENT_KERNEL_CONFIG)/$(component).libfilelist)) nonlto.o version.o .LDFLAGS $(filter %/MakeInc.kernel,$(MAKEFILE_LIST))
184*4f1223e8SApple OSS Distributions	@$(LOG_LIBTOOL) "$(@F)"
185*4f1223e8SApple OSS Distributions	$(_v)$(CAT) $(filter %.libfilelist,$+) < /dev/null > link.filelist
186*4f1223e8SApple OSS Distributions	$(_v)$(LIBTOOL) -static -csD -filelist link.filelist -o $@
187*4f1223e8SApple OSS Distributions	$(_v)$(LN) $(call function_convert_build_config_to_objdir,$(CURRENT_BUILD_CONFIG))/lib$(KERNEL_FILE_NAME).a $(OBJROOT)/lib$(KERNEL_FILE_NAME).a
188*4f1223e8SApple OSS Distributionsendif
189*4f1223e8SApple OSS Distributions
190*4f1223e8SApple OSS Distributions$(TARGET)/$(KERNEL_FILE_NAME).unstripped.noctf: $(addprefix $(TARGET)/,$(foreach component,$(COMPONENT_LIST),$(component)/$(CURRENT_KERNEL_CONFIG)/$(component).filelist)) lastkerneldataconst.o lastkernelconstructor.o nonlto.o version.o $(LDFILES_KERNEL_ONLY) .LDFLAGS $(filter %/MakeInc.kernel,$(MAKEFILE_LIST))
191*4f1223e8SApple OSS Distributionsifeq ($(PRE_LTO),1)
192*4f1223e8SApple OSS Distributions	@$(LOG_LTO) "$(@F)"
193*4f1223e8SApple OSS Distributions	$(_v)$(RM) ltolink.filelist
194*4f1223e8SApple OSS Distributions	$(_v)$(RM) nonltolink.filelist
195*4f1223e8SApple OSS Distributions	$(_v)$(RM) -r $(TARGET)/justlto.o
196*4f1223e8SApple OSS Distributions	$(_v)files="$$($(CAT) $(filter %.filelist,$+)) $(filter %.o,$+)"; \
197*4f1223e8SApple OSS Distributions	for ofile in $$files; \
198*4f1223e8SApple OSS Distributions	do \
199*4f1223e8SApple OSS Distributions		hdr=$$(od -An -N 4 -t x4 $$ofile); \
200*4f1223e8SApple OSS Distributions		if [ $$hdr = "0b17c0de" ]; \
201*4f1223e8SApple OSS Distributions			then \
202*4f1223e8SApple OSS Distributions				if [ -z "$$lto" ]; \
203*4f1223e8SApple OSS Distributions					then \
204*4f1223e8SApple OSS Distributions						lto="$$ofile"; \
205*4f1223e8SApple OSS Distributions					else \
206*4f1223e8SApple OSS Distributions						lto="$$(printf '%s\n%s' "$$lto" "$$ofile")"; \
207*4f1223e8SApple OSS Distributions				fi; \
208*4f1223e8SApple OSS Distributions			else \
209*4f1223e8SApple OSS Distributions				if [ -z "$$nonlto" ]; \
210*4f1223e8SApple OSS Distributions					then \
211*4f1223e8SApple OSS Distributions						nonlto="$$ofile"; \
212*4f1223e8SApple OSS Distributions					else \
213*4f1223e8SApple OSS Distributions						nonlto="$$(printf '%s\n%s' "$$nonlto" "$$ofile")"; \
214*4f1223e8SApple OSS Distributions				fi; \
215*4f1223e8SApple OSS Distributions			fi; \
216*4f1223e8SApple OSS Distributions	done; \
217*4f1223e8SApple OSS Distributions	printf '%s\n' "$$lto" >ltolink.filelist; \
218*4f1223e8SApple OSS Distributions	printf '%s\n' "$$nonlto" >nonltolink.filelist
219*4f1223e8SApple OSS Distributions	@$(LOG_LD) "$(@F)"
220*4f1223e8SApple OSS Distributions	$(_v)if [ -s ltolink.filelist ]; \
221*4f1223e8SApple OSS Distributions	then \
222*4f1223e8SApple OSS Distributions		$(LD) $($(addsuffix $(CURRENT_ARCH_CONFIG),ARCH_FLAGS_)) -r nonlto.o -filelist ltolink.filelist $(LDFLAGS_KERNEL_LTO) -Wl,-object_path_lto,$(TARGET)/justlto.o -o $(TARGET)/justlto.tmp.o && \
223*4f1223e8SApple OSS Distributions		if test -d $(TARGET)/justlto.o; \
224*4f1223e8SApple OSS Distributions		then \
225*4f1223e8SApple OSS Distributions		    $(LD) $(LDFLAGS_KERNEL) $(LDFLAGS_KERNEL_ONLY) -filelist nonltolink.filelist $(TARGET)/justlto.o/*.o $(LDFLAGS_KERNEL_STRIP_LTO) -o $@ $(LD_KERNEL_LIBS) $(LD_KERNEL_ARCHIVES); \
226*4f1223e8SApple OSS Distributions		else \
227*4f1223e8SApple OSS Distributions		    $(LD) $(LDFLAGS_KERNEL) $(LDFLAGS_KERNEL_ONLY) -filelist nonltolink.filelist $(TARGET)/justlto.o $(LDFLAGS_KERNEL_STRIP_LTO) -o $@ $(LD_KERNEL_LIBS) $(LD_KERNEL_ARCHIVES); \
228*4f1223e8SApple OSS Distributions		fi; \
229*4f1223e8SApple OSS Distributions	else \
230*4f1223e8SApple OSS Distributions		$(LD) $(LDFLAGS_KERNEL) $(LDFLAGS_KERNEL_ONLY) -filelist nonltolink.filelist -o $@ $(LD_KERNEL_LIBS) $(LD_KERNEL_ARCHIVES); \
231*4f1223e8SApple OSS Distributions	fi
232*4f1223e8SApple OSS Distributionselse
233*4f1223e8SApple OSS Distributions	@$(LOG_LD) "$(@F)"
234*4f1223e8SApple OSS Distributions	$(_v)$(CAT) $(filter %.filelist,$+) < /dev/null > link.filelist
235*4f1223e8SApple OSS Distributions	$(_v)$(LD) $(LDFLAGS_KERNEL) $(LDFLAGS_KERNEL_ONLY) -filelist link.filelist $(filter %.o,$+) -o $@ $(LD_KERNEL_LIBS) $(LD_KERNEL_ARCHIVES)
236*4f1223e8SApple OSS Distributionsendif
237*4f1223e8SApple OSS Distributions
238*4f1223e8SApple OSS Distributions$(TARGET)/compile_commands.json: $(addprefix $(TARGET)/,$(foreach component,$(COMPONENT_LIST),$(component)/$(CURRENT_KERNEL_CONFIG)/$(component).filelist))
239*4f1223e8SApple OSS Distributions	$(_v)files="$$(sed -e 's/$$/.json/' $(filter %.filelist,$+))"; \
240*4f1223e8SApple OSS Distributions	sed -e '1s/^/[\'$$'\n''/' -e '$$s/,$$/\'$$'\n'']/' $$files > compile_commands.json
241*4f1223e8SApple OSS Distributions
242*4f1223e8SApple OSS Distributions# for now, rename LASTDATA_CONST to LAST on static kernel cache builds
243*4f1223e8SApple OSS DistributionsEXTRA_KC_LINKARGS = -Wl,-rename_segment,__LASTDATA_CONST,__LAST
244*4f1223e8SApple OSS Distributions
245*4f1223e8SApple OSS Distributions$(TARGET)/$(KERNEL_FILE_NAME).link/$(KERNEL_FILE_NAME).a:   $(TARGET)/$(KERNEL_FILE_NAME).unstripped .LDFLAGS $(filter %/MakeInc.kernel,$(MAKEFILE_LIST))
246*4f1223e8SApple OSS Distributions	@$(LOG_LIBTOOL) "$(@F)"
247*4f1223e8SApple OSS Distributions	$(_v)$(MKDIR) $(dir $@)
248*4f1223e8SApple OSS Distributionsifeq ($(PRE_LTO),1)
249*4f1223e8SApple OSS Distributions	$(_v)if [ -d $(TARGET)/justlto.o ]; \
250*4f1223e8SApple OSS Distributions	then \
251*4f1223e8SApple OSS Distributions	    $(LIBTOOL) -ca $(TARGET)/justlto.o/*.o -filelist nonltolink.filelist -o $@; \
252*4f1223e8SApple OSS Distributions	else \
253*4f1223e8SApple OSS Distributions	    $(LIBTOOL) -ca $(TARGET)/justlto.o -filelist nonltolink.filelist -o $@; \
254*4f1223e8SApple OSS Distributions	fi
255*4f1223e8SApple OSS Distributionselse
256*4f1223e8SApple OSS Distributions	$(_v)$(LIBTOOL) -ca -filelist link.filelist version.o lastkerneldataconst.o lastkernelconstructor.o -o $@
257*4f1223e8SApple OSS Distributionsendif
258*4f1223e8SApple OSS Distributions	$(_v)cp $(TARGET)/all-kpi.exp $(TARGET)/$(KERNEL_FILE_NAME).link/$(KERNEL_FILE_NAME).exp
259*4f1223e8SApple OSS Distributions	$(_v)cp $(TARGET)/all-alias.exp $(TARGET)/$(KERNEL_FILE_NAME).link/$(KERNEL_FILE_NAME).alias.exp
260*4f1223e8SApple OSS Distributions	$(_v)echo "$(LD_KERNEL_ARCHIVES)" >$(TARGET)/$(KERNEL_FILE_NAME).link/$(KERNEL_FILE_NAME).linkarchives
261*4f1223e8SApple OSS Distributions	$(_v)echo "$(LDFLAGS_KERNEL) $(LD_KERNEL_LIBS) $(EXTRA_KC_LINKARGS)" >$(TARGET)/$(KERNEL_FILE_NAME).link/$(KERNEL_FILE_NAME).linkarguments
262*4f1223e8SApple OSS Distributions	$(_v)$(LN) $(call function_convert_build_config_to_objdir,$(CURRENT_BUILD_CONFIG))/$(KERNEL_FILE_NAME).link $(OBJROOT)/$(KERNEL_FILE_NAME).link
263*4f1223e8SApple OSS Distributions
264*4f1223e8SApple OSS Distributionsnonlto.o: .CFLAGS $(filter %/MakeInc.kernel,$(MAKEFILE_LIST))
265*4f1223e8SApple OSS Distributionsnonlto.o:   $(SRCROOT)/libsa/nonlto.c
266*4f1223e8SApple OSS Distributions	${C_RULE_0}
267*4f1223e8SApple OSS Distributions	${C_RULE_1A}$< $(CFLAGS_NOLTO_FLAG)
268*4f1223e8SApple OSS Distributions	${C_RULE_2}
269*4f1223e8SApple OSS Distributions
270*4f1223e8SApple OSS Distributions-include version.d
271*4f1223e8SApple OSS Distributionsversion.o: .CFLAGS $(filter %/MakeInc.kernel,$(MAKEFILE_LIST))
272*4f1223e8SApple OSS Distributionsversion.o: $(OBJPATH)/version.c
273*4f1223e8SApple OSS Distributions	${C_RULE_0}
274*4f1223e8SApple OSS Distributions	${C_RULE_1A}$<
275*4f1223e8SApple OSS Distributions	${C_RULE_2}
276*4f1223e8SApple OSS Distributions	${C_RULE_4}
277*4f1223e8SApple OSS Distributions
278*4f1223e8SApple OSS Distributions$(OBJPATH)/version.c: $(SRCROOT)/config/version.c.template $(NEWVERS) $(XNU_VERSION)
279*4f1223e8SApple OSS Distributions	$(_v)$(CP) $< $@
280*4f1223e8SApple OSS Distributions	$(_v)$(NEWVERS) $@ > /dev/null;
281*4f1223e8SApple OSS Distributions
282*4f1223e8SApple OSS Distributions# Generate xnuVersion file from B&I env var or the System.kext/Info.plist
283*4f1223e8SApple OSS Distributions# found in the SDK or KDK. Only update the file if the version number has
284*4f1223e8SApple OSS Distributions# actually changed to avoid rebuilding dependent source files unnecessarily.
285*4f1223e8SApple OSS Distributionsifeq ($(origin RC_DARWIN_KERNEL_VERSION), undefined)
286*4f1223e8SApple OSS DistributionsSDK_SYSTEM_KEXT_INFO_PLIST := $(firstword $(wildcard $(addsuffix $(SYSTEM_KEXT_INFO_PLIST),$(SDKROOT_RESOLVED) $(KDKROOT))))
287*4f1223e8SApple OSS Distributionsifneq ($(SDK_SYSTEM_KEXT_INFO_PLIST),)
288*4f1223e8SApple OSS DistributionsRC_DARWIN_KERNEL_VERSION := $(strip $(shell $(PLUTIL) -extract CFBundleVersion raw -n $(SDK_SYSTEM_KEXT_INFO_PLIST)))
289*4f1223e8SApple OSS Distributionsendif
290*4f1223e8SApple OSS Distributionsendif
291*4f1223e8SApple OSS Distributionsifeq ($(RC_DARWIN_KERNEL_VERSION),)
292*4f1223e8SApple OSS Distributions$(error Could not determine xnu version from SDK or KDK! Set RC_DARWIN_KERNEL_VERSION environment variable.)
293*4f1223e8SApple OSS Distributionsendif
294*4f1223e8SApple OSS DistributionsEXISTING_KERNEL_VERSION := $(strip $(shell test -r $(XNU_VERSION) && head -1 $(XNU_VERSION)))
295*4f1223e8SApple OSS Distributionsifneq ($(EXISTING_KERNEL_VERSION), $(RC_DARWIN_KERNEL_VERSION))
296*4f1223e8SApple OSS Distributions$(XNU_VERSION): ALWAYS
297*4f1223e8SApple OSS Distributions	@$(LOG_GENERATE) "$(notdir $@)$(Color0) with version \"$(ColorF)$(RC_DARWIN_KERNEL_VERSION)$(Color0)\""
298*4f1223e8SApple OSS Distributions	$(_v)printf > $@ '%s\n' "$(RC_DARWIN_KERNEL_VERSION)"
299*4f1223e8SApple OSS Distributionselse ifeq ($(VERBOSE),YES)
300*4f1223e8SApple OSS Distributions$(XNU_VERSION): ALWAYS
301*4f1223e8SApple OSS Distributions	@echo "xnuVersion unchanged: checked for \"$(RC_DARWIN_KERNEL_VERSION)\" in $@"
302*4f1223e8SApple OSS Distributionsendif
303*4f1223e8SApple OSS Distributions
304*4f1223e8SApple OSS Distributions-include lastkerneldataconst.d
305*4f1223e8SApple OSS Distributionslastkerneldataconst.o: .CFLAGS $(filter %/MakeInc.kernel,$(MAKEFILE_LIST))
306*4f1223e8SApple OSS Distributionslastkerneldataconst.o: $(SRCROOT)/libsa/lastkerneldataconst.c
307*4f1223e8SApple OSS Distributions	${C_RULE_0}
308*4f1223e8SApple OSS Distributions	${C_RULE_1A}$<
309*4f1223e8SApple OSS Distributions	${C_RULE_2}
310*4f1223e8SApple OSS Distributions
311*4f1223e8SApple OSS Distributions
312*4f1223e8SApple OSS Distributionslastkernelconstructor.o_CFLAGS_RM = -fprofile-instr-generate -fcoverage-mapping
313*4f1223e8SApple OSS Distributions# the LAST segment is mapped read-only on arm, so if we include llvm profiling
314*4f1223e8SApple OSS Distributions# here it will segfault the kernel.  (see arm_vm_init.c) We don't currently have
315*4f1223e8SApple OSS Distributions# a way of retrieving these counters from LAST anyway, so there's no harm in just
316*4f1223e8SApple OSS Distributions# disabling them.
317*4f1223e8SApple OSS Distributions
318*4f1223e8SApple OSS DistributionsLAST_FILES=lastkernelconstructor.o
319*4f1223e8SApple OSS Distributions-include lastkernelconstructor.d
320*4f1223e8SApple OSS Distributionslastkernelconstructor.o: .CFLAGS $(filter %/MakeInc.kernel,$(MAKEFILE_LIST))
321*4f1223e8SApple OSS Distributionslastkernelconstructor.o: $(SRCROOT)/libsa/lastkernelconstructor.c
322*4f1223e8SApple OSS Distributions	${C_RULE_0}
323*4f1223e8SApple OSS Distributions	${C_RULE_1A}$< $(CFLAGS_NOLTO_FLAG)
324*4f1223e8SApple OSS Distributions	${C_RULE_2}
325*4f1223e8SApple OSS Distributions	${C_RULE_3}
326*4f1223e8SApple OSS Distributions	${C_RULE_4}
327*4f1223e8SApple OSS Distributions	$(_v)for last_file in ${LAST_FILES};				\
328*4f1223e8SApple OSS Distributions	do							\
329*4f1223e8SApple OSS Distributions		$(SEG_HACK) -s __DATA -n __LASTDATA_CONST -o $${last_file}__ $${last_file} || exit 1; \
330*4f1223e8SApple OSS Distributions		mv $${last_file}__ $${last_file} || exit 1;		\
331*4f1223e8SApple OSS Distributions	done
332*4f1223e8SApple OSS DistributionsEXTRA_KC_LINKARGS = -Wl,-rename_segment,__LASTDATA_CONST,__LAST
333*4f1223e8SApple OSS Distributions
334*4f1223e8SApple OSS Distributions#
335*4f1223e8SApple OSS Distributions# Install rules. Each build config is classified as "primary" (the first
336*4f1223e8SApple OSS Distributions# config for an architecture) or "non-primary". Primary build configs
337*4f1223e8SApple OSS Distributions# have the semantic of competing to *combine* single-architecture
338*4f1223e8SApple OSS Distributions# files into a multi-architecture output in the DSTROOT, like
339*4f1223e8SApple OSS Distributions# $(DSTROOT)/$(KERNEL_FILE_NAME), and consequently each primary build config
340*4f1223e8SApple OSS Distributions# has its install target run serially with respect to other primary
341*4f1223e8SApple OSS Distributions# build configs. Non-primary build configs will never compete for
342*4f1223e8SApple OSS Distributions# files in the DSTROOT or SYMROOT, and can be installed in parallel
343*4f1223e8SApple OSS Distributions# with other non-primary configs (and even primary configs)
344*4f1223e8SApple OSS Distributions#
345*4f1223e8SApple OSS Distributions
346*4f1223e8SApple OSS Distributionsdo_build_install_primary:: do_install_machine_specific_kernel
347*4f1223e8SApple OSS Distributionsifeq ($(BUILD_DSYM),1)
348*4f1223e8SApple OSS Distributionsdo_build_install_primary:: do_install_machine_specific_kernel_dSYM
349*4f1223e8SApple OSS Distributionsendif
350*4f1223e8SApple OSS Distributions
351*4f1223e8SApple OSS Distributionsdo_build_install_non_primary:: do_install_machine_specific_kernel
352*4f1223e8SApple OSS Distributionsifeq ($(BUILD_DSYM),1)
353*4f1223e8SApple OSS Distributionsdo_build_install_non_primary:: do_install_machine_specific_kernel_dSYM
354*4f1223e8SApple OSS Distributionsendif
355*4f1223e8SApple OSS Distributions
356*4f1223e8SApple OSS Distributionsifeq ($(BUILD_DSYM),1)
357*4f1223e8SApple OSS Distributionsifeq ($(INSTALL_KERNEL_SYM_TO_KDK),1)
358*4f1223e8SApple OSS Distributionsdo_build_install_primary:: do_install_machine_specific_KDK_dSYM
359*4f1223e8SApple OSS Distributionsdo_build_install_non_primary:: do_install_machine_specific_KDK_dSYM
360*4f1223e8SApple OSS Distributionsendif
361*4f1223e8SApple OSS Distributionsendif
362*4f1223e8SApple OSS Distributions
363*4f1223e8SApple OSS Distributionsifneq ($(BUILD_XNU_LIBRARY),1)
364*4f1223e8SApple OSS Distributionsifeq ($(INSTALL_XNU_DEBUG_FILES),1)
365*4f1223e8SApple OSS Distributionsdo_build_install_primary:: do_install_xnu_debug_files
366*4f1223e8SApple OSS Distributionsendif
367*4f1223e8SApple OSS Distributions
368*4f1223e8SApple OSS Distributions.PHONY: do_install_xnu_debug_files
369*4f1223e8SApple OSS Distributions
370*4f1223e8SApple OSS Distributionsdo_install_xnu_debug_files:	$(DSTROOT)/$(DEVELOPER_EXTRAS_DIR)/README.DEBUG-kernel.txt
371*4f1223e8SApple OSS Distributions	@:
372*4f1223e8SApple OSS Distributionsendif
373*4f1223e8SApple OSS Distributions
374*4f1223e8SApple OSS Distributions#
375*4f1223e8SApple OSS Distributions# If the timestamp indicates the DSTROOT kernel is out of
376*4f1223e8SApple OSS Distributions# date, start over. Normal dependencies don't work because we can have
377*4f1223e8SApple OSS Distributions# ( BUILDA, BUILDB, INSTALLB, INSTALLA ) in which case at INSTALLA time
378*4f1223e8SApple OSS Distributions# the timestamps would $(DSTROOT)/$(KERNEL_FILE_NAME) is not out of date compared
379*4f1223e8SApple OSS Distributions# to BUILDA. So we maintain a separate file at the time make(1)
380*4f1223e8SApple OSS Distributions# was run and use it to determine what actions to take
381*4f1223e8SApple OSS Distributions#
382*4f1223e8SApple OSS Distributions
383*4f1223e8SApple OSS Distributions$(DSTROOT)/$(INSTALL_KERNEL_DIR)/$(KERNEL_FILE_NAME): $(TARGET)/$(KERNEL_FILE_NAME) ALWAYS
384*4f1223e8SApple OSS Distributions	$(_v)$(MKDIR) $(dir $@)
385*4f1223e8SApple OSS Distributions	@$(LOG_INSTALL) "$(@F)$(Color0) ($(ColorLF)$(CURRENT_ARCH_CONFIG_LC)$(Color0))"
386*4f1223e8SApple OSS Distributions    # -nt and -ot are evaluated differently by bash, dash, and zsh (and are not part of the POSIX specification).
387*4f1223e8SApple OSS Distributions    # Explicitly specify what should happen when the right hand file doesn't exist.
388*4f1223e8SApple OSS Distributions	$(_v)if [ $(OBJROOT)/.mach_kernel.timestamp -nt $@ -o \( -e $(OBJROOT)/.mach_kernel.timestamp -a \! -e $@ \) ]; then	\
389*4f1223e8SApple OSS Distributions		$(INSTALL) $(EXEC_INSTALL_FLAGS) $< $@;			\
390*4f1223e8SApple OSS Distributions		cmdstatus=$$?;						\
391*4f1223e8SApple OSS Distributions	else								\
392*4f1223e8SApple OSS Distributions		$(LIPO) -create $@ $< -output $@;			\
393*4f1223e8SApple OSS Distributions		cmdstatus=$$?;						\
394*4f1223e8SApple OSS Distributions	fi;								\
395*4f1223e8SApple OSS Distributions	exit $$cmdstatus
396*4f1223e8SApple OSS Distributions
397*4f1223e8SApple OSS Distributionsifeq ($(BUILD_STATIC_LINK),1)
398*4f1223e8SApple OSS Distributionsifeq ($(BUILD_XNU_LIBRARY),1)
399*4f1223e8SApple OSS Distributions
400*4f1223e8SApple OSS Distributions$(DSTROOT)/$(INSTALL_KERNEL_DIR)/lib$(KERNEL_FILE_NAME).a: $(TARGET)/lib$(KERNEL_FILE_NAME).a ALWAYS
401*4f1223e8SApple OSS Distributions	$(_v)$(MKDIR) $(dir $@)
402*4f1223e8SApple OSS Distributions	@$(LOG_INSTALL) "$(@F)"
403*4f1223e8SApple OSS Distributions	$(_v)$(INSTALL) $(INSTALL_FLAGS) $< $@
404*4f1223e8SApple OSS Distributions
405*4f1223e8SApple OSS Distributionselse
406*4f1223e8SApple OSS Distributions$(DSTROOT)/$(INSTALL_KERNEL_DIR)/$(KERNEL_FILE_NAME).link/$(KERNEL_FILE_NAME).a: $(TARGET)/$(KERNEL_FILE_NAME).link/$(KERNEL_FILE_NAME).a ALWAYS
407*4f1223e8SApple OSS Distributions	$(_v)$(MKDIR) $(dir $@)
408*4f1223e8SApple OSS Distributions	@$(LOG_INSTALL) "$(@F)"
409*4f1223e8SApple OSS Distributions	$(_v)$(INSTALL) $(INSTALL_FLAGS) $< $@
410*4f1223e8SApple OSS Distributions
411*4f1223e8SApple OSS Distributions$(DSTROOT)/$(INSTALL_KERNEL_DIR)/$(KERNEL_FILE_NAME).link/$(KERNEL_FILE_NAME).linkarguments: $(TARGET)/$(KERNEL_FILE_NAME).link/$(KERNEL_FILE_NAME).linkarguments ALWAYS
412*4f1223e8SApple OSS Distributions	$(_v)$(MKDIR) $(dir $@)
413*4f1223e8SApple OSS Distributions	@$(LOG_INSTALL) "$(@F)"
414*4f1223e8SApple OSS Distributions	$(_v)$(INSTALL) $(INSTALL_FLAGS) $< $@
415*4f1223e8SApple OSS Distributions
416*4f1223e8SApple OSS Distributions$(DSTROOT)/$(INSTALL_KERNEL_DIR)/$(KERNEL_FILE_NAME).link/$(KERNEL_FILE_NAME).linkarchives: $(TARGET)/$(KERNEL_FILE_NAME).link/$(KERNEL_FILE_NAME).linkarchives ALWAYS
417*4f1223e8SApple OSS Distributions	$(_v)$(MKDIR) $(dir $@)
418*4f1223e8SApple OSS Distributions	@$(LOG_INSTALL) "$(@F)"
419*4f1223e8SApple OSS Distributions	$(_v)$(INSTALL) $(INSTALL_FLAGS) $< $@
420*4f1223e8SApple OSS Distributions
421*4f1223e8SApple OSS Distributions$(DSTROOT)/$(INSTALL_KERNEL_DIR)/$(KERNEL_FILE_NAME).link/$(KERNEL_FILE_NAME).exp: $(TARGET)/$(KERNEL_FILE_NAME).link/$(KERNEL_FILE_NAME).exp ALWAYS
422*4f1223e8SApple OSS Distributions	$(_v)$(MKDIR) $(dir $@)
423*4f1223e8SApple OSS Distributions	@$(LOG_INSTALL) "$(@F)"
424*4f1223e8SApple OSS Distributions	$(_v)$(INSTALL) $(INSTALL_FLAGS) $< $@
425*4f1223e8SApple OSS Distributions
426*4f1223e8SApple OSS Distributions$(DSTROOT)/$(INSTALL_KERNEL_DIR)/$(KERNEL_FILE_NAME).link/$(KERNEL_FILE_NAME).alias.exp: $(TARGET)/$(KERNEL_FILE_NAME).link/$(KERNEL_FILE_NAME).alias.exp ALWAYS
427*4f1223e8SApple OSS Distributions	$(_v)$(MKDIR) $(dir $@)
428*4f1223e8SApple OSS Distributions	@$(LOG_INSTALL) "$(@F)"
429*4f1223e8SApple OSS Distributions	$(_v)$(INSTALL) $(INSTALL_FLAGS) $< $@
430*4f1223e8SApple OSS Distributionsendif
431*4f1223e8SApple OSS Distributions
432*4f1223e8SApple OSS Distributions# BUILD_STATIC_LINK
433*4f1223e8SApple OSS Distributionsendif
434*4f1223e8SApple OSS Distributions
435*4f1223e8SApple OSS Distributions$(SYMROOT)/$(KERNEL_FILE_NAME): $(TARGET)/$(KERNEL_FILE_NAME).unstripped ALWAYS
436*4f1223e8SApple OSS Distributions	$(_v)$(MKDIR) $(dir $@)
437*4f1223e8SApple OSS Distributions	@$(LOG_INSTALLSYM) "$(@F)$(Color0) ($(ColorLF)$(CURRENT_ARCH_CONFIG_LC)$(Color0))"
438*4f1223e8SApple OSS Distributions    # -nt and -ot are evaluated differently by bash, dash, and zsh (and are not part of the POSIX specification).
439*4f1223e8SApple OSS Distributions    # Explicitly specify what should happen when the right hand file doesn't exist.
440*4f1223e8SApple OSS Distributions	$(_v)if [ $(OBJROOT)/.mach_kernel.timestamp -nt $@ -o \( -e $(OBJROOT)/.mach_kernel.timestamp -a \! -e $@ \) ]; then		\
441*4f1223e8SApple OSS Distributions		$(INSTALL) $(EXEC_INSTALL_FLAGS) $< $@;				\
442*4f1223e8SApple OSS Distributions		cmdstatus=$$?;							\
443*4f1223e8SApple OSS Distributions	else									\
444*4f1223e8SApple OSS Distributions		$(LIPO) -create $@ $< -output $@;				\
445*4f1223e8SApple OSS Distributions		cmdstatus=$$?;							\
446*4f1223e8SApple OSS Distributions	fi;									\
447*4f1223e8SApple OSS Distributions	exit $$cmdstatus
448*4f1223e8SApple OSS Distributions
449*4f1223e8SApple OSS Distributions
450*4f1223e8SApple OSS Distributions$(SYMROOT)/$(KERNEL_FILE_NAME).dSYM/$(DSYMLLDBMACROSDIR)/lldbmacros                                                                     \
451*4f1223e8SApple OSS Distributions$(DSTROOT)/$(INSTALL_KERNEL_DIR)/$(KERNEL_FILE_NAME).link/$(KERNEL_FILE_NAME).dSYM/$(DSYMLLDBMACROSDIR)/lldbmacros                      \
452*4f1223e8SApple OSS Distributions$(DSTROOT)/$(INSTALL_KERNEL_SYM_DIR)/$(KERNEL_FILE_NAME).dSYM/$(DSYMLLDBMACROSDIR)/lldbmacros:                                          \
453*4f1223e8SApple OSS Distributions$(TARGET)/$(KERNEL_FILE_NAME).dSYM/$(DSYMLLDBMACROSDIR)/lldbmacros
454*4f1223e8SApple OSS Distributions	$(_v)$(MKDIR) $(dir $@)
455*4f1223e8SApple OSS Distributions	@$(LOG_INSTALLMACROS) "$(@F)$(Color0) $(ColorLF)$(CURRENT_ARCH_CONFIG_LC)$(Color0))"
456*4f1223e8SApple OSS Distributions	$(_v)$(CP) -r $< $(dir $@)
457*4f1223e8SApple OSS Distributions	$(_v)$(TOUCH) $@
458*4f1223e8SApple OSS Distributions
459*4f1223e8SApple OSS Distributions$(SYMROOT)/$(KERNEL_FILE_NAME).dSYM/$(DSYMLLDBMACROSDIR)/$(KERNEL_LLDBBOOTSTRAP_NAME)                                                   \
460*4f1223e8SApple OSS Distributions$(DSTROOT)/$(INSTALL_KERNEL_DIR)/$(KERNEL_FILE_NAME).link/$(KERNEL_FILE_NAME).dSYM/$(DSYMLLDBMACROSDIR)/$(KERNEL_LLDBBOOTSTRAP_NAME)    \
461*4f1223e8SApple OSS Distributions$(DSTROOT)/$(INSTALL_KERNEL_SYM_DIR)/$(KERNEL_FILE_NAME).dSYM/$(DSYMLLDBMACROSDIR)/$(KERNEL_LLDBBOOTSTRAP_NAME):                        \
462*4f1223e8SApple OSS Distributions$(TARGET)/$(KERNEL_FILE_NAME).dSYM/$(DSYMLLDBMACROSDIR)/$(KERNEL_LLDBBOOTSTRAP_NAME)
463*4f1223e8SApple OSS Distributions	$(_v)$(MKDIR) $(dir $@)
464*4f1223e8SApple OSS Distributions	@$(LOG_INSTALLMACROS) "$(@F)$(Color0) ($(ColorLF)$(CURRENT_ARCH_CONFIG_LC)$(Color0))"
465*4f1223e8SApple OSS Distributions	$(_v)$(INSTALL) $(INSTALL_FLAGS) $< $@
466*4f1223e8SApple OSS Distributions
467*4f1223e8SApple OSS Distributions$(DSTROOT)/$(DEVELOPER_EXTRAS_DIR)/README.DEBUG-kernel.txt: $(SRCROOT)/config/README.DEBUG-kernel.txt
468*4f1223e8SApple OSS Distributions	$(_v)$(MKDIR) $(dir $@)
469*4f1223e8SApple OSS Distributions	@$(LOG_INSTALL) "$(@F)"
470*4f1223e8SApple OSS Distributions	$(_v)$(INSTALL) $(INSTALL_FLAGS) $< $@
471*4f1223e8SApple OSS Distributions
472*4f1223e8SApple OSS Distributions$(SYMROOT)/$(KERNEL_FILE_NAME).dSYM/$(DSYMINFODIR)/Info.plist $(DSTROOT)/$(INSTALL_KERNEL_SYM_DIR)/$(KERNEL_FILE_NAME).dSYM/$(DSYMINFODIR)/Info.plist: $(TARGET)/$(KERNEL_FILE_NAME).dSYM/$(DSYMINFODIR)/Info.plist
473*4f1223e8SApple OSS Distributions	$(_v)$(MKDIR) $(dir $@)
474*4f1223e8SApple OSS Distributions	@$(LOG_INSTALLSYM) "$(ColorL)dSYM$(Color0) $(ColorF)$(@F)$(Color0) ($(ColorLF)$(CURRENT_ARCH_CONFIG_LC)$(Color0))"
475*4f1223e8SApple OSS Distributions	$(_v)$(INSTALL) $(INSTALL_FLAGS) $< $@
476*4f1223e8SApple OSS Distributions
477*4f1223e8SApple OSS Distributions$(SYMROOT)/$(KERNEL_FILE_NAME).dSYM/$(DSYMDWARFDIR)/$(KERNEL_FILE_NAME) $(DSTROOT)/$(INSTALL_KERNEL_SYM_DIR)/$(KERNEL_FILE_NAME).dSYM/$(DSYMDWARFDIR)/$(KERNEL_FILE_NAME): $(TARGET)/$(KERNEL_FILE_NAME).dSYM/$(DSYMDWARFDIR)/$(KERNEL_FILE_NAME) ALWAYS
478*4f1223e8SApple OSS Distributions	$(_v)$(MKDIR) $(dir $@)
479*4f1223e8SApple OSS Distributions	@$(LOG_INSTALLSYM) "$(ColorL)dSYM$(Color0) $(ColorF)$(@F).dSYM$(ColorF) ($(ColorLF)$(CURRENT_ARCH_CONFIG_LC)$(Color0))"
480*4f1223e8SApple OSS Distributions    # -nt and -ot are evaluated differently by bash, dash, and zsh (and are not part of the POSIX specification).
481*4f1223e8SApple OSS Distributions    # Explicitly specify what should happen when the right hand file doesn't exist.
482*4f1223e8SApple OSS Distributions	$(_v)if [ $(OBJROOT)/.mach_kernel.timestamp -nt $@ -o \( -e $(OBJROOT)/.mach_kernel.timestamp -a \! -e $@ \) ]; then			\
483*4f1223e8SApple OSS Distributions		$(INSTALL) $(EXEC_INSTALL_FLAGS) $< $@;					\
484*4f1223e8SApple OSS Distributions		cmdstatus=$$?;								\
485*4f1223e8SApple OSS Distributions	else										\
486*4f1223e8SApple OSS Distributions		$(LIPO) -create $@ $< -output $@;					\
487*4f1223e8SApple OSS Distributions		cmdstatus=$$?;								\
488*4f1223e8SApple OSS Distributions	fi;										\
489*4f1223e8SApple OSS Distributions	exit $$cmdstatus
490*4f1223e8SApple OSS Distributions
491*4f1223e8SApple OSS Distributions.PHONY: do_install_machine_specific_kernel do_install_machine_specific_kernel_dSYM
492*4f1223e8SApple OSS Distributions.PHONY: do_install_machine_specific_KDK_dSYM
493*4f1223e8SApple OSS Distributions
494*4f1223e8SApple OSS Distributionsifeq ($(BUILD_XNU_LIBRARY),1)
495*4f1223e8SApple OSS Distributions
496*4f1223e8SApple OSS Distributionsdo_install_machine_specific_kernel: $(KERNEL_STATIC_LINK_DST)
497*4f1223e8SApple OSS Distributions	@:
498*4f1223e8SApple OSS Distributionsdo_install_machine_specific_kernel_dSYM:
499*4f1223e8SApple OSS Distributions	@:
500*4f1223e8SApple OSS Distributions
501*4f1223e8SApple OSS Distributionselse
502*4f1223e8SApple OSS Distributions
503*4f1223e8SApple OSS Distributionsdo_install_machine_specific_kernel: $(DSTROOT)/$(INSTALL_KERNEL_DIR)/$(KERNEL_FILE_NAME)                \
504*4f1223e8SApple OSS Distributions			$(SYMROOT)/$(KERNEL_FILE_NAME)                                                              \
505*4f1223e8SApple OSS Distributions			$(KERNEL_STATIC_LINK_DST)
506*4f1223e8SApple OSS Distributions	@:
507*4f1223e8SApple OSS Distributions
508*4f1223e8SApple OSS Distributionsdo_install_machine_specific_kernel_dSYM: \
509*4f1223e8SApple OSS Distributions			$(SYMROOT)/$(KERNEL_FILE_NAME).dSYM/$(DSYMINFODIR)/Info.plist \
510*4f1223e8SApple OSS Distributions			$(SYMROOT)/$(KERNEL_FILE_NAME).dSYM/$(DSYMLLDBMACROSDIR)/lldbmacros \
511*4f1223e8SApple OSS Distributions			$(SYMROOT)/$(KERNEL_FILE_NAME).dSYM/$(DSYMLLDBMACROSDIR)/$(KERNEL_LLDBBOOTSTRAP_NAME) \
512*4f1223e8SApple OSS Distributions			$(SYMROOT)/$(KERNEL_FILE_NAME).dSYM/$(DSYMDWARFDIR)/$(KERNEL_FILE_NAME)
513*4f1223e8SApple OSS Distributions	@:
514*4f1223e8SApple OSS Distributions
515*4f1223e8SApple OSS Distributionsdo_install_machine_specific_KDK_dSYM: \
516*4f1223e8SApple OSS Distributions			$(DSTROOT)/$(INSTALL_KERNEL_SYM_DIR)/$(KERNEL_FILE_NAME).dSYM/$(DSYMINFODIR)/Info.plist \
517*4f1223e8SApple OSS Distributions			$(DSTROOT)/$(INSTALL_KERNEL_SYM_DIR)/$(KERNEL_FILE_NAME).dSYM/$(DSYMLLDBMACROSDIR)/lldbmacros \
518*4f1223e8SApple OSS Distributions			$(DSTROOT)/$(INSTALL_KERNEL_SYM_DIR)/$(KERNEL_FILE_NAME).dSYM/$(DSYMLLDBMACROSDIR)/$(KERNEL_LLDBBOOTSTRAP_NAME) \
519*4f1223e8SApple OSS Distributions			$(DSTROOT)/$(INSTALL_KERNEL_SYM_DIR)/$(KERNEL_FILE_NAME).dSYM/$(DSYMDWARFDIR)/$(KERNEL_FILE_NAME)
520*4f1223e8SApple OSS Distributions	@:
521*4f1223e8SApple OSS Distributions
522*4f1223e8SApple OSS Distributionsendif
523*4f1223e8SApple OSS Distributions
524*4f1223e8SApple OSS Distributions# The $(RM) is needed so that the $(LN) doesn't dereference an existing
525*4f1223e8SApple OSS Distributions# symlink during incremental builds and create a new symlink inside
526*4f1223e8SApple OSS Distributions# the target of the existing symlink
527*4f1223e8SApple OSS Distributionsifneq ($(INSTALLHDRS_SKIP_HOST),YES)
528*4f1223e8SApple OSS Distributionsdo_installhdrs_mi:: $(DSTROOT)/$(KRESDIR)/Info.plist
529*4f1223e8SApple OSS Distributions	$(_v)$(MKDIR) $(DSTROOT)/$(KINCFRAME)
530*4f1223e8SApple OSS Distributions	$(_v)$(MKDIR) $(DSTROOT)/$(KPINCDIR)
531*4f1223e8SApple OSS Distributions	$(_v)$(MKDIR) $(DSTROOT)/$(KRESDIR)
532*4f1223e8SApple OSS Distributions	$(_v)$(MKDIR) $(DSTROOT)/$(KLIBCXXINCDIR)
533*4f1223e8SApple OSS Distributions	$(_v)$(RM) $(DSTROOT)/$(KINCFRAME)/Versions/Current
534*4f1223e8SApple OSS Distributions	$(_v)$(LN) $(KINCVERS) $(DSTROOT)/$(KINCFRAME)/Versions/Current
535*4f1223e8SApple OSS Distributions	$(_v)$(RM) $(DSTROOT)/$(KINCFRAME)/Headers
536*4f1223e8SApple OSS Distributions	$(_v)$(LN) Versions/Current/Headers			\
537*4f1223e8SApple OSS Distributions		   $(DSTROOT)/$(KINCFRAME)/Headers
538*4f1223e8SApple OSS Distributions	$(_v)$(RM) $(DSTROOT)/$(KINCFRAME)/PrivateHeaders
539*4f1223e8SApple OSS Distributions	$(_v)$(LN) Versions/Current/PrivateHeaders		\
540*4f1223e8SApple OSS Distributions		   $(DSTROOT)/$(KINCFRAME)/PrivateHeaders
541*4f1223e8SApple OSS Distributions	$(_v)$(RM) $(DSTROOT)/$(KINCFRAME)/Resources
542*4f1223e8SApple OSS Distributions	$(_v)$(LN) Versions/Current/Resources			\
543*4f1223e8SApple OSS Distributions		   $(DSTROOT)/$(KINCFRAME)/Resources
544*4f1223e8SApple OSS Distributionsendif
545*4f1223e8SApple OSS Distributions
546*4f1223e8SApple OSS Distributionsifneq ($(INSTALLHDRS_SKIP_HOST),YES)
547*4f1223e8SApple OSS Distributions$(DSTROOT)/$(KRESDIR)/Info.plist: $(SOURCE)/EXTERNAL_HEADERS/Info.plist $(NEWVERS) $(XNU_VERSION)
548*4f1223e8SApple OSS Distributions	$(_v)$(MKDIR) $(DSTROOT)/$(KRESDIR)
549*4f1223e8SApple OSS Distributions	$(_v)$(INSTALL) $(DATA_INSTALL_FLAGS) $< $@
550*4f1223e8SApple OSS Distributions	$(_v)$(NEWVERS) $@ $(_vstdout)
551*4f1223e8SApple OSS Distributionsifeq ($(USE_BINARY_PLIST),1)
552*4f1223e8SApple OSS Distributions	$(_v)$(PLUTIL) -convert binary1 -o $@ $@
553*4f1223e8SApple OSS Distributionsendif
554*4f1223e8SApple OSS Distributionsendif
555*4f1223e8SApple OSS Distributions
556*4f1223e8SApple OSS Distributions$(DSTROOT)/$(INSTALL_KERNEL_DIR)/$(ALIAS_FILE_NAME): ALWAYS
557*4f1223e8SApple OSS Distributions	@$(LOG_ALIAS) "$(@F)$(Color0) ($(ColorLF)$(CURRENT_ARCH_CONFIG_LC)$(Color0) $(ColorLF)$(CURRENT_MACHINE_CONFIG_LC)$(Color0) $(ColorLF)$(CURRENT_ALIAS_MACHINE_CONFIG_LC)$(Color0))"
558*4f1223e8SApple OSS Distributions	$(_v)$(INSTALL) $(EXEC_INSTALL_FLAGS) $(DSTROOT)/$(INSTALL_KERNEL_DIR)/$(KERNEL_FILE_NAME) $@
559*4f1223e8SApple OSS Distributions
560*4f1223e8SApple OSS Distributionsinstall_alias: $(DSTROOT)/$(INSTALL_KERNEL_DIR)/$(ALIAS_FILE_NAME)
561*4f1223e8SApple OSS Distributions
562*4f1223e8SApple OSS Distributionsprint_exports:
563*4f1223e8SApple OSS Distributions	$(_v)printenv | sort
564*4f1223e8SApple OSS Distributions
565*4f1223e8SApple OSS Distributions# vim: set ft=make:
566