]> git.saurik.com Git - apple/xnu.git/blobdiff - Makefile
xnu-7195.101.1.tar.gz
[apple/xnu.git] / Makefile
index 1660223f5d5a0448a921997c57a5b8e5304c8a05..9b62aadb1fd8ff819fadf2ee3524ba6f166f3c54 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -1,5 +1,5 @@
 #
 #
-# Copyright (C) 1999-2016 Apple Inc. All rights reserved.
+# Copyright (C) 1999-2020 Apple Inc. All rights reserved.
 #
 ifndef VERSDIR
 export VERSDIR := $(shell /bin/pwd)
 #
 ifndef VERSDIR
 export VERSDIR := $(shell /bin/pwd)
@@ -17,6 +17,12 @@ endif
 ifndef SYMROOT
 export SYMROOT = $(SRCROOT)/BUILD/sym
 endif
 ifndef SYMROOT
 export SYMROOT = $(SRCROOT)/BUILD/sym
 endif
+ifndef MallocNanoZone
+export MallocNanoZone := 1
+endif
+
+# Avoid make default rules, make becomes faster
+MAKEFLAGS+=r
 
 export MakeInc_top=${VERSDIR}/makedefs/MakeInc.top
 export MakeInc_kernel=${VERSDIR}/makedefs/MakeInc.kernel
 
 export MakeInc_top=${VERSDIR}/makedefs/MakeInc.top
 export MakeInc_kernel=${VERSDIR}/makedefs/MakeInc.kernel
@@ -25,17 +31,24 @@ export MakeInc_def=${VERSDIR}/makedefs/MakeInc.def
 export MakeInc_rule=${VERSDIR}/makedefs/MakeInc.rule
 export MakeInc_dir=${VERSDIR}/makedefs/MakeInc.dir
 
 export MakeInc_rule=${VERSDIR}/makedefs/MakeInc.rule
 export MakeInc_dir=${VERSDIR}/makedefs/MakeInc.dir
 
+
 #
 # Dispatch non-xnu build aliases to their own build
 # systems. All xnu variants start with MakeInc_top.
 #
 
 #
 # Dispatch non-xnu build aliases to their own build
 # systems. All xnu variants start with MakeInc_top.
 #
 
-ifeq ($(findstring Libsyscall,$(RC_ProjectName)),Libsyscall)
+ifneq ($(findstring Libsyscall,$(RC_ProjectName)),)
+
+include $(MakeInc_cmd)
 
 ifeq ($(RC_ProjectName),Libsyscall_headers_Sim)
 TARGET=-target Libsyscall_headers_Sim
 endif
 
 
 ifeq ($(RC_ProjectName),Libsyscall_headers_Sim)
 TARGET=-target Libsyscall_headers_Sim
 endif
 
+ifeq ($(RC_ProjectName),Libsyscall_driverkit)
+TARGET=-target Libsyscall_driverkit
+endif
+
 default: install
 
 # default to OS X
 default: install
 
 # default to OS X
@@ -44,52 +57,58 @@ SDKROOT ?= macosx.internal
 installhdrs install:
        cd libsyscall ; \
                xcodebuild $@ $(TARGET) \
 installhdrs install:
        cd libsyscall ; \
                xcodebuild $@ $(TARGET) \
+                       $(MAKEOVERRIDES)        \
                        "SRCROOT=$(SRCROOT)/libsyscall"                                 \
                        "OBJROOT=$(OBJROOT)"                                            \
                        "SYMROOT=$(SYMROOT)"                                            \
                        "DSTROOT=$(DSTROOT)"                                            \
                        "SDKROOT=$(SDKROOT)"
 
                        "SRCROOT=$(SRCROOT)/libsyscall"                                 \
                        "OBJROOT=$(OBJROOT)"                                            \
                        "SYMROOT=$(SYMROOT)"                                            \
                        "DSTROOT=$(DSTROOT)"                                            \
                        "SDKROOT=$(SDKROOT)"
 
+Libsyscall_driverkit: install
+
+.PHONY: Libsyscall_driverkit
+
 clean:
 
 installsrc:
        pax -rw . $(SRCROOT)
 
 clean:
 
 installsrc:
        pax -rw . $(SRCROOT)
 
-else ifeq ($(RC_ProjectName),libkxld)
+else ifneq ($(findstring libkxld_host,$(RC_ProjectName)),)
 
 include $(MakeInc_cmd)
 
 default: install
 
 installhdrs install clean:
 
 include $(MakeInc_cmd)
 
 default: install
 
 installhdrs install clean:
-        $(MAKE) -C libkern/kxld $@ USE_APPLE_PB_SUPPORT=all
+        $(MAKE) -C libkern/kxld $@ USE_APPLE_PB_SUPPORT=all PRODUCT_TYPE=ARCHIVE
 
 installsrc:
        $(_v)$(MKDIR) $(SRCROOT)
        $(_v)$(FIND) -x . \! \( \( -name BUILD -o -name .svn -o -name .git -o -name cscope.\* -o -name \*~ \) -prune \) -print0 | $(PAX) -rw -p a -d0 $(SRCROOT)
        $(_v)$(CHMOD) -R go+rX $(SRCROOT)
 
 
 installsrc:
        $(_v)$(MKDIR) $(SRCROOT)
        $(_v)$(FIND) -x . \! \( \( -name BUILD -o -name .svn -o -name .git -o -name cscope.\* -o -name \*~ \) -prune \) -print0 | $(PAX) -rw -p a -d0 $(SRCROOT)
        $(_v)$(CHMOD) -R go+rX $(SRCROOT)
 
-else ifeq ($(RC_ProjectName),libkxld_host)
+else ifneq ($(findstring libkxld,$(RC_ProjectName)),)
 
 include $(MakeInc_cmd)
 
 default: install
 
 installhdrs install clean:
 
 include $(MakeInc_cmd)
 
 default: install
 
 installhdrs install clean:
-        $(MAKE) -C libkern/kxld $@ USE_APPLE_PB_SUPPORT=all PRODUCT_TYPE=ARCHIVE
+        $(MAKE) -C libkern/kxld $@ USE_APPLE_PB_SUPPORT=all
 
 installsrc:
        $(_v)$(MKDIR) $(SRCROOT)
        $(_v)$(FIND) -x . \! \( \( -name BUILD -o -name .svn -o -name .git -o -name cscope.\* -o -name \*~ \) -prune \) -print0 | $(PAX) -rw -p a -d0 $(SRCROOT)
        $(_v)$(CHMOD) -R go+rX $(SRCROOT)
 
 
 installsrc:
        $(_v)$(MKDIR) $(SRCROOT)
        $(_v)$(FIND) -x . \! \( \( -name BUILD -o -name .svn -o -name .git -o -name cscope.\* -o -name \*~ \) -prune \) -print0 | $(PAX) -rw -p a -d0 $(SRCROOT)
        $(_v)$(CHMOD) -R go+rX $(SRCROOT)
 
-else ifeq ($(RC_ProjectName),libkmod)
+else ifneq ($(findstring libkmod,$(RC_ProjectName)),)
 
 default: install
 
 installhdrs install:
        cd libkern/kmod ; \
                xcodebuild $@   \
 
 default: install
 
 installhdrs install:
        cd libkern/kmod ; \
                xcodebuild $@   \
+                       $(MAKEOVERRIDES)        \
                        "SRCROOT=$(SRCROOT)/libkern/kmod"                               \
                        "OBJROOT=$(OBJROOT)"                                            \
                        "SYMROOT=$(SYMROOT)"                                            \
                        "SRCROOT=$(SRCROOT)/libkern/kmod"                               \
                        "OBJROOT=$(OBJROOT)"                                            \
                        "SYMROOT=$(SYMROOT)"                                            \
@@ -101,15 +120,11 @@ clean:
 installsrc:
        pax -rw . $(SRCROOT)
 
 installsrc:
        pax -rw . $(SRCROOT)
 
-else ifeq ($(RC_ProjectName),xnu_tests)
+else ifneq ($(findstring xnu_tests,$(RC_ProjectName)),)
 
 export SYSCTL_HW_PHYSICALCPU := $(shell /usr/sbin/sysctl -n hw.physicalcpu)
 export SYSCTL_HW_LOGICALCPU  := $(shell /usr/sbin/sysctl -n hw.logicalcpu)
 
 export SYSCTL_HW_PHYSICALCPU := $(shell /usr/sbin/sysctl -n hw.physicalcpu)
 export SYSCTL_HW_LOGICALCPU  := $(shell /usr/sbin/sysctl -n hw.logicalcpu)
-ifeq ($(SYSCTL_HW_PHYSICALCPU),$(SYSCTL_HW_LOGICALCPU))
-MAKEJOBS := --jobs=$(shell expr $(SYSCTL_HW_PHYSICALCPU) + 1)
-else
-MAKEJOBS := --jobs=$(SYSCTL_HW_LOGICALCPU)
-endif
+MAKEJOBS := --jobs=$(shell expr $(SYSCTL_HW_LOGICALCPU) + 1)
 
 default: install
 
 
 default: install
 
@@ -119,6 +134,23 @@ install: xnu_tests
 
 clean:
 
 
 clean:
 
+installsrc:
+       pax -rw . $(SRCROOT)
+
+else ifeq ($(RC_ProjectName),xnu_tests_driverkit)
+
+export SYSCTL_HW_PHYSICALCPU := $(shell /usr/sbin/sysctl -n hw.physicalcpu)
+export SYSCTL_HW_LOGICALCPU  := $(shell /usr/sbin/sysctl -n hw.logicalcpu)
+MAKEJOBS := --jobs=$(shell expr $(SYSCTL_HW_LOGICALCPU) + 1)
+
+default: install
+
+installhdrs:
+
+install: xnu_tests_driverkit
+
+clean:
+
 installsrc:
        pax -rw . $(SRCROOT)
 
 installsrc:
        pax -rw . $(SRCROOT)
 
@@ -142,35 +174,31 @@ endif
 #
 export SYSCTL_HW_PHYSICALCPU := $(shell /usr/sbin/sysctl -n hw.physicalcpu)
 export SYSCTL_HW_LOGICALCPU  := $(shell /usr/sbin/sysctl -n hw.logicalcpu)
 #
 export SYSCTL_HW_PHYSICALCPU := $(shell /usr/sbin/sysctl -n hw.physicalcpu)
 export SYSCTL_HW_LOGICALCPU  := $(shell /usr/sbin/sysctl -n hw.logicalcpu)
-ifeq ($(SYSCTL_HW_PHYSICALCPU),$(SYSCTL_HW_LOGICALCPU))
-MAKEJOBS := --jobs=$(shell expr $(SYSCTL_HW_PHYSICALCPU) + 1)
-else
-MAKEJOBS := --jobs=$(SYSCTL_HW_LOGICALCPU)
-endif
-
-TOP_TARGETS =                                                          \
-       clean                                                           \
-       installsrc                                                      \
-       exporthdrs                                                      \
-       all all_desktop all_embedded                                    \
-       all_release_embedded all_development_embedded                   \
-       installhdrs installhdrs_desktop installhdrs_embedded            \
-       installhdrs_release_embedded installhdrs_development_embedded   \
-       install install_desktop install_embedded                        \
-       install_release_embedded install_development_embedded           \
-       installopensource                                               \
-       cscope tags TAGS reindent                                       \
+MAKEJOBS := --jobs=$(shell expr $(SYSCTL_HW_LOGICALCPU) + 1)
+
+TOP_TARGETS = \
+       clean \
+       installsrc \
+       exporthdrs \
+       all all_desktop all_embedded \
+       all_release_embedded all_development_embedded \
+       installhdrs installhdrs_desktop installhdrs_embedded \
+       installhdrs_release_embedded installhdrs_development_embedded \
+       install install_desktop install_embedded \
+       install_release_embedded install_development_embedded \
+       install_kernels \
+       cscope tags TAGS \
        help
 
 DEFAULT_TARGET = all
 
 # Targets for internal build system debugging
        help
 
 DEFAULT_TARGET = all
 
 # Targets for internal build system debugging
-TOP_TARGETS +=                                         \
-       print_exports print_exports_first_build_config  \
-       setup                                           \
-       build                                           \
-       config                                          \
-       install_textfiles                               \
+TOP_TARGETS += \
+       print_exports print_exports_first_build_config \
+       setup \
+       build \
+       config \
+       install_textfiles \
        install_config
 
 ifeq ($(BUILD_JSON_COMPILATION_DATABASE),1)
        install_config
 
 ifeq ($(BUILD_JSON_COMPILATION_DATABASE),1)
@@ -220,7 +248,7 @@ EXPINC_SUBDIRS_X86_64H = $(EXPINC_SUBDIRS)
 EXPINC_SUBDIRS_ARM = $(EXPINC_SUBDIRS)
 EXPINC_SUBDIRS_ARM64 = $(EXPINC_SUBDIRS)
 
 EXPINC_SUBDIRS_ARM = $(EXPINC_SUBDIRS)
 EXPINC_SUBDIRS_ARM64 = $(EXPINC_SUBDIRS)
 
-SETUP_SUBDIRS = SETUP san
+SETUP_SUBDIRS = SETUP san bsd
 
 COMP_SUBDIRS_X86_64 = $(ALL_SUBDIRS)
 COMP_SUBDIRS_X86_64H = $(ALL_SUBDIRS)
 
 COMP_SUBDIRS_X86_64 = $(ALL_SUBDIRS)
 COMP_SUBDIRS_X86_64H = $(ALL_SUBDIRS)
@@ -229,6 +257,10 @@ COMP_SUBDIRS_ARM64 = $(ALL_SUBDIRS)
 
 INSTTEXTFILES_SUBDIRS =        \
        bsd
 
 INSTTEXTFILES_SUBDIRS =        \
        bsd
+INSTTEXTFILES_SUBDIRS_X86_64 = $(INSTTEXTFILES_SUBDIRS)
+INSTTEXTFILES_SUBDIRS_X86_64H = $(INSTTEXTFILES_SUBDIRS)
+INSTTEXTFILES_SUBDIRS_ARM = $(INSTTEXTFILES_SUBDIRS)
+INSTTEXTFILES_SUBDIRS_ARM64 = $(INSTTEXTFILES_SUBDIRS)
 
 include $(MakeInc_kernel)
 include $(MakeInc_rule)
 
 include $(MakeInc_kernel)
 include $(MakeInc_rule)
@@ -240,7 +272,19 @@ endif # all other RC_ProjectName
 
 installapi_libkdd installhdrs_libkdd install_libkdd:
        cd libkdd; \
 
 installapi_libkdd installhdrs_libkdd install_libkdd:
        cd libkdd; \
-               xcodebuild -target libkdd $(subst _libkdd,,$@)  \
+               xcodebuild -target Default $(subst _libkdd,,$@) \
+                       $(MAKEOVERRIDES)        \
+                       "SRCROOT=$(SRCROOT)/libkdd"             \
+                       "OBJROOT=$(OBJROOT)"                    \
+                       "SYMROOT=$(SYMROOT)"                    \
+                       "DSTROOT=$(DSTROOT)"                    \
+                       "SDKROOT=$(SDKROOT)"
+
+
+installapi_libkdd_tests installhdrs_libkdd_tests install_libkdd_tests:
+       cd libkdd; \
+               xcodebuild -target tests $(subst _libkdd_tests,,$@)     \
+                       $(MAKEOVERRIDES)        \
                        "SRCROOT=$(SRCROOT)/libkdd"             \
                        "OBJROOT=$(OBJROOT)"                    \
                        "SYMROOT=$(SYMROOT)"                    \
                        "SRCROOT=$(SRCROOT)/libkdd"             \
                        "OBJROOT=$(OBJROOT)"                    \
                        "SYMROOT=$(SYMROOT)"                    \
@@ -250,7 +294,8 @@ installapi_libkdd installhdrs_libkdd install_libkdd:
 
 installapi_libkdd_host installhdrs_libkdd_host install_libkdd_host:
        cd libkdd; \
 
 installapi_libkdd_host installhdrs_libkdd_host install_libkdd_host:
        cd libkdd; \
-               xcodebuild -target kdd.framework $(subst _libkdd_host,,$@)      \
+               xcodebuild -configuration ReleaseHost -target kdd.framework $(subst _libkdd_host,,$@)   \
+                       $(MAKEOVERRIDES)        \
                        "SRCROOT=$(SRCROOT)/libkdd"             \
                        "OBJROOT=$(OBJROOT)"                    \
                        "SYMROOT=$(SYMROOT)"                    \
                        "SRCROOT=$(SRCROOT)/libkdd"             \
                        "OBJROOT=$(OBJROOT)"                    \
                        "SYMROOT=$(SYMROOT)"                    \
@@ -265,3 +310,49 @@ installapi_libkdd_host installhdrs_libkdd_host install_libkdd_host:
 xnu_tests:
        $(MAKE) -C $(SRCROOT)/tools/tests       $(if $(filter -j,$(MAKEFLAGS)),,$(MAKEJOBS)) \
                SRCROOT=$(SRCROOT)/tools/tests
 xnu_tests:
        $(MAKE) -C $(SRCROOT)/tools/tests       $(if $(filter -j,$(MAKEFLAGS)),,$(MAKEJOBS)) \
                SRCROOT=$(SRCROOT)/tools/tests
+       $(MAKE) -C $(SRCROOT)/tests     $(if $(filter -j,$(MAKEFLAGS)),,$(MAKEJOBS)) \
+               SRCROOT=$(SRCROOT)/tests
+
+xnu_tests_driverkit:
+       $(MAKE) -C $(SRCROOT)/tests/driverkit $(if $(filter -j,$(MAKEFLAGS)),,$(MAKEJOBS)) \
+               SRCROOT=$(SRCROOT)/tests/driverkit
+
+
+include $(MakeInc_cmd)
+
+#
+# The "analyze" target defined below invokes Clang Static Analyzer
+# with a predefined set of checks and options for the project.
+#
+
+# By default, analysis results are available in BUILD/StaticAnalyzer.
+# Set this variable in your make invocation to use a different directory.
+# Note that these results are only deleted when the build directory
+# is cleaned. They aren't deleted every time the analyzer is re-run,
+# but they are deleted after "make clean".
+STATIC_ANALYZER_OUTPUT_DIR ?= $(SRCROOT)/BUILD/StaticAnalyzer
+
+# By default, the default make target is analyzed. You can analyze
+# other targets by setting this variable in your make invocation.
+STATIC_ANALYZER_TARGET ?=
+
+# You can pass additional flags to scan-build by setting this variable
+# in your make invocation. For example, you can enable additional checks.
+STATIC_ANALYZER_EXTRA_FLAGS ?=
+
+analyze:
+# This is where the reports are going to be available.
+# Old reports are deleted on make clean only.
+       $(_v)$(MKDIR) $(STATIC_ANALYZER_OUTPUT_DIR)
+
+# Recursively build the requested target under scan-build.
+# Exclude checks that weren't deemed to be security critical,
+# like null pointer dereferences.
+       $(_v)$(XCRUN) $(SCAN_BUILD) -o $(STATIC_ANALYZER_OUTPUT_DIR) \
+               -disable-checker deadcode.DeadStores \
+               -disable-checker core.NullDereference \
+               -disable-checker core.DivideZero \
+               $(STATIC_ANALYZER_EXTRA_FLAGS) \
+               $(MAKE) $(STATIC_ANALYZER_TARGET) QUIET=1 2>&1 | $(GREP) "^scan-build:"
+
+.PHONY: analyze