]> git.saurik.com Git - apple/xnu.git/blobdiff - config/Makefile
xnu-1504.3.12.tar.gz
[apple/xnu.git] / config / Makefile
index db72f8acd7e7951e97c95a5efade83de8d2d4a6b..9a00f1027c64ca00e18deda96c020b9af7fd0cb0 100644 (file)
@@ -17,6 +17,8 @@ INSTINC_SUBDIRS_PPC =
 
 INSTINC_SUBDIRS_I386 = 
 
+INSTINC_SUBDIRS_X86_64 = 
+
 INSTINC_SUBDIRS_ARM = 
 
 EXPINC_SUBDIRS = 
@@ -25,6 +27,8 @@ EXPINC_SUBDIRS_PPC =
 
 EXPINC_SUBDIRS_I386 = 
 
+EXPINC_SUBDIRS_X86_64 = 
+
 EXPINC_SUBDIRS_ARM = 
 
 COMP_SUBDIRS = 
@@ -33,7 +37,6 @@ INST_SUBDIRS =
 
 
 INSTALL_DATA_LIST= \
-       IPFirewall.kext/Info.plist \
        System.kext/Info.plist \
        System.kext/PlugIns/Libkern.kext/Info.plist \
        System.kext/PlugIns/Mach.kext/Info.plist \
@@ -45,6 +48,7 @@ INSTALL_DATA_LIST= \
        System.kext/PlugIns/IONVRAMFamily.kext/Info.plist \
        System.kext/PlugIns/IOSystemManagement.kext/Info.plist \
        System.kext/PlugIns/Unsupported.kext/Info.plist \
+       System.kext/PlugIns/Private.kext/Info.plist \
        \
        System.kext/PlugIns/System6.0.kext/Info.plist \
        System.kext/PlugIns/Libkern6.0.kext/Info.plist \
@@ -57,10 +61,8 @@ INSTALL_DATA_DIR= \
 
 INSTMAN_SUBDIRS = 
 
-#
-
-KEXT_CREATE_SYMBOL_SET = /usr/local/bin/kextsymboltool
-NEWVERS = $(SRCROOT)/config/newvers.pl
+MD_SUPPORTED_KPI_FILENAME="SupportedKPIs-${ARCH_CONFIG_LC}.txt"
+MI_SUPPORTED_KPI_FILENAME="SupportedKPIs-all-archs.txt"
 
 ifneq ($(MACHINE_CONFIG), DEFAULT)
 OBJPATH = $(OBJROOT)/$(KERNEL_CONFIG)_$(ARCH_CONFIG)_$(MACHINE_CONFIG)
@@ -68,13 +70,22 @@ else
 OBJPATH = $(OBJROOT)/$(KERNEL_CONFIG)_$(ARCH_CONFIG)
 endif
 
+ifeq ($(ARCH_CONFIG),I386)
+SUPPORT_SYSTEM60_KEXT  = 1
+else ifeq ($(ARCH_CONFIG),ARM)
+SUPPORT_SYSTEM60_KEXT  = 1
+else
+SUPPORT_SYSTEM60_KEXT  = 0
+endif
+
 SYMBOL_COMPONENT_LIST =        \
         System6.0      \
         BSDKernel      \
         IOKit          \
         Libkern        \
         Mach   \
-       Unsupported
+       Unsupported     \
+       Private
 
 ifdef MAC
 SYMBOL_COMPONENT_LIST += MACFramework
@@ -89,23 +100,48 @@ SYMBOL_SET_FAT = $(foreach set, $(SYMBOL_COMPONENT_LIST), $(OBJROOT)/$(set).symb
 ## .SUFFIXES: .symbolset .symbollist
 
 $(OBJPATH)/allsymbols: $(OBJPATH)/mach_kernel
-       $(_v)nm -gj $< > $@
+       $(_v)$(NM) -gj $< > $@
 
 $(SYMBOL_SET_BUILD): $(OBJPATH)/%.symbolset :  %.exports %.$(ARCH_CONFIG_LC).exports $(OBJPATH)/allsymbols
-       $(_v)$(KEXT_CREATE_SYMBOL_SET) \
+       $(_v)if [ "$*" != System6.0 -o $(SUPPORT_SYSTEM60_KEXT) -eq 1 ]; then   \
+               $(KEXT_CREATE_SYMBOL_SET) \
                $($(addsuffix $(ARCH_CONFIG),ARCH_FLAGS_ALL_)) \
                -import $(OBJPATH)/allsymbols \
                -export $*.exports \
                -export $*.$(ARCH_CONFIG_LC).exports \
-               -output $@;
-
-ifneq ($(MACHINE_CONFIG), DEFAULT)
-$(SYMBOL_SET_FAT): $(OBJROOT)/%.symbolset : $(foreach arch, $(INSTALL_ARCHS), $(OBJROOT)/$(KERNEL_CONFIG)_$(arch)_$(MACHINE_CONFIG)/%.symbolset)
-       $(LIPO) $(foreach arch, $(INSTALL_ARCHS), $(OBJROOT)/$(KERNEL_CONFIG)_$(arch)_$(MACHINE_CONFIG)/$*.symbolset) -create -output $@;
-else
-$(SYMBOL_SET_FAT): $(OBJROOT)/%.symbolset : $(foreach arch, $(INSTALL_ARCHS), $(OBJROOT)/$(KERNEL_CONFIG)_$(arch)/%.symbolset)
-       $(_v)$(LIPO) $(foreach arch, $(INSTALL_ARCHS), $(OBJROOT)/$(KERNEL_CONFIG)_$(arch)/$*.symbolset) -create -output $@;
-endif
+               -output $@ $(_vstdout); \
+       fi
+       $(_v)if [ ! -e $@ ]; then       \
+               printf "" > $@;         \
+       fi
+
+# When building the top-level install target for all architectures, aggregate the per-arch
+# symbolsets for the primary machine configuration for each kernel/arch config
+$(SYMBOL_SET_FAT): $(OBJROOT)/%.symbolset :
+       $(_v)per_arch_symbolsets="";                    \
+       kernel_config=$(INSTALL_TYPE);                  \
+       machine_config=$(MACHINE_CONFIG);               \
+       for arch_config in $(INSTALL_ARCHS);            \
+       do                                              \
+       if [ $${arch_config} = ARM ] ; then             \
+               if [ $${machine_config} = DEFAULT ] ; then              \
+                       machine_config=$(DEFAULT_ARM_MACHINE_CONFIG);   \
+               fi;                                                     \
+       fi;                                             \
+       if [ $${machine_config} = DEFAULT ] ; then      \
+               objpath=${OBJROOT}/$${kernel_config}_$${arch_config};   \
+       else            \
+               objpath=${OBJROOT}/$${kernel_config}_$${arch_config}_$${machine_config};        \
+       fi;             \
+       if [ -s "$${objpath}/$*.symbolset" ]; then                      \
+               per_arch_symbolsets="$${per_arch_symbolsets} $${objpath}/$*.symbolset";         \
+       fi;             \
+       done;           \
+       if [ -n "$${per_arch_symbolsets}" ]; then                       \
+               $(LIPO) $${per_arch_symbolsets} -create -output $@;     \
+       else            \
+               printf "" > $@;                                         \
+       fi
 
 build_symbol_sets:     $(SYMBOL_SET_BUILD)
        $(_v)$(KEXT_CREATE_SYMBOL_SET) \
@@ -122,33 +158,81 @@ build_symbol_sets:        $(SYMBOL_SET_BUILD)
                $(MACFRAMEWORKEXPORTS) \
                -export $(SRCROOT)/$(COMPONENT)/Unsupported.exports \
                -export $(SRCROOT)/$(COMPONENT)/Unsupported.$(ARCH_CONFIG_LC).exports \
-               -output /dev/null;
+               -output /dev/null $(_vstdout);
+       $(_v)$(KEXT_CREATE_SYMBOL_SET) \
+               $($(addsuffix $(ARCH_CONFIG),ARCH_FLAGS_)) \
+               -import $(OBJPATH)/allsymbols \
+               -export $(SRCROOT)/$(COMPONENT)/Libkern.exports \
+               -export $(SRCROOT)/$(COMPONENT)/Libkern.$(ARCH_CONFIG_LC).exports \
+               -export $(SRCROOT)/$(COMPONENT)/Mach.exports \
+               -export $(SRCROOT)/$(COMPONENT)/Mach.$(ARCH_CONFIG_LC).exports \
+               -export $(SRCROOT)/$(COMPONENT)/IOKit.exports \
+               -export $(SRCROOT)/$(COMPONENT)/IOKit.$(ARCH_CONFIG_LC).exports \
+               -export $(SRCROOT)/$(COMPONENT)/BSDKernel.exports \
+               -export $(SRCROOT)/$(COMPONENT)/BSDKernel.$(ARCH_CONFIG_LC).exports \
+               $(MACFRAMEWORKEXPORTS) \
+               -export $(SRCROOT)/$(COMPONENT)/Private.exports \
+               -export $(SRCROOT)/$(COMPONENT)/Private.$(ARCH_CONFIG_LC).exports \
+               -output /dev/null $(_vstdout);
+       $(_v) $(SRCROOT)/$(COMPONENT)/list_supported.sh $(SRCROOT)/$(COMPONENT) $(ARCH_CONFIG_LC) $(OBJPATH)/${MD_SUPPORTED_KPI_FILENAME};
+       $(_v)if [ -n `echo $${ARCH_CONFIGS%%\ *} | grep -i  $(ARCH_CONFIG)` ]; \
+       then \
+               $(SRCROOT)/$(COMPONENT)/list_supported.sh $(SRCROOT)/$(COMPONENT) "ALL"  $(OBJROOT)/${MI_SUPPORTED_KPI_FILENAME}; \
+       fi
+
 
 install_symbol_sets:   $(SYMBOL_SET_FAT) $(SRCROOT)/config/MasterVersion
-       $(_v)install $(INSTALL_FLAGS) $(OBJROOT)/System6.0.symbolset $(DSTROOT)/$(INSTALL_DATA_DIR)/System.kext/PlugIns/System6.0.kext/kernel.6.0;
-       $(_v)install $(INSTALL_FLAGS) $(OBJROOT)/BSDKernel.symbolset $(DSTROOT)/$(INSTALL_DATA_DIR)/System.kext/PlugIns/BSDKernel.kext/BSDKernel;
-ifdef MAC
-       $(_v)install $(INSTALL_FLAGS) $(OBJROOT)/MACFramework.symbolset $(DSTROOT)/$(INSTALL_DATA_DIR)/System.kext/PlugIns/MACFramework.kext/MACFramework;
-endif
-       $(_v)install $(INSTALL_FLAGS) $(OBJROOT)/IOKit.symbolset     $(DSTROOT)/$(INSTALL_DATA_DIR)/System.kext/PlugIns/IOKit.kext/IOKit;
-       $(_v)install $(INSTALL_FLAGS) $(OBJROOT)/Libkern.symbolset   $(DSTROOT)/$(INSTALL_DATA_DIR)/System.kext/PlugIns/Libkern.kext/Libkern;
-       $(_v)install $(INSTALL_FLAGS) $(OBJROOT)/Mach.symbolset      $(DSTROOT)/$(INSTALL_DATA_DIR)/System.kext/PlugIns/Mach.kext/Mach;
-       $(_v)install $(INSTALL_FLAGS) $(OBJROOT)/Unsupported.symbolset      $(DSTROOT)/$(INSTALL_DATA_DIR)/System.kext/PlugIns/Unsupported.kext/Unsupported;
+       $(_v)if [ -s "$(OBJROOT)/System6.0.symbolset" ]; then   \
+               install $(INSTALL_FLAGS) $(OBJROOT)/System6.0.symbolset    $(DSTROOT)/$(INSTALL_DATA_DIR)/System.kext/PlugIns/System6.0.kext/kernel.6.0;        \
+               install $(INSTALL_FLAGS) $(OBJROOT)/System6.0.symbolset    $(DSTROOT)/$(INSTALL_DATA_DIR)/System.kext/PlugIns/Mach6.0.kext/Mach6.0;     \
+               install $(INSTALL_FLAGS) $(OBJROOT)/System6.0.symbolset    $(DSTROOT)/$(INSTALL_DATA_DIR)/System.kext/PlugIns/BSDKernel6.0.kext/BSDKernel6.0;   \
+               install $(INSTALL_FLAGS) $(OBJROOT)/System6.0.symbolset    $(DSTROOT)/$(INSTALL_DATA_DIR)/System.kext/PlugIns/Libkern6.0.kext/Libkern6.0;       \
+               install $(INSTALL_FLAGS) $(OBJROOT)/System6.0.symbolset    $(DSTROOT)/$(INSTALL_DATA_DIR)/System.kext/PlugIns/IOKit6.0.kext/IOKit6.0;   \
+       fi
+       $(_v)install $(INSTALL_FLAGS) $(OBJROOT)/BSDKernel.symbolset    $(DSTROOT)/$(INSTALL_DATA_DIR)/System.kext/PlugIns/BSDKernel.kext/BSDKernel;
+       $(_v)install $(INSTALL_FLAGS) $(OBJROOT)/IOKit.symbolset        $(DSTROOT)/$(INSTALL_DATA_DIR)/System.kext/PlugIns/IOKit.kext/IOKit;
+       $(_v)install $(INSTALL_FLAGS) $(OBJROOT)/Libkern.symbolset      $(DSTROOT)/$(INSTALL_DATA_DIR)/System.kext/PlugIns/Libkern.kext/Libkern;
+       $(_v)install $(INSTALL_FLAGS) $(OBJROOT)/Mach.symbolset         $(DSTROOT)/$(INSTALL_DATA_DIR)/System.kext/PlugIns/Mach.kext/Mach;
+       $(_v)install $(INSTALL_FLAGS) $(OBJROOT)/Unsupported.symbolset  $(DSTROOT)/$(INSTALL_DATA_DIR)/System.kext/PlugIns/Unsupported.kext/Unsupported;
+       $(_v)install $(INSTALL_FLAGS) $(OBJROOT)/Private.symbolset      $(DSTROOT)/$(INSTALL_DATA_DIR)/System.kext/PlugIns/Private.kext/Private;
        $(_v)$(NEWVERS) $(DSTROOT)/$(INSTALL_DATA_DIR)/System.kext/Info.plist \
                $(DSTROOT)/$(INSTALL_DATA_DIR)/System.kext/PlugIns/AppleNMI.kext/Info.plist \
                $(DSTROOT)/$(INSTALL_DATA_DIR)/System.kext/PlugIns/ApplePlatformFamily.kext/Info.plist \
                $(DSTROOT)/$(INSTALL_DATA_DIR)/System.kext/PlugIns/BSDKernel.kext/Info.plist \
-               $(DSTROOT)/$(INSTALL_DATA_DIR)/System.kext/PlugIns/MACFramework.kext/Info.plist \
                $(DSTROOT)/$(INSTALL_DATA_DIR)/System.kext/PlugIns/IOKit.kext/Info.plist \
                $(DSTROOT)/$(INSTALL_DATA_DIR)/System.kext/PlugIns/IONVRAMFamily.kext/Info.plist \
                $(DSTROOT)/$(INSTALL_DATA_DIR)/System.kext/PlugIns/IOSystemManagement.kext/Info.plist \
                $(DSTROOT)/$(INSTALL_DATA_DIR)/System.kext/PlugIns/Libkern.kext/Info.plist \
                $(DSTROOT)/$(INSTALL_DATA_DIR)/System.kext/PlugIns/Mach.kext/Info.plist \
-               $(DSTROOT)/$(INSTALL_DATA_DIR)/System.kext/PlugIns/Unsupported.kext/Info.plist
+               $(DSTROOT)/$(INSTALL_DATA_DIR)/System.kext/PlugIns/Unsupported.kext/Info.plist \
+               $(DSTROOT)/$(INSTALL_DATA_DIR)/System.kext/PlugIns/Private.kext/Info.plist;
+       $(_v)$(MKDIR) $(DSTROOT)/$(KRESDIR);
+       $(_v)install $(INSTALL_FLAGS) $(OBJPATH)/$(MD_SUPPORTED_KPI_FILENAME) $(DSTROOT)/$(KRESDIR);
+       $(_v)if [ -n `echo $${ARCH_CONFIGS%%\ *} | grep -i  $(ARCH_CONFIG)` ]; then \
+               install $(INSTALL_FLAGS) $(OBJROOT)/$(MI_SUPPORTED_KPI_FILENAME) $(DSTROOT)/$(KRESDIR); \
+       fi
+ifdef MAC
+       $(_v)install $(INSTALL_FLAGS) $(OBJROOT)/MACFramework.symbolset $(DSTROOT)/$(INSTALL_DATA_DIR)/System.kext/PlugIns/MACFramework.kext/MACFramework;
+       $(_v)$(NEWVERS) $(DSTROOT)/$(INSTALL_DATA_DIR)/System.kext/PlugIns/MACFramework.kext/Info.plist
+endif
+       $(_v)$(CP) -rf $(DSTROOT)/$(INSTALL_DATA_DIR)/System.kext $(SYMROOT)
 
 do_build_all:  build_symbol_sets
 
-do_build_install:      install_symbol_sets
+do_build_install:      install_symbol_sets 
+
+EXPORTS_FILE_LIST = $(addprefix $(SOURCE)/,$(foreach set,$(SYMBOL_COMPONENT_LIST), $(set).exports $(set).$(ARCH_CONFIG_LC).exports))
+EXPORTS_FILE_LIST_NOSYSTEM60 = $(addprefix $(SOURCE)/,$(foreach set, $(filter-out System6.0,$(SYMBOL_COMPONENT_LIST)), $(set).exports $(set).$(ARCH_CONFIG_LC).exports))
+
+# Does not include "whole-kernel" clients
+build_mach_kernel_exports:
+       $(_v)if [ $(SUPPORT_SYSTEM60_KEXT) -eq 1 ]; then \
+               $(SOURCE)/generate_linker_exports.sh $(OBJPATH)/kernel-kpi.exp \
+                        $(EXPORTS_FILE_LIST) || exit 1; \
+       else \
+               $(SOURCE)/generate_linker_exports.sh $(OBJPATH)/kernel-kpi.exp \
+                        $(EXPORTS_FILE_LIST_NOSYSTEM60) || exit 1; \
+       fi;
 
 include $(MakeInc_rule)
 include $(MakeInc_dir)