xref: /xnu-10002.61.3/config/Makefile (revision 0f4c859e951fba394238ab619495c4e1d54d0f34)
1export MakeInc_cmd=${SRCROOT}/makedefs/MakeInc.cmd
2export MakeInc_def=${SRCROOT}/makedefs/MakeInc.def
3export MakeInc_rule=${SRCROOT}/makedefs/MakeInc.rule
4export MakeInc_dir=${SRCROOT}/makedefs/MakeInc.dir
5
6include $(MakeInc_cmd)
7include $(MakeInc_def)
8
9# config is not a COMPONENT but we still want to build most files in a TARGET subdir
10override TARGET := $(OBJPATH)/config
11
12MD_SUPPORTED_KPI_FILENAME := SupportedKPIs-${CURRENT_ARCH_CONFIG_LC}.txt
13MI_SUPPORTED_KPI_FILENAME := SupportedKPIs-all-archs.txt
14
15INSTALL_KEXT_DIR = $(DSTROOT)$(INSTALL_EXTENSIONS_DIR)
16
17KEXT_PLIST_LIST := \
18	System.kext/Info.plist \
19	System.kext/PlugIns/Kasan.kext/Info.plist \
20	System.kext/PlugIns/Kcov.kext/Info.plist \
21	System.kext/PlugIns/AppleNMI.kext/Info.plist \
22	System.kext/PlugIns/ApplePlatformFamily.kext/Info.plist \
23	System.kext/PlugIns/IONVRAMFamily.kext/Info.plist \
24	System.kext/PlugIns/IOSystemManagement.kext/Info.plist
25
26SYMBOL_COMPONENT_LIST :=	\
27        BSDKernel	\
28        IOKit		\
29        Libkern		\
30        Mach		\
31        MACFramework	\
32        Unsupported	\
33        Private
34
35SYMBOL_SET_PLIST_COMPONENT_LIST := $(SYMBOL_COMPONENT_LIST) Kasan Kcov
36
37KEXT_PLIST_LIST += $(foreach symbolset,$(SYMBOL_COMPONENT_LIST),System.kext/PlugIns/$(symbolset).kext/Info.plist)
38
39# In general you want it to be possible to have a CPU sub-type's symbol exports
40# alias to the parent type's exports. This is a special-case way to handle it
41# for now:
42ifeq ($(CURRENT_ARCH_CONFIG_LC),x86_64h)
43EXPORT_SOURCE_ARCH_CONFIG_LC := x86_64
44else
45EXPORT_SOURCE_ARCH_CONFIG_LC := $(CURRENT_ARCH_CONFIG_LC)
46endif
47
48EXPORTS_FILES := $(foreach symbolset,$(SYMBOL_COMPONENT_LIST),$(symbolset).exports \
49	$(symbolset).$(EXPORT_SOURCE_ARCH_CONFIG_LC).exports \
50	$(notdir $(wildcard $(SOURCE)/$(symbolset).$(EXPORT_SOURCE_ARCH_CONFIG_LC).$(PLATFORM).exports))) \
51	Unused.exports
52
53Kasan_EXPORTS := $(SRCROOT)/config/Kasan_disabled.exports
54Kcov_EXPORTS := $(SRCROOT)/config/Kcov_disabled.exports
55
56ifneq ($(filter $(CURRENT_KERNEL_CONFIG),$(KCOV_RUNTIME)),)
57Kcov_EXPORTS := $(SRCROOT)/config/Kcov_enabled.exports
58endif
59
60ifeq ($(KASAN),1)
61ifeq ($(CURRENT_ARCH_CONFIG_LC),x86_64h)
62KASAN_ARCH_SUFFIX := x86_64
63else
64KASAN_ARCH_SUFFIX := $(CURRENT_ARCH_CONFIG_LC)
65endif
66Kasan_EXPORTS := $(SRCROOT)/config/Kasan_enabled.$(KASAN_ARCH_SUFFIX).exports
67endif
68
69define symbol_set_template
70$(1)_EXPORTS := $$(addprefix $$(SOURCE)/,$$(filter $(1)%,$$(EXPORTS_FILES)))
71$$(TARGET)/$(1).symbolset: MY_EXPORTS_ARGS := $$(foreach file,$$($(1)_EXPORTS),-export $$(file))
72$$(TARGET)/$(1).symbolset: $$($(1)_EXPORTS) $$(TARGET)/allsymbols $$(KEXT_CREATE_SYMBOL_SET)
73	@$$(LOG_SYMBOLSET) "$(1)$$(Color0) ($$(ColorLF)$$(CURRENT_ARCH_CONFIG_LC)$$(Color0))"
74	$$(_v)$$(KEXT_CREATE_SYMBOL_SET)			\
75		$$(ARCH_FLAGS_$$(CURRENT_ARCH_CONFIG))	\
76		-import $$(TARGET)/allsymbols		\
77		$$(MY_EXPORTS_ARGS)			\
78		-output $$@ $$(_vstdout)
79
80SYMBOL_SET_BUILD += $$(TARGET)/$(1).symbolset
81endef
82
83# Each parallel invocation of this target must use a distinct location, as it is
84# not safe to call multiple NEWVERS on the same file concurrently (rdar://66173684)
85define kext_plist_template
86$$(TARGET)/$(1): $$(SOURCE)/$(1) $$(NEWVERS) $$(XNU_VERSION)
87	@$$(LOG_GENERATE) "$(1)"
88	$$(_v)$$(MKDIR) $$(@D)
89	$$(_v)$$(CP) $$< $$@
90	$$(_v)$$(NEWVERS) $$@ > /dev/null
91
92KEXT_PLIST_BUILD += $$(TARGET)/$(1)
93SYMROOT_INSTALL_KEXT_PLISTS += $$(SYMROOT)/$(1)
94DSTROOT_INSTALL_KEXT_PLISTS += $$(INSTALL_KEXT_DIR)/$(1)
95endef
96
97define symbol_set_plist_template
98$(1)_KEXT_PLIST := $$(filter %/$(1).kext/Info.plist,$$(KEXT_PLIST_LIST))
99$$(TARGET)/$(1).symbolset.plist: $$(TARGET)/$$($(1)_KEXT_PLIST) $$($(1)_EXPORTS)
100	@$$(LOG_SYMBOLSETPLIST) "$(1)$$(Color0) ($$(ColorLF)$$(CURRENT_ARCH_CONFIG_LC)$$(Color0))"
101	$$(_v)$$(SOURCE)/generate_symbolset_plist.sh $$@ $$+ $$(_vstdout)
102	$$(_v)$$(PLUTIL) -lint -s $$@
103
104SYMBOL_SET_PLIST_BUILD += $$(TARGET)/$(1).symbolset.plist
105endef
106
107$(foreach symbolset,$(SYMBOL_COMPONENT_LIST),$(eval $(call symbol_set_template,$(symbolset))))
108$(foreach plist,$(KEXT_PLIST_LIST),$(eval $(call kext_plist_template,$(plist))))
109$(foreach symbolset,$(SYMBOL_SET_PLIST_COMPONENT_LIST),$(eval $(call symbol_set_plist_template,$(symbolset))))
110
111$(OBJPATH)/symbolsets.plist: $(SYMBOL_SET_PLIST_BUILD)
112	$(_v)$(SOURCE)/generate_combined_symbolsets_plist.sh $@ $^ $(_vstdout)
113	$(_v)$(PLUTIL) -convert binary1 -s $@
114
115build_symbol_set_plists: $(KEXT_PLIST_BUILD) $(OBJPATH)/symbolsets.plist
116
117$(TARGET)/allsymbols: $(OBJPATH)/$(KERNEL_FILE_NAME)
118	$(_v)$(NM) -gj $< | sort -u > $@
119
120check_all_exports: $(TARGET)/allsymbols $(KEXT_CREATE_SYMBOL_SET)
121	$(_v)$(KEXT_CREATE_SYMBOL_SET)					\
122		$(ARCH_FLAGS_$(CURRENT_ARCH_CONFIG))			\
123		-import $(TARGET)/allsymbols				\
124		$(foreach symbolset,$(filter-out Private,$(SYMBOL_COMPONENT_LIST)),	\
125			-export $(SOURCE)/$(symbolset).exports		\
126			-export $(SOURCE)/$(symbolset).$(EXPORT_SOURCE_ARCH_CONFIG_LC).exports)	\
127		-output /dev/null $(_vstdout)
128	$(_v)$(KEXT_CREATE_SYMBOL_SET)					\
129		$(ARCH_FLAGS_$(CURRENT_ARCH_CONFIG))			\
130		-import $(TARGET)/allsymbols				\
131		$(foreach symbolset,$(filter-out Unsupported,$(SYMBOL_COMPONENT_LIST)),	\
132			-export $(SOURCE)/$(symbolset).exports		\
133			-export $(SOURCE)/$(symbolset).$(EXPORT_SOURCE_ARCH_CONFIG_LC).exports)	\
134		-output /dev/null $(_vstdout)
135
136$(OBJPATH)/$(MD_SUPPORTED_KPI_FILENAME): $(EXPORTS_FILES)
137	@$(LOG_SUPPORTED_KPI) "$(CURRENT_ARCH_CONFIG_LC)"
138	$(_v)$(SRCROOT)/config/list_supported.sh $(SOURCE) $(EXPORT_SOURCE_ARCH_CONFIG_LC) $@
139
140$(OBJPATH)/$(MI_SUPPORTED_KPI_FILENAME): $(EXPORTS_FILES)
141	@$(LOG_SUPPORTED_KPI) "all"
142	$(_v)$(SRCROOT)/config/list_supported.sh $(SOURCE) all $@
143
144build_symbol_sets: check_all_exports $(SYMBOL_SET_BUILD) $(TARGET)/allsymbols \
145			$(OBJPATH)/$(MD_SUPPORTED_KPI_FILENAME) \
146			$(OBJPATH)/$(MI_SUPPORTED_KPI_FILENAME)
147
148# Generate rules for symroot fat kexts with dependencies on every corresponding symbolset for each build config.
149# This target must only run from do_config_install for a single build config after the do_config_all phases for
150# all build configs have completed. This ensures every unique slice built by any config is pulled into the fat
151# symbolset kext (note that not all slices are reflected as distinct xnu build config ARCHS!) (rdar://70703349)
152define symroot_symbol_set_template
153$$(SYMROOT_SYSTEM_KEXT_PATH)/$(1).kext/$(1): $$(addsuffix /config/$(1).symbolset, \
154		$$(addprefix $$(OBJROOT)/,$$(foreach bc,$(BUILD_CONFIGS),$$(call function_convert_build_config_to_objdir,$$(bc)))))
155	@$$(LOG_INSTALLSYM) "$$(Color0)symbolset $$(ColorF)$(1)"
156	$$(_v)$$(MKDIR) $$(@D)
157	$$(_v)$$(LIPO) -create `(echo $$^ | xargs -L 1 lipo -detailed_info) | \
158		awk '/is architecture/ {s[$$$$6]=$$$$3} END {for (a in s) {print s[a]}}'` -output $$@ $$(_vstdout)
159
160SYMROOT_INSTALL_KEXT_MACHO_FILES += $$(SYMROOT_SYSTEM_KEXT_PATH)/$(1).kext/$(1)
161DSTROOT_INSTALL_KEXT_MACHO_FILES += $$(DSTROOT_SYSTEM_KEXT_PATH)/$(1).kext/$(1)
162endef
163$(foreach symbolset,$(SYMBOL_COMPONENT_LIST),$(eval $(call symroot_symbol_set_template,$(symbolset))))
164
165$(SYMROOT_INSTALL_KEXT_PLISTS): $(SYMROOT)/% : $(TARGET)/%
166	$(_v)$(MKDIR) $(@D)
167	@$(LOG_INSTALLSYM) "$(Color0)kextplist $(ColorF)$*"
168	$(_v)$(INSTALL) $(DATA_INSTALL_FLAGS) $< $@
169
170$(DSTROOT_INSTALL_KEXT_PLISTS): $(INSTALL_KEXT_DIR)/% : $(SYMROOT)/%
171	$(_v)$(MKDIR) $(@D)
172	@$(LOG_INSTALL) "$(Color0)kextplist $(ColorF)$*"
173	$(_v)$(INSTALL) $(DATA_INSTALL_FLAGS) $< $@
174
175$(DSTROOT_INSTALL_KEXT_MACHO_FILES): $(DSTROOT_SYSTEM_KEXT_PATH)/% : $(SYMROOT_SYSTEM_KEXT_PATH)/%
176	$(_v)$(MKDIR) $(@D)
177	@$(LOG_INSTALL) "$(Color0)symbolset $(ColorF)$(@F)"
178	$(_v)$(INSTALL) $(EXEC_INSTALL_FLAGS) $< $@
179
180$(DSTROOT)/$(KRESDIR)/$(MD_SUPPORTED_KPI_FILENAME) $(DSTROOT)/$(KRESDIR)/$(MI_SUPPORTED_KPI_FILENAME): $(DSTROOT)/$(KRESDIR)/% : $(OBJPATH)/%
181	$(_v)$(MKDIR) $(@D)
182	@$(LOG_INSTALL) "$*"
183	$(_v)$(INSTALL) $(INSTALL_FLAGS) $< $@
184
185ifneq ($(RC_ProjectName),xnu_libraries)
186
187do_build_all:: build_symbol_set_plists
188do_config_all:: build_symbol_sets
189
190ifneq ($(INSTALL_KASAN_ONLY),1)
191
192do_config_install_primary:: \
193				$(DSTROOT)/$(KRESDIR)/$(MD_SUPPORTED_KPI_FILENAME)
194
195do_config_install:: \
196				$(SYMROOT_INSTALL_KEXT_MACHO_FILES) \
197				$(SYMROOT_INSTALL_KEXT_PLISTS) \
198				$(DSTROOT_INSTALL_KEXT_MACHO_FILES) \
199				$(DSTROOT_INSTALL_KEXT_PLISTS) \
200				$(DSTROOT)/$(KRESDIR)/$(MI_SUPPORTED_KPI_FILENAME)
201endif
202
203else
204# We are building XNU as a static library - avoid creating symbol sets
205endif
206
207$(OBJPATH)/all-kpi.exp: $(EXPORTS_FILES)
208	$(_v)$(SOURCE)/generate_linker_exports.sh $@ $+ $(Kasan_EXPORTS) $(Kcov_EXPORTS)
209
210$(OBJPATH)/all-alias.exp: $(EXPORTS_FILES)
211	$(_v)$(SOURCE)/generate_linker_aliases.sh $@ $+ $(Kasan_EXPORTS) $(Kcov_EXPORTS)
212
213do_build_all:: $(OBJPATH)/all-kpi.exp $(OBJPATH)/all-alias.exp
214
215include $(MakeInc_rule)
216include $(MakeInc_dir)
217
218.PHONY: build_symbol_set_plists build_symbol_sets check_all_exports
219