diff options
Diffstat (limited to 'Config.kmk')
-rw-r--r-- | Config.kmk | 9141 |
1 files changed, 9141 insertions, 0 deletions
diff --git a/Config.kmk b/Config.kmk new file mode 100644 index 00000000..38833aa2 --- /dev/null +++ b/Config.kmk @@ -0,0 +1,9141 @@ +# $Id: Config.kmk $ +## @file +# The global build configuration file for VBox. +# +# This file gets included by all makefiles through the +# include $(KBUILD_PATH)/header.kmk statement. +# + +# +# Copyright (C) 2006-2023 Oracle and/or its affiliates. +# +# This file is part of VirtualBox base platform packages, as +# available from https://www.virtualbox.org. +# +# This program is free software; you can redistribute it and/or +# modify it under the terms of the GNU General Public License +# as published by the Free Software Foundation, in version 3 of the +# License. +# +# This program is distributed in the hope that it will be useful, but +# WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program; if not, see <https://www.gnu.org/licenses>. +# +# SPDX-License-Identifier: GPL-3.0-only +# + +# Marker. +VBOX_ROOT_CONFIG_KMK_INCLUDED = 1 + +# +# kBuild stuff +# + +# Build with umask 022 (requires kBuild r2556 to work, harmless on earlier). +$(set-umask 022) + +# Add our own directories to the search paths. +KBUILD_TOOL_PATHS = $(KBUILD_DEVTOOLS)/kBuildTools/ +KBUILD_UNIT_PATHS = $(KBUILD_DEVTOOLS)/kBuildUnits/ + +# Modify the build types. +KBUILD_BLD_TYPES = release profile debug kprofile + +## 'strict' builds +# Same as release builds, except that RT_STRICT and VBOX_STRICT are defined, +# meaning all assertions are in action. (Appending means '.strict' props take +# precedence in argument lists.) +KBUILD_BLD_TYPES += strict +BLD_TYPE_strict_EXTENDS = release +BLD_TYPE_strict_EXTENDS_BY = appending + +## 'asan' builds +# Same as release builds, except that some form of address sanitizer (e.g. +# VBOX_WITH_GCC_SANITIZER=1 or VBOX_WITH_EF_WRAPS) is enabled. In addition +# RT_STRICT and VBOX_STRICT are defined so assertions and sanity checks will +# also be enabled (mainly for not needing to build+test strict builds separately). +KBUILD_BLD_TYPES += asan +BLD_TYPE_asan_EXTENDS = release +BLD_TYPE_asan_EXTENDS_BY = appending + +## 'dbgopt' builds +# Same as debug builds, except that compiler optimizations are enabled. This +# intended for cases where all the debug facitities (logging, assertions, ++) +# is wanted but actual source level debugging as important as execution speed. +KBUILD_BLD_TYPES += dbgopt +BLD_TYPE_dbgopt_EXTENDS = debug +BLD_TYPE_dbgopt_EXTENDS_BY = overriding + +# Temporary hack for kBuild ticket #83. +## @todo kBuild: remove after closing ticket #83. +PROPS_ACCUMULATE_L_LNK += INTERMEDIATES +PROPS_PROGRAMS_ACCUMULATE_L += INTERMEDIATES +PROPS_LIBRARIES_ACCUMULATE_L += INTERMEDIATES +PROPS_DLLS_ACCUMULATE_L += INTERMEDIATES +PROPS_SYSMODS_ACCUMULATE_L += INTERMEDIATES +PROPS_MISCBINS_ACCUMULATE_L += INTERMEDIATES + +# Misc names used by the install paths below. +VBOX_PUEL_MANGLED_NAME := Oracle_VM_VirtualBox_Extension_Pack + +# Install paths +## @todo This will change after 4.1 is branched off! +# What is now 'bin' and 'lib' will be moved down under 'staged/', except on +# darwin where it's currently called 'dist' which will be renamed to 'staged'. +# When running 'kmk install' files will be copied to 'dist/', on unix systems +# this will be done in FHS fashion assuming /usr/local or /usr as 'prefix'. +# +# Changes related to this are marked VBOX_WITH_NEW_LAYOUT. +ifndef VBOX_WITH_NEW_LAYOUT + PATH_INS = $(PATH_OUT)/dist + PATH_STAGE = $(PATH_OUT) + INST_DEBUG := stage/debug/ +endif + +ifeq ($(KBUILD_TARGET),darwin) + ifndef VBOX_WITH_NEW_LAYOUT + INST_DIST = dist/ + else + INST_DIST := + endif + INST_SDK = $(INST_DIST)sdk/ + + # the bundles + INST_VIRTUALBOX = $(INST_DIST)VirtualBox.app/ + INST_VBOXDRV = $(INST_DIST)VBoxDrv.kext/ + INST_VBOXNETFLT = $(INST_DIST)VBoxNetFlt.kext/ + INST_VBOXNETADP = $(INST_DIST)VBoxNetAdp.kext/ + INST_VBOXUSB = $(INST_DIST)VBoxUSB.kext/ + + # put everything in the VirtualBox app bundle. + INST_BIN = $(INST_VIRTUALBOX)Contents/MacOS/ + INST_DLL = $(INST_BIN) + INST_SYS = $(INST_BIN) + INST_TESTCASE = $(INST_BIN)testcase/ + INST_ADDITIONS = $(INST_DIST)additions/ + INST_ADDITIONS_ISO = $(INST_BIN) + INST_UNATTENDED_TEMPLATES = $(INST_BIN)UnattendedTemplates/ + + INST_VBOXDBG_SYMS = $(INST_VIRTUALBOX)Contents/Resources/VBoxDbgSyms/ + + # other paths + INST_LIB = lib/ + INST_ADDITIONS_LIB = $(INST_LIB)additions/ + VBOX_INST_DTRACE_LIB = $(INST_BIN)dtrace/lib/ + VBOX_INST_DTRACE_TST = $(INST_BIN)dtrace/testcase/ + VBOX_INST_TOOLS = $(INST_BIN)tools/ + +else + + INST_BIN = bin/ + INST_DIST = $(INST_BIN) + INST_SDK = $(INST_BIN)sdk/ + + INST_VIRTUALBOX = $(INST_BIN) + INST_VBOXDRV = $(INST_BIN) + INST_VBOXNETFLT = $(INST_BIN) + INST_VBOXNETADP = $(INST_BIN) + INST_VBOXUSB = $(INST_BIN) + + INST_DLL = $(INST_BIN) + INST_SYS = $(INST_BIN) + INST_TESTCASE = $(INST_BIN)testcase/ + INST_ADDITIONS = $(INST_BIN)additions/ + INST_ADDITIONS_ISO = $(INST_ADDITIONS) + INST_UNATTENDED_TEMPLATES = $(INST_BIN)UnattendedTemplates/ + + INST_LIB = lib/ + INST_ADDITIONS_LIB = $(INST_LIB)additions/ + VBOX_INST_DTRACE_LIB = $(INST_BIN)dtrace/lib/ + VBOX_INST_DTRACE_TST = $(INST_BIN)dtrace/testcase/ + + INST_VBOXDBG_SYMS = $(INST_BIN)VBoxDbgSyms/ + VBOX_INST_TOOLS = $(INST_BIN)tools/ +endif + + +INST_VALIDATIONKIT = validationkit/ +INST_TESTBOXSCRIPT = testboxscript/ + +INST_DOC = doc/ +INST_EXTPACK = $(INST_BIN)ExtensionPacks/ +INST_EXTPACK_CERTS = $(INST_BIN)ExtPackCertificates/ +INST_EXTPACK_PUEL = $(INST_EXTPACK)$(VBOX_PUEL_MANGLED_NAME)/ +INST_PACKAGES = packages/ + +VBOX_PATH_SDK = $(patsubst %/,%,$(PATH_STAGE)/$(INST_SDK)) +VBOX_PATH_DIST = $(patsubst %/,%,$(PATH_STAGE)/$(INST_DIST)) +VBOX_PATH_VALIDATIONKIT = $(patsubst %/,%,$(PATH_STAGE)/$(INST_VALIDATIONKIT)) +VBOX_PATH_ADDITIONS = $(patsubst %/,%,$(PATH_STAGE)/$(INST_ADDITIONS)) +VBOX_PATH_ADDITIONS_ISO = $(patsubst %/,%,$(PATH_STAGE)/$(INST_ADDITIONS_ISO)) +VBOX_PATH_ADDITIONS_LIB = $(patsubst %/,%,$(PATH_STAGE)/$(INST_ADDITIONS_LIB)) +VBOX_PATH_EXTPACK_PUEL = $(patsubst %/,%,$(PATH_STAGE)/$(INST_EXTPACK_PUEL)) +VBOX_PATH_PACKAGES = $(patsubst %/,%,$(PATH_STAGE)/$(INST_PACKAGES)) +VBOX_PATH_TOOLS = $(patsubst %/,%,$(PATH_STAGE)/$(VBOX_INST_TOOLS)) + + +# +# Some source paths of global interest. +# +VBOX_PATH_SRC_CERTIFICATES = $(PATH_ROOT)/src/VBox/HostDrivers/Support/Certificates + + +# +# Delete targets on failure. +# +.DELETE_ON_ERROR: + +# +# Notify about important kBuild updates. +# +if $(KBUILD_VERSION_MAJOR) == 0 \ + && ( $(KBUILD_VERSION_MINOR) >= 2 \ + || ( $(KBUILD_VERSION_MINOR) == 1 \ + && $(KBUILD_VERSION_PATCH) >= 999)) + VBOX_MIN_KMK_REVISION := 3093 + VBOX_MIN_KBUILD_KMK_REVISION := $(if-expr "$(KBUILD_HOST)" == "win",3097,$(if-expr "$(KBUILD_HOST).$(KBUILD_HOST_ARCH)" == "solaris.sparc64",2511,3074)) + if $(KMK_REVISION) >= $(VBOX_MIN_KMK_REVISION) + if $(KBUILD_KMK_REVISION) >= $(VBOX_MIN_KBUILD_KMK_REVISION) + # OK. + else + $(error You must update kBuild! Requires kBuild binaries $(VBOX_MIN_KBUILD_KMK_REVISION) or later, kmk says $(KBUILD_KMK_REVISION) ($(KBUILD_VERSION))) + endif + else + $(error You must update kBuild! Requires kBuild revision $(VBOX_MIN_KMK_REVISION) or later, found $(KMK_REVISION) ($(KBUILD_VERSION))) + endif +else + $(error You must update kBuild! Requires 0.1.999 or later, found $(KBUILD_VERSION)) +endif + +# +# Define USERNAME early on. +# +ifndef USERNAME + ifdef USER + USERNAME = $(USER) + else + $(warning Warning: You must have USERNAME or USER in your environment.) + endif +endif + +# +# Detect the darwin host version number so we can disable stuff that doesn't +# currently build on Lion. +# +ifeq ($(KBUILD_HOST),darwin) + VBOX_DARWIN_HOST_VERSION := $(subst ., ,$(shell uname -r)) + # Keep counting _MAJOR past 19.x (macOS 10.15.x) to simplify dealing with macOS 11.x. + VBOX_DARWIN_HOST_VERSION_MAJOR := $(expr $(word 1, $(VBOX_DARWIN_HOST_VERSION)) - 4) + VBOX_DARWIN_HOST_VERSION_MINOR := $(word 2, $(VBOX_DARWIN_HOST_VERSION)) + VBOX_DARWIN_HOST_VERSION_PATCH := $(word 3, $(VBOX_DARWIN_HOST_VERSION)) + if $(VBOX_DARWIN_HOST_VERSION_MAJOR) <= 15 + VBOX_DARWIN_HOST_VERSION := 10.$(VBOX_DARWIN_HOST_VERSION_MAJOR).$(VBOX_DARWIN_HOST_VERSION_MINOR) + else + VBOX_DARWIN_HOST_VERSION := 11.$(expr $(VBOX_DARWIN_HOST_VERSION_MAJOR) - 16).$(VBOX_DARWIN_HOST_VERSION_MINOR) + endif +endif + +include $(PATH_ROOT)/Version.kmk + +# The raw version string. This *must not* contain any other information/fields than +# major, minor and build revision (as it is now) -- also will be used for host/guest version +# comparison. +VBOX_VERSION_STRING_RAW = $(VBOX_VERSION_MAJOR).$(VBOX_VERSION_MINOR).$(VBOX_VERSION_BUILD) + +# VBOX_VERSION_STRING without the publisher. +VBOX_VERSION_STRING_NO_PUB = $(VBOX_VERSION_STRING_RAW)$(addprefix _,$(VBOX_VERSION_PRERELEASE)) + +# Full version string (may include more than just x.y.z, but no spaces or other problematic chars). +# Note! The BETA[n],ALPHA[n],RC[n] indicators should be inserted before the +# publisher so that RTStrVersionCompare have a chance of comparing +# prerelease from different publishers correctly. +VBOX_VERSION_STRING = $(VBOX_VERSION_STRING_NO_PUB)$(VBOX_BUILD_PUBLISHER) + + +## Make a numeric value from the major, minor and build numbers (params) +VBOX_FULL_VERSION_MAKE = $(expr ($1 << 24) | ($2 << 16) | $3) + +## Checks if the current VBox version is higher or equal to the major, minor and +# build numbers given as parameters. +# @returns 1 if true, 0 if false. For use with 'if'. +VBOX_VERSION_PREREQ = $(expr $(call VBOX_FULL_VERSION_MAKE,$(VBOX_VERSION_MAJOR),$(VBOX_VERSION_MINOR),$(VBOX_VERSION_BUILD)) \ + >= $(call VBOX_FULL_VERSION_MAKE,$1,$2,$3)) + +# Enable host screen saver toggle by default +VBOX_WITH_SCREENSAVER_CONTROL = 1 + +# Force the additions.sh script to get an exact additions build when we're doing the release. +if $(VBOX_VERSION_BUILD) % 2 == 0 + ifeq ($(VBOX_VERSION_PRERELEASE),) + VBOX_RELEASE_EXACT_MATCH = 1 + endif +endif +ifneq ($(VBOX_RELEASE_EXACT_MATCH),) + export VBOX_ADDITIONS_SH_MODE = release + export VBOX_DOCUMENTATION_SH_MODE = release + export VBOX_EFI_SH_MODE = release + export VBOX_EXTPACKS_SH_MODE = release +endif + +# Some info on the vendor +VBOX_VENDOR = Oracle and/or its affiliates +VBOX_VENDOR_SHORT = Oracle +VBOX_PRODUCT = Oracle VM VirtualBox +# Not all could be done automatically. Here is a list of known places which +# have to be updated manually, please keep this up to date: +# src/VBox/Devices/PC/PXE/client/uinit.asm +# src/VBox/RDP/webclient/flash/com/sun/network/rdp/Version.as +# src/VBox/Frontends/VirtualBox/src/globals/UICommon.cpp +# src/VBox/Frontends/VirtualBox/src/settings/global/VBoxGLSettingsLanguage.cpp +# src/VBox/Frontends/VirtualBox/nls/*.ts +# debian/control +# src/VBox/Installer/linux/{debian,rpm} +# src/VBox/Installer/linux/virtualbox.desktop +# src/VBox/Additions/WINNT/Installer/ISO/ReadmeDrivers.txt +# src/VBox/Main/nls/*.ts +# src/VBox/ExtPacks/Puel/nls/*.ts +# src/VBox/Frontends/VBoxManage/nls/*.ts +# */*.inf, */*.rc + +# Maybe we want set this manually. +VBOX_C_YEAR = $(date-utc %Y) + +# +# The VirtualBox package type. +# +ifeq ($(KBUILD_TARGET),win) + VBOX_PACKAGE_OS = WINDOWS +else ifeq ($(KBUILD_TARGET),linux) + VBOX_PACKAGE_OS = LINUX +else ifeq ($(KBUILD_TARGET),darwin) + VBOX_PACKAGE_OS = DARWIN +else ifeq ($(KBUILD_TARGET),solaris) + VBOX_PACKAGE_OS = SOLARIS +else ifeq ($(KBUILD_TARGET),os2) + VBOX_PACKAGE_OS = OS2 +else ifeq ($(KBUILD_TARGET),haiku) + VBOX_PACKAGE_OS = HAIKU +else if1of ($(KBUILD_TARGET), dragonfly freebsd netbsd openbsd) + VBOX_PACKAGE_OS = BSD +else + $(error Cannot determine VBOX_PACKAGE_OS) +endif +ifeq ($(KBUILD_TARGET_ARCH),x86) + VBOX_PACKAGE_ARCH = 32BITS +else + VBOX_PACKAGE_ARCH = 64BITS +endif +# distribution, mostly for Linux/Solaris where we support different distributions +# this strip will be overridden by the Linux packaging scripts +VBOX_PACKAGE_DIST ?= GENERIC +# Full string +VBOX_PACKAGE_STRING = $(VBOX_PACKAGE_OS)_$(VBOX_PACKAGE_ARCH)_$(VBOX_PACKAGE_DIST) + +# Supported VirtualBox host architectures. +VBOX_SUPPORTED_HOST_ARCHS := amd64 +if1of ($(KBUILD_TARGET), darwin) # Work in progress. + VBOX_SUPPORTED_HOST_ARCHS += arm64 +endif + + +# +# The VirtualBox Configuration Defaults. +# +# We try to document all the build configuration options here, things which +# aren't enabled by default are left commented out just to show that they +# exist and which value they should have (usually 1, but anyway). +# + +# Indicate VBOX_ONLY build if any of the VBOX_ONLY_* variables are set. +VBOX_ONLY_BUILD := $(strip $(foreach x, ADDITIONS DOCS EXTPACKS SDK VALIDATIONKIT \ + , $(if-expr defined(VBOX_ONLY_$(x)),VBOX_ONLY_$(x)))) +if $(words $(VBOX_ONLY_BUILD)) > 1 + $(error VBox: More than one VBOX_ONLY build enabled! $(VBOX_ONLY_BUILD)) +endif + +# Select new Xcode based on host OS X version. +ifeq ($(KBUILD_HOST),darwin) + if "$(KBUILD_TARGET_ARCH)" == "arm64" + VBOX_WITH_EVEN_NEWER_XCODE := 1 + else if !defined(VBOX_WITH_EVEN_NEWER_XCODE) && !defined(VBOX_WITHOUT_EVEN_NEWER_XCODE) && !defined(VBOX_WITH_NEW_XCODE) && $(KBUILD_HOST_VERSION_MAJOR) >= 16 # (OS X 10.12 Sierra) + VBOX_WITH_EVEN_NEWER_XCODE := 1 + else if !defined(VBOX_WITH_NEW_XCODE) && !defined(VBOX_WITHOUT_NEW_XCODE) && $(KBUILD_HOST_VERSION_MAJOR) >= 13 # (OS X 10.9 Mavericks) + VBOX_WITH_NEW_XCODE := 1 + endif +endif +# Select new VC++ on Windows. +VBOX_WITH_NEW_VCC = 1 +# Use this to disable control flow. +#VBOX_WITHOUT_CONTROL_FLOW_GUARD = 1 +# Select Windows 11 SDK. +VBOX_WITH_NEW_WINDOWS_SDK = 1 +# Select Windows 11 DDK. +VBOX_WITH_NEW_WINDOWS_DDK = 1 +# Don't use the compiler CRT for statically linked modules, use IPRT with some +# additional CRT functionality. +# Note! This has only been tested with Visual C++ 2019. +if "$(KBUILD_TARGET)" == "win" && "$(KBUILD_TYPE)" != "asan" + VBOX_WITH_NOCRT_STATIC := 1 +endif + +## @name Additions +## @{ +# This indicates that additions (of some kind or another) is being _built_. +# VBOX_WITHOUT_ADDITIONS overrides it. +VBOX_WITH_ADDITIONS = 1 +# Build the optional ring-0 part of the additions for syntax checking. +# On linux we build this as a test case instead. +# Skip for darwin.arm64 for now. +if "$(KBUILD_TARGET)" != "linux" && "$(intersects $(KBUILD_TARGET).$(KBUILD_TARGET_ARCH), darwin.arm64)" == "" + VBOX_WITH_ADDITION_DRIVERS = 1 +endif +# Build X11 additions. Can be disabled separately. +if1of ($(KBUILD_TARGET), dragonfly freebsd linux netbsd openbsd solaris) + VBOX_WITH_X11_ADDITIONS = 1 +endif +# Enable the building of shared folders in the windows additions. +VBOX_WITH_WIN32_ADDITIONS_SHAREDFOLDERS = 1 +# Take the binaries of the OS/2 Additions. +VBOX_WITH_OS2_ADDITIONS_BIN = 1 +# Use additions from the build server. +#VBOX_WITH_ADDITIONS_FROM_BUILD_SERVER = 1 +# Include additions in the package +VBOX_WITH_ADDITIONS_PACKING = 1 +# Don't include any CRTs. +# For Windows hosts this would be the MS Visual Studio Redistributable (2019). +VBOX_WITH_CRT_PACKING = +# Only build the additions (for the additions build server). +#VBOX_ONLY_ADDITIONS = 1 +ifdef VBOX_ADDITIONS_ONLY # typical mistake. + $(error It is VBOX_ONLY_ADDITIONS=1 not VBOX_ADDITIONS_ONLY!) +endif +# Don't bother with additions, overrides VBOX_WITH_ADDITIONS. +# This is not used by makefiles, only Config.kmk, see below. +ifdef VBOX_ONLY_SDK + VBOX_WITHOUT_ADDITIONS = 1 +endif +# Don't create the additions ISO. +# (Used by the additions build server, don't invert it.) +#VBOX_WITHOUT_ADDITIONS_ISO = 1 +## @} + +# Set build options right for building the Additions as an RPM package. +# VBOX_ONLY_RPM_ADDITIONS = 1 +ifdef VBOX_ONLY_RPM_ADDITIONS + VBOX_ONLY_ADDITIONS = 1 + VBOX_ONLY_ADDITIONS_WITHOUT_RTISOMAKER = 1 + # We build the RPMs using public sources. + VBOX_OSE = 1 + # We want to re-use parts of the packing pass, but not all. + VBOX_WITHOUT_LINUX_GUEST_PACKAGE = 1 + VBOX_WITHOUT_ADDITIONS_ISO = 1 +endif + +## @name Documentation +## @{ +# The documentation +VBOX_WITH_DOCS = 1 +# Use documentation from the build server. +#VBOX_WITH_DOCS_FROM_BUILD_SERVER = 1 +# Include documentation in the package +VBOX_WITH_DOCS_PACKING = 1 +# Include CHM when building docs (unset in LocalConfig.kmk to suppress CHM) +## @todo CHM docs are on the way out... +if1of ($(KBUILD_TARGET), win) + VBOX_WITH_DOCS_CHM = + VBOX_WITH_DOCS_CHM_PACKING = +endif +# Build QHelp documentation, needs qhelpgenerator +VBOX_WITH_DOCS_QHELP = 1 +# Include QHelp documentation in the package +VBOX_WITH_DOCS_QHELP_PACKING = 1 +# By default only include translations in documentation-only builds +ifdef VBOX_ONLY_DOCS + ifndef VBOX_NO_DOCS_TRANSLATIONS + VBOX_WITH_DOCS_TRANSLATIONS = 1 + endif +endif +# Default languages +VBOX_MANUAL_LANGUAGES = en_US +ifdef VBOX_WITH_DOCS_TRANSLATIONS + # The French translation is too outdated to be useful, needs a fresh start. + #VBOX_MANUAL_ADD_LANGUAGES = fr_FR +endif +# Don't bother with documentation, overrides VBOX_WITH_DOCS. +# This is not used by makefiles, only Config.kmk, see below. +#VBOX_WITHOUT_DOCS = 1 +# Only build the documentation (for the documentation build server). +#VBOX_ONLY_DOCS = 1 +ifdef VBOX_DOCS_ONLY # typical mistake. + $(error It is VBOX_ONLY_DOCS=1 not VBOX_DOCS_ONLY!) +endif +## @} + +## @name VMM related settings. +## @{ +# Enable the VT-x & AMD-V execution manager (HM). +if "$(KBUILD_TARGET)" == "amd64" && !defined(VBOX_WITHOUT_HWVIRT) + VBOX_WITH_HWVIRT := 1 +endif +# Enable .r0 modules. +if "$(KBUILD_TARGET_ARCH)" == "amd64" + VBOX_WITH_R0_MODULES := 1 +endif +# Enable safe STR (store task register) emulation for raw-mode. +VBOX_WITH_SAFE_STR = 1 +# Enable support for 64-bit guests. +VBOX_WITH_64_BITS_GUESTS = 1 +# Enable multi-core VCPUs. +VBOX_WITH_MULTI_CORE = 1 +# Activate this to force the VM to pre-allocate the guest RAM before startup +VBOX_WITH_PREALLOC_RAM_BY_DEFAULT = +# Enable the debugger. +VBOX_WITH_DEBUGGER = 1 +# Enable the debugger GUI. +VBOX_WITH_DEBUGGER_GUI = 1 +# Nested hardware virtualization (64-bit hosts only). +ifeq ($(KBUILD_TARGET_ARCH),amd64) + # Enables SVM nested hardware virtualization support. + VBOX_WITH_NESTED_HWVIRT_SVM = 1 + # Enables VMX nested hardware virtualization support. + VBOX_WITH_NESTED_HWVIRT_VMX = 1 + # Enables nested hardware virtualization support but only in IEM. + #VBOX_WITH_NESTED_HWVIRT_ONLY_IN_IEM = 1 + ifdef VBOX_WITH_NESTED_HWVIRT_ONLY_IN_IEM + if !defined(VBOX_WITH_NESTED_HWVIRT_SVM) && !defined(VBOX_WITH_NESTED_HWVIRT_VMX) + $(error VBOX_WITH_NESTED_HWVIRT_ONLY_IN_IEM defined without enabling nested VMX or nested SVM support) + endif + endif + # Enables guest EPT support for VMX nested hardware virtualization. + ifn1of ($(KBUILD_TARGET), darwin) + VBOX_WITH_NESTED_HWVIRT_VMX_EPT = 1 + endif + if defined(VBOX_WITH_NESTED_HWVIRT_VMX_EPT) && !defined(VBOX_WITH_NESTED_HWVIRT_VMX) + $(error VBOX_WITH_NESTED_HWVIRT_VMX_EPT requires VBOX_WITH_NESTED_HWVIRT_VMX) + endif +endif +# Enable the TLBs in IEM (experimental). +if1of ($(KBUILD_TARGET_ARCH), arm64) + VBOX_WITH_IEM_TLB := 1 +endif +# Enable native NEM on windows and macOS. +if1of ($(KBUILD_TARGET), win darwin) + VBOX_WITH_NATIVE_NEM = 1 +endif +# Enable NEM fallback if the driver is not available. +if1of ($(KBUILD_TARGET), darwin) + VBOX_WITH_DRIVERLESS_NEM_FALLBACK = 1 +endif +# Enable forced driverless mode by default. +if1of ($(KBUILD_TARGET), darwin) + VBOX_WITH_DRIVERLESS_FORCED = 1 + VBOX_WITH_INTNET_SERVICE_IN_R3 = 1 +endif +# Enables the new breakpoint handling code, see @bugref{8650} +VBOX_WITH_DBGF_FLOW_TRACING = 1 +if1of ($(KBUILD_TARGET).$(KBUILD_TARGET_ARCH), linux.amd64) + ifdef VBOX_WITH_R0_MODULES + # Enable IBT branch protection for the R0 modules. + # (A make warning will be shown if gcc is too old.) + VBOX_WITH_R0_MOD_IBT_BRANCH_PROTECTION = 1 + endif +endif +## @} + + +## @name Devices, Drivers, ... +## @{ +# Build the Host Guest Communication Manager component. +VBOX_WITH_HGCM = 1 +## Build the bugcheck detection code. +#VBOX_WITH_GUEST_BUGCHECK_DETECTION = +# Enable the USB feature. This includes VBOX_WITH_VUSB! +VBOX_WITH_USB = 1 +# Enable the USB 1.1 controller plus virtual USB HID devices. +VBOX_WITH_VUSB = 1 +# Enable the USB 2.0 controller. +VBOX_WITH_EHCI = 1 +# Enable the ISCSI feature. +VBOX_WITH_ISCSI = 1 +# Enable INIP support in the ISCSI feature. +VBOX_WITH_INIP = 1 +# Enables lwip as a core of NAT service +VBOX_WITH_LWIP_NAT = 1 +# Enables compilation of NAT service +VBOX_WITH_NAT_SERVICE = 1 +# Enable the E1000 feature. +VBOX_WITH_E1000 = 1 +# Enable the Virtio feature. +VBOX_WITH_VIRTIO = 1 +# Enable the Virtio SCSI device. +VBOX_WITH_VIRTIO_SCSI = 1 +# HDA emulation is Intel HDA by default. +VBOX_WITH_INTEL_HDA = 1 +ifn1of ($(KBUILD_TARGET), win darwin) + # Enable OSS audio support. + VBOX_WITH_AUDIO_OSS = 1 +endif +if1of ($(KBUILD_TARGET), linux) + # Enable ALSA audio support. + VBOX_WITH_AUDIO_ALSA = 1 +endif +if1of ($(KBUILD_TARGET), linux) + # Enable PulseAudio audio support. + VBOX_WITH_AUDIO_PULSE = 1 +endif +# Enable building debugging backend. +# Only will be used at runtime when "VBoxInternal2/Audio/Debug/Enabled" (VM / global) is set. +VBOX_WITH_AUDIO_DEBUG = 1 +# Enables the audio endpoint detection on Windows hosts. +VBOX_WITH_AUDIO_MMNOTIFICATION_CLIENT = 1 +# Enable PCI passthrough support. +# (disabled with 6.1, since it's not complete/useful enough) +VBOX_WITH_PCI_PASSTHROUGH = +# Enable statically linked dbus support. +if1of ($(KBUILD_TARGET), linux solaris) + VBOX_WITH_DBUS = 1 +endif +# Enable building PAM modules. +if1of ($(KBUILD_TARGET), linux solaris) + VBOX_WITH_PAM = 1 +endif +# Enable internal networking. +VBOX_WITH_INTERNAL_NETWORKING = 1 +# Enable vmsvga (svga2) graphics device variant, 2D part +VBOX_WITH_VMSVGA = 1 +# Enable vmsvga (svga2) graphics device variant, 3D part +if1of ($(KBUILD_TARGET), darwin linux win) + VBOX_WITH_VMSVGA3D = 1 +endif +# Enable vmsvga (svga2) graphics device variant, 3D part, VGPU10 DX commands +ifdef VBOX_WITH_VMSVGA3D + VBOX_WITH_VMSVGA3D_DX = 1 + # Enable DXVK library for supporting VGPU10 DX on non Windows hosts + if1of ($(KBUILD_TARGET), linux) + VBOX_WITH_DXVK = 1 + endif +endif +# Enable the generic 3D settings support if at least one 3D capable solution is enabled +ifdef VBOX_WITH_VMSVGA3D + VBOX_WITH_3D_ACCELERATION = 1 +endif +# Enable Host Guest Shared Memory Interface. +VBOX_WITH_HGSMI = 1 +# Enable Video 2D Acceleration. +if1of ($(KBUILD_TARGET), darwin linux win freebsd) + VBOX_WITH_VIDEOHWACCEL = 1 +endif +# Enable Wddm Video driver for Vista+ guests. +VBOX_WITH_WDDM = 1 +# Lazy developer!! +VBOXWDDM_WITH_VBVA = 1 +# Lazy developer!! +ifdef VBOX_WITH_WDDM + VBOX_WITH_VDMA = 1 +else ifdef VBOX_WITH_VDMA + undefine VBOX_WITH_VDMA +endif +# Gallium based WDDM driver +if1of ($(KBUILD_TARGET), win) + VBOX_WITH_MESA3D = 1 +endif +# VGPU10 UMD driver for Vista+ guests in the guest additions installer +ifdef VBOX_WITH_VMSVGA3D_DX + if1of ($(KBUILD_TARGET), win) + VBOX_WITH_WDDM_DX = 1 + endif +endif +# Disable the Intel PXE ROM (uses Etherboot). +VBOX_WITH_INTEL_PXE = +# Enable EFI support +VBOX_WITH_EFI = 1 +# Enable Secure Boot in the EFI firmware. +VBOX_WITH_EFI_SECURE_BOOT = 1 +# Enable TPM support in the EFI firmware. +VBOX_WITH_EFI_TPM = 1 +# Embed the EFI firmwares in VBoxDD2.dll/dylib/so. +VBOX_WITH_EFI_IN_DD2 = 1 +# Fetch EFI firmware image from the build server +#VBOX_WITH_EFIFW_FROM_BUILD_SERVER = 1 +# Include the EFI firmware into the package +ifndef VBOX_WITH_EFI_IN_DD2 + VBOX_WITH_EFIFW_PACKING = 1 +endif +# Enable setuid wrapper for Solaris host DVD. +#VBOX_WITH_SUID_WRAPPER = 1 +# Enable the virtual SATA/AHCI controller +VBOX_WITH_AHCI = 1 +# Enable the new async completion manager +VBOX_WITH_PDM_ASYNC_COMPLETION = 1 +ifdef VBOX_WITH_USB + VBOX_WITH_VUSB = 1 + VBOX_WITH_XHCI_IMPL = 1 +endif +ifdef VBOX_WITH_EHCI + VBOX_WITH_EHCI_IMPL = 1 +endif +ifdef VBOX_WITH_PCI_PASSTHROUGH + ## @bugref{9218}: Disabled awaiting conversion of the device to new PDM device style. + #VBOX_WITH_PCI_PASSTHROUGH_IMPL = 1 +endif +ifndef VBOX_WITHOUT_HOSTWEBCAM + VBOX_WITH_USB_VIDEO_IMPL = 1 +endif +# Enable the hal/sysfs USB code on Linux. +ifeq ($(KBUILD_TARGET),linux) + VBOX_USB_WITH_SYSFS = 1 + # Disabled for now + # VBOX_USB_WITH_DBUS = 1 + VBOX_USB_WITH_INOTIFY = 1 +endif +# Enable performance API. +VBOX_WITH_RESOURCE_USAGE_API = 1 +# Use VBoxVolInfo for getting FS dependecies. +if1of ($(KBUILD_TARGET), linux) + VBOX_WITH_DEVMAPPER = 1 +endif +# Enable unattended installation API +VBOX_WITH_UNATTENDED = 1 +# Enable BusLogic SCSI host adapter +VBOX_WITH_BUSLOGIC = 1 +# Enable LsiLogic SCSI host adapter +VBOX_WITH_LSILOGIC = 1 +# Enable SCSI drivers +VBOX_WITH_SCSI = 1 +# Enable this setting to force a fallback to default DMI data on configuration errors +VBOX_BIOS_DMI_FALLBACK = +# Enable the builtin PXE ROM +VBOX_WITH_PXE_ROM = 1 +# Enable MSI support in devices +VBOX_WITH_MSI_DEVICES = 1 +# Enable host network interface API. +if1of ($(KBUILD_TARGET), darwin freebsd linux solaris win) + VBOX_WITH_HOSTNETIF_API = 1 +endif +# Emulated USB smart card reader +VBOX_WITH_USB_CARDREADER = 1 +# Disk crypt plugin +VBOX_WITH_PLUGIN_CRYPT = 1 +# VirtualKD stub/loader device, only relevant on Windows host +VBOX_WITH_VIRTUALKD = 1 +# NVMe device emulation +VBOX_WITH_NVME_IMPL = 1 +# Storage related debug drivers +VBOX_WITH_DRV_DISK_INTEGRITY = 1 +# Enables the AMD IOMMU +VBOX_WITH_IOMMU_AMD = 1 +# Enables the Intel IOMMU +VBOX_WITH_IOMMU_INTEL = 1 +# Enables the new DBGF tracing framework +VBOX_WITH_DBGF_TRACING = 1 +# Enable TPM device emulation support. +VBOX_WITH_TPM = 1 +# Enable libtpms, required for the in process TPM emulation. +if1of ($(KBUILD_TARGET), linux darwin win solaris) + VBOX_WITH_LIBTPMS = 1 +endif +## @} + +# legacy +ifdef VBOX_ONLY_TESTSUITE + $(warning VBOX_ONLY_TESTSUITE was renamed to VBOX_ONLY_VALIDATIONKIT) + VBOX_ONLY_VALIDATIONKIT = $(VBOX_ONLY_TESTSUITE) +endif + +## @name Other Component +## @{ +# Build the installer. +VBOX_WITH_INSTALLER = 1 +VBOX_WITH_GUEST_INSTALLER_UNICODE = 1 +# The kernel driver/module and related runtime libraries. +# On Linux we build this as a test case instead. +# On darwin we don't use a support driver. +if "$(KBUILD_TARGET)" != "linux" && "$(KBUILD_TARGET)" != "darwin" + VBOX_WITH_VBOXDRV = 1 +endif +# The main api. +VBOX_WITH_MAIN = 1 +# Enables proxy stub for MS COM (speeds up setting IPC for objects). +# (The VBOX_MIDL_PROXY_CLSID and VBOX_MIDL_PROXY_CLSID_IS are just two +# representations of the class ID for the proxy stub.) +VBOX_WITH_MIDL_PROXY_STUB = 1 +VBOX_MIDL_PROXY_CLSID := {0bb3b78c-1807-4249-5ba5-ea42d66af0bf} +VBOX_MIDL_PROXY_CLSID_IS := {0x0bb3b78c,0x1807,0x4249,{0x5b,0xa5,0xea,0x42,0xd6,0x6a,0xf0,0xbf}} +# Whether to also ship 32-bit main API on 64-bit systems. +if1of ($(KBUILD_TARGET).$(KBUILD_TARGET_ARCH), solaris.amd64 win.amd64) + if !defined(VBOX_ONLY_VALIDATIONKIT) && !defined(VBOX_ONLY_ADDITIONS) && !defined(VBOX_ONLY_DOCS) && !defined(VBOX_ONLY_EXTPACKS) + VBOX_WITH_32_ON_64_MAIN_API = 1 + endif +endif +# Whether to generate a database of USB vendor IDs and device IDs into VBoxSVC. +VBOX_WITH_MAIN_USB_ID_DATABASE = 1 +# Whether to enable error message translation in Main. +ifndef VBOX_ONLY_BUILD + VBOX_WITH_MAIN_NLS = 1 +endif +# Whether to enable error message translation in Extension VM Pack. +if !defined(VBOX_ONLY_BUILD) || defined(VBOX_ONLY_EXTPACKS) + VBOX_WITH_PUEL_NLS = 1 +endif +# Whether to enable message translation in VBoxManage. +#ifndef VBOX_ONLY_BUILD +VBOX_WITH_VBOXMANAGE_NLS = 1 +#endif +# Set this to prefix all C symbols in XPCOM, to avoid dynamic linking problems +# caused by our XPCOM library polluting the symbol namespace for system libs. +if1of ($(KBUILD_TARGET), linux solaris) + VBOX_WITH_XPCOM_NAMESPACE_CLEANUP = 1 +endif +# The webservices api. +VBOX_WITH_WEBSERVICES = 1 +VBOX_WITH_WEBSERVICES_SSL = 1 +# The Qt GUI. +VBOX_WITH_QTGUI = 1 +# Indicates the Qt is Cocoa based on the Mac. +ifeq ($(KBUILD_TARGET),darwin) + VBOX_WITH_COCOA_QT = 1 +endif +# Use Qt6 instead of Qt5. +if1of ($(KBUILD_TARGET).$(KBUILD_TARGET_ARCH), darwin.arm64) + VBOX_WITH_QT6 := 1 +endif +# Enable the QHelp based help function in UI. +if1of ($(KBUILD_TARGET), darwin linux solaris win) + VBOX_WITH_QHELP_VIEWER = 1 +endif +# VBox Ballooning Control frontend. +VBOX_WITH_FE_BALLOONCTRL = 1 +# VBox Autostart Service. +VBOX_WITH_FE_AUTOSTART = 1 +# VBox Bug Report tool. +VBOX_WITH_FE_BUGREPORT = 1 +# Enable this to get the SDL based GUI built. Mostly useful for development +# purposes. For production use it's recommended to use the Qt GUI which can +# be also stripped down. See VBOX_WITH_QTGUI. +VBOX_WITH_VBOXSDL = +# Start VBoxSVC in windows session 0 (services session). +VBOX_WITH_VBOXSVC_SESSION_0 = 1 +# The headless frontend. +VBOX_WITH_HEADLESS = 1 +# Enable the build of VRDP server. +VBOX_WITH_VRDP = 1 +# Build the VRDP authentication modules. +VBOX_WITH_VRDP_AUTHMOD = 1 +# Build enhanced version of rdesktop. +VBOX_WITH_VRDP_RDESKTOP = 1 +## The Direct Framebuffer GUI. +#VBOX_WITH_VBOXFB = 1 +# Enables the Python<->XPCOM, Python<->COM and (WS enabled) Python<->WS bindings. +VBOX_WITH_PYTHON ?= 1 +# Enables the PERL<->WS binding (if WS enabled). +#VBOX_WITH_PERL ?= 1 +# Enables the PHP<->WS binding (if WS enabled). +VBOX_WITH_PHP ?= 1 +if1of ($(KBUILD_TARGET), darwin linux solaris) + # Enable Java<->XPCOM bridge + glue code + VBOX_WITH_JXPCOM ?= 1 +endif +if1of ($(KBUILD_TARGET), ) # scm:ignore-empty-if1of-set + # Enable Java<->MSCOM glue, bridge is provided by an external lib (Jacob) + VBOX_WITH_JMSCOM ?= 1 +endif +if1of ($(KBUILD_TARGET), darwin linux solaris) + # Enable Java<->JAX-WS bridge + VBOX_WITH_JWS ?= 1 +endif +# Use XPIDL instead of XSLT stylesheet +VBOX_WITH_JAVA_SUPPORT_IN_XPIDL ?= +# Build against multiple Python versions present in the system (only up to 3.2, +# unless VBOX_WITH_ONLY_PYTHON_LIMITED_API is overridden). +VBOX_WITH_MULTIVERSION_PYTHON ?= 1 +# Only build the limited Python extension API version for 3.3 and later. +VBOX_WITH_ONLY_PYTHON_LIMITED_API = 1 +# Build the Validation Kit. +VBOX_WITH_VALIDATIONKIT = 1 +# Include unit tests (testcases) on the Validation Kit .ISO +# so that we can perform testing on older platforms which we don't support +# on the host anymore. +if1of ($(KBUILD_TARGET), darwin.amd64 linux win) + VBOX_WITH_VALIDATIONKIT_UNITTESTS_PACKING = 1 +endif +# Set if we should ship the audio test from the Validation Kit with the host installer. +VBOX_WITH_HOST_SHIPPING_AUDIO_TEST = 1 +# Set if we should ship the audio test from the Validation Kit with the guest additions. +VBOX_WITH_ADDITIONS_SHIPPING_AUDIO_TEST = 1 +# Build the testcases. +VBOX_WITH_TESTCASES = 1 +# Enable this to build vbox-img even if VBOX_WITH_TESTCASES is disabled +VBOX_WITH_VBOX_IMG = +# Enables recording support. +VBOX_WITH_RECORDING = 1 +# Enable VPX (VP8 / VP9 codec), required for video capturing. +VBOX_WITH_LIBVPX = 1 +# Enables audio support for recording (depends on VBOX_WITH_RECORDING). +VBOX_WITH_AUDIO_RECORDING = 1 +if defined(VBOX_WITH_AUDIO_RECORDING) && !defined(VBOX_WITH_RECORDING) + $(error Audio recording (VBOX_WITH_AUDIO_RECORDING) needs the general recording feature (VBOX_WITH_RECORDING) enabled) +endif +# Enables libvorbis (Ogg Vorbis), required for encoding audio into the recorded data. +VBOX_WITH_LIBVORBIS = 1 +# Enables libogg (Ogg file format). Required for building libvorbis above. +VBOX_WITH_LIBOGG = 1 +if defined(VBOX_WITH_LIBVORBIS) && !defined(VBOX_WITH_LIBOGG) + $(error Need libogg (VBOX_WITH_LIBOGG) in order to build libvorbis (VBOX_WITH_LIBVORBIS)) +endif +# Enable shared folders +VBOX_WITH_SHARED_FOLDERS = 1 +# Enable shared clipboard +VBOX_WITH_SHARED_CLIPBOARD = 1 +# Enable shared clipboard (file) transfers +#if1of ($(KBUILD_TARGET), win linux) +# VBOX_WITH_SHARED_CLIPBOARD_TRANSFERS = 1 +# if1of ($(KBUILD_TARGET), linux) +# VBOX_WITH_SHARED_CLIPBOARD_TRANSFERS_HTTP = 1 +# endif +#endif +# Enable the host/guest information service (aka guest properties). +VBOX_WITH_GUEST_PROPS = 1 +# Enable this to prevent the guest from writing guest properties. +VBOX_WITH_GUEST_PROPS_RDONLY_GUEST = +# Compile the host channel +VBOX_WITH_HOST_CHANNEL = 1 +# Enable the guest control service. +if1of ($(KBUILD_TARGET), darwin freebsd linux solaris win) + VBOX_WITH_GUEST_CONTROL = 1 +endif +# Enable ballooning +VBOX_WITH_MEMBALLOON = 1 +# Enable cURL (required for the network part of the GUI) +VBOX_WITH_LIBCURL = 1 +# Enable libssh (required for cloud network attachment) +if1of ($(KBUILD_TARGET), darwin linux win) + VBOX_WITH_LIBSSH = 1 +endif +# Enable Host=>Guest Drag'n'Drop +if1of ($(KBUILD_TARGET), darwin linux solaris win) + VBOX_WITH_DRAG_AND_DROP = 1 + if1of ($(KBUILD_TARGET), darwin linux solaris win) + VBOX_WITH_DRAG_AND_DROP_GH = $(VBOX_WITH_DRAG_AND_DROP) + endif + ifdef VBOX_WITH_DRAG_AND_DROP_GH + ifeq ($(KBUILD_TARGET),darwin) + # On OS X (Darwin) this needs to be set in order to get proper + # guest->host support. + # Note: Setting this requires Qt also having this feature enabled! + VBOX_WITH_DRAG_AND_DROP_PROMISES = $(VBOX_WITH_DRAG_AND_DROP) + endif + endif +endif +# Enable audio support for VRDE. +VBOX_WITH_AUDIO_VRDE = 1 +ifdef VBOX_WITH_VALIDATIONKIT + # Ship the Validation Kit audio driver for running tests (driver disabled by default). + VBOX_WITH_AUDIO_VALIDATIONKIT = 1 +endif +# Use the VRDE external authentication library from VBoxSVC. +if1of ($(KBUILD_TARGET), win) + VBOX_WITH_VRDEAUTH_IN_VBOXSVC = 1 +endif +# Enables use of merge modules in the windows installer. This will increase +# the overall installer size significantly because merge modules are not able +# to use a common .cab file to reduce their size. +#VBOX_WITH_MSM_INSTALL = 1 +# Enables full VM encryption support @bugref{9955}. +VBOX_WITH_FULL_VM_ENCRYPTION = 1 +# Enables the 'sign' command in bldRTSignTool. We may need this on windows. +if1of ($(KBUILD_TARGET), win) + VBOX_WITH_BLD_RTSIGNTOOL_SIGNING = 1 +endif +# Enables support for liblzma inside of IPRT - (only used for the ipxe zbin utility in 7.0). +if1of ($(KBUILD_TARGET), linux) + VBOX_WITH_LIBLZMA = 1 +endif +## @} + + +## @name Networking +## @{ +# Use VBoxNetFlt for host interface networking. +if1of ($(KBUILD_TARGET), darwin freebsd linux solaris win) + VBOX_WITH_NETFLT = 1 + ifeq ($(KBUILD_TARGET),solaris) + # requires snv_159+. + VBOX_WITH_NETFLT_CROSSBOW = 1 + endif + # Use VBoxNetAdp for host only networking. + if1of ($(KBUILD_TARGET), darwin freebsd linux solaris win) + VBOX_WITH_NETADP = 1 + endif +endif +# Enables the UDP tunnel transport. +VBOX_WITH_UDPTUNNEL = 1 +# Enable the netshaper support +VBOX_WITH_NETSHAPER = 1 +# Enable Virtual Distributed Ethernet or not. +if1of ($(KBUILD_TARGET), freebsd linux) + VBOX_WITH_VDE = 1 +endif +# Use new VBoxNetDhcpd instead of old VBoxNetDHCP +VBOX_WITH_DHCPD = 1 +# Experimental suport for cloud network integration (depends on libssh) +ifdef VBOX_WITH_LIBSSH + VBOX_WITH_CLOUD_NET = 1 +endif +# Use Mac OS X VMNET API instead of network kernel extensions +VBOX_WITH_VMNET = 1 +## @} + + +## @name Extension pack +## @{ +# Enables the extension pack feature. +VBOX_WITH_EXTPACK = 1 +# Enables separating code into the Oracle VM VirtualBox Extension Pack, dubbed PUEL. +VBOX_WITH_EXTPACK_PUEL = 1 +# Enables building+packing the Oracle VM VirtualBox Extension Pack, includes VBOX_WITH_EXTPACK_PUEL +VBOX_WITH_EXTPACK_PUEL_BUILD = 1 +# Enable the BusMouse sample extension pack. +#VBOX_WITH_EXTPACK_BUSMOUSESAMPLE = 1 +# Enable the VNC server extension pack (GPL only). +#VBOX_WITH_EXTPACK_VNC = 1 +# Enables the VBoxDTrace extension pack. +VBOX_WITH_EXTPACK_VBOXDTRACE = 1 +## @} + +## @name Misc +## @{ +# Enables all the doxgen bits. +VBOX_WITH_ALL_DOXYGEN_TARGETS = 1 +# Set this to skip installing the redistributable compiler runtime. +#VBOX_WITHOUT_COMPILER_REDIST = 1 +# Enables VMMR0.r0 (++) loading using the native loader on solaris. +# Good for debugging and analysis. Experimental. +#VBOX_WITH_NATIVE_SOLARIS_LOADING = 1 +# Set this to enable user mode dtrace probes. +if1of ($(KBUILD_TARGET), darwin linux solaris) + if1of ($(KBUILD_TARGET_ARCH), x86 amd64) ## @todo bugref:9898 + VBOX_WITH_DTRACE_R3 := 1 + VBOX_WITH_DTRACE_R3_MAIN := 1 + endif +endif +# Set this to enable kernel driver dtrace probes. +if1of ($(KBUILD_TARGET), darwin solaris) + if1of ($(KBUILD_TARGET_ARCH), x86 amd64) ## @todo bugref:9898 + VBOX_WITH_DTRACE_R0DRV := 1 + endif +endif +# Set this to enable dtrace probes in platform agnostic kernel code. +ifn1of ($(KBUILD_TARGET), os2) + if1of ($(KBUILD_TARGET_ARCH), x86 amd64) ## @todo bugref:9898 + VBOX_WITH_DTRACE_R0 := 1 + endif +endif +# Set this to enable dtrace probes raw-mode context code. +if1of ($(KBUILD_TARGET), linux solaris) + if1of ($(KBUILD_TARGET_ARCH), x86 amd64) ## @todo bugref:9898 + VBOX_WITH_DTRACE_RC := 1 + endif +endif +# Set this to enable support for dtrace probes in guest code. +#VBOX_WITH_DTRACE_GST = 1 +# Set this to indicate that the host ships with DTrace. +if1of ($(KBUILD_TARGET), darwin solaris) + if1of ($(KBUILD_TARGET_ARCH), x86 amd64) ## @todo bugref:9898 + VBOX_WITH_NATIVE_DTRACE := 1 + endif +endif +# Makes it possible to run some of the testcases and tools on older +# windows versions (only define when buildling win.x86). +#VBOX_WITH_MORE_NT4_COMPAT_BINARIES = 1 +# Set this to enable building of the vboximg-mount FUSE mounting utility. +if1of ($(KBUILD_TARGET), darwin linux) + VBOX_WITH_VBOXIMGMOUNT = 1 +endif +# Set this to enable packaging the fuse related bits into our installer. +# Newer versions prohibit from distributing with commercial software @bugref{8515} +#if1of ($(KBUILD_TARGET).$(KBUILD_TARGET_ARCH), darwin.amd64) +# VBOX_WITH_FUSE_PACKING = 1 +#endif +# Enables updating checking through Main. +# Only available if cURL is being used. +ifdef VBOX_WITH_LIBCURL + VBOX_WITH_UPDATE_AGENT = 1 +endif +## @} + + +## @name Compiler and linker config +## @{ +# For treating compiler and linker warnings as errors where possible. +if1of ($(KBUILD_TARGET).$(KBUILD_TARGET_ARCH), darwin.x86 darwin.amd64 linux.x86 linux.amd64 win.x86 win.amd64) + VBOX_WITH_WARNINGS_AS_ERRORS = 1 +endif +# Whether we can use Open Watcom to build stuff. +if1of ($(KBUILD_TARGET), darwin linux os2 win) + if1of ($(KBUILD_TARGET_ARCH), amd64 x86) + VBOX_WITH_OPEN_WATCOM := 1 + endif +endif +## @} + + +## @name Hardening +## @{ +# Enables hardening. +# Most developers will want to disable this in their LocalConfig.kmk. +VBOX_WITH_HARDENING = 1 +# Where the application files are (going to be) installed. +#VBOX_PATH_APP_PRIVATE = /usr/lib/virtualbox +ifdef VBOX_WITH_HARDENING + if1of ($(KBUILD_TARGET), linux solaris) + VBOX_PATH_APP_PRIVATE = /opt/VirtualBox + else ifeq ($(KBUILD_TARGET),darwin) + VBOX_PATH_APP_PRIVATE = /Applications/VirtualBox.app/Contents/MacOS + else ifeq ($(KBUILD_TARGET),freebsd) + VBOX_PATH_APP_PRIVATE = /usr/local/lib/virtualbox + else ifeq ($(KBUILD_TARGET),haiku) + VBOX_PATH_APP_PRIVATE = /boot/system/apps/VirtualBox + endif +endif +# Where the architecture specific application files are (going to be) installed. +#VBOX_PATH_APP_PRIVATE_ARCH = /usr/lib/virtualbox +ifdef VBOX_WITH_HARDENING + if1of ($(KBUILD_TARGET), solaris) + VBOX_PATH_APP_PRIVATE_ARCH_TOP = $(VBOX_PATH_APP_PRIVATE) + VBOX_PATH_APP_PRIVATE_ARCH = $(VBOX_PATH_APP_PRIVATE_ARCH_TOP)/$(if-expr $(KBUILD_TARGET_ARCH) == "amd64",amd64,i386) + else ifdef VBOX_PATH_APP_PRIVATE + VBOX_PATH_APP_PRIVATE_ARCH = $(VBOX_PATH_APP_PRIVATE) + endif +endif +# Where the shared libraries are (going to be) installed. +#VBOX_PATH_SHARED_LIBS = /usr/lib +ifdef VBOX_WITH_HARDENING + if1of ($(KBUILD_TARGET), solaris) + VBOX_PATH_SHARED_LIBS = $(VBOX_PATH_APP_PRIVATE)/$(if-expr $(KBUILD_TARGET_ARCH) == "amd64",amd64,i386) + else ifdef VBOX_PATH_APP_PRIVATE + VBOX_PATH_SHARED_LIBS = $(VBOX_PATH_APP_PRIVATE) + endif +endif +# Where the documentation is (going to be) installed. +#VBOX_PATH_APP_DOCS = /usr/share/doc/virtualbox +ifdef VBOX_WITH_HARDENING + ifdef VBOX_PATH_APP_PRIVATE + VBOX_PATH_APP_DOCS = $(VBOX_PATH_APP_PRIVATE) + endif +endif +# The DT_RPATH/DT_RUNPATH to embed into the binaries (ELF). +# (This one is used for all binaries, there is no need to adjust this +# depending on the location of the object.) +#VBOX_WITH_RUNPATH = /usr/lib/virtualbox +ifdef VBOX_WITH_HARDENING + if1of ($(KBUILD_TARGET), solaris) + VBOX_WITH_RUNPATH = $(VBOX_PATH_APP_PRIVATE)/$(if-expr $(KBUILD_TARGET_ARCH) == "amd64",amd64,i386) + else if1of ($(KBUILD_TARGET), freebsd linux) + VBOX_WITH_RUNPATH = $(VBOX_PATH_APP_PRIVATE) + endif +endif +# Enable use of the $ORIGIN DT_RPATH/DT_RUNPATH feature (ELF). +# Because of the setuid usage on all ELF platforms when hardening the build +# things gets a bit complicated since the $ORIGIN+setuid policy differs. +#VBOX_WITH_ORIGIN = 1 +ifndef VBOX_WITH_HARDENING + if1of ($(KBUILD_TARGET), freebsd linux netbsd openbsd solaris) # duplicated further down + VBOX_WITH_ORIGIN = 1 + endif +endif +# Enable the system wide support service/daemon. +# Very sketchy work in progress. +#VBOX_WITH_SUPSVC = 1 + +# Continue to support Vista w/o any service pack, at least for now. +VBOX_WITH_VISTA_NO_SP = 1 +ifdef VBOX_WITH_VBOXDRV + # Enable image verification on darwin @bugref{9232}. + VBOX_WITH_DARWIN_R0_DARWIN_IMAGE_VERIFICATION = 1 +endif +## @} + + +# Strip binaries of release and profile builds before packing them into the installer +# archive. When building .deb/.rpms, don't strip the symbols as they are required for +# the debug packages containing symbols for gdb located in /usr/lib/debug. +# In rpm Additions we also need to do part of packing without strip. +ifndef VBOX_ONLY_RPM_ADDITIONS + VBOX_DO_STRIP := $(if $(filter release profile,$(KBUILD_TYPE)),1,) +endif + + +# +# Config items for enabling work in progress. +# +# It's good pratice to add stuff here even if it is currently disabled by +# default. +# +# Note! Please, do *not* add stuff to the global DEFS unless it is *really* +# necessary! The other guys will hate for it you when they have to +# recompile everything when the feature is enabled or disabled. Put +# the ifdefs in target or template definitions. +# + +# Mask all Local APIC interrupt vectors which are set up to NMI mode when switching +# to/from the guest in raw mode. Modern Linux kernels use the performance counter +# to raise an NMI from time to time. +if1of ($(KBUILD_TARGET), linux) + VBOX_WITH_VMMR0_DISABLE_LAPIC_NMI = 1 +endif +## For testing deadlock detection and lock order validation. +# If issues are found, create high priority defects and temporarily comment +# the next line. +VBOX_WITH_STRICT_LOCKS = 1 +## VBoxSDS is the bridge windows service that sits between +# VirtualBox object client and VBoxSVC that fixes problem +# when multiple VBoxSVC starts for the same user +# it is enabled for windows build only +ifeq ($(KBUILD_TARGET),win) + VBOX_WITH_SDS = 1 +endif + + +# +# Branding +# +VBOX_BRAND_BIOS_LOGO := $(PATH_ROOT)/src/VBox/Devices/Graphics/BIOS/puel_logo.bmp +VBOX_BRAND_LICENSE_HTML := $(PATH_ROOT)/doc/License-gpl-3.0.html +VBOX_BRAND_LICENSE_RTF := $(PATH_ROOT)/doc/License-gpl-3.0.rtf +VBOX_BRAND_LICENSE_TXT := $(PATH_ROOT)/doc/License-gpl-3.0.txt +VBOX_BRAND_LICENSE_VER := +VBOX_BRAND_GUI_ABOUT_PNG := $(PATH_ROOT)/src/VBox/Frontends/VirtualBox/images/NonOSE/about.png +VBOX_BRAND_GUI_ABOUT_X2_PNG := $(PATH_ROOT)/src/VBox/Frontends/VirtualBox/images/NonOSE/about_x2.png +VBOX_BRAND_GUI_ABOUT_X3_PNG := $(PATH_ROOT)/src/VBox/Frontends/VirtualBox/images/NonOSE/about_x3.png +VBOX_BRAND_GUI_ABOUT_X4_PNG := $(PATH_ROOT)/src/VBox/Frontends/VirtualBox/images/NonOSE/about_x4.png +VBOX_BRAND_GUI_ABOUT_16PX_PNG := $(PATH_ROOT)/src/VBox/Frontends/VirtualBox/images/NonOSE/about_16px.png +VBOX_BRAND_GUI_ABOUT_16PX_X2_PNG := $(PATH_ROOT)/src/VBox/Frontends/VirtualBox/images/NonOSE/about_16px_x2.png +VBOX_BRAND_GUI_ABOUT_16PX_X3_PNG := $(PATH_ROOT)/src/VBox/Frontends/VirtualBox/images/NonOSE/about_16px_x3.png +VBOX_BRAND_GUI_ABOUT_16PX_X4_PNG := $(PATH_ROOT)/src/VBox/Frontends/VirtualBox/images/NonOSE/about_16px_x4.png +VBOX_BRAND_GUI_VBOX_16PX_PNG := $(PATH_ROOT)/src/VBox/Frontends/VirtualBox/images/NonOSE/VirtualBox_16px.png +VBOX_BRAND_GUI_VBOX_20PX_PNG := $(PATH_ROOT)/src/VBox/Frontends/VirtualBox/images/NonOSE/VirtualBox_20px.png +VBOX_BRAND_GUI_VBOX_32PX_PNG := $(PATH_ROOT)/src/VBox/Frontends/VirtualBox/images/NonOSE/VirtualBox_32px.png +VBOX_BRAND_GUI_VBOX_40PX_PNG := $(PATH_ROOT)/src/VBox/Frontends/VirtualBox/images/NonOSE/VirtualBox_40px.png +VBOX_BRAND_GUI_VBOX_48PX_PNG := $(PATH_ROOT)/src/VBox/Frontends/VirtualBox/images/NonOSE/VirtualBox_48px.png +VBOX_BRAND_GUI_VBOX_64PX_PNG := $(PATH_ROOT)/src/VBox/Frontends/VirtualBox/images/NonOSE/VirtualBox_64px.png +VBOX_BRAND_GUI_VBOX_SVG := $(PATH_ROOT)/src/VBox/Artwork/NonOSE/virtualbox.svg +VBOX_BRAND_WIN_INST_DLGJPG := $(PATH_ROOT)/src/VBox/Installer/win/Binary/Dialog.jpg +VBOX_BRAND_WIN_INST_EXT := +VBOX_BRAND_WIN_ADD_INST_DLGBMP := $(PATH_ROOT)/src/VBox/Additions/WINNT/Installer/welcome.bmp +VBOX_BRAND_DARWIN_DISKIMAGE_DS_STORE := $(PATH_ROOT)/src/VBox/Installer/darwin/DiskImage/DS_Store +VBOX_BRAND_DARWIN_DISKIMAGE_BG := $(PATH_ROOT)/src/VBox/Installer/darwin/DiskImage/vbox_folder.tiff +VBOX_BRAND_DARWIN_INSTALLER_BG := $(PATH_ROOT)/src/VBox/Installer/darwin/VirtualBox_mpkg/background.tif + +# +# Skip stuff. +# + +ifdef VBOX_ONLY_EXTPACKS + # Clear some VBOX_WITH_XXX variables instead of adding ifdefs all over the place. + VBOX_WITH_DEBUGGER = + VBOX_WITH_ADDITIONS = + VBOX_WITH_VBOXDRV = + VBOX_WITH_TESTCASES = +endif + +# VBOX_QUICK can be used by core developers to speed to the build +ifdef VBOX_QUICK + # undefine variables by assigning blank. + VBOX_WITH_ADDITIONS = + VBOX_WITH_VALIDATIONKIT = + VBOX_WITH_TESTCASES = + VBOX_WITH_VBOXSDL = + VBOX_WITH_HEADLESS = + VBOX_WITH_VRDP = + VBOX_WITH_VRDP_RDESKTOP = + VBOX_WITH_DOCS = + VBOX_WITH_WEBSERVICES = + VBOX_WITH_32_ON_64_MAIN_API = +endif # VBOX_QUICK + +# Only AMD64 is supported for the main product, so disable most of the other bits. +ifn1of ($(KBUILD_TARGET_ARCH), $(VBOX_SUPPORTED_HOST_ARCHS)) + VBOX_WITH_MAIN = + VBOX_WITH_QTGUI = + VBOX_WITH_VBOXSDL = + VBOX_WITH_VBOXHEADLESS = + VBOX_WITH_WEBSERVICES = + VBOX_WITH_DEBUGGER_GUI = +endif + +ifeq ($(KBUILD_TARGET),darwin) + VBOX_WITH_VRDP_RDESKTOP = + # Permanent (no working SDL). + VBOX_WITH_VBOXSDL = + + ifeq ($(KBUILD_TARGET_ARCH),arm64) + # No Qt yet, so no GUI, NLS or qhelp. + VBOX_WITH_NLS := + VBOX_WITH_MAIN_NLS := + VBOX_WITH_PUEL_NLS := + VBOX_WITH_VBOXMANAGE_NLS := + VBOX_WITH_DOCS_QHELP := + VBOX_WITH_DOCS_QHELP_PACKING := + # Skip webservices as those are tedious to build. + VBOX_WITH_WEBSERVICES := + # Ditto for the java<->XPCOM bridge. + VBOX_WITH_JXPCOM := + endif + + ifdef VBOX_WITH_DRIVERLESS_FORCED + # No need for hardening when not using the driver. + VBOX_WITH_HARDENING := + endif +endif + +ifeq ($(KBUILD_TARGET),freebsd) + VBOX_WITH_DOCS = +endif + +ifeq ($(KBUILD_TARGET),haiku) + VBOX_WITH_VRDP_RDESKTOP = + # Permanent (no working SDL). + VBOX_WITH_VBOXSDL = + VBOX_WITH_DOCS = + VBOX_WITH_VBOXDRV = + VBOX_WITH_VRDP = + VBOX_WITH_HEADLESS = + VBOX_WITH_VBOXSDL = + VBOX_WITH_QTGUI = + # VBOX_WITH_MAIN= + VBOX_WITH_DOCS = + VBOX_WITH_ISCSI = + VBOX_WITH_INIP = + VBOX_WITH_INTERNAL_NETWORKING = + VBOX_WITH_PDM_ASYNC_COMPLETION = + VBOX_WITH_HARDENING = +endif + + +ifeq ($(KBUILD_TARGET),os2) + VBOX_WITH_WEBSERVICES = + VBOX_WITH_INSTALLER = + VBOX_WITH_VRDP_AUTHMOD = + VBOX_WITH_VRDP_RDESKTOP = + VBOX_WITH_VALIDATIONKIT = + VBOX_WITH_QTGUI = + VBOX_WITH_USB = + VBOX_WITH_EHCI = + VBOX_WITH_DOCS = + VBOX_WITH_PDM_ASYNC_COMPLETION = + VBOX_WITH_HARDENING = +endif + +ifeq ($(KBUILD_TARGET),win) + VBOX_WITH_VRDP_RDESKTOP = +endif + +ifn1of ($(KBUILD_TARGET_ARCH), x86 amd64 arm64) + VBOX_WITH_ADDITION_DRIVERS = + VBOX_WITH_DEBUGGER = + VBOX_WITH_DOCS = + VBOX_WITH_EHCI = + VBOX_WITH_HARDENING = + VBOX_WITH_HEADLESS = + VBOX_WITH_HGCM = + VBOX_WITH_HGSMI = + VBOX_WITH_INIP = + VBOX_WITH_INSTALLER = + VBOX_WITH_INTERNAL_NETWORKING = + VBOX_WITH_ISCSI = + VBOX_WITH_MAIN = + VBOX_WITH_PDM_ASYNC_COMPLETION = + VBOX_WITH_QTGUI = + VBOX_WITH_RAW_MODE = + VBOX_WITH_VALIDATIONKIT = + VBOX_WITH_USB = + VBOX_WITH_VBOXDRV = + VBOX_WITH_VBOXSDL = + VBOX_WITH_WEBSERVICES = + VBOX_WITH_XPCOM = + VBOX_WITHOUT_HARDENING = 1 + # remove later: + VBOX_WITH_VRDP = + VBOX_WITH_VRDP_AUTHMOD = + VBOX_WITH_VRDP_RDESKTOP = +endif + + +# +# Include automatic and local config file to override the above settings +# and to provide defaults for the settings below this point. +# +ifndef AUTOCFG + AUTOCFG := $(wildcard $(PATH_ROOT)/AutoConfig.kmk) +endif +ifneq ($(AUTOCFG),) + include $(AUTOCFG) +endif + +ifndef LOCALCFG + LOCALCFG := $(wildcard $(PATH_ROOT)/LocalConfig.kmk) + ifneq ($(LOCALCFG),) + include $(LOCALCFG) + endif +else + # Ignore it if it doesn't exist. + if exists "$(LOCALCFG)" + include $(LOCALCFG) + else + $(warning LOCALCFG='$(LOCALCFG)' does not exist) + override LOCALCFG := + endif +endif + +# +# Allow to overwrite the branding information from an external file +# +ifdef VBOX_BRANDING_CFG + include $(VBOX_BRANDING_CFG) +endif + +# +# Bitch about old settings. +# +ifdef VBOX_WITHOUT_LINUX_COMPILER_H + $(warning VBOX_WITHOUT_LINUX_COMPILER_H was renamed to VBOX_WITH_LINUX_COMPILER_H, the meaning is inverted.) +endif + +# +# Indicate VBOX_ONLY build if any of the VBOX_ONLY_* variables are set. +# +VBOX_ONLY_BUILD_NEW := $(strip $(foreach x, ADDITIONS DOCS EXTPACKS SDK VALIDATIONKIT \ + , $(if-expr defined(VBOX_ONLY_$(x)),VBOX_ONLY_$(x)))) +ifneq ($(VBOX_ONLY_BUILD),$(VBOX_ONLY_BUILD_NEW)) + $(error VBox: LocalConfig.kmk changed the VBOX_ONLY_ build status, VBOX_ONLY_* must be on the kmk command line or in the environment: $(VBOX_ONLY_BUILD) -> $(VBOX_ONLY_BUILD_NEW)) +endif + +# +# Enforce VBOX_WITH_NLS. It controls all NLS (except the GUI at the moment). +# +if defined(VBOX_WITH_MAIN_NLS) || defined(VBOX_WITH_PUEL_NLS) || defined(VBOX_WITH_VBOXMANAGE_NLS) + VBOX_WITH_NLS := 1 + ifndef VBOX_WITH_NLS # (We test again to account for 'override VBOX_WITH_NLS :=') + VBOX_WITH_MAIN_NLS := + VBOX_WITH_PUEL_NLS := + VBOX_WITH_VBOXMANAGE_NLS := + endif +endif + +# +# For the docs build box. +# +ifdef VBOX_ONLY_DOCS + # Phase out the .chm docs + VBOX_WITH_DOCS_CHM = + # Always produce HTML docs (for publishing on website as part of release) + VBOX_WITH_DOCS_HTML = 1 + # Always produce QHelp docs (for help in the UI, replacing CHM) + VBOX_WITH_DOCS_QHELP = 1 + VBOX_WITH_TOOLS_QT_LINUX = 1 +endif + +# +# Disable components that are not open sourced. +# +ifdef VBOX_OSE + VBOX_WITH_VRDP = + VBOX_WITH_USB_VIDEO_IMPL = + VBOX_WITH_NVME_IMPL = + VBOX_WITH_EXTPACK_PUEL = + VBOX_WITH_EXTPACK_PUEL_BUILD = + VBOX_WITH_PCI_PASSTHROUGH_IMPL = + VBOX_WITH_OS2_ADDITIONS_BIN = + VBOX_WITH_LIBSSH = + # not yet + VBOX_WITH_PLUGIN_CRYPT = + VBOX_WITH_DRAG_AND_DROP_PROMISES = + ifn1of ($(KBUILD_TARGET), linux) + VBOX_WITH_DOCS = + VBOX_WITH_DOCS_PACKING = + endif + if1of ($(KBUILD_TARGET), solaris) + VBOX_WITH_32_ON_64_MAIN_API = + endif + if1of ($(KBUILD_TARGET), win) + # tar/gzip uncommon on Windows + VBOX_WITH_EXTPACK_VBOXDTRACE = + endif + # Enable any translations in OSE, even partial ones. + ifndef ($(VBOX_NO_DOCS_TRANSLATIONS)) + VBOX_WITH_DOCS_TRANSLATIONS = 1 + endif + VBOX_WITH_INTEL_PXE = + # Disable for OSE, requires snv_159+. + VBOX_WITH_NETFLT_CROSSBOW = + ifn1of ($(KBUILD_TARGET), darwin linux solaris win) + VBOX_WITH_INSTALLER = + endif + if1of ($(KBUILD_TARGET), win) + # Undefine codec libraries which are not needed. + VBOX_WITH_LIBVPX = + VBOX_WITH_LIBVORBIS = + VBOX_WITH_LIBOGG = + # Disable recording (with audio support). + VBOX_WITH_RECORDING = + VBOX_WITH_AUDIO_RECORDING = + endif + # branding + VBOX_BRAND_LICENSE_HTML := $(PATH_ROOT)/doc/License-gpl-3.0.html + VBOX_BRAND_LICENSE_RTF := $(PATH_ROOT)/doc/License-gpl-3.0.rtf + VBOX_BRAND_LICENSE_TXT := $(PATH_ROOT)/doc/License-gpl-3.0.txt + VBOX_BRAND_LICENSE_VER := + VBOX_BRAND_BIOS_LOGO := $(PATH_ROOT)/src/VBox/Devices/Graphics/BIOS/ose_logo.bmp + VBOX_BRAND_GUI_ABOUT_PNG := $(PATH_ROOT)/src/VBox/Frontends/VirtualBox/images/OSE/about.png + VBOX_BRAND_GUI_ABOUT_X2_PNG := $(PATH_ROOT)/src/VBox/Frontends/VirtualBox/images/OSE/about_x2.png + VBOX_BRAND_GUI_ABOUT_X3_PNG := $(PATH_ROOT)/src/VBox/Frontends/VirtualBox/images/OSE/about_x3.png + VBOX_BRAND_GUI_ABOUT_X4_PNG := $(PATH_ROOT)/src/VBox/Frontends/VirtualBox/images/OSE/about_x4.png + VBOX_BRAND_GUI_ABOUT_16PX_PNG := $(PATH_ROOT)/src/VBox/Frontends/VirtualBox/images/OSE/about_16px.png + VBOX_BRAND_GUI_ABOUT_16PX_X2_PNG := $(PATH_ROOT)/src/VBox/Frontends/VirtualBox/images/OSE/about_16px_x2.png + VBOX_BRAND_GUI_ABOUT_16PX_X3_PNG := $(PATH_ROOT)/src/VBox/Frontends/VirtualBox/images/OSE/about_16px_x3.png + VBOX_BRAND_GUI_ABOUT_16PX_X4_PNG := $(PATH_ROOT)/src/VBox/Frontends/VirtualBox/images/OSE/about_16px_x4.png + VBOX_BRAND_GUI_VBOX_16PX_PNG := $(PATH_ROOT)/src/VBox/Frontends/VirtualBox/images/OSE/VirtualBox_16px.png + VBOX_BRAND_GUI_VBOX_20PX_PNG := $(PATH_ROOT)/src/VBox/Frontends/VirtualBox/images/OSE/VirtualBox_20px.png + VBOX_BRAND_GUI_VBOX_32PX_PNG := $(PATH_ROOT)/src/VBox/Frontends/VirtualBox/images/OSE/VirtualBox_32px.png + VBOX_BRAND_GUI_VBOX_40PX_PNG := $(PATH_ROOT)/src/VBox/Frontends/VirtualBox/images/OSE/VirtualBox_40px.png + VBOX_BRAND_GUI_VBOX_48PX_PNG := $(PATH_ROOT)/src/VBox/Frontends/VirtualBox/images/OSE/VirtualBox_48px.png + VBOX_BRAND_GUI_VBOX_64PX_PNG := $(PATH_ROOT)/src/VBox/Frontends/VirtualBox/images/OSE/VirtualBox_64px.png + VBOX_BRAND_GUI_CUBE_42PX_PNG := $(PATH_ROOT)/src/VBox/Frontends/VirtualBox/images/OSE/VirtualBox_cube_42px.png + VBOX_BRAND_GUI_VBOX_SVG := $(PATH_ROOT)/src/VBox/Artwork/OSE/virtualbox.svg +endif + +# +# VBOX_WITHOUT_HARDENING is for developers (put in LocalConfig.kmk). +# Note that this is a bit rough since hardening governs more than one +# variable... Also note that we allow VBOX_WITH_HARDENING=1 on the +# command line to overrule VBOX_WITHOUT_HARDENING (the check below). +# +ifdef VBOX_WITHOUT_HARDENING + VBOX_WITH_HARDENING = + ifeq ($(VBOX_WITH_HARDENING),) + VBOX_PATH_APP_PRIVATE = + VBOX_PATH_APP_PRIVATE_ARCH = + VBOX_PATH_APP_PRIVATE_ARCH_TOP = + VBOX_PATH_SHARED_LIBS = + VBOX_PATH_APP_DOCS = + VBOX_WITH_RUNPATH = + if1of ($(KBUILD_TARGET), freebsd linux netbsd openbsd solaris) # duplicated up above + VBOX_WITH_ORIGIN = 1 + endif + endif +endif + +# +# Sanitize the additions build config variables. +# +ifdef VBOX_WITH_ADDITIONS_FROM_BUILD_SERVER + VBOX_WITHOUT_ADDITIONS := 1 + ifdef VBOX_ONLY_ADDITIONS + $(error VBOX_ONLY_ADDITIONS + VBOX_WITH_ADDITIONS_FROM_BUILD_SERVER does not add up!) + endif +endif + +ifdef VBOX_ONLY_ADDITIONS + ifdef VBOX_WITHOUT_ADDITIONS + $(error VBOX_ONLY_ADDITIONS + VBOX_WITHOUT_ADDITIONS does not add up!) + endif + ifndef VBOX_WITH_ADDITIONS + $(error VBOX_ONLY_ADDITIONS + unset VBOX_WITH_ADDITIONS does not add up!) + endif +endif + +ifdef VBOX_WITHOUT_ADDITIONS + # Zap anything that could be contradicting this. + VBOX_WITH_ADDITIONS := +endif + +# +# Sanitize the documentation build config variables. +# +ifdef VBOX_WITH_DOCS_FROM_BUILD_SERVER + VBOX_WITHOUT_DOCS := 1 + ifdef VBOX_ONLY_DOCS + $(error VBOX_ONLY_DOCS + VBOX_WITH_DOCS_FROM_BUILD_SERVER does not add up!) + endif +endif + +ifdef VBOX_ONLY_DOCS + ifdef VBOX_WITHOUT_DOCS + $(error VBOX_ONLY_DOCS + VBOX_WITHOUT_DOCS does not add up!) + endif +endif + +ifdef VBOX_WITHOUT_DOCS + # Zap anything that could be contradicting this. + VBOX_WITH_DOCS := + VBOX_WITH_DOCS_CHM := +endif + +# +# Disable components for headless +# +ifdef VBOX_HEADLESS + VBOX_WITH_QTGUI = + VBOX_WITH_VBOXSDL = + VBOX_WITH_VRDP_RDESKTOP = +endif + +# +# Undefined VBOX_WITH_MAIN implies exclusion of a few more items. +# +ifndef VBOX_WITH_MAIN + VBOX_WITH_VBOXSDL = + VBOX_WITH_QTGUI = + VBOX_WITH_DEBUGGER_GUI = + VBOX_WITH_HEADLESS = + ifdef VBOX_ONLY_DOCS + $(error Oh, does VBOX_ONLY_DOCS actually end up here. sweet.) + endif + VBOX_WITH_DOCS = +endif + +ifdef VBOX_WITH_EXTPACK_PUEL_BUILD + VBOX_WITH_EXTPACK_PUEL = 1 +endif + +ifdef VBOX_WITH_TESTSUITE + $(warning VBOX_WITH_TESTSUITE was renamed to VBOX_WITH_VALIDATIONKIT) + VBOX_WITH_VALIDATIONKIT = $(VBOX_WITH_TESTSUITE) +endif + + +# +# Derived indicators. +# + +# +# Mark OSE builds clearly, helps figuring out limitations more easily. +# +ifdef VBOX_OSE + # This can be overridden (e.g. in LocalConfig.kmk) by whoever publishes a set + # of VirtualBox binaries. We request though that you always use something that + # clearly identifies your build and makes it clear that it is not one done by + # the VirtualBox team. + VBOX_BUILD_PUBLISHER ?= _OSE +endif + +# Keep in sync with G_virtualBoxPackage in glue-jaxws.xsl and glue-java.xsl +# Changed with every new version, so beware! +if $(VBOX_VERSION_BUILD) < 51 + VBOX_API_VERSION = $(VBOX_VERSION_MAJOR)_$(VBOX_VERSION_MINOR) +else + VBOX_API_VERSION = $(VBOX_VERSION_MAJOR)_$(expr $(VBOX_VERSION_MINOR) + 1) +endif +VBOX_API_SUFFIX = _$(VBOX_API_VERSION) +VBOX_JAVA_PACKAGE = org.virtualbox$(VBOX_API_SUFFIX) + +# +# Derived / helper config indicators. Not configurable. +# + +# Use the OpenGL module in qt when the video hardware acceleration feature +# is enabled. +if defined(VBOX_WITH_VIDEOHWACCEL) && defined(VBOX_WITH_QTGUI) + VBOX_GUI_USE_QGL = 1 +else + VBOX_GUI_USE_QGL = +endif + +# Collection macro mainly for deciding whether VBoxDTrace needs shipping. +VBOX_WITH_DTRACE := $(if-expr defined(VBOX_WITH_DTRACE_R0) || defined(VBOX_WITH_DTRACE_R0DRV) \ + || defined(VBOX_WITH_DTRACE_R3) || defined(VBOX_WITH_DTRACE_RC),1,) + +# kSubmit / kWorker is only available on windows. +ifdef VBOX_USE_KSUBMIT + ifeq ($(KBUILD_HOST),win) + TOOL_VCC142AMD64_USE_KSUBMIT := 1 + TOOL_VCC142X86_USE_KSUBMIT := 1 + # TOOL_VCC120AMD64_USE_KSUBMIT := 1 + # TOOL_VCC120X86_USE_KSUBMIT := 1 + TOOL_VCC100AMD64_USE_KSUBMIT := 1 + TOOL_VCC100X86_USE_KSUBMIT := 1 + TOOL_QT5_USE_KSUBMIT := 1 + TOOL_OPENWATCOM_USE_KSUBMIT := 1 + TOOL_YASM_USE_KSUBMIT := 1 + TOOL_NASM_USE_KSUBMIT := 1 + TOOL_VBoxNasm_USE_KSUBMIT := 1 + else + VBOX_USE_KSUBMIT := + endif +endif + +# +# Requested permissions to the host OS (only the entitlements +# crap on darwin for now). +# +ifeq ($(KBUILD_TARGET),darwin) + # + # The first two entitlements are required to get everything working + # on Catalina which we want to keep supported for now. + # + VBOX_DARWIN_ENTITLEMENTS_LIST := \ + com.apple.security.cs.allow-unsigned-executable-memory \ + com.apple.security.cs.disable-executable-page-protection \ + com.apple.security.device.audio-input \ + com.apple.security.device.camera \ + com.apple.security.device.usb + + # + # The hypervisor entitlement is required in adhoc signing mode + # to get access to the Hypervisor framework. For release signing + # the entitlement is included in our developer certificate. + # + # The device-access and networking entitlemnents are reserved for + # only specific vendors and are only available in release mode signing + # (binaries signed with these entitlements in adhoc mode will just crash + # with a code signing error). + # + ifeq ($(VBOX_SIGNING_MODE),adhoc) + VBOX_DARWIN_ENTITLEMENTS_LIST += \ + com.apple.security.hypervisor + else + VBOX_DARWIN_ENTITLEMENTS_LIST += \ + com.apple.vm.device-access \ + com.apple.vm.networking + endif + + # Where the dynamic generated entitlements can be found. + VBOX_DARWIN_ENTITLEMENTS_FILE := $(PATH_OUT)/Entitlements.plist +endif + +# +# Image and object format config. +# +if1of ($(KBUILD_TARGET), freebsd haiku linux netbsd openbsd solaris) + VBOX_LDR_FMT = elf +endif +ifeq ($(KBUILD_TARGET),darwin) + VBOX_LDR_FMT = macho +endif +ifeq ($(KBUILD_TARGET),os2) + VBOX_LDR_FMT = lx + VBOX_LDR_FMT32 = lx + VBOX_LDR_FMT64 = elf + DONT_USE_YASM = 1 # yasm doesn't implement omf yet. +endif +ifeq ($(KBUILD_TARGET),win) + VBOX_LDR_FMT = pe +endif +VBOX_LDR_FMT32 ?= $(VBOX_LDR_FMT) +VBOX_LDR_FMT64 ?= $(VBOX_LDR_FMT) + +# +# Assembler setup. +# +# This is a bit complicated since we have to support two different assmblers +# (yasm/nasm) and possibly two different formats (32-bit/64-bit). +# +if1of ($(KBUILD_TARGET_ARCH), amd64 x86) + ifeq ($(VBOX_LDR_FMT),elf) + ifeq ($(KBUILD_TARGET_ARCH),x86) + VBOX_ASFLAGS_FMT = -f elf32 -DASM_FORMAT_ELF + else + VBOX_ASFLAGS_FMT = -f elf64 -DASM_FORMAT_ELF + endif + VBOX_ASFLAGS_DBFINFO = -g dwarf2 + endif + ifeq ($(VBOX_LDR_FMT),lx) + VBOX_ASFLAGS_FMT = -f obj -DASM_FORMAT_OMF + VBOX_ASFLAGS_DBFINFO = -g stabs + endif + ifeq ($(VBOX_LDR_FMT),macho) + ifeq ($(KBUILD_TARGET_ARCH),x86) + VBOX_ASFLAGS_FMT = -f macho32 -DASM_FORMAT_MACHO + else + VBOX_ASFLAGS_FMT = -f macho64 -DASM_FORMAT_MACHO + endif + VBOX_ASFLAGS_DBFINFO = -g dwarf2 + endif + ifeq ($(VBOX_LDR_FMT),pe) + ifeq ($(KBUILD_TARGET_ARCH),x86) + VBOX_ASFLAGS_FMT = -f win32 -DASM_FORMAT_PE + else + VBOX_ASFLAGS_FMT = -f win64 -DASM_FORMAT_PE + endif + VBOX_ASFLAGS_DBFINFO = -g cv8 + endif + ifndef VBOX_ASFLAGS_FMT + $(error VBOX_ASFLAGS_FMT is not defined. VBOX_LDR_FMT=$(VBOX_LDR_FMT)) + endif + + ifeq ($(VBOX_LDR_FMT32),elf) + VBOX_ASFLAGS_FMT32 = -f elf32 -DASM_FORMAT_ELF + VBOX_ASFLAGS_DBFINFO32 = -g dwarf2 + endif + ifeq ($(VBOX_LDR_FMT32),lx) + VBOX_ASFLAGS_FMT32 = -f obj -DASM_FORMAT_OMF + VBOX_ASFLAGS_DBFINFO32 = -g stabs + endif + ifeq ($(VBOX_LDR_FMT32),macho) + VBOX_ASFLAGS_FMT32 = -f macho32 -DASM_FORMAT_MACHO + VBOX_ASFLAGS_DBFINFO32 = -g dwarf2 + endif + ifeq ($(VBOX_LDR_FMT32),pe) + VBOX_ASFLAGS_FMT32 = -f win32 -DASM_FORMAT_PE + VBOX_ASFLAGS_DBFINFO32 = -g cv8 + endif + ifndef VBOX_ASFLAGS_FMT32 + $(error VBOX_ASFLAGS_FMT32 is not defined. VBOX_LDR_FMT32=$(VBOX_LDR_FMT32)) + endif + + ifeq ($(VBOX_LDR_FMT64),elf) + VBOX_ASFLAGS_FMT64 = -f elf64 -DASM_FORMAT_ELF + VBOX_ASFLAGS_DBFINFO64 = -g dwarf2 + endif + ifeq ($(VBOX_LDR_FMT64),macho) + VBOX_ASFLAGS_FMT64 = -f macho64 -DASM_FORMAT_MACHO + VBOX_ASFLAGS_DBFINFO64 = -g dwarf2 + endif + ifeq ($(VBOX_LDR_FMT64),pe) + VBOX_ASFLAGS_FMT64 = -f win64 -DASM_FORMAT_PE + VBOX_ASFLAGS_DBFINFO64 = -g cv8 + endif + ifndef VBOX_ASFLAGS_FMT64 + $(error VBOX_ASFLAGS_FMT64 is not defined. VBOX_LDR_FMT64=$(VBOX_LDR_FMT64)) + endif + + ifndef DONT_USE_YASM + VBOX_ASTOOL = YASM + VBOX_LDR_FMT_2_YASM_DBGINFO.elf = -g dwarf2 + VBOX_LDR_FMT_2_YASM_DBGINFO.lx = -g stabs + VBOX_LDR_FMT_2_YASM_DBGINFO.macho = + VBOX_LDR_FMT_2_YASM_DBGINFO.pe = -g cv8 + VBOX_ASFLAGS = $(VBOX_ASFLAGS_FMT) -D__YASM__ -Worphan-labels $(VBOX_YASM_Wno-segreg-in-64bit) $(VBOX_LDR_FMT_2_YASM_DBGINFO.$(VBOX_LDR_FMT)) + VBOX_ASFLAGS32 = $(VBOX_ASFLAGS_FMT32) -D__YASM__ -Worphan-labels $(VBOX_YASM_Wno-segreg-in-64bit) $(VBOX_LDR_FMT_2_YASM_DBGINFO.$(VBOX_LDR_FMT32)) + VBOX_ASFLAGS64 = $(VBOX_ASFLAGS_FMT64) -D__YASM__ -Worphan-labels $(VBOX_YASM_Wno-segreg-in-64bit) $(VBOX_LDR_FMT_2_YASM_DBGINFO.$(VBOX_LDR_FMT64)) + else + VBOX_ASTOOL = NASM + VBOX_ASFLAGS = $(subst elf32,elf,$(VBOX_ASFLAGS_FMT)) -D__NASM__ -w+orphan-labels -g + VBOX_ASFLAGS32 = $(subst elf32,elf,$(VBOX_ASFLAGS_FMT32)) -D__NASM__ -w+orphan-labels -g + VBOX_ASFLAGS64 = $(VBOX_ASFLAGS_FMT64) -D__NASM__ -w+orphan-labels -g + endif +else # ifn1of ($(KBUILD_TARGET_ARCH), amd64 x86) + VBOX_ASTOOL =# No tool, just use the compiler one. + VBOX_LDR_FMT_2_FLAGS.elf := -DASM_FORMAT_ELF + VBOX_LDR_FMT_2_FLAGS.macho := -DASM_FORMAT_MACHO + VBOX_LDR_FMT_2_FLAGS.pe := -DASM_FORMAT_PE + VBOX_ASFLAGS := -g $(VBOX_LDR_FMT_2_FLAGS.$(VBOX_LDR_FMT)) + VBOX_ASFLAGS32 := -g $(VBOX_LDR_FMT_2_FLAGS.$(VBOX_LDR_FMT32)) + VBOX_ASFLAGS64 := -g $(VBOX_LDR_FMT_2_FLAGS.$(VBOX_LDR_FMT64)) + if1of ($(KBUILD_TARGET_ARCH), sparc32 sparc64) + VBOX_ASFLAGS += -m$(VBOX_HC_ARCH_BITS) + VBOX_ASFLAGS32 += -m32 + VBOX_ASFLAGS64 += -m64 + endif +endif # ifn1of ($(KBUILD_TARGET_ARCH), amd64 x86) + +# +# Windows only has mingw handy. On *nix we have to deal with cross compiling +# 32-bit targets on 64-bit platforms, meaning we'll be using gcc32/g++32. +# In the latter case we'll also have to disable all the all the R0 driver related stuff. +# +ifndef VBOX_GCC_TOOL + ifeq ($(KBUILD_TARGET),win) + ifeq ($(KBUILD_TARGET_ARCH),x86) + VBOX_GCC_TOOL := MINGW32 + TOOL_MINGW32_CFLAGS := $(UNDEFINED) # override -g + else + VBOX_GCC_TOOL := MINGWW64 + endif + else ifeq ($(KBUILD_TARGET),os2) + VBOX_GCC_TOOL := GXX3OMF + else ifeq ($(KBUILD_TARGET),darwin) + ifdef VBOX_WITH_EVEN_NEWER_XCODE + VBOX_GCC_TOOL := CLANGXXMACHO + DARWINCMN_TOOLCHAIN_DIRS_IGNORE_DEVTOOLS = 1# Use the system toolchains, not anything from tools/darwin.*. + else ifdef VBOX_WITH_NEW_XCODE + VBOX_GCC_TOOL := VBoxXcode62 + else + VBOX_GCC_TOOL := GXX4MACHO + endif + else ifeq ($(KBUILD_TARGET),haiku) + # Haiku shouldn't pass '-r' to the linker by default + VBOX_GCC_TOOL := GXX3PLAIN + else ifeq ($(KBUILD_TARGET),solaris) + VBOX_GCC_TOOL := GXX3PLAIN + VBOX_GCC32_TOOL := GCC3PLAIN + ifeq ($(KBUILD_HOST),solaris) + TOOL_GXX3PLAIN_LD_SYSMOD ?= /usr/ccs/bin/ld + endif + else + VBOX_GCC_TOOL := GXX3 + ifeq ($(KBUILD_TARGET_ARCH).$(KBUILD_HOST_ARCH),x86.amd64) ## @todo mixing target/host here! + VBOX_GCC_TOOL := GXX32 + VBOX_WITH_VBOXDRV = + else ifeq ($(KBUILD_TARGET_ARCH).$(KBUILD_HOST_ARCH),amd64.x86) + VBOX_GCC_TOOL := GXX64 + VBOX_WITH_VBOXDRV = + endif + endif +endif +ifndef VBOX_GCC32_TOOL + ifeq ($(KBUILD_TARGET_ARCH),x86) + VBOX_GCC32_TOOL := $(VBOX_GCC_TOOL) + else ifeq ($(KBUILD_TARGET),win) + VBOX_GCC32_TOOL := MINGW32 + else + VBOX_GCC32_TOOL := GCC32 + endif +endif + +# +# Decide which Visual C++ compiler version we're using by default. +# +ifndef VBOX_VCC_TOOL_STEM + ifdef VBOX_WITH_NEW_VCC + VBOX_VCC_TOOL_STEM := VCC142 + else + VBOX_VCC_TOOL_STEM := VCC100 + endif +else ifn1of ($(VBOX_VCC_TOOL_STEM), VCC100 VCC110 VCC120 VCC140 VCC141 VCC142) + $(error VBox: VBOX_VCC_TOOL_STEM='$(VBOX_VCC_TOOL_STEM)' is not supported, only VCC100, VCC110, VCC120, VCC140, VCC141, VCC142 are) +endif +ifndef VBOX_VCC_TOOL + VBOX_VCC_TOOL := $(VBOX_VCC_TOOL_STEM)$(toupper $(KBUILD_TARGET_ARCH)) +endif + +# +# Decide which Visual C++ compiler version we're using for newer stuff. +# +ifndef VBOX_NEWER_VCC_TOOL_STEM + if "$(VBOX_VCC_TOOL_STEM)" >= "VCC120" + VBOX_NEWER_VCC_TOOL_STEM := $(VBOX_VCC_TOOL_STEM) + else + VBOX_NEWER_VCC_TOOL_STEM := VCC120 + endif +else ifn1of ($(VBOX_NEWER_VCC_TOOL_STEM), VCC120 VCC140 VCC141 VCC142) + $(error VBox: VBOX_NEWER_VCC_TOOL_STEM='$(VBOX_NEWER_VCC_TOOL_STEM)' is not supported) +endif +ifndef VBOX_NEWER_VCC_TOOL + VBOX_NEWER_VCC_TOOL := $(VBOX_NEWER_VCC_TOOL_STEM)$(toupper $(KBUILD_TARGET_ARCH)) +endif + +# Temporary measure while kBuild / tools updates their define quoting. +ifdef KMK_WITH_QUOTING + if ("$(VBOX_VCC_TOOL_STEM)" >= "VCC140" && "$(KBUILD_TARGET)" == "win") \ + || ("$(KBUILD_TARGET)" != "darwin" && "$(KBUILD_TARGET)" != "win" && "$(KMK_REVISION)" >= 3566) \ + || ("$(KBUILD_TARGET)" == "darwin" && "$(KMK_REVISION)" >= 3579) + VBOX_WITH_AUTOMATIC_DEFS_QUOTING := 1 + endif +endif + + +# +# Default tool nonsense. +# +## @todo Remove the default tool crap here! +TOOL = $(VBOX_GCC_TOOL) +TOOL.win.x86 = $(VBOX_VCC_TOOL_STEM)X86 +TOOL.win.amd64 = $(VBOX_VCC_TOOL_STEM)AMD64 +ASTOOL := $(VBOX_ASTOOL) + + +# +# Setup the global defines and includes. +# +# Note! The __SOMETHING__ #defines are deprecated as they violate the C/C++ specs. +# +INCS += $(PATH_ROOT)/include $(PATH_OUT) +DEFS += VBOX +DEFS.debug := DEBUG DEBUG_$(subst $(subst _, ,_),_,$(USERNAME)) DEBUG_USERNAME=$(subst $(subst _, ,_),_,$(USERNAME)) +DEFS.dbgopt = $(DEFS.debug) +DEFS.profile = VBOX_WITH_STATISTICS +DEFS.strict = RT_STRICT VBOX_STRICT +DEFS.asan = RT_STRICT VBOX_STRICT +DEFS.x86 = RT_ARCH_X86 __X86__ +DEFS.amd64 = RT_ARCH_AMD64 __AMD64__ +DEFS.arm64 = RT_ARCH_ARM64 +DEFS.sparc32 = RT_ARCH_SPARC +DEFS.sparc64 = RT_ARCH_SPARC64 +DEFS.darwin = RT_OS_DARWIN __DARWIN__ +DEFS.freebsd = RT_OS_FREEBSD __FREEBSD__ +DEFS.haiku = RT_OS_HAIKU +DEFS.linux = RT_OS_LINUX _FILE_OFFSET_BITS=64 +DEFS.netbsd = RT_OS_NETBSD +DEFS.openbsd = RT_OS_OPENBSD +DEFS.os2 = RT_OS_OS2 +DEFS.os-agnostic = RT_OS_AGNOSTIC +DEFS.solaris = RT_OS_SOLARIS _FILE_OFFSET_BITS=64 +DEFS.win = RT_OS_WINDOWS __WIN__ +DEFS.win.x86 = __WIN32__ +DEFS.win.amd64 = __WIN64__ +# optional defines (use environment or make commandline) +ifdef VBOX_WITH_STATISTICS + DEFS += VBOX_WITH_STATISTICS +endif +ifdef VBOX_STRICT + DEFS += VBOX_STRICT +endif +ifdef LOG_ENABLED + DEFS += LOG_ENABLED +endif +ifdef VBOX_OSE + DEFS += VBOX_OSE +endif +ifdef VBOX_WITH_64_BITS_GUESTS + DEFS += VBOX_WITH_64_BITS_GUESTS +endif +ifdef VBOX_WITH_REM + DEFS += VBOX_WITH_REM +endif +ifdef VBOX_WITH_RAW_MODE + DEFS += VBOX_WITH_RAW_MODE +endif +ifdef VBOX_WITH_DRIVERLESS_FORCED + DEFS += VBOX_WITH_DRIVERLESS_FORCED +endif + +# Don't flood CDEFS, old MASMs doesn't like too many defines. +ifdef VBOX_WITH_DEBUGGER + CDEFS += VBOX_WITH_DEBUGGER +endif +ifdef VBOX_WITH_HARDENING + CDEFS += VBOX_WITH_HARDENING +endif +if defined(VBOX_WITH_STRICT_LOCKS) && ($(KBUILD_TYPE) == "debug" || $(KBUILD_TYPE) == "strict" || $(KBUILD_TYPE) == "asan") + CDEFS += RT_LOCK_STRICT RT_LOCK_STRICT_ORDER +endif +ifdef VBOX_WITH_EF_WRAPS + CDEFS += RTMEM_WRAP_TO_EF_APIS RTMEM_WRAP_SOME_NEW_AND_DELETE_TO_EF +endif + +# Quoted strings should not be passed to the assemblers since they might not +# subscribe to C preprocessing semantics. +ifdef VBOX_PATH_APP_PRIVATE + ifdef VBOX_WITH_AUTOMATIC_DEFS_QUOTING + CDEFS += RTPATH_APP_PRIVATE="$(VBOX_PATH_APP_PRIVATE)" + else + CDEFS += RTPATH_APP_PRIVATE=\"$(VBOX_PATH_APP_PRIVATE)\" + endif +endif +ifdef VBOX_PATH_APP_PRIVATE_ARCH + ifdef VBOX_WITH_AUTOMATIC_DEFS_QUOTING + CDEFS += RTPATH_APP_PRIVATE_ARCH="$(VBOX_PATH_APP_PRIVATE_ARCH)" + else + CDEFS += RTPATH_APP_PRIVATE_ARCH=\"$(VBOX_PATH_APP_PRIVATE_ARCH)\" + endif +endif +ifdef VBOX_PATH_APP_PRIVATE_ARCH_TOP + ifdef VBOX_WITH_AUTOMATIC_DEFS_QUOTING + CDEFS += RTPATH_APP_PRIVATE_ARCH_TOP="$(VBOX_PATH_APP_PRIVATE_ARCH_TOP)" + else + CDEFS += RTPATH_APP_PRIVATE_ARCH_TOP=\"$(VBOX_PATH_APP_PRIVATE_ARCH_TOP)\" + endif +endif +ifdef VBOX_PATH_SHARED_LIBS + ifdef VBOX_WITH_AUTOMATIC_DEFS_QUOTING + CDEFS += RTPATH_SHARED_LIBS="$(VBOX_PATH_SHARED_LIBS)" + else + CDEFS += RTPATH_SHARED_LIBS=\"$(VBOX_PATH_SHARED_LIBS)\" + endif +endif +ifdef VBOX_PATH_APP_DOCS + ifdef VBOX_WITH_AUTOMATIC_DEFS_QUOTING + CDEFS += RTPATH_APP_DOCS="$(VBOX_PATH_APP_DOCS)" + else + CDEFS += RTPATH_APP_DOCS=\"$(VBOX_PATH_APP_DOCS)\" + endif +endif +if1of ($(KBUILD_TARGET), os2) # The gcc here is too old to grok #pragma once, instead it complains. + CDEFS += RT_WITHOUT_PRAGMA_ONCE +endif +CXXDEFS += $(CDEFS) +PCHDEFS += $(CDEFS) +OBJCDEFS += $(CDEFS) + +USES += dtrace +USES.win += vboximportchecker + + +# +# Decide which Windows DDK to use by default. +# +ifdef VBOX_WITH_NEW_WINDOWS_DDK + VBOX_WINDDK ?= WINSDK10-KM + VBOX_WINDDK_WLH ?= $(VBOX_WINDDK) + VBOX_WINDDK_GST_W8 ?= WINSDK10-KM-W8 + VBOX_WINDDK_GST_W7 ?= WINSDK10-KM-W7 + VBOX_WINDDK_GST_WLH ?= WINDDK71WLH +else if1of ($(VBOX_VCC_TOOL_STEM), VCC110) + VBOX_WINDDK ?= WINDDK80 +else + VBOX_WINDDK ?= WINDDK71 +endif +VBOX_WINDDK_WLH ?= $(VBOX_WINDDK)WLH + +VBOX_WINDDK_GST ?= $(VBOX_WINDDK) +VBOX_WINDDK_GST_W8 ?= WINDDK80W8 +VBOX_WINDDK_GST_W7 ?= $(VBOX_WINDDK_GST)W7 +VBOX_WINDDK_GST_WLH ?= $(VBOX_WINDDK_GST)WLH +VBOX_WINDDK_GST_W2K3 ?= WINDDK71WNET +ifeq ($(KBUILD_TARGET_ARCH),x86) + VBOX_WINDDK_GST_WXP ?= WINDDK71WXP + VBOX_WINDDK_GST_W2K ?= $(VBOX_WINDDK_GST_WXP) + VBOX_WINDDK_GST_NT4 ?= $(VBOX_WINDDK_GST_WXP) +else + VBOX_WINDDK_GST_WXP ?= $(VBOX_WINDDK_GST_W2K3) + VBOX_WINDDK_GST_W2K ?= $(VBOX_WINDDK_GST_W2K3) + VBOX_WINDDK_GST_NT4 ?= $(VBOX_WINDDK_GST_W2K3) +endif + + +# +# Decide which Windows SDK to use by default. +# +ifdef VBOX_WITH_NEW_WINDOWS_SDK + VBOX_WINPSDK ?= WINSDK10-UM + VBOX_WINPSDK_INCS ?= $(VBOX_WINPSDK)-INCS +else if1of ($(VBOX_VCC_TOOL_STEM), VCC110) + VBOX_WINPSDK ?= WINPSDK80 + VBOX_WINPSDK_INCS ?= $(VBOX_WINPSDK)INCS +else + VBOX_WINPSDK ?= WINPSDK71 + VBOX_WINPSDK_INCS ?= $(VBOX_WINPSDK)INCS +endif +VBOX_WINPSDK_GST ?= $(VBOX_WINPSDK) +VBOX_WINPSDK_GST_INCS ?= $(VBOX_WINPSDK_INCS) +ifneq ($(VBOX_WINPSDK_GST),WINPSDK71) + VBOX_WINPSDK_GST_W8 ?= $(VBOX_WINPSDK_GST) +else + VBOX_WINPSDK_GST_W8 ?= WINPSDK80 +endif +VBOX_WINPSDK_GST_W7 ?= $(VBOX_WINPSDK_GST) +VBOX_WINPSDK_GST_WLH ?= $(VBOX_WINPSDK_GST) +VBOX_WINPSDK_GST_WXP ?= $(VBOX_WINPSDK_GST) +ifeq ($(KBUILD_TARGET_ARCH),x86) + VBOX_WINPSDK_GST_W2K ?= $(VBOX_WINPSDK_GST) + VBOX_WINPSDK_GST_NT4 ?= $(VBOX_WINPSDK_GST) +else + VBOX_WINPSDK_GST_W2K ?= $(VBOX_WINPSDK_GST_WXP) + VBOX_WINPSDK_GST_NT4 ?= $(VBOX_WINPSDK_GST_WXP) +endif + + +# +# ARCH_BITS_DEFS. +# +if1of ($(KBUILD_TARGET_ARCH), amd64 sparc64 arm64) + VBOX_HC_ARCH_BITS := 64 + ARCH_BITS_DEFS := HC_ARCH_BITS=64 +else if1of ($(KBUILD_TARGET_ARCH), x86 sparc32) + VBOX_HC_ARCH_BITS := 32 + ARCH_BITS_DEFS := HC_ARCH_BITS=32 +else + $(error VBox: KBUILD_TARGET_ARCH=$(KBUILD_TARGET_ARCH)) +endif + +ifdef VBOX_WITH_64_BITS_GUESTS + VBOX_GC_ARCH_BITS_DEFS := GC_ARCH_BITS=64 +else + VBOX_GC_ARCH_BITS_DEFS := GC_ARCH_BITS=32 +endif +ARCH_BITS_DEFS += $(VBOX_GC_ARCH_BITS_DEFS) + +# +# Add the output dir(s) to the dynamic loader search path. +# +if1of ($(KBUILD_HOST), freebsd linux netbsd openbsd solaris) + export LD_LIBRARY_PATH:=$(PATH_STAGE_BIN):$(PATH_STAGE_LIB):$(LD_LIBRARY_PATH) +endif +ifeq ($(KBUILD_HOST),haiku) + export LIBRARY_PATH:=$(PATH_STAGE_BIN):$(PATH_STAGE_LIB):$(LIBRARY_PATH) +endif +ifeq ($(KBUILD_HOST),os2) + #fixme! export BEGINLIBPATH:=$(PATH_STAGE_BIN);$(PATH_STAGE_LIB);$(BEGINLIBPATH) +endif +ifeq ($(KBUILD_HOST),win) + # This check is a bit hacky, but avoids problems with PATH being changed + # again when the makefiles are reread because some automatically generated + # makefile has been modified. + ifeq ($(findstring $(PATH_STAGE_BIN);$(PATH_STAGE_LIB);,$(PATH)),) + export PATH:=$(PATH_STAGE_BIN);$(PATH_STAGE_LIB);$(PATH) + endif +endif + +# +# Common libraries and tools. +# +ifeq ($(KBUILD_TARGET),darwin) + LIB_RUNTIME = $(PATH_STAGE_BIN)/VBoxRT.dylib + LIB_RUNTIME_EF = #$(PATH_STAGE_LIB)/RuntimeEFCPP.a + VBOX_LIB_RUNTIME_X86 = $(PATH_STAGE_BIN)/VBoxRT-x86.dylib + LIB_KPROFILE = $(PATH_STAGE_BIN)/kPrf2.dylib + LIB_VMM = $(PATH_STAGE_BIN)/VBoxVMM.dylib + LIB_VMMRC = $(PATH_STAGE_BIN)/VMMRC.rc + LIB_REM = $(PATH_STAGE_LIB)/VBoxREM.dylib + LIB_XPCOM = $(PATH_STAGE_BIN)/VBoxXPCOM.dylib + LIB_XPCOM_IMP = $(PATH_STAGE_LIB)/VBoxXPCOMImp.dylib + VBOX_LIB_XPCOM_X86 = $(PATH_STAGE_BIN)/VBoxXPCOM-x86.dylib + LIB_DDU = $(PATH_STAGE_BIN)/VBoxDDU.dylib + VBOX_LIB_SUPR0 := +endif +if1of ($(KBUILD_TARGET), freebsd haiku linux netbsd openbsd solaris) + LIB_RUNTIME = $(PATH_STAGE_BIN)/VBoxRT.so + LIB_RUNTIME_EF = $(PATH_STAGE_LIB)/RuntimeEFCPP.a + VBOX_LIB_RUNTIME_X86 = $(PATH_STAGE_BIN)/VBoxRT-x86.so + LIB_KPROFILE = $(PATH_STAGE_BIN)/kPrf2.so + LIB_VMM = $(PATH_STAGE_BIN)/VBoxVMM.so + LIB_VMMRC = $(PATH_STAGE_BIN)/VMMRC.rc + LIB_REM = $(PATH_STAGE_LIB)/VBoxREM.so + LIB_XPCOM = $(PATH_STAGE_BIN)/VBoxXPCOM.so + LIB_XPCOM_IMP = $(PATH_STAGE_LIB)/VBoxXPCOMImp.so + VBOX_LIB_XPCOM_X86 = $(PATH_STAGE_BIN)/VBoxXPCOM-x86.so + LIB_DDU = $(PATH_STAGE_BIN)/VBoxDDU.so + VBOX_LIB_SUPR0 := +endif +ifeq ($(KBUILD_TARGET),os2) + LIB_RUNTIME = $(PATH_STAGE_BIN)/VBoxRT.dll + LIB_RUNTIME_EF = #$(PATH_STAGE_LIB)/RuntimeEFCPP.a + VBOX_LIB_RUNTIME_X86 = $(PATH_STAGE_BIN)/VBoxRT-x86.dll + LIB_KPROFILE = $(PATH_STAGE_BIN)/kPrf2.dll + LIB_VMM = $(PATH_STAGE_BIN)/VBoxVMM.dll + LIB_VMMRC = $(PATH_STAGE_LIB)/VMMRCImp.lib + LIB_REM = $(PATH_STAGE_LIB)/VBoxREMImp.lib + LIB_XPCOM = $(PATH_STAGE_BIN)/VBoxXCOM.dll + LIB_XPCOM_IMP = $(PATH_STAGE_LIB)/VBoxXPCOMImp.lib + VBOX_LIB_XPCOM_X86 = $(PATH_STAGE_BIN)/VBoxXPCOM-x86.dll + LIB_DDU = $(PATH_STAGE_BIN)/VBoxDDU.dll + VBOX_OBJ_SYS0 = $(PATH_OBJ)/RuntimeR0/os2/sys0.obj + VBOX_LIB_SUPR0 = $(PATH_STAGE_LIB)/SUPR0$(VBOX_SUFF_LIB) +endif +ifeq ($(KBUILD_TARGET),win) + LIB_RUNTIME = $(PATH_STAGE_LIB)/VBoxRT.lib + LIB_RUNTIME_EF = #$(PATH_STAGE_LIB)/RuntimeEFCPP.lib + VBOX_LIB_RUNTIME_X86 = $(PATH_STAGE_LIB)/VBoxRT-x86.lib + LIB_KPROFILE = $(PATH_STAGE_LIB)/kPrf2.lib + LIB_VMM = $(PATH_STAGE_LIB)/VBoxVMM.lib + LIB_VMMRC = $(PATH_OBJ)/VMMRC/VMMRC.lib + LIB_REM = $(PATH_STAGE_LIB)/VBoxREMImp.lib + LIB_XPCOM = + LIB_XPCOM_IMP = + VBOX_LIB_XPCOM_X86 = + LIB_DDU = $(PATH_STAGE_LIB)/VBoxDDU.lib + VBOX_LIB_SUPR0 = $(PATH_STAGE_LIB)/SUPR0$(VBOX_SUFF_LIB) +endif +ifn1of ($(KBUILD_TARGET_ARCH), $(VBOX_SUPPORTED_HOST_ARCHS)) # Hack to build a couple of extpack things that thing they need the VMM lib. + LIB_VMM := + LIB_VMMRC := +endif +VBOX_LIB_SUPHARDENED = $(PATH_STAGE_LIB)/SUPR3HardenedStatic$(VBOX_SUFF_LIB) +VBOX_LIB_RUNTIME_STATIC = $(PATH_STAGE_LIB)/RuntimeR3$(VBOX_SUFF_LIB) +VBOX_LIB_RUNTIME_STATIC_X86 = $(PATH_STAGE_LIB)/RuntimeR3-x86$(VBOX_SUFF_LIB) +if "$(KBUILD_TARGET)" == "win" && "$(KBUILD_TYPE)" == "asan" + VBOX_LIB_RUNTIME_STATIC_NO_ASAN = $(PATH_STAGE_LIB)/RuntimeR3NoAsan$(VBOX_SUFF_LIB) +else + VBOX_LIB_RUNTIME_STATIC_NO_ASAN = $(VBOX_LIB_RUNTIME_STATIC) +endif + +ifndef VBOX_WITH_REM + LIB_REM := +endif + +# Python +ifndef VBOX_BLD_PYTHON + if1of ($(KBUILD_HOST), win) + VBOX_BLD_PYTHON := $(firstword $(rsort $(wildcard $(KBUILD_DEVTOOLS)/win.x86/python/v*/python$(HOSTSUFF_EXE))) \ + python-not-found.exe) + else ifndef VBOX_WITH_PYTHON2_PREFERENCE + VBOX_BLD_PYTHON := $(firstword \ + $(which python3$(HOSTSUFF_EXE)) \ + $(which python3.10$(HOSTSUFF_EXE)) \ + $(which python3.9$(HOSTSUFF_EXE)) \ + $(which python3.8$(HOSTSUFF_EXE)) \ + $(which python3.7$(HOSTSUFF_EXE)) \ + $(which python3.6$(HOSTSUFF_EXE)) \ + $(which python3.5$(HOSTSUFF_EXE)) \ + $(which python3.4$(HOSTSUFF_EXE)) \ + $(which python2.7$(HOSTSUFF_EXE)) \ + $(which python$(HOSTSUFF_EXE)) \ + $(which python2.6$(HOSTSUFF_EXE)) \ + python-not-found$(HOSTSUFF_EXE) ) + else + VBOX_BLD_PYTHON := $(firstword \ + $(which python2.7$(HOSTSUFF_EXE)) \ + $(which python2.6$(HOSTSUFF_EXE)) \ + $(which python$(HOSTSUFF_EXE)) \ + $(which python3$(HOSTSUFF_EXE)) \ + python-not-found$(HOSTSUFF_EXE) ) + endif +endif +## For running python unittests in the validation kit. +VBOX_UNITTEST_PYTHON ?= $(VBOX_BLD_PYTHON) + +# +# pylint setup, see https://www.pylint.org/. +# +# Disabled: +# W0301 - Unnecessary semicolon. +# W0511 - TODO/XXX/FIXME/+++. +# W0603 - Using the global statement. +# W0702 - No exception type(s) specified. +# W0703 - Catch "Exception". +# I0011 - Locally disabling XXXXX. +# C0321 - More than one statement on a single line. +# R0201 - Method could be a function. +# C0326 - ???? +# W0123 - ???? +# C0330:bad-continuation - Wrong continued indentation (add X spaces). +# * Triggering on perfectly legal comments in array initializers and stuff. +# C0413:wrong-import-position - Import "YYYYY XXXXX" should be placed at the top of the module. +# * False positives due to __copyright__, __version__, probably. +# E0012:bad-option-value - Bad option value XXXXX. +# * Newer pylint doesn't grok older warning disables in sources (e.g. W0142 in db.py). Wonderful! +# I0012:locally-enabled - Locally enabling XXXXX. +# * We temporarily disable stuff and then renabled it. Very tedious. +# +# Note! Yes, --max-branchs is a typo, but not by me. +# +# Note! Users of older pylint release (< 1.0) needs to define +# VBOX_WITH_PYLINT_PRE_V1_0 in LocalConfig because they changed the +# output arguments in an backwards incompatible way and added more +# attribute regex options. +# +ifndef VBOX_PYLINT + VBOX_PYLINT := $(firstword $(which pylint-2.7) $(which pylint-2.6) $(which pylint2) $(which pylint)) + #ifdef VBOX_PYLINT # -- why was this needed. It messes up when using pylint w/ 3.x and building with 2.7. + # VBOX_PYLINT := $(VBOX_BLD_PYTHON) $(VBOX_PYLINT) + #endif +endif +if !defined(VBOX_WITH_PYLINT) && defined(VBOX_PYLINT) + VBOX_WITH_PYLINT := 1 + ifndef VBOX_PYLINT_VERSION + ifdef VBOX_WITH_PYLINT_PRE_V1_0 + VBOX_PYLINT_VERSION = 9999 + else ifdef VBOX_WITH_PYLINT_V1_2_1_PLUS + VBOX_PYLINT_VERSION = 10201 + else ifdef VBOX_WITH_PYLINT_V1_1_PLUS + VBOX_PYLINT_VERSION = 10100 + else + VBOX_PYLINT_VERSION = 10000 + endif + endif +endif +VBOX_PYLINT_FLAGS = $(if-expr $(VBOX_PYLINT_VERSION) >= 10500,--reports=n,--report=n) \ + $(if-expr $(VBOX_PYLINT_VERSION) >= 10000 \ + ,--msg-template='{path}:{line}: <{msg_id}>({obj}:{symbol}): {msg}' \ + ,--output-format=msvs --include-ids=y) \ + --persistent=n \ + --rcfile=$(PATH_ROOT)/tools/pylintrc \ + --max-line-length=130 \ + --max-attributes=32 \ + --max-branch$(if-expr $(VBOX_PYLINT_VERSION) >= 10000,e,)s=50 \ + --max-statements=100 \ + --max-returns=100 \ + --max-public-methods=139 \ + --max-args=9 \ + --max-module-lines=4096 \ + --max-locals=32 \ + $(if-expr $(VBOX_PYLINT_VERSION) >= 10500,--max-bool-expr=99,) \ + --min-public-methods=0 \ + --function-rgx='[a-z_][a-zA-Z0-9_]{2,40}$(DOLLAR)' \ + --method-rgx='[a-z_][a-zA-Z0-9_]{2,40}$(DOLLAR)' \ + --argument-rgx='([a-z_][a-zA-Z0-9_]{2,30}|rc|hr|s|c|ch|cx|cy|cb|fn)$(DOLLAR)' \ + --variable-rgx='([a-z_][a-zA-Z0-9_]{2,30}|rc|hr|s|c|ch|cx|cy|cb|fn)$(DOLLAR)' \ + --attr-rgx='([a-z_][a-zA-Z0-9_]{2,30}|rc|hr|o)$(DOLLAR)' \ + --module-rgx='(([a-z_][a-z0-9_]*)|([A-Z][a-zA-Z0-9]+)|(td[A-Z][a-zA-Z0-9]+)|(t(e|)st(-|)[a-zA-Z0-9]+))$(DOLLAR)' \ + --class-rgx='(td|)[A-Z_][a-zA-Z0-9_]+$(DOLLAR)' \ + --const-rgx='(g_(k|)[abcdefhmnpilorstu]+[A-Z][a-zA-Z0-9]+|[A-Z_][A-Z0-9_]+|__copyright__|__version__|__file__|__all__)$(DOLLAR)' \ + --good-names='i,j,k,t,o,c,e,ch,s,_' \ + $(if-expr $(VBOX_PYLINT_VERSION) >= 10000,--class-attribute-rgx='(k[abcdefhmnpilorstu]+[A-Z0-9][a-zA-Z0-9_]{0,32}|[A-Z_][A-Z0-9_]{2,32})',) \ + $(if-expr $(VBOX_PYLINT_VERSION) >= 10500,--max-nested-blocks=9,) \ + $(if-expr $(VBOX_PYLINT_VERSION) >= 10100,--disable=bad-whitespace,) \ + $(if-expr $(VBOX_PYLINT_VERSION) >= 10201,--disable=bad-continuation --disable=eval-used,) \ + $(if-expr $(VBOX_PYLINT_VERSION) >= 10201 && $(VBOX_PYLIN_VERSION) < 10500,--disable=bad-option-value,) \ + $(if-expr $(VBOX_PYLINT_VERSION) >= 10500,--disable=wrong-import-position --disable=E0012 --disable=locally-enabled,) \ + $(if-expr $(VBOX_PYLINT_VERSION) >= 10600,--disable=missing-docstring --disable=trailing-newlines --disable=ungrouped-imports,) \ + $(if-expr $(VBOX_PYLINT_VERSION) >= 10800,--disable=redundant-keyword-arg,) \ + $(if-expr $(VBOX_PYLINT_VERSION) >= 20000,--disable=useless-object-inheritance --disable=useless-return,) \ + $(if-expr $(VBOX_PYLINT_VERSION) >= 20400,--disable=import-outside-toplevel,) \ + $(if-expr $(VBOX_PYLINT_VERSION) >= 20900,--disable=super-with-arguments --disable=raise-missing-from,) \ + $(if-expr $(VBOX_PYLINT_VERSION) >= 21200,--disable=consider-using-f-string --disable=unnecessary-semicolon --disable=redundant-u-string-prefix) \ + --disable=unnecessary-semicolon,invalid-encoded-data,global-statement,bare-except,broad-except,multiple-statements,no-self-use,fixme \ + --disable=I0011 \ + --ignored-classes=testdriver.vboxcon + + +# Define the macro for win path conversion. +if !defined(VBOX_ONLY_SDK) || defined(VBOX_ONLY_SDK_ON_HOST) || defined(VBOX_ONLY_SDK_IN_VM) + VBOX_FN_MAKE_WIN_PATH = "$(quote-sh-dq $(subst /,\,$(requote unq, $(1))))" +else + # Z: is always FS root for Wine. + VBOX_FN_MAKE_WIN_PATH = $(subst /,\\,$(patsubst /%,Z:/%,$(1))) +endif + +# The kprofile build automagically links with kProfile. +ifeq ($(KBUILD_TYPE),kprofile) + LIB_RUNTIME += $(LIB_KPROFILE) +endif + +# Enable C++ electric fence heap. (Warning: will easily run out of virtual memory / kernel stuff on Linux/Windows.) +ifdef VBOX_WITH_CPP_EF + LIB_RUNTIME <= $(LIB_RUNTIME_EF) +endif + +# Overridable libraries (unix). +LIB_PTHREAD ?= pthread + +# Xcursor (consider an SDK for this). +ifeq ($(VBOX_XCURSOR_LIBS),) + ifeq ($(KBUILD_TARGET),solaris) + VBOX_XCURSOR_LIBS := $(lastword $(wildcard $(KBUILD_DEVTOOLS_TRG)/libXcursor/*/lib/libXcursor.a)) + ifneq ($(VBOX_XCURSOR_LIBS),) + VBOX_XCURSOR_INCS := $(patsubst %/lib/libXcursor.a,%/include, $(VBOX_XCURSOR_LIBS)) + VBOX_XCURSOR_LIBS += X11 Xrender Xfixes + endif + endif + ifeq ($(VBOX_XCURSOR_LIBS),) + VBOX_XCURSOR_LIBS := Xcursor + endif +endif + + +# Intel ASL compiler for ACPI +VBOX_IASLCMD ?= $(firstword $(wildcard $(KBUILD_DEVTOOLS_HST)/bin/iasl$(HOSTSUFF_EXE)) iasl$(HOSTSUFF_EXE)) + +# libxslt XSLT processor. (see PATH_TOOL_YASM for explanation why it's temporarily located in bin.) +ifeq ($(VBOX_XSLTPROC),) + ifeq ($(KBUILD_HOST),win) + VBOX_XSLTPROC := $(wildcard $(KBUILD_DEVTOOLS)/$(KBUILD_HOST).$(KBUILD_HOST_ARCH)/libxslt/10128/bin/xsltproc.exe) + ifeq ($(VBOX_XSLTPROC),) + VBOX_XSLTPROC := $(KBUILD_DEVTOOLS)/win.x86/bin/xsltproc.exe + endif + else ifeq ($(KBUILD_HOST),os2) + VBOX_XSLTPROC := BEGINLIBPATH="$(KBUILD_DEVTOOLS_HST)/bin;$$BEGINLIBPATH" $(KBUILD_DEVTOOLS_HST)/bin/xsltproc.exe + else ifeq ($(KBUILD_HOST),haiku) + VBOX_XSLTPROC := $(KBUILD_DEVTOOLS)/haiku.x86/bin/xsltproc + else + VBOX_XSLTPROC := xsltproc$(HOSTSUFF_EXE) + endif +endif + +# Doxygen +ifeq ($(VBOX_DOXYGEN),) + VBOX_DOXYGEN := $(firstfile $(rversortfiles $(qwildcard , $(KBUILD_DEVTOOLS_HST)/doxygen/v*/doxygen$(HOSTSUFF_EXE))) doxygen$(HOSTSUFF_EXE)) +endif + +# bin2c (convert binary files into C arrays) +VBOX_BIN2C ?= $(PATH_OBJ)/bin2c/bin2c$(HOSTSUFF_EXE) + +# genalias (generate aliases for nocrt_ functions) +VBOX_GENALIAS ?= $(PATH_OBJ)/genalias/genalias$(HOSTSUFF_EXE) + +# RTManifest (extension pack manifest utility) +VBOX_RTMANIFEST ?= $(PATH_OBJ)/bldRTManifest/bldRTManifest$(HOSTSUFF_EXE) + +# RTSignTool (certificate extraction tool) +VBOX_RTSIGNTOOL ?= $(PATH_OBJ)/bldRTSignTool/bldRTSignTool$(HOSTSUFF_EXE) + +# RTIsoMaker (our own ISO maker). +VBOX_RTISOMAKER ?= $(PATH_OBJ)/bldRTIsoMaker/bldRTIsoMaker$(HOSTSUFF_EXE) + +# RTLdrCheckImports (checks imports against oldest supported OS version (GAs typically)) +VBOX_RTLDRCHECKIMPORTS ?= $(PATH_OBJ)/bldRTLdrCheckImports/bldRTLdrCheckImports$(HOSTSUFF_EXE) + +# VBoxCmp (simple /bin/cmp with more sensible output) +VBOX_VBOXCMP ?= $(PATH_OBJ)/VBoxCmp/VBoxCmp$(HOSTSUFF_EXE) + +# VBoxCPP (special purpose C preprocessor) +VBOX_VBOXCPP ?= $(PATH_OBJ)/VBoxCPP/VBoxCPP$(HOSTSUFF_EXE) + +# VBoxTpG (tracepoint generator) +VBOX_VBOXTPG ?= $(PATH_OBJ)/VBoxTpG/VBoxTpG$(HOSTSUFF_EXE) + +# VBoxPeSetVersion (changes the minimum OS version of an image) +VBOX_PE_SET_VERSION ?= $(PATH_OBJ)/VBoxPeSetVersion/VBoxPeSetVersion$(HOSTSUFF_EXE) + +# Visual C++ EditBin.exe. +VBOX_VCC_EDITBIN = $(if $(PATH_TOOL_$(VBOX_VCC_TOOL)_BIN_QSH),$(PATH_TOOL_$(VBOX_VCC_TOOL)_BIN_QSH)/,$(if $(PATH_TOOL_$(VBOX_VCC_TOOL)_BIN),$(PATH_TOOL_$(VBOX_VCC_TOOL)_BIN)/,))editbin.exe /NoLogo + +# filesplitter (splits java files) +VBOX_FILESPLIT ?= $(PATH_OBJ)/filesplitter/filesplitter$(HOSTSUFF_EXE) + +# biossums (set BIOS checksums) +VBOX_BIOSSUMS ?= $(PATH_OBJ)/biossums/biossums$(HOSTSUFF_EXE) + +# MakeAlternativeSource (for BIOSes) +VBOX_MAKE_ALTERNATIVE_SOURCE ?= $(PATH_OBJ)/MakeAlternativeSource/MakeAlternativeSource$(HOSTSUFF_EXE) + +# VBoxDef2LazyLoad (lazy dynamic library loader assembly generator) +VBOX_DEF_2_LAZY_LOAD ?= $(PATH_OBJ)/VBoxDef2LazyLoad/VBoxDef2LazyLoad$(HOSTSUFF_EXE) + +# VBoxCheckImports (checks what we imports from on windows) +VBOX_CHECK_IMPORTS ?= $(PATH_OBJ)/VBoxCheckImports/VBoxCheckImports$(HOSTSUFF_EXE) + +# VBoxEditCoffLib (symbol name tweaking for VBoxSF on windows) +VBOX_EDIT_COFF_LIB ?= $(PATH_OBJ)/VBoxEditCoffLib/VBoxEditCoffLib$(HOSTSUFF_EXE) + +# GNU tar if present. +if1of ($(KBUILD_TARGET), linux os2 win) + VBOX_GTAR ?= tar +else if1of ($(KBUILD_TARGET), freebsd netbsd solaris) + VBOX_GTAR ?= gtar +endif + +# zip +VBOX_ZIP ?= zip$(HOSTSUFF_EXE) + +ifeq ($(KBUILD_TARGET),win) + ifeq ($(KBUILD_TARGET_ARCH),x86) # Normally we should test for KBUILD_HOST_ARCH but we only require MINGWW64 for 64-bit _targets_ + VBOX_NM ?= $(PATH_TOOL_MINGW32)/bin/nm.exe -p + else + VBOX_NM ?= $(PATH_TOOL_MINGWW64)/bin/nm.exe -p + endif +else ifeq ($(KBUILD_HOST),darwin) # Xcode 7.3.1 nm doesn't like -t, and -x behaves very differently. Throwing in -B (bsd) to make sure. + VBOX_NM ?= $(subst $(REDIRECT_INT),$(REDIRECT_EXT),$(TOOL_$(VBOX_GCC_TOOL)_ENV_SETUP) $(PATH_TOOL_$(VBOX_GCC_TOOL)_TOOLCHAIN_BIN_SLASH)nm) -p \ + $(if-expr $(VBOX_XCODE_VERSION_MAJOR) > 7 || ($(VBOX_XCODE_VERSION_MAJOR) == 7 && $(VBOX_XCODE_VERSION_MINOR) >= 3),-B,) +else + VBOX_NM ?= nm -p -t x +endif + +# Makeself for the linux installers. +VBOX_MAKESELF ?= $(KBUILD_DEVTOOLS)/common/makeself/v2.4.5-r2/makeself.sh + +# Microsoft HTML Help Workshop. +VBOX_PATH_HTML_HELP_WORKSHOP ?= $(KBUILD_DEVTOOLS)/win.x86/HTML_Help_Workshop/v1.3/ + +# Path to the null soft installer. +VBOX_PATH_NSIS ?= $(KBUILD_DEVTOOLS)/win.x86/nsis/v3.08-log + +# Windows install tools... +# Note! The scripts has been moved to Bin in v8.0. +VBOX_PATH_WIX ?= $(KBUILD_DEVTOOLS)/win.x86/wix/v3.11.2 +ifdef VBOX_WITH_NEW_WINDOWS_SDK + VBOX_PATH_MSITRAN ?= $(PATH_SDK_$(VBOX_WINPSDK)_BIN)/../x86/MsiTran.Exe + VBOX_PATH_MSIDB ?= $(PATH_SDK_$(VBOX_WINPSDK)_BIN)/../x86/MsiDb.Exe + VBOX_PATH_WISUBSTG ?= $(PATH_SDK_$(VBOX_WINPSDK)_BIN)/WiSubStg.vbs + VBOX_PATH_WISUMINFO ?= $(PATH_SDK_$(VBOX_WINPSDK)_BIN)/WiSumInf.vbs +else + VBOX_PATH_MSITRAN ?= $(KBUILD_DEVTOOLS)/win.x86/sdk/v7.1/Bin/MsiTran.Exe + VBOX_PATH_MSIDB ?= $(KBUILD_DEVTOOLS)/win.x86/sdk/v7.1/Bin/MsiDb.Exe + VBOX_PATH_WISUBSTG ?= $(KBUILD_DEVTOOLS)/win.x86/sdk/v7.1/Samples/sysmgmt/msi/scripts/WiSubStg.vbs + VBOX_PATH_WISUMINFO ?= $(KBUILD_DEVTOOLS)/win.x86/sdk/v7.1/Samples/sysmgmt/msi/scripts/WiSumInf.vbs +endif +VBOX_PATH_DIFX ?= $(KBUILD_DEVTOOLS)/win.$(KBUILD_TARGET_ARCH)/DIFx/v2.1-r3 + +ifdef VBOX_OSE ## @todo try get rid of this crap! People can use the latest and greatest Yasm release, no need to check in the binary for OSE. + # We need to export YASM for OSE, but since it was converted to .zip we need to + # allow for the location used by the zip to be properly cleaned up first. + if1of ($(KBUILD_HOST).$(KBUILD_HOST_ARCH), linux.x86 solaris.x86 win.x86) + PATH_TOOL_YASM ?= $(KBUILD_DEVTOOLS_HST)/bin + endif +endif + +# bison and flex for windows. Needed by mesa and also used by VBoxDTrace. +ifeq ($(KBUILD_HOST),win) + ifndef TOOL_BISON_YACC + TOOL_BISON_YACC := $(firstfile $(rversortfiles $(qwildcard ,$(KBUILD_DEVTOOLS)/win.x86/win_flex_bison/v*/*bison*$(HOSTSUFF_EXE))) bison.exe) + endif + ifndef TOOL_FLEX_LEX + TOOL_FLEX_LEX := $(firstfile $(rversortfiles $(qwildcard ,$(KBUILD_DEVTOOLS)/win.x86/win_flex_bison/v*/*flex*$(HOSTSUFF_EXE))) flex.exe) + endif +endif + + +# The Microsoft IDL compiler (the SDK build needs this on non-Windows). +VBOX_WIN_MIDL ?= $(EXEC_X86_WIN32) $(call VBOX_FN_MAKE_WIN_PATH,$(qfirstfile ,$(qwildcard ,$(qaddsuffix ,/[Mm][Ii][Dd][Ll].[Ee][Xx][Ee], \ + $(PATH_SDK_$(VBOX_WINPSDK)_BIN) \ + $(KBUILD_DEVTOOLS)/win.x86/sdk/v7.1/Bin$(if-expr "$(KBUILD_HOST).$(KBUILD_HOST_ARCH)" == "win.amd64",/x64,) \ + $(KBUILD_DEVTOOLS)/win.x86/ddk/7600.16385.1/bin/x86 \ + $(KBUILD_DEVTOOLS)/win.x86/bin \ + $(PATH_SDK_$(VBOX_WINPSDK)_BIN) \ + $(PATH_SDK_$(VBOX_WINPSDK)) \ + $(PATH_SDK_WINPSDK_BIN) \ + $(PATH_SDK_WINPSDK) \ + )) Sorry_Cannot_Find_The_Midl_Compiler_In_The_PSDK)) + +# Tricks to work around midl.exe problems with spaces in the /cpp_cmd value, it +# forgets to quote it when creating the commandline and cl.exe gets very confused. +if1of (quote, $(KMK_FEATURES)) + VBOX_MIDL_REDIRECT = $(REDIRECT) --prepend "$(quote-sh-dq PATH=$(PATH_TOOL_$(VBOX_VCC_TOOL)_BIN);$(qaddsuffix ,;,$(PATH_TOOL_$(VBOX_VCC_TOOL)_DLL_BIN)))" -- + VBOX_MIDL_REDIRECT_X86 = $(REDIRECT) --prepend "$(quote-sh-dq PATH=$(PATH_TOOL_$(VBOX_VCC_TOOL_STEM)X86_BIN);$(qaddsuffix ,;,$(PATH_TOOL_$(VBOX_VCC_TOOL_STEM)X86_DLL_BIN)))" -- +else + VBOX_MIDL_REDIRECT = $(REDIRECT) --prepend 'PATH=$(PATH_TOOL_$(VBOX_VCC_TOOL)_BIN);$(PATH)' -- + VBOX_MIDL_REDIRECT_X86 = $(REDIRECT) --prepend 'PATH=$(PATH_TOOL_$(VBOX_VCC_TOOL_STEM)X86_BIN);$(PATH)' -- +endif +VBOX_MIDL_CPP_CMD = $(lastword $(notdir ,$(subst $(EXEC_X86_WIN32),,$(TOOL_$(VBOX_VCC_TOOL)_CC)))) +VBOX_MIDL_CPP_CMD_X86 = $(lastword $(notdir ,$(subst $(EXEC_X86_WIN32),,$(TOOL_$(VBOX_VCC_TOOL_STEM)X86_CC)))) + +## +# Edits $1 and adding #pragma directives for disabling warnings windows.h causes. +# @param 1 The name of the file to edit. +define def_VBoxMidlOutputDisableMscWarnings + $(QUIET)$(MV) -f "$1" "$1.tmp" + $(QUIET)$(APPEND) -nt "$1" \ + '#if _MSC_VER >= 1920 /* RT_MSC_VER_VS2019 */' \ + '# pragma warning(disable:5031 5032) /* buggy winioctl.h in some w10 sdks */ ' \ + '#endif' \ + '#pragma warning(push) /* -Wall and windows.h */' \ + '#pragma warning(disable:4668 4255)' \ + '#if _MSC_VER >= 1800 /* RT_MSC_VER_VC120 */' \ + '# pragma warning(disable:4005)' \ + '#endif' \ + '#if _MSC_VER >= 1900 /* RT_MSC_VER_VC140 */' \ + '# pragma warning(disable:5039)' \ + '#endif' \ + '' + $(QUIET)$(CAT_EXT) "$1.tmp" >> "$1" + $(QUIET)$(APPEND) -n "$1" \ + '' \ + '#pragma warning(pop)' \ + '' + $(QUIET)$(RM) -f "$1.tmp" + +endef + +# XPCOM setup for all but win32. +ifneq ($(KBUILD_TARGET),win) + VBOX_WITH_XPCOM = 1 + # if updating, also update xpidl_INST var in src/libs/xpcom18a4/Makefile.kmk + VBOX_XPIDL ?= $(PATH_STAGE_BIN)/xpidl$(HOSTSUFF_EXE) + ifeq ($(KBUILD_TARGET),os2) + VBOX_XPIDL_ENV = BEGINLIBPATH="$(dir $(VBOX_XPIDL));$$BEGINLIBPATH"$(SP) + endif + VBOX_PATH_XPCOM_IDL ?= $(VBOX_PATH_SDK)/bindings/xpcom/idl + VBOX_XPCOM_INCS ?= \ + $(VBOX_PATH_SDK)/bindings/xpcom/include \ + $(VBOX_PATH_SDK)/bindings/xpcom/include/xpcom \ + $(VBOX_PATH_SDK)/bindings/xpcom/include/string \ + $(VBOX_PATH_SDK)/bindings/xpcom/include/xpcom \ + $(VBOX_PATH_SDK)/bindings/xpcom/include/nsprpub \ + $(VBOX_PATH_SDK)/bindings/xpcom/include/ipcd + ifneq ($(KBUILD_TARGET),os2) + # libIDL-config (for xpcom18a4) + ifeq ($(origin VBOX_LIBIDL_CONFIG),undefined) + ifeq ($(KBUILD_HOST),solaris) + VBOX_LIBIDL_CONFIG_FALLBACK = $(lastword $(wildcard $(KBUILD_DEVTOOLS)/solaris.amd64/libIDL/*/bin/libIDL-config-2)) + endif + export VBOX_LIBIDL_CONFIG := $(firstword $(which libIDL-config-2 libIDL-config) $(VBOX_LIBIDL_CONFIG_FALLBACK) libIDL-config-2-not-found) + endif + endif +endif + +# The X11 LIBPATH. (The amd64 hack is for RHEL4.) +ifeq ($(KBUILD_TARGET_ARCH),amd64) + VBOX_LIBPATH_X11 ?= /usr/X11R6/lib64 /usr/X11R6/lib +else + VBOX_LIBPATH_X11 ?= /usr/X11R6/lib +endif + +# 32bit X11 LIBPATH for building 32bit guest additions +VBOX_LIBPATH32_X11 ?= /usr/X11R6/lib32 /usr/X11R6/lib + +# Good windows shell. +VBOX_GOOD_COMSPEC = $(subst \,/,$(SystemRoot))/System32/cmd.exe +VBOX_GOOD_COMSPEC_BS ?= $(subst /,\,$(VBOX_GOOD_COMSPEC)) + +# +# Macros dealing with the darwin version we're targeting. +# The DEF in VBOX_DEF_MACOSX_VERSION_MIN mean default. The default min +# version is assumed to be the +# +ifeq ($(KBUILD_TARGET),darwin) + # The minimum macOS version we're targetting. + ifndef VBOX_DEF_MACOSX_VERSION_MIN + if1of ($(VBOX_GCC_TOOL), GXX4MACHO GXX42MACHO) # For GAs. + VBOX_DEF_MACOSX_VERSION_MIN := 10.6# Snow Leopard + else if1of ($(VBOX_GCC_TOOL), VBoxXcode62) + VBOX_DEF_MACOSX_VERSION_MIN := 10.9# Mavericks + else ifeq ($(KBUILD_TARGET_ARCH),arm64) + VBOX_DEF_MACOSX_VERSION_MIN := 11.0# The Jack Kerouac novel. + else + if defined(VBOX_WITH_VMNET) && !defined(VBOX_ONLY_BUILD) # Force SDK 10.15 for VMNET + VBOX_DEF_MACOSX_VERSION_MIN := 10.15# Catalina + else + VBOX_DEF_MACOSX_VERSION_MIN := 10.13# High Sierra + endif + endif + endif + VBOX_DEF_MACOSX_VERSION_MIN_NO_DOT := $(subst .,,$(VBOX_DEF_MACOSX_VERSION_MIN)) + + if1of ($(VBOX_GCC_TOOL), GXX4MACHO GXX42MACHO) # For GAs. + # Check for the Xcode 4.1 bits in tools/darwin.x86. + if !defined(VBOX_WITH_MACOSX_COMPILERS_FROM_DEVEL) \ + && !defined(VBOX_XCODE_VERSION) \ + && exists "$(KBUILD_DEVTOOLS)/darwin.x86/xcode/v4.1" + VBOX_WITH_MACOSX_COMPILERS_FROM_DEVEL := 1 + VBOX_PATH_MACOSX_DEVEL_ROOT := $(KBUILD_DEVTOOLS)/darwin.x86/xcode/v4.1 + VBOX_XCODE_VERSION := 4.1 + else + # Fallback - system / LocalConfig.kmk. + VBOX_PATH_MACOSX_DEVEL_ROOT ?= /Developer + VBOX_PATH_MACOSX_SDK_ROOT ?= $(VBOX_PATH_MACOSX_DEVEL_ROOT)/SDKs + VBOX_PATH_MACOSX_TOOLCHAIN_ROOT ?= $(VBOX_PATH_MACOSX_DEVEL_ROOT) + endif + else ifeq ($(VBOX_GCC_TOOL),VBoxXcode62) + # Use the tool path of the compiler (it's clang, not gcc in this instance). + include $(KBUILD_TOOL_PATHS)/$(VBOX_GCC_TOOL).kmk + VBOX_PATH_MACOSX_DEVEL_ROOT := $(PATH_TOOL_$(VBOX_GCC_TOOL)) + # Fallback - system / LocalConfig.kmk. + ifndef VBOX_PATH_MACOSX_DEVEL_ROOT + VBOX_PATH_MACOSX_DEVEL_ROOT := $(firstword $(wildcard /Applications/Xcode.app/Contents/Developer /Developer /Library/Developer)) + endif + ifndef VBOX_PATH_MACOSX_SDK_ROOT + VBOX_PATH_MACOSX_SDK_ROOT := $(firstword $(wildcard \ + $(PATH_TOOL_$(VBOX_GCC_TOOL)_SDKS) \ + $(VBOX_PATH_MACOSX_DEVEL_ROOT)/SDKs/. \ + /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/. \ + /Developer/SDKs/. \ + /Library/Developer/CommandLineTools/SDKs/. )) + endif + ifndef VBOX_PATH_MACOSX_TOOLCHAIN_ROOT + VBOX_PATH_MACOSX_TOOLCHAIN_ROOT := $(firstword $(wildcard \ + $(PATH_TOOL_$(VBOX_GCC_TOOL)_TOOLCHAIN) \ + $(VBOX_PATH_MACOSX_DEVEL_ROOT)/Library/Developer/CommandLineTools/. \ + $(VBOX_PATH_MACOSX_DEVEL_ROOT)/Toolchains/XcodeDefault.xctoolchain/. \ + /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/. \ + /Library/Developer/CommandLineTools/. \ + ) /. ) + endif + else + # VBOX_WITH_EVEN_NEWER_XCODE ends up here. + include $(KBUILD_PATH)/tools/$(VBOX_GCC_TOOL).kmk + include $(KBUILD_PATH)/sdks/MACOSX$(VBOX_DEF_MACOSX_VERSION_MIN_NO_DOT).kmk + ifndef VBOX_PATH_MACOSX_SDK + VBOX_PATH_MACOSX_SDK := $(PATH_SDK_MACOSX$(VBOX_DEF_MACOSX_VERSION_MIN_NO_DOT)) + endif + VBOX_PATH_MACOSX_SDK_ROOT = $(dir $(VBOX_PATH_MACOSX_SDK)) + endif + + # Figure the default SDK location and obsolete linker tricks. + ifeq ($(VBOX_DEF_MACOSX_VERSION_MIN),10.4) + ifeq ($(origin VBOX_DARWIN_CLASSIC_LINKER),undefined) + VBOX_DARWIN_CLASSIC_LINKER := $(shell ld -v 2>&1 ) + ifneq ($(filter ld64%, $(subst :, , $(VBOX_DARWIN_CLASSIC_LINKER))),) + export VBOX_DARWIN_CLASSIC_LINKER := -Wl,-classic_linker + else + export VBOX_DARWIN_CLASSIC_LINKER := + endif + endif + endif + if !defined(VBOX_PATH_MACOSX_SDK) && !defined(VBOX_WITH_EVEN_NEWER_XCODE) # newer xcode handles this above + VBOX_PATH_MACOSX_SDK_ROOT_DIRS ?= \ + $(VBOX_PATH_MACOSX_SDK_ROOT) \ + $(KBUILD_DEVTOOLS)/darwin.x86/SDKs/ \ + $(KBUILD_DEVTOOLS)/darwin.amd64/SDKs/ \ + $(KBUILD_DEVTOOLS)/darwin.x86/xcode/v4.1/SDKs \ + $(KBUILD_DEVTOOLS)/darwin.x86/xcode/v3.2.6/SDKs + ifeq ($(VBOX_DEF_MACOSX_VERSION_MIN),10.4) + VBOX_PATH_MACOSX_SDK := $(firstword $(wildcard $(addsuffix /MacOSX$(VBOX_DEF_MACOSX_VERSION_MIN)u.sdk, $(VBOX_PATH_MACOSX_SDK_ROOT_DIRS))) \ + $(VBOX_PATH_MACOSX_SDK_ROOT)/MacOSX$(VBOX_DEF_MACOSX_VERSION_MIN)u.sdk ) + else + VBOX_PATH_MACOSX_SDK := $(firstword $(wildcard $(addsuffix /MacOSX$(VBOX_DEF_MACOSX_VERSION_MIN).sdk, $(VBOX_PATH_MACOSX_SDK_ROOT_DIRS))) \ + $(VBOX_PATH_MACOSX_SDK_ROOT)/MacOSX$(VBOX_DEF_MACOSX_VERSION_MIN).sdk ) + endif + endif + + ## The Xcode version (not relevant for command line tools, so we skip this in VBOX_WITH_EVEN_NEWER_XCODE mode). + ifdef VBOX_WITH_EVEN_NEWER_XCODE + VBOX_XCODE_VERSION ?= 10.98## Just a high non-existing version number. + else ifeq ($(KBUILD_HOST),darwin) + ifndef VBOX_XCODE_VERSION + if1of ($(VBOX_GCC_TOOL), VBoxXcode62) + VBOX_XCODE_VERSION := $(shell exec $(VBOX_PATH_MACOSX_DEVEL_ROOT)/usr/bin/xcodebuild -version 2>&1) + ifneq ($(pos Symbol not found,$(VBOX_XCODE_VERSION)),0) # Try detect unresolved symbol running Xcode 6.2 on Catalina. + VBOX_XCODE_VERSION = 6.2 + else + VBOX_XCODE_VERSION := $(word 2, $(VBOX_XCODE_VERSION)) + endif + else if defined(VBOX_WITH_MACOSX_COMPILERS_FROM_DEVEL) || exists "$(VBOX_PATH_MACOSX_DEVEL_ROOT)/usr/bin/xcodebuild" + VBOX_XCODE_VERSION := $(word 2, $(shell $(VBOX_PATH_MACOSX_DEVEL_ROOT)/usr/bin/xcodebuild -version)) + else + VBOX_XCODE_VERSION := $(word 2, $(shell xcodebuild -version)) + endif + ifeq ($(strip $(VBOX_XCODE_VERSION)),) + if1of ($(VBOX_GCC_TOOL), GXX4MACHO GXX42MACHO) + VBOX_XCODE_VERSION := 4.1 + else if1of ($(VBOX_GCC_TOOL), VBoxXcode62) + VBOX_XCODE_VERSION := 6.2 + else + VBOX_XCODE_VERSION := 9.4# whatever + endif + endif + endif + if1of ($(VBOX_GCC_TOOL), VBoxXcode62) + ifdef KBUILD_USE_KOBJCACHE + $(warning KBUILD_USE_KOBJCACHE does _not_ currently work with this version of Xcode) + endif + endif + else + VBOX_XCODE_VERSION ?= 4.1## @todo Anything special for GA, extpack and valkit tools fetching? + endif + VBOX_XCODE_VERSION_MAJOR := $(word 1, $(subst ., ,$(VBOX_XCODE_VERSION))) + VBOX_XCODE_VERSION_MINOR := $(word 2, $(subst ., ,$(VBOX_XCODE_VERSION))) + VBOX_XCODE_VERSION := $(VBOX_XCODE_VERSION_MAJOR).$(VBOX_XCODE_VERSION_MINOR) + + ifeq ($(KBUILD_TARGET_ARCH),x86) + if1of ($(VBOX_DEF_MACOSX_VERSION_MIN), 10.4 10.5) + VBOX_DARWIN_NO_COMPACT_LINKEDIT ?= $(VBOX_LD_no_compact_linkedit) + TOOL_GXX4MACHO_SUFFIX ?= -4.0 + endif + else if $(VBOX_XCODE_VERSION_MAJOR) < 4 && "$(VBOX_XCODE_VERSION)" != "3.2" + ifeq ($(PATH_CURRENT),$(PATH_ROOT)/tools) + $(warning VBox: 64-bit darwin builds require Xcode 3.2 or later, you have $(VBOX_XCODE_VERSION)) + else + $(error VBox: 64-bit darwin builds require Xcode 3.2 or later, you have $(VBOX_XCODE_VERSION)) + endif + endif + if1of ($(VBOX_GCC_TOOL), GXX4MACHO GXX42MACHO) + if $(VBOX_XCODE_VERSION_MAJOR) > 4 || ($(VBOX_XCODE_VERSION_MAJOR) == 4 && $(VBOX_XCODE_VERSION_MINOR) >= 2) + TOOL_GXX4MACHO_PREFIX ?= llvm- + endif + if $(VBOX_XCODE_VERSION_MAJOR) < 5 + TOOL_GXX4MACHO_SUFFIX ?= -4.2 + endif + VBOX_DARWIN_NO_COMPACT_LINKEDIT ?= + + TOOL_GCC4MACHO_SUFFIX ?= $(TOOL_GXX4MACHO_SUFFIX)$(HOSTSUFF_EXE) + TOOL_GCC4MACHO_PREFIX ?= $(TOOL_GXX4MACHO_PREFIX) + if defined(VBOX_WITH_MACOSX_COMPILERS_FROM_DEVEL) + TOOL_GCC4MACHO_PREFIX := $(VBOX_PATH_MACOSX_TOOLCHAIN_ROOT)/usr/bin/$(TOOL_GCC4MACHO_PREFIX) + TOOL_GXX4MACHO_PREFIX := $(VBOX_PATH_MACOSX_TOOLCHAIN_ROOT)/usr/bin/$(TOOL_GXX4MACHO_PREFIX) + TOOL_GCC4MACHO_SUFFIX := $(TOOL_GCC4MACHO_SUFFIX) -isysroot "$(VBOX_PATH_MACOSX_SDK)" + TOOL_GXX4MACHO_SUFFIX := $(TOOL_GXX4MACHO_SUFFIX) -isysroot "$(VBOX_PATH_MACOSX_SDK)" + ifndef SVN # must expand first so we won't be using old svn. + SVN := $(firstword $(which svn) svn) + endif + if $(VBOX_XCODE_VERSION_MAJOR) > 4 || ($(VBOX_XCODE_VERSION_MAJOR) == 4 && $(VBOX_XCODE_VERSION_MINOR) >= 2) + export PATH:=$(VBOX_PATH_MACOSX_DEVEL_ROOT)/usr/bin/:$(VBOX_PATH_MACOSX_SDK)/usr/bin:$(VBOX_PATH_MACOSX_TOOLCHAIN_ROOT)/usr/bin:$(PATH) + export DEVELOPER_DIR:=$(VBOX_PATH_MACOSX_DEVEL_ROOT) + else + export PATH:=$(VBOX_PATH_MACOSX_DEVEL_ROOT)/usr/bin/:$(PATH) + endif + TOOL_GXX32_CC = $(TOOL_GCC4MACHO_PREFIX)gcc$(TOOL_GCC4MACHO_SUFFIX) -m32 + TOOL_GXX32_CXX = $(TOOL_GCC4MACHO_PREFIX)g++$(TOOL_GCC4MACHO_SUFFIX) -m32 + TOOL_GXX32_LD = $(TOOL_GXX32_CXX) + override TOOL_StandardDTrace_DTRACE := dtrace "-xcpppath=$(TOOL_GCC4MACHO_PREFIX)cpp-4.2" + endif + if $(VBOX_XCODE_VERSION_MAJOR) < 5 + ## @todo WTF do we do the -m32/64 stuff here for these compilers? Also the visibility should be elsewhere... + TOOL_GXX4MACHO_OBJC = $(TOOL_GCC4MACHO_PREFIX)gcc$(TOOL_GCC4MACHO_SUFFIX) $(if-expr $(KBUILD_TARGET_ARCH) == "x86",-m32,-m64) -fvisibility=hidden + TOOL_GXX4MACHO_OBJCXX = $(TOOL_GCC4MACHO_PREFIX)gcc$(TOOL_GCC4MACHO_SUFFIX) $(if-expr $(KBUILD_TARGET_ARCH) == "x86",-m32,-m64) -fvisibility=hidden -fvisibility-inlines-hidden + endif + else if1of ($(VBOX_GCC_TOOL), VBoxXcode62) + if $(KBUILD_HOST_VERSION_MAJOR) >= 18 # HACK ALERT! dtrace doesn't work on Mojave if we specify our Xcode 6.2 environment. + override TOOL_StandardDTrace_DTRACE := dtrace "-xcpppath=$(VBOX_PATH_MACOSX_DEVEL_ROOT)/usr/bin/gcc" + else + override TOOL_StandardDTrace_DTRACE := $(TOOL_$(VBOX_GCC_TOOL)_ENV_SETUP) dtrace "-xcpppath=$(VBOX_PATH_MACOSX_DEVEL_ROOT)/usr/bin/gcc" + endif + export PATH:=$(VBOX_PATH_MACOSX_SDK)/usr/bin:$(PATH) + else # effectively VBOX_WITH_EVEN_NEWER_XCODE + override TOOL_StandardDTrace_DTRACE := $(TOOL_$(VBOX_GCC_TOOL)_ENV_SETUP) dtrace "-xcpppath=$(filter-out -f%,$(TOOL_$(VBOX_GCC_TOOL)_CC))" + endif + + ifdef VBOX_WITH_EVEN_NEWER_XCODE + VBOX_DARWIN_DEF_SDK_SDKS := MACOSX$(VBOX_DEF_MACOSX_VERSION_MIN_NO_DOT) + VBOX_DARWIN_DEF_SDK_DEFS := MAC_OS_X_VERSION_MAX_ALLOWED=$(SDK_MACOSX$(VBOX_DEF_MACOSX_VERSION_MIN_NO_DOT)_VERSION_VALUE) + VBOX_DARWIN_DEF_SDK_LDFLAGS = $(VBOX_DARWIN_CLASSIC_LINKER) $(VBOX_DARWIN_NO_COMPACT_LINKEDIT) + else + VBOX_DARWIN_DEF_SDK_DEFS := MAC_OS_X_VERSION_MIN_REQUIRED=$(VBOX_DEF_MACOSX_VERSION_MIN_NO_DOT)0 \ + MAC_OS_X_VERSION_MAX_ALLOWED=$(VBOX_DEF_MACOSX_VERSION_MIN_NO_DOT)0 + VBOX_DARWIN_DEF_SDK_CFLAGS := -mmacosx-version-min=$(VBOX_DEF_MACOSX_VERSION_MIN) -isysroot "$(VBOX_PATH_MACOSX_SDK)" + VBOX_DARWIN_DEF_SDK_CXXFLAGS := -mmacosx-version-min=$(VBOX_DEF_MACOSX_VERSION_MIN) -isysroot "$(VBOX_PATH_MACOSX_SDK)" + VBOX_DARWIN_DEF_SDK_OBJCFLAGS := -mmacosx-version-min=$(VBOX_DEF_MACOSX_VERSION_MIN) -isysroot "$(VBOX_PATH_MACOSX_SDK)" + VBOX_DARWIN_DEF_SDK_OBJCXXFLAGS := -mmacosx-version-min=$(VBOX_DEF_MACOSX_VERSION_MIN) -isysroot "$(VBOX_PATH_MACOSX_SDK)" + VBOX_DARWIN_DEF_SDK_LDFLAGS = -mmacosx-version-min=$(VBOX_DEF_MACOSX_VERSION_MIN) -Wl,-syslibroot,"$(VBOX_PATH_MACOSX_SDK)" \ + $(VBOX_DARWIN_CLASSIC_LINKER) $(VBOX_DARWIN_NO_COMPACT_LINKEDIT) + endif + + # specific versions - only used by xpcom18a4 (python) and 10.7 by UsbWebcam. + ## @todo s/VBOX_DARWIN_DEF_SDK_10/VBOX_DARWIN_SDK_10/g + + if1of ($(VBOX_DEF_MACOSX_VERSION_MIN), 10.4) # classic linker detection is bust otherwise + VBOX_PATH_MACOSX_SDK_10_4 ?= $(VBOX_PATH_MACOSX_SDK_ROOT)/MacOSX10.4u.sdk + VBOX_DARWIN_DEF_SDK_10_4_DEFS := MAC_OS_X_VERSION_MIN_REQUIRED=1040 MAC_OS_X_VERSION_MAX_ALLOWED=1040 + VBOX_DARWIN_DEF_SDK_10_4_CFLAGS := -mmacosx-version-min=10.4 -isysroot "$(VBOX_PATH_MACOSX_SDK_10_4)" + VBOX_DARWIN_DEF_SDK_10_4_CXXFLAGS := -mmacosx-version-min=10.4 -isysroot "$(VBOX_PATH_MACOSX_SDK_10_4)" + VBOX_DARWIN_DEF_SDK_10_4_OBJCFLAGS := -mmacosx-version-min=10.4 -isysroot "$(VBOX_PATH_MACOSX_SDK_10_4)" + VBOX_DARWIN_DEF_SDK_10_4_OBJCXXFLAGS := -mmacosx-version-min=10.4 -isysroot "$(VBOX_PATH_MACOSX_SDK_10_4)" + VBOX_DARWIN_DEF_SDK_10_4_LDFLAGS := -mmacosx-version-min=10.4 -Wl,-syslibroot,"$(VBOX_PATH_MACOSX_SDK_10_4)" $(VBOX_DARWIN_CLASSIC_LINKER) + else + VBOX_PATH_MACOSX_SDK_10_4 = $(error VBox: $(if $(target),$(target): ,)Using 10.4 SDK) + VBOX_DARWIN_DEF_SDK_10_4_CXXFLAGS = $(error VBox: $(if $(target),$(target): ,)Using 10.4 SDK) + VBOX_DARWIN_DEF_SDK_10_4_LDFLAGS = $(error VBox: $(if $(target),$(target): ,)Using 10.4 SDK) + endif + + if1of ($(VBOX_DEF_MACOSX_VERSION_MIN), 10.4 10.5) + VBOX_PATH_MACOSX_SDK_10_5 ?= $(VBOX_PATH_MACOSX_SDK_ROOT)/MacOSX10.5.sdk + VBOX_DARWIN_DEF_SDK_10_5_DEFS := MAC_OS_X_VERSION_MIN_REQUIRED=1050 MAC_OS_X_VERSION_MAX_ALLOWED=1050 + VBOX_DARWIN_DEF_SDK_10_5_CFLAGS := -mmacosx-version-min=10.5 -isysroot "$(VBOX_PATH_MACOSX_SDK_10_5)" + VBOX_DARWIN_DEF_SDK_10_5_CXXFLAGS := -mmacosx-version-min=10.5 -isysroot "$(VBOX_PATH_MACOSX_SDK_10_5)" + VBOX_DARWIN_DEF_SDK_10_5_OBJCFLAGS := -mmacosx-version-min=10.5 -isysroot "$(VBOX_PATH_MACOSX_SDK_10_5)" + VBOX_DARWIN_DEF_SDK_10_5_OBJCXXFLAGS := -mmacosx-version-min=10.5 -isysroot "$(VBOX_PATH_MACOSX_SDK_10_5)" + VBOX_DARWIN_DEF_SDK_10_5_LDFLAGS := -mmacosx-version-min=10.5 -Wl,-syslibroot,"$(VBOX_PATH_MACOSX_SDK_10_5)" $(VBOX_DARWIN_NO_COMPACT_LINKEDIT) + else + VBOX_PATH_MACOSX_SDK_10_5 = $(error VBox: $(if $(target),$(target): ,)Using 10.5 SDK) + VBOX_DARWIN_DEF_SDK_10_5_CXXFLAGS = $(error VBox: $(if $(target),$(target): ,)Using 10.5 SDK) + VBOX_DARWIN_DEF_SDK_10_5_LDFLAGS = $(error VBox: $(if $(target),$(target): ,)Using 10.5 SDK) + endif + + if1of ($(VBOX_DEF_MACOSX_VERSION_MIN), 10.4 10.5 10.6) + VBOX_PATH_MACOSX_SDK_10_6 ?= $(VBOX_PATH_MACOSX_SDK_ROOT)/MacOSX10.6.sdk + VBOX_DARWIN_DEF_SDK_10_6_DEFS := MAC_OS_X_VERSION_MIN_REQUIRED=1060 MAC_OS_X_VERSION_MAX_ALLOWED=1060 + VBOX_DARWIN_DEF_SDK_10_6_CFLAGS := -mmacosx-version-min=10.6 -isysroot "$(VBOX_PATH_MACOSX_SDK_10_6)" + VBOX_DARWIN_DEF_SDK_10_6_CXXFLAGS := -mmacosx-version-min=10.6 -isysroot "$(VBOX_PATH_MACOSX_SDK_10_6)" + VBOX_DARWIN_DEF_SDK_10_6_OBJCFLAGS := -mmacosx-version-min=10.6 -isysroot "$(VBOX_PATH_MACOSX_SDK_10_6)" + VBOX_DARWIN_DEF_SDK_10_6_OBJCXXFLAGS := -mmacosx-version-min=10.6 -isysroot "$(VBOX_PATH_MACOSX_SDK_10_6)" + VBOX_DARWIN_DEF_SDK_10_6_LDFLAGS := -mmacosx-version-min=10.6 -Wl,-syslibroot,"$(VBOX_PATH_MACOSX_SDK_10_6)" + else + VBOX_PATH_MACOSX_SDK_10_6 = $(error VBox: $(if $(target),$(target): ,)Using 10.6 SDK) + VBOX_DARWIN_DEF_SDK_10_6_CXXFLAGS = $(error VBox: $(if $(target),$(target): ,)Using 10.6 SDK) + VBOX_DARWIN_DEF_SDK_10_6_LDFLAGS = $(error VBox: $(if $(target),$(target): ,)Using 10.6 SDK) + endif + + if1of ($(VBOX_DEF_MACOSX_VERSION_MIN), 10.4 10.5 10.6 10.7) + ifndef VBOX_PATH_MACOSX_SDK_10_7 + ifneq ($(wildcard $(VBOX_PATH_MACOSX_SDK_ROOT)/MacOSX10.7.sdk),) + VBOX_PATH_MACOSX_SDK_10_7 = $(VBOX_PATH_MACOSX_SDK_ROOT)/MacOSX10.7.sdk + else + VBOX_PATH_MACOSX_SDK_10_7 = $(KBUILD_DEVTOOLS)/darwin.x86/SDKs/MacOSX10.7.sdk + endif + endif + VBOX_DARWIN_DEF_SDK_10_7_DEFS := MAC_OS_X_VERSION_MIN_REQUIRED=1070 MAC_OS_X_VERSION_MAX_ALLOWED=1070 + VBOX_DARWIN_DEF_SDK_10_7_CFLAGS := -mmacosx-version-min=10.7 -isysroot "$(VBOX_PATH_MACOSX_SDK_10_7)" + VBOX_DARWIN_DEF_SDK_10_7_CXXFLAGS := -mmacosx-version-min=10.7 -isysroot "$(VBOX_PATH_MACOSX_SDK_10_7)" + VBOX_DARWIN_DEF_SDK_10_7_OBJCFLAGS := -mmacosx-version-min=10.7 -isysroot "$(VBOX_PATH_MACOSX_SDK_10_7)" + VBOX_DARWIN_DEF_SDK_10_7_OBJCXXFLAGS := -mmacosx-version-min=10.7 -isysroot "$(VBOX_PATH_MACOSX_SDK_10_7)" + VBOX_DARWIN_DEF_SDK_10_7_LDFLAGS := -mmacosx-version-min=10.7 -Wl,-syslibroot,"$(VBOX_PATH_MACOSX_SDK_10_7)" + else + VBOX_PATH_MACOSX_SDK_10_7 = $(error VBox: $(if $(target),$(target): ,)Using 10.7 SDK) + VBOX_DARWIN_DEF_SDK_10_7_CXXFLAGS = $(error VBox: $(if $(target),$(target): ,)Using 10.7 SDK) + VBOX_DARWIN_DEF_SDK_10_7_LDFLAGS = $(error VBox: $(if $(target),$(target): ,)Using 10.7 SDK) + endif + + # + # Use bison and flex from Xcode to avoid linking issues (bison). + # + TOOL_BISON_YACC ?= $(TOOL_$(VBOX_GCC_TOOL)_ENV_SETUP) $(PATH_TOOL_$(VBOX_GCC_TOOL)_TOOLCHAIN_BIN_SLASH)bison + TOOL_FLEX_LEX ?= $(TOOL_$(VBOX_GCC_TOOL)_ENV_SETUP) $(PATH_TOOL_$(VBOX_GCC_TOOL)_TOOLCHAIN_BIN_SLASH)flex + + # + # Disable VMNet if the SDK is too old. + # + if defined(VBOX_WITH_VMNET) && "$(VBOX_DEF_MACOSX_VERSION_MIN)" vlt "10.15" + VBOX_WITH_VMNET := + endif + +endif # target=darwin + +# +# Macro switching between @executable_path, @rpath and /Applications/VirtualBox.app +# depending on whether the build is hardened or not (dylib install_name). +# +ifeq ($(KBUILD_TARGET),darwin) + ifndef VBOX_DYLD_EXECUTABLE_PATH + ifdef VBOX_WITH_HARDENING + VBOX_DYLD_EXECUTABLE_PATH = $(VBOX_PATH_APP_PRIVATE_ARCH) + else if 0 + VBOX_DYLD_EXECUTABLE_PATH = @executable_path + else + VBOX_DYLD_EXECUTABLE_PATH = @rpath + VBOX_WITH_RELATIVE_RUNPATH = @loader_path/ + endif + endif +endif + +# +# Check for incompatible rpath combinations. +# +if defined(VBOX_WITH_RUNPATH) && defined(VBOX_WITH_ORIGIN) + $(error VBox: VBOX_WITH_RUNPATH and VBOX_WITH_ORIGIN are mutually exclusive) +endif +if defined(VBOX_WITH_RELATIVE_RUNPATH) && defined(VBOX_WITH_ORIGIN) + $(error VBox: VBOX_WITH_RELATIVE_RUNPATH and VBOX_WITH_ORIGIN are mutually exclusive) +endif +if defined(VBOX_WITH_RUNPATH) && defined(VBOX_WITH_RELATIVE_RUNPATH) + $(error VBox: VBOX_WITH_RUNPATH and VBOX_WITH_RELATIVE_RUNPATH are mutually exclusive) +endif +if defined(VBOX_WITH_RELATIVE_RUNPATH) && defined(VBOX_WITH_HARDENING) + $(error VBox: VBOX_WITH_RELATIVE_RUNPATH and VBOX_WITH_HARDENING are mutually exclusive) +endif + +# +# VBOX_WITH_ORIGIN translates into VBOX_WITH_RELATIVE_RUNPATH. +# +# We use two helper variables for the VBOX_WITH_ORIGIN stuff: +# VBOX_ORIGIN - Indirect expansion trick. +# VBOX_GCC_RPATH_OPT - Different GCC/LD combinations needs different options. +# +VBOX_ORIGIN = $$ORIGIN +ifeq ($(KBUILD_TARGET),solaris) + VBOX_GCC_RPATH_OPT = -R +else + VBOX_GCC_RPATH_OPT = -Wl,-rpath, + VBOX_GCC_ORIGIN_OPT = -Wl,-z,origin +endif +ifdef VBOX_WITH_ORIGIN + VBOX_WITH_RELATIVE_RUNPATH = $$(VBOX_ORIGIN) +endif + + +# +# Configure 'asan' type builds. +# +# We ASSUME that anyone doing this kind of build on linux has a compiler +# with sanitizer support (otherwise we'd end up with a circular dependency +# with DynamicConfig.kmk here to check the compiler version). +# +ifeq ($(KBUILD_TYPE),asan) + if "$(KBUILD_TARGET)" == "linux" + VBOX_WITH_GCC_SANITIZER := 1 + else if "$(KBUILD_TARGET)" == "darwin" + VBOX_WITH_GCC_SANITIZER := 1 + else if "$(KBUILD_TARGET)" == "win" + VBOX_WITH_VCC_SANITIZER := 1 + else + VBOX_WITH_EF_WRAPS := 1 + endif +endif + +# +# The address sanitiser library intercepts dlopen() and breaks RPATH $ORIGIN, +# so we need to link it statically or set LD_LIBRARY_PATH. To link statically, +# set VBOX_WITH_GCC_SANITIZER_STATIC in addition. +# +ifdef VBOX_WITH_GCC_SANITIZER + VBOX_GCC_SANITIZER_FLAGS := \ + -fsanitize=undefined \ + -fsanitize=address \ + -fsanitize=return \ + -fsanitize=bounds \ + -fsanitize=object-size \ + -fno-sanitize=alignment \ + -fno-sanitize=vptr \ + -fno-common \ + -DIPRT_WITH_GCC_SANITIZER \ + -DVBOX_WITH_GCC_SANITIZER +else ifdef VBOX_WITH_CLANG_SANITIZER ## @todo make work... + VBOX_GCC_SANITIZER_FLAGS := \ + -DIPRT_WITH_GCC_SANITIZER \ + -DVBOX_WITH_GCC_SANITIZER \ + -fsanitize=object-size \ + -fsanitize-undefined-trap-on-error +else + VBOX_GCC_SANITIZER_FLAGS = +endif + +# -libasan-static is currently not supported in combination with -no-undefined. +VBOX_GCC_NO_UNDEFINED := +VBOX_GCC_NO_UNDEFINED_R0 := +ifdef VBOX_WITH_GCC_SANITIZER + ifdef VBOX_WITH_GCC_SANITIZER_STATIC + VBOX_GCC_NO_UNDEFINED := -Wl,--no-undefined + VBOX_GCC_NO_UNDEFINED_R0 := -no-undefined + VBOX_GCC_SANITIZER_LDFLAGS += -static-libasan + else + if "$(KBUILD_TARGET)" == "darwin" + VBOX_GCC_SANITIZER_LDFLAGS += -fsanitize=address + else + VBOX_GCC_SANITIZER_LDFLAGS += -lasan + endif + endif +endif + +# The config for Visual C++ 2019 update 9 and later. +ifdef VBOX_WITH_VCC_SANITIZER + VBOX_VCC_SANITIZER_FLAGS := -fsanitize=address -fno-sanitize-address-vcasan-lib + # experimental: VBOX_VCC_SANITIZER_FLAGS += /fsanitize-address-use-after-return + VBOX_VCC_SANITIZER_LDFLAGS := +else + VBOX_VCC_SANITIZER_FLAGS := + VBOX_VCC_SANITIZER_LDFLAGS := +endif + + +# +# The X11 headers. +# +VBOX_PATH_X11_ROOT = $(PATH_ROOT)/src/VBox/Additions/x11/x11include + + +# +# Miscellaneous includes +# +VBOX_GRAPHICS_INCS = $(PATH_ROOT)/include/VBox/Graphics +VBOX_JPEG_INCS = $(PATH_ROOT)/src/libs/libjpeg-turbo-2.1.3 + + +# The icons to use. +ifdef VBOX_OSE + VBOX_WINDOWS_ICON_FILE ?= $(PATH_ROOT)/src/VBox/Artwork/win/OSE/VirtualBox_win.ico + VBOX_WINDOWS_ADDITIONS_ICON_FILE ?= $(PATH_ROOT)/src/VBox/Artwork/win/OSE/VirtualBox_win.ico + VBOX_NSIS_ICON_FILE ?= $(PATH_ROOT)/src/VBox/Artwork/win/OSE/VirtualBox_win.ico + VBOX_MACOSX_ICON_FILE ?= $(PATH_ROOT)/src/VBox/Artwork/darwin/OSE/VirtualBox.icns +else + ifeq ($(KBUILD_HOST),win) + VBOX_WINDOWS_ICON_FILE ?= $(PATH_ROOT)/src/VBox/Artwork/win/NonOSE/VirtualBox-vista.ico + VBOX_WINDOWS_ADDITIONS_ICON_FILE ?= $(PATH_ROOT)/src/VBox/Artwork/win/NonOSE/VirtualBoxGA-vista.ico + VBOX_NSIS_ICON_FILE ?= $(PATH_ROOT)/src/VBox/Artwork/win/NonOSE/VirtualBoxGA-nsis.ico + TOOL_VCC80X86_RC := $(KBUILD_DEVTOOLS)/win.x86/ddk/6000/bin/x86/rc.exe + TOOL_VCC80AMD64_RC := $(KBUILD_DEVTOOLS)/win.x86/ddk/6000/bin/x86/rc.exe + TOOL_VCC70_RC := $(KBUILD_DEVTOOLS)/win.x86/ddk/6000/bin/x86/rc.exe + else + VBOX_WINDOWS_ICON_FILE ?= $(PATH_ROOT)/src/VBox/Artwork/win/NonOSE/VirtualBox-winxp.ico + VBOX_WINDOWS_ADDITIONS_ICON_FILE ?= $(PATH_ROOT)/src/VBox/Artwork/win/NonOSE/VirtualBoxGA-winxp.ico + VBOX_NSIS_ICON_FILE ?= $(PATH_ROOT)/src/VBox/Artwork/win/NonOSE/VirtualBox-nsis.ico + endif + VBOX_MACOSX_ICON_FILE ?= $(PATH_ROOT)/src/VBox/Artwork/darwin/NonOSE/VirtualBox.icns +endif + + +ifndef VBOX_NOINC_DYNAMIC_CONFIG_KMK + # + # GCC and YASM dynamic properties. + # Most of this is resolved on first kmk invocation and cached in PATH_OUT. + # + # Note! That a harmless warning is printed if the file doesn't exist. + # Note! Changes in GCC are not detected automatically (yet). + # + if $(pos VBox,$(VBOX_GCC_TOOL)) > 0 + include $(KBUILD_TOOL_PATHS)/$(VBOX_GCC_TOOL).kmk + else + include $(KBUILD_PATH)/tools/$(VBOX_GCC_TOOL).kmk + endif + ifneq ($(VBOX_GCC_TOOL),$(VBOX_GCC32_TOOL)) + if $(pos VBox,$(VBOX_GCC32_TOOL)) > 0 + include $(KBUILD_TOOL_PATHS)/$(VBOX_GCC32_TOOL).kmk + else + include $(KBUILD_PATH)/tools/$(VBOX_GCC32_TOOL).kmk + endif + endif + + # These tests never worked on Windows because of /dev/null, so, there + # can be no harm in just dropping them until cygwin is mp safe. + ifeq ($(KBUILD_HOST),win) + VBOX_GCC_CHECK_EX_CC = $(3) + VBOX_GCC_CHECK_EX_CXX = $(3) + VBOX_GCC_CHECK_EX_LD = $(3) + VBOX_GCC_CHECK_CC = $(2) + VBOX_GCC_CHECK_CXX = $(2) + VBOX_GCC_CHECK_LD = $(2) + VBOX_GCC32_CHECK_CXX = $(2) + else + # Note! The chcking for 'error: unknown warning option' is for clang on darwin not giving us a + # non-zero exit code when using an invalid option here, but it does later on. + ifndef CLOSEPAR + CLOSEPAR := ) + endif + VBOX_GCC_CHECK_EX_CC_CXX = $(shell \ + if $(1) $(subst -Wno-,-W,$(2)) -Werror -c -o /dev/null $(4) > /dev/null 2>&1; then \ + case "`LC_ALL=C $(1) $(subst -Wno-,-W,$(2)) -Werror -c -o /dev/null $(4) 2>&1`" in \ + "error: unknown warning option"*$(CLOSEPAR) echo "$(3)";; \ + *$(CLOSEPAR) echo "$(2)";; \ + esac; \ + else echo "$(3)"; fi; ) + VBOX_GCC_CHECK_EX_CC = $(call VBOX_GCC_CHECK_EX_CC_CXX,$(1),$(2),$(3),-xc $(PATH_OUT)/DynamicConfig.c) + VBOX_GCC_CHECK_EX_CXX = $(call VBOX_GCC_CHECK_EX_CC_CXX,$(1),$(2),$(3),-xc++ $(PATH_OUT)/DynamicConfig.cpp) + VBOX_GCC_CHECK_EX_LD = $(shell \ + if $(1) -Wl,$(2) $(if $(eq $(KBUILD_HOST),darwin),-Wl$(COMMA)-u$(COMMA)start -Wl$(COMMA)-undefined$(COMMA)dynamic_lookup,) \ + -nostdlib -o /dev/null -xc /dev/null > /dev/null 2>&1; \ + then echo "-Wl,$(2)"; else echo "$(3)"; fi; ) + + VBOX_GCC_CHECK_CC = $(call VBOX_GCC_CHECK_EX_CC, $(TOOL_$(VBOX_GCC_TOOL)_ENV_SETUP) $(TOOL_$(VBOX_GCC_TOOL)_CC),$1,$2) + VBOX_GCC_CHECK_CXX = $(call VBOX_GCC_CHECK_EX_CXX, $(TOOL_$(VBOX_GCC_TOOL)_ENV_SETUP) $(TOOL_$(VBOX_GCC_TOOL)_CXX),$1,$2) + VBOX_GCC_CHECK_LD = $(call VBOX_GCC_CHECK_EX_LD, $(TOOL_$(VBOX_GCC_TOOL)_ENV_SETUP) $(TOOL_$(VBOX_GCC_TOOL)_LD),$1,$2) + VBOX_GCC32_CHECK_CXX = $(call VBOX_GCC_CHECK_EX_CXX, $(TOOL_$(VBOX_GCC32_TOOL)_ENV_SETUP) $(TOOL_$(VBOX_GCC32_TOOL)_CXX),$1,$2) + endif + + ifeq ($(KBUILD_HOST),win) + # We're not using gcc on windows anymore, just cook the result. + VBOX_GCC_VERSION := $(expr 10000 * 3 + 100 * 3 + 3) + else + # This is kind of bad, the returned string needs to be re-evaluated before use. + # The reason for this hack is that the windows kmk_ash cannot deal with $((1+1)). + # Some versions of gcc (e.g. openSUSE11) return only major.minor on `gcc -dumpversion`. + # gcc-5 of openSUSE42.1 only returns the major version on `gcc -dumpversion`! + VBOX_GCC_VERSION = $(shell ($(1) -dumpfullversion 2>/dev/null || $(1) -dumpversion) | \ + $(SED_EXT) 's|\([0-9][0-9]*\)\.\{0,1\}\([0-9]\{0,\}\)\.\{0,1\}\([0-9]\{0,\}\).*|$$(expr 10000 * \1 + 100 * $$(firstword \2 0) + $$(firstword \3 0))|' ) + ifeq ($(KBUILD_TARGET),darwin) + VBOX_CLANG_VERSION = $(shell $(1) --version | \ + $(SED_EXT) -n 's|.*version \([0-9][0-9]*\)\.\{0,1\}\([0-9]\{0,\}\)\.\{0,1\}\([0-9]\{0,\}\).*|$$(expr 10000 * \1 + 100 * $$(firstword \2 0) + $$(firstword \3 0))|p' ) + endif + endif + + # YASM macros + ifndef DONT_USE_YASM + include $(KBUILD_PATH)/tools/YASM.kmk + if1of ($(KBUILD_HOST), win os2) + VBOX_YASM_CHECK = $(if-expr "$(shell $(TOOL_YASM_AS) -e -o nul $1 - < /dev/null 2>&1)" == "",$(1),) + else + VBOX_YASM_CHECK = $(if-expr "$(shell $(TOOL_YASM_AS) -e -o /dev/null $1 - < /dev/null 2>&1)" == "",$(1),) + endif + else + VBOX_YASM_CHECK = + endif + + # NASM macros (input and output must differ with recent versions (strcmp)). + ifndef DONT_USE_NASM + include $(KBUILD_PATH)/tools/NASM.kmk + if1of ($(KBUILD_HOST), win os2) + VBOX_NASM_CHECK = $(if-expr "$(shell $(TOOL_NASM_AS) -e -o nul $1 NUL 2>&1)" == "",$(1),$(2)) + else + VBOX_NASM_CHECK = $(if-expr "$(shell $(TOOL_NASM_AS) -e -o /dev/./null $1 /dev/null 2>&1)" == "",$(1),$(2)) + endif + else + VBOX_NASM_CHECK = + endif + + # Figures the pylint version. + VBOX_PYLINT_FIGURE_VERSION = $(shell $(1) --version 2> /dev/null \ + | $(SED_EXT) -n -e 's/pylint-[^[:blank:]]*/pylint/' \ + -e 's|^ *pylint *\([0-9][0-9]*\).\([0-9][0-9]*\)\.\([0-9][0-9]*\).*$(DOLLAR)|$$(expr \1 * 10000 + \2 * 100 + \3)|p' ) + + # Java stuff. + ifeq ($(KBUILD_TARGET),darwin) + VBOX_JAVA_BIN_PATH = $(firstword $(wildcard \ + /System/Library/Java/JavaVirtualMachines/1.6.0.jdk/Contents/Commands \ + /System/Library/Frameworks/JavaVM.framework/Versions/1.6.0/Commands \ + $(if-expr $(VBOX_XCODE_VERSION_MAJOR) >= 4,/System/Library/Frameworks/JavaVM.framework/Versions/A/Commands,) \ + $(if-expr $(VBOX_XCODE_VERSION_MAJOR) >= 10,/Library/Java/JavaVirtualMachines/jdk1.8.*.jdk/Contents/Home/bin,) \ + ) /usr/bin) + VBOX_JAVA = $(VBOX_JAVA_BIN_PATH)/java + VBOX_JAVAC = $(VBOX_JAVA_BIN_PATH)/javac + VBOX_JAVAH = $(VBOX_JAVA_BIN_PATH)/javah + VBOX_JAR = $(VBOX_JAVA_BIN_PATH)/jar + VBOX_JAVADOC = $(VBOX_JAVA_BIN_PATH)/javadoc + VBOX_WSIMPORT = $(VBOX_JAVA_BIN_PATH)/wsimport + if $(VBOX_XCODE_VERSION_MAJOR) >= 4 # Lion (4.1-preview 5) has a broken CurrentJDK link. Blindly applying it to 4.0. + VBOX_JAVA_INC = $(firstword $(wildcard \ + $(VBOX_PATH_MACOSX_SDK)/System/Library/Frameworks/JavaVM.framework/Versions/A/Headers \ + /Library/Java/JavaVirtualMachines/jdk1.8.*.jdk/Contents/Home/include \ + ) ) + else + VBOX_JAVA_INC = $(VBOX_PATH_MACOSX_SDK)/System/Library/Frameworks/JavaVM.framework/Versions/1.6/Headers + endif + + else # !darwin + + ifeq ($(KBUILD_TARGET),linux) + ifeq ($(origin VBOX_JAVA_HOME),undefined) + # Add correct detection for you distro after the /usr/../java-6-sun line. + VBOX_JAVA_HOME := $(firstword $(wildcard \ + $(KBUILD_DEVTOOLS)/linux.x86/jdk1.6.0_27 \ + /usr/lib/jvm/java-6-sun \ + /usr/lib/jvm/java-6-openjdk \ + /usr/lib/jvm/java-6-openjdk-i386 \ + /usr/lib/jvm/java-6-openjdk-amd64 \ + /usr/lib/jvm/java-7-openjdk-i386 \ + /usr/lib/jvm/java-7-openjdk-amd64 \ + /usr/lib/jvm/default-java \ + /usr/lib/jvm/java \ + \ + /usr/lib/jvm/sun-jdk-1.6 \ + ) /usr/lib/jvm/java-6-sun) + endif + endif + + ifeq ($(KBUILD_TARGET),solaris) + # VBOX_JAVA_HOME ?= /usr/jdk/jdk1.6.0 + VBOX_JAVA_HOME ?= $(firstword $(abspath $(wildcard \ + /usr/jdk/latest/include/.. \ + /usr/jdk/instances/jdk1.8*/include/.. \ + /usr/jdk/instances/jdk1.7*/include/.. \ + /usr/jdk/instances/jdk1.6*/include/.. \ + )) /usr/java) + endif + + ifeq ($(KBUILD_TARGET),win) + VBOX_JAVA_HOME ?= c:/jdk + endif + + VBOX_JAVA_BIN_PATH ?= $(VBOX_JAVA_HOME)/bin + VBOX_JAVA ?= "$(VBOX_JAVA_BIN_PATH)/java$(HOSTSUFF_EXE)" + VBOX_JAVAC = "$(VBOX_JAVA_BIN_PATH)/javac$(HOSTSUFF_EXE)" + VBOX_JAVAH = "$(VBOX_JAVA_BIN_PATH)/javah$(HOSTSUFF_EXE)" + VBOX_JAR = "$(VBOX_JAVA_BIN_PATH)/jar$(HOSTSUFF_EXE)" + VBOX_JAVADOC = "$(VBOX_JAVA_BIN_PATH)/javadoc$(HOSTSUFF_EXE)" + # With Java 11 wsimport was removed, usually part of a separate install now. + VBOX_WSIMPORT = $(firstword $(wildcard $(VBOX_JAVA_BIN_PATH)/wsimport$(HOSTSUFF_EXE)) wsimport$(HOSTSUFF_EXE)) + # correct for targets we care about + VBOX_MD_OS = $(KBUILD_TARGET) + VBOX_JAVA_INC = \ + $(VBOX_JAVA_HOME)/include \ + $(VBOX_JAVA_HOME)/include/$(VBOX_MD_OS) + endif # !darwin + # The first transform the almost usless openjdk versions like "javac 9-Ubuntu" into something the 2nd expression groks. + VBOX_JAVA_FIGURE_VERSION = $(shell $(1) -version 2>&1 \ + | $(SED_EXT) -n \ + -e 's/ \([0-9][0-9]*\)\(-[[:alpha:]][[:alpha:]]\)/ \1.0.0\2/' \ + -e 's|^[^ ]* *\([0-9][0-9]*\)\.\([0-9][0-9]*\)\.\([0-9][0-9]*\).*$(DOLLAR)|$$(expr \1 * 10000 + \2 * 100 + \3)|p' ) + + # Test C and C++ files. + $(PATH_OUT)/DynamicConfig.c $(PATH_OUT)/DynamicConfig.cpp: + $(QUIET)$(MKDIR) -p $(@D) + $(QUIET)$(APPEND) -tn "$@" "int foobar(void)" "{" " return 42;" "}" "" + + # No $(QUIET) here as it's interesting to see what goes into the file. + $(PATH_OUT)/DynamicConfig.kmk: \ + $(PATH_ROOT)/Config.kmk \ + $(LOCALCFG) \ + $(AUTOCFG) \ + $(VBOX_GCC_PATH_CC) \ + $(VBOX_GCC_PATH_CXX) \ + $(VBOX_GCC_LIBGCC) \ + $(VBOX_GCC32_PATH_CC) \ + $(VBOX_GCC32_PATH_CXX) \ + $(VBOX_GCC32_LIBGCC) \ + $(if-expr "$(KBUILD_HOST).$(KBUILD_HOST_ARCH)" == "solaris.amd64" && $(KBUILD_HOST_VERSION_MINOR) >= 11 \ + , /platform/i86pc/kernel/$(KBUILD_HOST_ARCH)/unix,) \ + | $(PATH_OUT)/DynamicConfig.c $(PATH_OUT)/DynamicConfig.cpp + $(call MSG_GENERATE,,$@,) + $(QUIET)$(RM) -f '$@' + $(QUIET)$(MKDIR) -p $(@D) + $(QUIET)$(APPEND) '$@' '# Host version: $(KBUILD_HOST_VERSION_MAJOR).$(KBUILD_HOST_VERSION_MINOR).$(KBUILD_HOST_VERSION_PATCH); full: $(KBUILD_HOST_VERSION)' + ifneq ($(KBUILD_TARGET),win) + $(QUIET)$(APPEND) '$@' '# $(KBUILD_HOST_UNAME_SYSNAME) - $(KBUILD_HOST_UNAME_RELEASE) - $(KBUILD_HOST_UNAME_VERSION)' + endif + ifeq ($(KBUILD_TARGET),darwin) + $(QUIET)$(APPEND) '$@' '# VBOX_XCODE_VERSION: $(VBOX_XCODE_VERSION)' + $(QUIET)$(APPEND) '$@' '# VBOX_PATH_MACOSX_TOOLCHAIN_ROOT: $(VBOX_PATH_MACOSX_TOOLCHAIN_ROOT)' + $(QUIET)$(APPEND) '$@' '# VBOX_PATH_MACOSX_SDK_ROOT: $(VBOX_PATH_MACOSX_SDK_ROOT)' + $(QUIET)$(APPEND) '$@' '# VBOX_PATH_MACOSX_DEVEL_ROOT: $(VBOX_PATH_MACOSX_DEVEL_ROOT)' + $(QUIET)$(APPEND) '$@' 'VBOX_CLANG_VERSION_CC ?= $(call VBOX_CLANG_VERSION,$(TOOL_$(VBOX_GCC_TOOL)_CC))' + $(QUIET)$(APPEND) '$@' 'VBOX_CLANG_VERSION_CXX ?= $(call VBOX_CLANG_VERSION,$(TOOL_$(VBOX_GCC_TOOL)_CXX))' + endif + # HC compiler switch detection. + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_VERSION_CC ?= $(call VBOX_GCC_VERSION,$(TOOL_$(VBOX_GCC_TOOL)_CC))' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_VERSION_CXX ?= $(call VBOX_GCC_VERSION,$(TOOL_$(VBOX_GCC_TOOL)_CXX))' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_PATH_CC ?= $(which $(TOOL_$(VBOX_GCC_TOOL)_CC))' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_PATH_CXX ?= $(which $(TOOL_$(VBOX_GCC_TOOL)_CXX))' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_LIBGCC ?= $(shell $(TOOL_$(VBOX_GCC_TOOL)_CC) -print-libgcc-file-name)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-pointer-sign ?= $(call VBOX_GCC_CHECK_CC,-Wno-pointer-sign,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-array_bounds ?= $(call VBOX_GCC_CHECK_CC,-Wno-array-bounds,)' + # -Wextra produces additional useful warnings but includes -Wno-missing-field-initializers (too noisy) + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wextra ?= $(call VBOX_GCC_CHECK_CC,-Wextra,)' + $(QUIET)$(APPEND) '$@' 'ifneq ($$(VBOX_GCC_VERSION_CC),)' + $(QUIET)$(APPEND) '$@' ' if $$(VBOX_GCC_VERSION_CC) >= 40500' + $(QUIET)$(APPEND) '$@' ' VBOX_GCC_Wlogical-op ?= $(call VBOX_GCC_CHECK_CC,-Wlogical-op,)' + $(QUIET)$(APPEND) '$@' ' VBOX_GCC_Wno-logical-op ?= $$(subst -Wlogical-op,-Wno-logical-op,$$(VBOX_GCC_Wlogical-op)) + $(QUIET)$(APPEND) '$@' ' endif' + $(QUIET)$(APPEND) '$@' 'endif' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-address ?= $(call VBOX_GCC_CHECK_CXX,-Wno-address,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-delete-non-virtual-dtor ?= $(call VBOX_GCC_CHECK_CXX,-Wno-delete-non-virtual-dtor,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-non-virtual-dtor ?= $(call VBOX_GCC_CHECK_CXX,-Wno-non-virtual-dtor,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-int-in-bool-context ?= $(call VBOX_GCC_CHECK_CC,-Wno-int-in-bool-context,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-int-to-pointer-cast ?= $(call VBOX_GCC_CHECK_CC,-Wno-int-to-pointer-cast,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-invalid-offsetof ?= $(call VBOX_GCC_CHECK_CXX,-Wno-invalid-offsetof,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-literal-suffix ?= $(call VBOX_GCC_CHECK_CXX,-Wno-literal-suffix,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-misleading-indentation ?= $(call VBOX_GCC_CHECK_CC,-Wno-misleading-indentation,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-missing-field-initializers ?= $(call VBOX_GCC_CHECK_CC,-Wno-missing-field-initializers,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-pointer-to-int-cast ?= $(call VBOX_GCC_CHECK_CC,-Wno-pointer-to-int-cast,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-variadic-macros ?= $(call VBOX_GCC_CHECK_CXX,-Wno-variadic-macros,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-vla ?= $(call VBOX_GCC_CHECK_CXX,-Wno-vla,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-overlength-strings ?= $(call VBOX_GCC_CHECK_CC,-Wno-overlength-strings,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-overloaded-virtual ?= $(call VBOX_GCC_CHECK_CXX,-Wno-overloaded-virtual,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-ignored-qualifiers ?= $(call VBOX_GCC_CHECK_CXX,-Wno-ignored-qualifiers,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-multistatement-macros ?= $(call VBOX_GCC_CHECK_CXX,-Wno-multistatement-macros,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-class-memaccess ?= $(call VBOX_GCC_CHECK_CXX,-Wno-class-memaccess,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-stringop-overflow ?= $(call VBOX_GCC_CHECK_CXX,-Wno-stringop-overflow,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-stringop-truncation ?= $(call VBOX_GCC_CHECK_CXX,-Wno-stringop-truncation,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-cast-function-type ?= $(call VBOX_GCC_CHECK_CC,-Wno-cast-function-type,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-deprecated-declarations ?= $(call VBOX_GCC_CHECK_CC,-Wno-deprecated-declarations,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-implicit-fallthrough ?= $(call VBOX_GCC_CHECK_CC,-Wno-implicit-fallthrough,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-inline ?= $(call VBOX_GCC_CHECK_CXX,-Wno-inline,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-unknown-pragmas ?= $(call VBOX_GCC_CHECK_CXX,-Wno-unknown-pragmas,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-deprecated-copy ?= $(call VBOX_GCC_CHECK_CXX,-Wno-deprecated-copy,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_fno-stack-protector ?= $(call VBOX_GCC_CHECK_CC,-fno-stack-protector,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_fno-dwarf2-cfi-asm ?= $(call VBOX_GCC_CHECK_CC,-fno-dwarf2-cfi-asm,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_m64 ?= $(call VBOX_GCC_CHECK_CC,-m64,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_msse4.1 ?= $(call VBOX_GCC_CHECK_CC,-msse4.1,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_mavx ?= $(call VBOX_GCC_CHECK_CC,-mavx,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_mavx2 ?= $(call VBOX_GCC_CHECK_CC,-mavx2,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_no-pie ?= $(call VBOX_GCC_CHECK_CC,-no-pie,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_fdiagnostics-show-option ?= $(call VBOX_GCC_CHECK_CC,-fdiagnostics-show-option,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_fno-printf-return-value ?= $(call VBOX_GCC_CHECK_CC,-fno-printf-return-value,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wa_cma_nocompress_debug_sections ?= $(call VBOX_GCC_CHECK_CC,-Wa$(COMMA)--nocompress-debug-sections,)' + # Produce code optimized for the most common IA32/AMD64/EM64T processors. Introduced with gcc version 4.2. + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_mtune-generic ?= $(call VBOX_GCC_CHECK_CC,-mtune=generic,)' + $(QUIET)$(APPEND) '$@' 'VBOX_LD_as_needed ?= $(call VBOX_GCC_CHECK_LD,--as-needed,)' + $(QUIET)$(APPEND) '$@' 'VBOX_LD_hash_style_sysv ?= $(call VBOX_GCC_CHECK_LD,--hash-style=sysv,)' + $(QUIET)$(APPEND) '$@' 'VBOX_LD_gc_sections ?= $(call VBOX_GCC_CHECK_LD,--gc-sections,)' + # Set default attribute for ELF and MACH-O symbols to ``hidden'' to reduce the number + # of relocation entries and PLT indirections in shared libraries. Don't allow for gcc version < 4. + $(QUIET)$(APPEND) '$@' 'ifneq ($$(VBOX_GCC_VERSION_CC),)' + $(QUIET)$(APPEND) '$@' ' if $$(VBOX_GCC_VERSION_CC) >= 40000' + $(QUIET)$(APPEND) '$@' ' VBOX_GCC_fvisibility-hidden ?= $(call VBOX_GCC_CHECK_CC,-fvisibility=hidden -DVBOX_HAVE_VISIBILITY_HIDDEN -DRT_USE_VISIBILITY_DEFAULT,)' + $(QUIET)$(APPEND) '$@' ' endif' + $(QUIET)$(APPEND) '$@' 'endif' + ifn1of ($(KBUILD_TARGET), haiku) + # Set default attribute for inline functions to ``hidden'' to reduce the number + # of relocation entries and PLT indirections in shared libraries. Don't allow for gcc version < 4. + $(QUIET)$(APPEND) '$@' 'ifneq ($$(VBOX_GCC_VERSION_CXX),)' + $(QUIET)$(APPEND) '$@' ' if $$(VBOX_GCC_VERSION_CXX) >= 40000' + $(QUIET)$(APPEND) '$@' ' VBOX_GCC_fvisibility-inlines-hidden ?= $(call VBOX_GCC_CHECK_CXX,-fvisibility-inlines-hidden,)' + $(QUIET)$(APPEND) '$@' ' endif' + $(QUIET)$(APPEND) '$@' 'endif' + endif + # Prevent warnings about unused parameters as of gcc-4.8 / clang 6 as this warning is now very verbose + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-unused-parameter ?= $(call VBOX_GCC_CHECK_CC,-Wno-unused-parameter,)' + # Clang 6. + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-language-extension-token ?= $(call VBOX_GCC_CHECK_CC,-Wno-language-extension-token,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-extended-offsetof ?= $(call VBOX_GCC_CHECK_CC,-Wno-extended-offsetof,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-gnu-folding-constant ?= $(call VBOX_GCC_CHECK_CC,-Wno-gnu-folding-constant,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-return-type-c-linkage ?= $(call VBOX_GCC_CHECK_CXX,-Wno-return-type-c-linkage,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-string-plus-int ?= $(call VBOX_GCC_CHECK_CC,-Wno-string-plus-int,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-nested-anon-types ?= $(call VBOX_GCC_CHECK_CC,-Wno-nested-anon-types,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-gnu-anonymous-struct ?= $(call VBOX_GCC_CHECK_CXX,-Wno-gnu-anonymous-struct,)' + # Clang 11. + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-c++17-compat-mangling ?= $(call VBOX_GCC_CHECK_CXX,-Wno-c++17-compat-mangling,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-nullability-extension ?= $(call VBOX_GCC_CHECK_CXX,-Wno-nullability-extension,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-gnu-statement-expression ?= $(call VBOX_GCC_CHECK_CXX,-Wno-gnu-statement-expression,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-import-preprocessor-directive-pedantic ?= $(call VBOX_GCC_CHECK_CXX,-Wno-import-preprocessor-directive-pedantic,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-undefined-var-template ?= $(call VBOX_GCC_CHECK_CXX,-Wno-undefined-var-template,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-c11-extensions ?= $(call VBOX_GCC_CHECK_CXX,-Wno-c11-extensions,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_Wno-tautological-pointer-compare ?= $(call VBOX_GCC_CHECK_CC,-Wno-tautological-pointer-compare,)' + ifdef VBOX_WITH_R0_MOD_IBT_BRANCH_PROTECTION + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_fcf-protection_branch ?= $(call VBOX_GCC_CHECK_CXX,-fcf-protection=branch,)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_fcf-protection_check ?= $(call VBOX_GCC_CHECK_CXX,-fcf-protection=check)' + endif + ifeq ($(KBUILD_TARGET),solaris) + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_msave-args ?= $(call VBOX_GCC_CHECK_CXX,-msave-args,)' + # Detect the solaris assembler. It is used by the the 4.x gcc compilers, + # apparently. It will not be able to handle IEMAll via a -pipe, only when + # passed a file. The solaris assmbler rulez ... not! + $(QUIET)$(APPEND) '$@' 'VBOX_AS_VERSION ?= $(shell `gcc -print-prog-name=as` -V -o /dev/null < /dev/null 2>&1 | kmk_sed -e '1!d' -e 's/^as: *//' )' + $(QUIET)$(APPEND) '$@' 'if $$(pos Sun Compiler Common,$$(VBOX_AS_VERSION)) > 0' + $(QUIET)$(APPEND) '$@' ' VBOX_GCC_USING_SOLARIS_AS=1' + $(QUIET)$(APPEND) '$@' 'endif' + $(QUIET)$(APPEND) '$@' 'ifndef VBOX_GCC_USING_SOLARIS_AS' + $(QUIET)$(APPEND) '$@' ' VBOX_GCC_pipe ?= -pipe' + $(QUIET)$(APPEND) '$@' 'endif' + else + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_pipe ?= -pipe' + endif + # Find the compiler includes for IPRT no-crt. + # Note that `$(dir $(gcc -print-libgcc-file-name))/include does not work for a 64-bit cross build on a 32-bit build host. + ifeq ($(KBUILD_HOST),win) + # With the cygwin issues and gcc on windows returning a useless path, just skip this on windows. + $(QUIET)$(APPEND) '$@' 'VBOX_PATH_GCC_INCS ?= ' + else + $(QUIET)$(APPEND) '$@' 'VBOX_PATH_GCC_INCS ?= $(shell LC_ALL=C $(TOOL_$(VBOX_GCC_TOOL)_CC) -print-search-dirs|$(SED_EXT) -ne 's+^install: \(.*[^/][^/]*\)/+\1+p')/include' + endif + # 32-bit (GC) compiler switch detection. + $(QUIET)$(APPEND) '$@' 'VBOX_GCC32_PATH_CC ?= $(which $(TOOL_$(VBOX_GCC32_TOOL)_CC))' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC32_PATH_CXX ?= $(which $(TOOL_$(VBOX_GCC32_TOOL)_CXX))' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC32_VERSION_CC ?= $(call VBOX_GCC_VERSION,$(TOOL_$(VBOX_GCC32_TOOL)_CC))' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC32_VERSION_CXX ?= $(call VBOX_GCC_VERSION,$(TOOL_$(VBOX_GCC32_TOOL)_CXX))' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC32_LIBGCC ?= $(shell $(TOOL_$(VBOX_GCC32_TOOL)_CC) -print-libgcc-file-name)' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC32_Wno-variadic-macros ?= $(call VBOX_GCC32_CHECK_CXX,-Wno-variadic-macros,)' + # darwin no_compact_linkedit starting at Xcode 3.2 + ifeq ($(KBUILD_HOST),darwin) + $(QUIET)$(APPEND) '$@' 'VBOX_LD_no_compact_linkedit ?= $(call VBOX_GCC_CHECK_LD,-no_compact_linkedit,)' + endif + ifn1of ($(KBUILD_TARGET_ARCH), sparc32 sparc64) + # YASM + $(QUIET)$(APPEND) '$@' '# debug: TOOL_YASM_AS="$(TOOL_YASM_AS)"' + $(QUIET)$(APPEND) '$@' 'VBOX_YASM_Wno-segreg-in-64bit ?= $(call VBOX_YASM_CHECK,-Wno-segreg-in-64bit,)' + # NASM (--allow-64-bit: 2.12rc2) + $(QUIET)$(APPEND) '$@' 'VBOX_NASM_allow_64_bit ?= $(call VBOX_NASM_CHECK,--allow-64-bit,)' + endif + if1of ($(KBUILD_TARGET), linux) + ifeq ($(KBUILD_TARGET),$(KBUILD_HOST)) + $(QUIET)$(RM) -f -- "$@.sanitizer.so" "$@.sanitizer32.so" '$@.sanitizer.c' + $(APPEND) -t '$@.sanitizer.c' 'int foo() { return 42; }' + $(QUIET)$(APPEND) '$@' 'VBOX_GCC_SANITIZER_SO_FILES := \' + $(TOOL_$(VBOX_GCC_TOOL)_ENV_SETUP) $(TOOL_$(VBOX_GCC_TOOL)_CC) -fPIC -shared \ + $(VBOX_GCC_SANITIZER_FLAGS) $(VBOX_GCC_SANITIZER_LDFLAGS) -o "$@.sanitizer.so" "$@.sanitizer.c" + ldd "$@.sanitizer.so" | $(SED_EXT) --append '$@' -re '/lib(a|ub)san\.so/!d' -e 's/.* => //' -e 's/ \(0x[0-9a-fA-F]*\) *$(DOLLAR)/ \\/' + $(QUIET)$(APPEND) '$@' '' + # $(QUIET)$(APPEND) '$@' 'VBOX_GCC32_SANITIZER_SO_FILES := \' + # $(TOOL_$(VBOX_GCC32_TOOL)_ENV_SETUP) $(TOOL_$(VBOX_GCC32_TOOL)_CC) -fPIC -shared \ + # $(VBOX_GCC_SANITIZER_FLAGS) $(VBOX_GCC_SANITIZER_LDFLAGS) -o "$@.sanitizer32.so" "$@.sanitizer.c" + # ldd "$@.sanitizer32.so" | $(SED_EXT) --append '$@' -re '/lib(a|ub)san\.so/!d' -e 's/.* => //' -e 's/ \(0x[0-9a-fA-F]*\) *$(DOLLAR)/ \\/' + # $(QUIET)$(APPEND) '$@' '' + $(QUIET)$(RM) -f -- "$@.sanitizer.so" "$@.sanitizer32.so" '$@.sanitizer.c' + endif + endif + ifdef VBOX_PATH_PREFIX_MINGW32 + $(QUIET)$(APPEND) '$@' 'VBOX_MINGW32_VERSION_CC ?= $(call VBOX_GCC_VERSION,$(VBOX_PATH_PREFIX_MINGW32)gcc -m32)' + $(QUIET)$(APPEND) '$@' 'VBOX_MINGW32_VERSION_CXX ?= $(call VBOX_GCC_VERSION,$(VBOX_PATH_PREFIX_MINGW32)g++ -m32)' + $(QUIET)$(APPEND) '$@' 'VBOX_MINGW32_Wno-array-bounds ?= $(call VBOX_GCC_CHECK_EX_CXX,$(VBOX_PATH_PREFIX_MINGW32)g++ -m32,-Wno-array-bounds,)' + $(QUIET)$(APPEND) '$@' 'VBOX_MINGW32_Wno-unused-but-set-variable ?= $(call VBOX_GCC_CHECK_EX_CXX,$(VBOX_PATH_PREFIX_MINGW32)g++ -m32,-Wno-unused-but-set-variable,)' + $(QUIET)$(APPEND) '$@' 'VBOX_MINGW32_Wno-maybe-uninitialized ?= $(call VBOX_GCC_CHECK_EX_CXX,$(VBOX_PATH_PREFIX_MINGW32)g++ -m32,-Wno-maybe-uninitialized,)' + $(QUIET)$(APPEND) '$@' 'VBOX_MINGW32_USER_LABEL_PREFIX ?= $(shell echo "__USER_LABEL_PREFIX__" | $(VBOX_PATH_PREFIX_MINGW32)g++ -m32 -E -xc++ - | $(SED) -e "/^$(HASH)/d")' + endif + ifdef VBOX_PATH_PREFIX_MINGW64 + $(QUIET)$(APPEND) '$@' 'VBOX_MINGW64_VERSION_CC ?= $(call VBOX_GCC_VERSION,$(VBOX_PATH_PREFIX_MINGW64)gcc -m64)' + $(QUIET)$(APPEND) '$@' 'VBOX_MINGW64_VERSION_CXX ?= $(call VBOX_GCC_VERSION,$(VBOX_PATH_PREFIX_MINGW64)g++ -m64)' + $(QUIET)$(APPEND) '$@' 'VBOX_MINGW64_Wno-array-bounds ?= $(call VBOX_GCC_CHECK_EX_CXX,$(VBOX_PATH_PREFIX_MINGW64)g++ -m64,-Wno-array-bounds,)' + $(QUIET)$(APPEND) '$@' 'VBOX_MINGW64_Wno-unused-but-set-variable ?= $(call VBOX_GCC_CHECK_EX_CXX,$(VBOX_PATH_PREFIX_MINGW64)g++ -m64,-Wno-unused-but-set-variable,)' + $(QUIET)$(APPEND) '$@' 'VBOX_MINGW64_Wno-maybe-uninitialized ?= $(call VBOX_GCC_CHECK_EX_CXX,$(VBOX_PATH_PREFIX_MINGW64)g++ -m64,-Wno-maybe-uninitialized,)' + $(QUIET)$(APPEND) '$@' 'VBOX_MINGW64_USER_LABEL_PREFIX ?= $(shell echo "__USER_LABEL_PREFIX__" | $(VBOX_PATH_PREFIX_MINGW64)g++ -m64 -E -xc++ - | $(SED) -e "/^$(HASH)/d")' + endif + if defined(TOOL_FLEX) || defined(TOOL_BISON) + echo "Do NOT include the flex or bison tools before Config.kmk gets loaded" + exit 1 # + endif + $(QUIET)$(APPEND) '$@' 'VBOX_HAVE_FLEX ?= $(firstfile $(TOOL_FLEX_LEX) $(which flex))' + $(QUIET)$(APPEND) '$@' 'VBOX_HAVE_BISON ?= $(firstfile $(TOOL_BISON_YACC) $(which bison))' + $(QUIET)$(APPEND) '$@' 'VBOX_HAVE_XMLLINT ?= $(which xmllint)' + if "$(KBUILD_HOST)" == "solaris" && $(KBUILD_HOST_VERSION_MAJOR) == 5 && $(KBUILD_HOST_VERSION_MINOR) == 11 + # BRANCH_VERSION format on S11 - S11.3: + # <trunk_id>.<update>.<sru>.<reserved>.<buildid>.<nightly_id> + # e.g.: 0.175.3.32.0.4.0:20180427T232405Z - N.B. trunk_id = 0.175 + # BRANCH_VERSION format on S11.4: + # <minor>.<update>.<sru>.<reserved>.<reserved>.<buildid>.<nightly_id> + # e.g.: 11.4.0.0.1.10.0:20180702T173343Z + # We're interested in <update> and <buildid>. + $(QUIET)$(APPEND) '$@' "VBOX_SOLARIS_11_BRANCH_VERSION := $(shell pkg contents -H -t set -o pkg.fmri system/kernel | $(SED_EXT) -e '1!d' -e 's/^.*\-//;s/\:.*//;s/.*,//')" + $(QUIET)$(APPEND) '$@' 'ifeq ($$(word 2, $$(subst ., ,$$(VBOX_SOLARIS_11_BRANCH_VERSION))),175)' + $(QUIET)$(APPEND) '$@' ' VBOX_SOLARIS_11_UPDATE_VERSION := $$(word 3, $$(subst ., ,$$(VBOX_SOLARIS_11_BRANCH_VERSION)))' + $(QUIET)$(APPEND) '$@' 'else' + $(QUIET)$(APPEND) '$@' ' VBOX_SOLARIS_11_UPDATE_VERSION := $$(word 2, $$(subst ., ,$$(VBOX_SOLARIS_11_BRANCH_VERSION)))' + $(QUIET)$(APPEND) '$@' 'endif' + $(QUIET)$(APPEND) '$@' 'VBOX_SOLARIS_11_BUILD_VERSION := $$(word 6, $$(subst ., ,$$(VBOX_SOLARIS_11_BRANCH_VERSION)))' + endif + if1of ($(KBUILD_HOST), darwin freebsd solaris) + $(QUIET)$(APPEND) '$@' 'VBOX_HOST_DTRACE_VERSION := $(shell dtrace -V)' + endif + if defined(VBOX_PYLINT) && !defined(VBOX_WITH_PYLINT_PRE_V1_0) && !defined(VBOX_WITH_PYLINT_V1_1_PLUS) && !defined(VBOX_WITH_PYLINT_V1_2_1_PLUS) + $(QUIET)$(APPEND) '$@' "VBOX_PYLINT_VERSION := $(call VBOX_PYLINT_FIGURE_VERSION, $(VBOX_PYLINT))" + endif + if defined(VBOX_JAVAC) + $(QUIET)$(APPEND) '$@' 'VBOX_JAVA_VERSION := $(call VBOX_JAVA_FIGURE_VERSION, $(VBOX_JAVAC))' + endif + + $(QUIET)$(ECHO) '========= START OF $@ =========' + $(QUIET)$(CAT) $@ + $(QUIET)$(ECHO) '=========== END OF $@ =========' + + include $(PATH_OUT)/DynamicConfig.kmk +endif # !VBOX_NOINC_DYNAMIC_CONFIG_KMK + + +# +# C++ language level +# See https://en.cppreference.com/w/cpp/compiler_support and compiler docs. +# +## @todo consider maxing this out. +ifndef VBOX_GCC_std + if1of ($(KBUILD_TARGET).$(KBUILD_TARGET_ARCH), darwin.arm64) # Go straight for c++17 here. + VBOX_GCC_std := -std=c++17 + # else if "$(VBOX_CLANG_VERSION_CXX)" vge 60000 # Most language features complete by v6. Lib stuff was less complete in v6, but hopefully acceptable for out purposes. + #VBOX_GCC_std := -std=c++17 + else if "$(VBOX_CLANG_VERSION_CXX)" vge 50000 # darwin Xcode 5 allegedly knows what C++11 is + VBOX_GCC_std := -std=c++11 + # else if "$(VBOX_GCC_VERSION_CXX)" vge 70000 # Language feature P0512R0 was v8, rest v7 or earlier. Most lib stuff present in 7, complete in v12. + #VBOX_GCC_std := -std=gnu++17 + else if "$(VBOX_GCC_VERSION_CXX)" vge 40800 + VBOX_GCC_std := -std=c++11 + else if "$(VBOX_GCC_VERSION_CXX)" vge 40600 + VBOX_GCC_std := -std=c++0x + endif +endif +ifndef VBOX_VCC_std + if $(VBOX_VCC_TOOL_STEM) >= VCC141 # since 2017 15.3 + VBOX_VCC_std := -std:c++17 -Zc:__cplusplus + endif +endif + + +# +# Compiler warning control. +# +VBOX_GCC_WARN ?= -Wall $(VBOX_GCC_Wextra) $(VBOX_GCC_Wno-missing-field-initializers) -Wno-unused -Wno-trigraphs \ + $(VBOX_GCC_fdiagnostics-show-option) $(VBOX_GCC_Wno-unused-parameter) $(VBOX_GCC_Wno-language-extension-token) \ + $(VBOX_GCC_Wno-extended-offsetof) $(VBOX_GCC_Wno-gnu-folding-constant) $(VBOX_GCC_Wno-gnu-anonymous-struct) \ + $(VBOX_GCC_Wlogical-op) $(VBOX_GCC_Wno-string-plus-int) $(VBOX_GCC_Wno-nested-anon-types) $(VBOX_GCC_Wno-variadic-macros) \ + $(VBOX_GCC_Wno-c++17-compat-mangling) +VBOX_GCC_WARN_PEDANTIC = -Wshadow $(VBOX_GCC_WARN) -Wno-long-long +if $(VBOX_GCC_VERSION_CXX) >= 40200 || defined(VBOX_WITH_MASOCHISTIC_WARNINGS) # gcc 4.2.x+ (4.1.2 is causing trouble with the extpack & add builds) + VBOX_GCC_WARN_MASOCHISTIC ?= -Wunused-variable -Wunused-function -Wunused-label -Wunused-parameter +endif +if $(KBUILD_TARGET) == "linux" \ + || ($(KBUILD_TARGET) == "darwin" && "$(VBOX_GCC_TOOL)" != "GXX4MACHO" && "$(VBOX_GCC_TOOL)" != "GXX42MACHO") \ + || defined(VBOX_WITH_MASOCHISTIC_WARNINGS) + VBOX_GCC_WARN_PEDANTIC += $(VBOX_GCC_WARN_MASOCHISTIC) +endif + +ifdef VBOX_GCC_Wno-variadic-macros # Don't use -pedantic unless -Wno-variadic-macros also works. Too noisy. + VBOX_GCC_PEDANTIC_OPTION ?= -pedantic +else + VBOX_GCC_PEDANTIC_OPTION ?= +endif +VBOX_GCC_PEDANTIC_CXX ?= $(VBOX_GCC_PEDANTIC_OPTION) $(VBOX_GCC_WARN_PEDANTIC) $(VBOX_GCC_Wno-return-type-c-linkage) $(VBOX_GCC_Wno-overloaded-virtual) $(VBOX_GCC_Wno-undefined-var-template) +VBOX_GCC_PEDANTIC_C ?= $(VBOX_GCC_PEDANTIC_OPTION) $(VBOX_GCC_WARN_PEDANTIC) -Wmissing-prototypes -Wstrict-prototypes -Wmissing-declarations -Werror-implicit-function-declaration + +# Avoid freaking out when using flexible arrays in C++ code (ldrPE.cpp, ++). +if ($(VBOX_GCC_VERSION_CXX) < 60100 || $(VBOX_GCC_VERSION_CXX) >= 70000) && "$(VBOX_GCC_Wno-array_bounds)" != "" + VBOX_GCC_PEDANTIC_CXX += $(VBOX_GCC_Wno-array_bounds) +endif +# Stupid problem with (__typeof__((*ppv)) casts in asm.h where volatile is involved and ignored. +if $(VBOX_GCC_VERSION_CXX) >= 80000 && "$(VBOX_GCC_Wno-ignored-qualifiers)" + VBOX_GCC_PEDANTIC_CXX += $(VBOX_GCC_Wno-ignored-qualifiers) +endif + + +VBOX_GCC_NON_PEDANTIC_CXX ?= -Wno-sign-compare +VBOX_GCC_NON_PEDANTIC_C ?= -Wno-sign-compare -Werror-implicit-function-declaration + +if "$(KBUILD_TARGET)" == "darwin" && "$(VBOX_GCC_TOOL)" != "GXX4MACHO" && "$(VBOX_GCC_TOOL)" != "GXX42MACHO" + VBOX_GCC_PEDANTIC_CXX += -Wno-c99-extensions + VBOX_GCC_NON_PEDANTIC_CXX += -Wno-c99-extensions +endif + + +# Disabled Visual C++ warnings, W4: +# -wd4065: switch statement contains 'default' but no 'case' labels +# -wd4996: deprecated / insecure. +# -wd4127: conditional expression is constant [level 4] +# -wd4706: assignment within conditional expression [level 4] +# -wd4201: nonstandard extension used : nameless struct/union [level 4] +# -wd4214: nonstandard extension used : bit field types other than int [level 4] +# -wd4510: 'VM::<unnamed-tag>' : default constructor could not be generated +# -wd4512: 'VM' : assignment operator could not be generated +# -wd4610: union 'VM::<unnamed-tag>' can never be instantiated - user defined constructor required +# Disabled Visual C++ warnings, Wall: +# -wd4514: unreferenced inline function has been removed +# -wd4820: 'RTSTRSPACECORE' : '7' bytes padding added after data member 'RTSTRSPACECORE::uchHeight' +# -wd4365: '=' : conversion from 'unsigned char' to 'char', signed/unsigned mismatch +# -wd4987: nonstandard extension used: 'throw (...)' (setjmp.h + our stuff) +# -wd4710: 'std::string std::_Narrow_str(std::wstring)' : function not inlined +# -wd4061: enumerator 'RTASN1TYPE_END' in switch of enum 'RTASN1TYPE' is not explicitly handled by a case label +# Note! C4062 checks for the same but includes the 'default' case, just like gcc. So, no trouble disabling this. +# -wd4986: 'operator new[]': exception specification does not match previous declaration (crtdbg.h vs new, exception specification only) +# -wd4191: 'type cast' : unsafe conversion from 'int (__cdecl *)(gzFile)' to 'PFNRT' +# -wd4574: 'INCL_WINSOCK_API_TYPEDEFS' is defined to be '0': did you mean to use '#if INCL_WINSOCK_API_TYPEDEFS'? +# -wd4917: 'OLE_XPOS_HIMETRIC' : a GUID can only be associated with a class, interface or namespace +# -wd4711: function 'void __cdecl rtMemCacheFreeOne(struct RTMEMCACHEINT * __ptr64,void * __ptr64)' selected for automatic inline expansion +# -wd4571: Informational: catch(...) semantics changed since Visual C++ 7.1; structured exceptions (SEH) are no longer caught +# -wd4611: interaction between '_setjmp' and C++ object destruction is non-portable +# -wd4324: '_TDI_PNP_CONTEXT_XP' : structure was padded due to __declspec(align()) +# -wd4505: VBoxNetFltNobj.h(45) : warning C4505: 'VBoxNetFltNobj::Release' : unreferenced local function has been removed +# Probably related to http://stackoverflow.com/questions/3051992/compiler-warning-at-c-template-base-class +# -wd4263: 'int VRDPChannelClipboard::SendPacket(const void *,uint32_t)' : member function does not override any base class virtual member function +# Probably useful, but impractical, just like the next one. +# -wd4264: 'int VRDPOutputCtx::SendPacket(void)' : no override available for virtual member function from base 'VRDPOutputCtx'; function is hidden +# -wd4738: storing 32-bit float result in memory, possible loss of performance +# -wd4371: UIActionPool.h(393) : warning C4371: 'UIActionPool::PointerToFunction' : layout of class may have changed from a previous version of the compiler due to better packing of member 'UIActionPool::PointerToFunction::ptfr' +# -wd4748: uiactionpoolmanager.cpp(2723) : warning C4748: /GS can not protect parameters and local variables from local buffer overrun because optimizations are disabled in function +# Want to enable these: +# -wd4242: '=' : conversion from 'uint32_t' to 'uint8_t', possible loss of data +# -wd4244: 'conversion' conversion from 'type1' to 'type2', possible loss of data +# -wd4200: nonstandard extension used : zero-sized array in struct/union +# Cannot generate copy-ctor or copy-assignment operator when UDT contains a zero-sized array +VBOX_VCC_WARN_ALL := -W4 -Wall -wd4065 -wd4996 -wd4127 -wd4706 -wd4201 -wd4214 -wd4510 -wd4512 -wd4610 \ + -wd4514 -wd4820 -wd4365 -wd4987 -wd4710 -wd4061 -wd4986 -wd4191 -wd4574 -wd4917 -wd4711 -wd4611 -wd4571 -wd4324 -wd4505 \ + -wd4263 -wd4264 -wd4738 -wd4200 -wd4371 -wd4748 +if1of ($(VBOX_VCC_TOOL_STEM), VCC120) + # -wd4350: behavior change: 'std::_Wrap_alloc<std::allocator<char>>::_Wrap_alloc(const std::_Wrap_alloc<std::allocator<char>> &) throw()' called instead of 'std::_Wrap_alloc<std::allocator<char>>::_Wrap_alloc<std::_Wrap_alloc<std::allocator<char>>>(_Other &) throw()' + # -wd4435: iprt/cpp/xml.h(185) : warning C4435: 'xml::Input' : Object layout under /vd2 will change due to virtual base 'xml::Stream' + VBOX_VCC_WARN_ALL += -wd4350 -wd4435 +endif +if "$(VBOX_VCC_TOOL_STEM)" >= "VCC140" + # -wd5045: Compiler will insert Spectre mitigation for memory load if /Qspectre switch specified + # -wd5039: 'RTStrSpaceDestroy': pointer or reference to potentially throwing function passed to extern C function under -EHc. Undefined behavior may occur if this function throws an exception. + # -wd4464: relative include path contains '..' (iprt/nocrt/compiler.msc.h) + # -wd4623: 'VM': default constructor was implicitly defined as deleted + # -wd4625: 'SUPDRVTRACERDATA': copy constructor was implicitly defined as deleted + # -wd4626: 'SUPDRVTRACERDATA': assignment operator was implicitly defined as deleted + # -wd5026: 'SUPDRVTRACERDATA': move constructor was implicitly defined as deleted + # -wd5027: 'SUPDRVTRACERDATA': move assignment operator was implicitly defined as deleted + # -wd4435: 'xml::Input': Object layout under /vd2 will change due to virtual base 'xml::Stream' + # -wd4577: 'noexcept' used with no exception handling mode specified; termination on exception is not guaranteed. Specify /EHsc + VBOX_VCC_WARN_ALL += -wd5045 -wd4464 -wd4623 -wd4625 -wd4626 -wd5026 -wd5027 -wd4435 -wd4577 +endif +if "$(VBOX_VCC_TOOL_STEM)" >= "VCC142" # With v16.11.9, not with v16.6.0 4242 + # -wd5220: 'RTDBGMODINT::cRefs': a non-static data member with a volatile qualified type no longer implies that compiler generated copy/move constructors and copy/move assignment operators are not trivial + VBOX_VCC_WARN_ALL += -wd5220 + # Temporarily: + # -wd4242: asn1-ut-string.cpp(729): warning C4242: 'argument': conversion from 'uint32_t' to 'uint16_t', possibl loss of data + # -wd4244: asn1-ut-objid.cpp(124): warning C4244: '=': conversion from 'uint32_t' to 'uint8_t', possible loss of data + VBOX_VCC_WARN_ALL += -wd4242 -wd4244 +endif +# -wd4548: socket.cpp(1931): warning C4548: expression before comma has no effect; expected expression with side-effect +VBOX_VCC_WARN_ALL += -wd4548 +ifndef VBOX_WITH_NEW_WINDOWS_SDK + # -wd5031: iprt/win/windows.h(55): warning C5031: #pragma warning(pop): likely mismatch, popping warning state pushed in different file + # -wd5032: iprt/win/windows.h(37): warning C5032: detected #pragma warning(push) with no corresponding #pragma warning(pop) + VBOX_VCC_WARN_ALL += -wd5031 -wd5032 +endif +ifndef VBOX_NEWER_VCC_WARN_ALL + if "$(VBOX_VCC_TOOL_STEM)" < "VCC120" + VBOX_NEWER_VCC_WARN_ALL := $(VBOX_VCC_WARN_ALL) -wd4350 -wd4435 + else + VBOX_NEWER_VCC_WARN_ALL := $(VBOX_VCC_WARN_ALL) + endif +endif + + +# Disable pedantic warnings for NP/NonPedantic templates. +# -wd4131: 'bi_flush' : uses old-style declarator +# -wd4255: 'tr_static_init' : no function prototype given: converting '()' to '(void)' +# -wd4668: '_WIN32_WCE' is not defined as a preprocessor macro, replacing with '0' for '#if/#elif'/ +# -wd4100: 'cinfo' : unreferenced formal parameter +# -wd4189: 'sz' : local variable is initialized but not referenced +# -wd4132: 'xmlStringComment' : const object should be initialized +# -wd4152: nonstandard extension, function/data pointer conversion in expression +# -wd4702: unreachable code +# -wd4057: '=' : 'xmlChar *' differs in indirection to slightly different base types from 'char *' +# -wd4296: '>=' : expression is always true +# -wd4389: '==' : signed/unsigned mismatch +# -wd4018: '<=' : signed/unsigned mismatch +# -wd4245: '=' : conversion from 'int' to 'unsigned int', signed/unsigned mismatch +# -wd4267: '+=' : conversion from 'size_t' to 'long', possible loss of data +# -wd4295: 'vendor_string' : array is too small to include a terminating null character +VBOX_VCC_NON_PEDANTIC = -wd4131 -wd4255 -wd4668 -wd4100 -wd4189 -wd4132 -wd4152 -wd4702 -wd4057 -wd4296 -wd4389 -wd4018 -wd4245 \ + -wd4267 -wd4295 +VBOX_NEWER_VCC_NON_PEDANTIC = $(VBOX_VCC_NON_PEDANTIC) + +ifeq ($(KBUILD_TARGET),win) + VBOX_C_CXX_FLAGS_NO_UNUSED_PARAMETERS = -wd4100 +else + VBOX_C_CXX_FLAGS_NO_UNUSED_PARAMETERS = -Wno-unused-parameter +endif + +# +# Version dependent Visual C++ stuff. +# +if1of (win, $(KBUILD_TARGET) $(KBUILD_HOST)) + ifn1of ($(VBOX_VCC_TOOL_STEM), VCC100 VCC110 VCC120) + ifndef VBOX_WITHOUT_CONTROL_FLOW_GUARD + VBOX_VCC_CC_GUARD_CF = -guard:cf + VBOX_VCC_LD_GUARD_CF = -Guard:CF + else + VBOX_VCC_CC_GUARD_CF = + VBOX_VCC_LD_GUARD_CF = + endif + VBOX_VCC_LD_HIGH_ENTRYOPY_VA = /HighEntropyVA + else + VBOX_VCC_CC_GUARD_CF = + VBOX_VCC_LD_GUARD_CF = + VBOX_VCC_LD_HIGH_ENTRYOPY_VA = + endif + ifn1of ((VBOX_VCC_TOOL_STEM), VCC100 VCC110 VCC120 VCC140 VCC141) + # 16.7 and later, so not in our linker yet. + ## @todo BUGBUG! Update VCC before 7.0 is released. + #VBOX_VCC_LD_CET_COMPAT = /CetCompat + VBOX_VCC_LD_CET_COMPAT = + else + VBOX_VCC_LD_CET_COMPAT = + endif +endif + +# +# Compiler optimization flags. +# +ifeq ($(KBUILD_TYPE),debug) + VBOX_GCC_FP ?= -fno-omit-frame-pointer + VBOX_GCC_OPT ?= -O0 + VBOX_VCC_FP ?= -Oy- + VBOX_VCC_OPT ?= + VBOX_GCC_R0_FP ?= -fno-omit-frame-pointer -fno-optimize-sibling-calls + VBOX_GCC_R0_OPT ?= -O2 + VBOX_VCC_R0_FP ?= -Oy- + VBOX_VCC_R0_OPT ?= + VBOX_GCC_GC_FP ?= -fno-omit-frame-pointer -fno-optimize-sibling-calls + VBOX_GCC_GC_OPT ?= -O2 + VBOX_VCC_GC_FP ?= -Oy- + VBOX_VCC_GC_OPT ?= +else + # We should use -fomit-frame-pointer for GCC / -Oy for VCC. + # -funwind-tables provides support for backtraces in gdb then. + VBOX_GCC_FP ?= -fno-omit-frame-pointer + VBOX_GCC_OPT ?= -O2 $(VBOX_GCC_mtune-generic) + VBOX_VCC_FP ?= -Oy- + VBOX_VCC_OPT ?= -O2 + VBOX_GCC_R0_FP ?= -fno-omit-frame-pointer + VBOX_GCC_R0_OPT ?= -O2 $(VBOX_GCC_mtune-generic) + VBOX_VCC_R0_FP ?= -Oy- + VBOX_VCC_R0_OPT ?= -O2 + VBOX_GCC_GC_FP ?= -fno-omit-frame-pointer + VBOX_GCC_GC_OPT ?= -O2 $(VBOX_GCC_mtune-generic) + VBOX_VCC_GC_FP ?= -Oy- + VBOX_VCC_GC_OPT ?= -O2 +endif +ifeq ($(KBUILD_TARGET_ARCH),x86) + ifneq ($(KBUILD_TARGET),darwin) + # (The '<=' operator is for prepending (kmk specific).) + VBOX_GCC_OPT <= -march=i586 + endif +endif + + +# +# Select the CRT type we're using with Microsoft Visual C++. +# +if1of ($(KBUILD_TYPE), debug dbgopt strict) + #not yet# VBOX_WITH_DEBUG_VCC_CRT = 1 +endif +ifdef VBOX_WITH_DEBUG_VCC_CRT + VBOX_VCC_CRT_TYPE = d + VBOX_VCC_CRT_TYPE_N = +else + VBOX_VCC_CRT_TYPE = + VBOX_VCC_CRT_TYPE_N = d +endif + + +# +# Warnings as errors. +# +# GCC: We disable warnings on non-X86 systems because of the variadic +# macro usage in the logger. +# +ifdef VBOX_WITH_WARNINGS_AS_ERRORS + if $(VBOX_GCC_VERSION_CXX) >= 40000 + VBOX_GCC_WERR ?= -Werror + endif + VBOX_VCC_WERR ?= -WX + VBOX_VCC_LD_WERR ?= ## @todo later also: -WX +endif + +# +# The general GCC/Clang no warning policy. +# +# Note! This doesn't control everything. Instead set VBOX_GCC_WERR=$(NO_SUCH_VARIABLE) to +# completely disable -Werror. +# +if !defined(VBOX_WITHOUT_NO_GCC_WARNING_POLICY) && !defined(VBOX_WITH_NO_GCC_WARNING_POLICY) + if defined(VBOX_WITH_MASOCHISTIC_WARNINGS) # gcc 4.6.x+ + VBOX_WITH_NO_GCC_WARNING_POLICY = 1 + else if "$(KBUILD_TARGET)" == "darwin" + ifn1of ($(VBOX_GCC_TOOL), GXX4MACHO GXX42MACHO) + VBOX_WITH_NO_GCC_WARNING_POLICY = 1 + endif + else if1of ($(KBUILD_TARGET), linux) + if $(VBOX_GCC_VERSION_CXX) >= 40600 # gcc 4.6.x+ + VBOX_WITH_NO_GCC_WARNING_POLICY = 1 + endif + endif +endif +ifdef VBOX_WITH_NO_GCC_WARNING_POLICY + $(info build debug: VBOX_WITH_NO_GCC_WARNING_POLICY is enabled) +endif + +# +# Misc stuff that should be after including DynamicConfig.kmk. +# + +# libxml XML linter. +ifeq ($(VBOX_XMLLINT),) + ifeq ($(KBUILD_HOST),win) + VBOX_XMLLINT := $(wildcard $(KBUILD_DEVTOOLS)/$(KBUILD_HOST).$(KBUILD_HOST_ARCH)/libxslt/10128/bin/xmllint.exe) + endif + ifeq ($(VBOX_XMLLINT),) + VBOX_XMLLINT := $(VBOX_HAVE_XMLLINT) + endif + ifneq ($(VBOX_XMLLINT),) + VBOX_HAVE_XMLLINT := 1 + else + VBOX_XMLLINT := xmllint + VBOX_HAVE_XMLLINT := + endif +else + VBOX_HAVE_XMLLINT := 1 +endif + +# Older versions of GCC cannot compile libssh, so disable it and the feature if that's the case. +ifn1of ($(KBUILD_TARGET), darwin win) + if $(VBOX_GCC_VERSION_CC) < 50000 + VBOX_WITH_LIBSSH := + VBOX_WITH_CLOUD_NET := + endif +endif + + +# +# Misc macros. +# + +## +# Edits VirtualBox version, vendor and package strings in a text file. +# +# The rule using this must list $(VBOX_SVN_REV_KMK) as a prerequisite. +# +# @param 1 The input filename. +# @param 2 The output filename. +# +VBOX_EDIT_VERSION_CMD_FN = $(SED) \ + -e 's+@VBOX_VERSION_MAJOR@+$(VBOX_VERSION_MAJOR)+g' \ + -e 's+@VBOX_VERSION_MINOR@+$(VBOX_VERSION_MINOR)+g' \ + -e 's+@VBOX_VERSION_BUILD@+$(VBOX_VERSION_BUILD)+g' \ + -e 's+@VBOX_VERSION_STRING@+$(VBOX_VERSION_STRING)+g' \ + -e 's+@VBOX_SVN_REV@+$(VBOX_SVN_REV)+g' \ + -e 's+@VBOX_VENDOR@+$(VBOX_VENDOR)+g' \ + -e 's+@VBOX_VENDOR_SHORT@+$(VBOX_VENDOR_SHORT)+g' \ + -e 's+@VBOX_PRODUCT@+$(VBOX_PRODUCT)+g' \ + -e 's+@VBOX_C_YEAR@+$(VBOX_C_YEAR)+g' \ + -e 's+@VBOX_PACKAGE_STRING@+$(VBOX_PACKAGE_STRING)+g' \ + --output $(2) $(1) + +## +# Generates a rule for editing a file using VBOX_EDIT_VERSION_CMD_FN. +# +# @param 1 The target name. +# @param 2 The input filename relative to the current sub-makefile. +# @param 3 The output filename relative to the target output dir. +# Optional, defaults to 2. +# +VBOX_EDIT_VERSION_RULE_FN = $(eval $(value VBOX_EDIT_VERSION_RULE_DEF)) +define VBOX_EDIT_VERSION_RULE_DEF + $$($(1)_0_OUTDIR)/$(if $(3),$(3),$(2)): $(PATH_SUB_CURRENT)/$(2) $(VBOX_SVN_REV_KMK) | $$(dir $$@) + $(call MSG_GENERATE,$(1),$@,$<) + $(QUIET)$(call VBOX_EDIT_VERSION_CMD_FN,$<,$@) + $(eval $(1)_CLEAN += $$($(1)_0_OUTDIR)/$(if $(3),$(3),$(2))) +endef + + +## +# Edits VirtualBox version, vendor, package, build target, build arch, and build type strings in a text file. +# +# Please use VBOX_EDIT_VERSION_AND_BUILD_RULE_FN to generate edit rule. +# +# @param 1 The input filename. +# @param 2 The output filename. +# +VBOX_EDIT_VERSION_AND_BUILD_CMD_FN = $(SED) \ + -e 's+@VBOX_VERSION_MAJOR@+$(VBOX_VERSION_MAJOR)+g' \ + -e 's+@VBOX_VERSION_MINOR@+$(VBOX_VERSION_MINOR)+g' \ + -e 's+@VBOX_VERSION_BUILD@+$(VBOX_VERSION_BUILD)+g' \ + -e 's+@VBOX_VERSION_STRING@+$(VBOX_VERSION_STRING)+g' \ + -e 's+@VBOX_SVN_REV@+$(VBOX_SVN_REV)+g' \ + -e 's+@VBOX_VENDOR@+$(VBOX_VENDOR)+g' \ + -e 's+@VBOX_VENDOR_SHORT@+$(VBOX_VENDOR_SHORT)+g' \ + -e 's+@VBOX_PRODUCT@+$(VBOX_PRODUCT)+g' \ + -e 's+@VBOX_C_YEAR@+$(VBOX_C_YEAR)+g' \ + -e 's+@VBOX_PACKAGE_STRING@+$(VBOX_PACKAGE_STRING)+g' \ + -e 's+@KBUILD_TYPE@+$(KBUILD_TYPE)+g' \ + -e 's+@KBUILD_TARGET@+$(KBUILD_TARGET)+g' \ + -e 's+@KBUILD_TARGET_ARCH@+$(KBUILD_TARGET_ARCH)+g' \ + --output $(2) $(1) + +## +# Generates a rule for editing a file using VBOX_EDIT_VERSION_CMD_FN. +# +# @param 1 The target name. +# @param 2 The input filename relative to the current sub-makefile. +# @param 3 The output filename relative to the target output dir. +# Optional, defaults to 2. +# +VBOX_EDIT_VERSION_AND_BUILD_RULE_FN = $(eval $(VBOX_EDIT_VERSION_AND_BUILD_RULE_DEF)) +define VBOX_EDIT_VERSION_AND_BUILD_RULE_DEF + $$$$($(1)_0_OUTDIR)/$(if $(3),$(3),$(2)): $$(PATH_SUB_CURRENT)/$(2) $$(VBOX_SVN_REV_KMK) | $$$$(dir $$$$@) + $$(call MSG_GENERATE,$(1),$$@,$$<) + $$(QUIET)$$(call VBOX_EDIT_VERSION_AND_BUILD_CMD_FN,$$<,$$@) + $(1)_CLEAN += $$($(1)_0_OUTDIR)/$(if $(3),$(3),$(2)) +endef + + +## +# Fill in am import library target based on a somewhat special windows .def file. +# +# @param 1 The target name of the import library. +# @param 2 The name of the real library. +# @param 3 The .def-file paths relative to the current makefile. +# +VBOX_GENERATE_IMPORT_TARGET_FN = $(eval $(VBOX_GENERATE_IMPORT_TARGET_DEF)) +define VBOX_GENERATE_IMPORT_TARGET_DEF + $(1)_TEMPLATE = VBoxR3Dll + $(1)_INST = $(INST_LIB) + if $(KBUILD_TARGET) == "darwin" + $(1)_LDFLAGS = -install_name $(VBOX_DYLD_EXECUTABLE_PATH)/$(2)$(SUFF_DLL) + else ifn1of ($(KBUILD_TARGET), os2 win) + $(1)_SONAME = $(2)$(SUFF_DLL) + endif + if1of ($(KBUILD_TARGET), os2 win) + $(1)_SOURCES = $$($(1)_0_OUTDIR)/$(1)Imp.def + $(1)_CLEAN = $$($(1)_0_OUTDIR)/$(1)Imp.def + else + $(1)_SOURCES = $$($(1)_0_OUTDIR)/$(1)Imp.c + $(1)_CLEAN = $$($(1)_0_OUTDIR)/$(1)Imp.c + endif + + $$$$($(1)_SOURCES): $(addprefix $(PATH_SUB_CURRENT)/,$(3)) $(PATH_ROOT)/src/bldprogs/deftoimp.sed | $$$$(dir $$$$@) + $$(call MSG_GENERATE,,$$@) + ifeq ($(KBUILD_TARGET),os2) + $$(SED) \ + -e '/not-$(KBUILD_TARGET)/d' \ + -e '/not-$(KBUILD_TARGET_ARCH)/d' \ + -e 's/^LIBRARY[[:space:]][[:space:]]*\(.*\)\.dll/LIBRARY \1 INITINSTANCE TERMINSTANCE\nDATA MULTIPLE\n/' \ + -e 's/^[ \t][ \t]*\([_a-zA-Z]\)/ _\1/' \ + -e 's/[ \t]DATA[ \t]*/ /' \ + --output $$@ $(addprefix $(PATH_SUB_CURRENT)/,$(3)) + else ifeq ($(KBUILD_TARGET),win) + $$(SED) \ + -e '/not-$(KBUILD_TARGET)/d' \ + -e '/not-$(KBUILD_TARGET_ARCH)/d' \ + --output $$@ $(addprefix $(PATH_SUB_CURRENT)/,$(3)) + else + $$(QUIET)$$(APPEND) -tn $$@ \ + '#ifdef VBOX_HAVE_VISIBILITY_HIDDEN' \ + '# define EXPORT __attribute__((visibility("default")))' \ + '# define EXPORT_DATA __attribute__((visibility("default")))' \ + '#else' \ + '# define EXPORT' \ + '# define EXPORT_DATA' \ + '#endif' \ + '' + $$(SED) \ + -e '/not-$(KBUILD_TARGET)/d' \ + -e '/not-$(KBUILD_TARGET_ARCH)/d' \ + -f $(PATH_ROOT)/src/bldprogs/deftoimp.sed \ + --append $$@ $(addprefix $(PATH_SUB_CURRENT)/,$(3)) + endif +endef # VBOX_GENERATE_IMPORT_TARGET_DEF + + +## VBOX_UTF8_MANIFEST_CMDS +# Wrapper around VBOX_UTF8_MANIFEST_FN that makes sure it's an EXE link target, +# as this UTF-8 manifest doesn't make sense for non-executables. +ifn1of ($(VBOX_VCC_TOOL_STEM), VCC100 VCC110 VCC120) + ## VBOX_UTF8_MANIFEST_FN + # Adds a manifest resource with ID 1 that tells windows 10 1903 and later to + # use UTF-8 for the ANSI and OEM code pages. We only do this when using UCRT + # as the VCC100 CRT typically ends up with its internal code page not being + # CP_UTF8 but the default codepage for the locale. + # + # @param 1 the output filename. + # @param 2 the architecture (required for xp rtm) + # + VBOX_UTF8_MANIFEST_FN = \ + $(QUIET)$(APPEND) -tn "$(1).manifest" \ + '<?xml version="1.0" encoding="UTF-8" standalone="yes"?>' \ + '<assembly manifestVersion="1.0" xmlns="urn:schemas-microsoft-com:asm.v1" xmlns:asmv3="urn:schemas-microsoft-com:asm.v3">' \ + ' <assemblyIdentity type="win32" name="$(notdir $(1))" processorArchitecture="$(2)" version="$(VBOX_VERSION_MAJOR).$(VBOX_VERSION_MINOR).$(VBOX_VERSION_BUILD).$(expr $(VBOX_SVN_REV) % 50000)" />' \ + ' <asmv3:application>' \ + ' <asmv3:windowsSettings>' \ + ' <activeCodePage xmlns="http://schemas.microsoft.com/SMI/2019/WindowsSettings">UTF-8</activeCodePage>' \ + ' </asmv3:windowsSettings>' \ + ' </asmv3:application>' \ + '</assembly>' \ + $(NLTAB)$(QUIET)$(REDIRECT) -- $(requote sh,$(PATH_SDK_$(VBOX_WINPSDK)_BIN)/mt.exe) \ + -nologo -manifest '$(subst /,\,$(1).manifest)' '-outputresource:$(subst /,\,$(1));$(HASH)1' \ + $(NLTAB)$(QUIET)$(RM) -f -- "$(1).manifest" + VBOX_UTF8_MANIFEST_CMDS ?= $(if-expr "$(tool_do)" == "LINK_PROGRAM",$(call VBOX_UTF8_MANIFEST_FN,$(out),$(bld_trg_arch)),) +else + VBOX_UTF8_MANIFEST_CMDS = +endif + + +# +# Code Signing. +# +# There are two signing modes; 'test' and 'release'. +# - The 'test' mode is tailored local development, where typically test +# certificates are involved. Only the bar minimum of files are signed and +# nothing is timestamped (if we can control timestamping) in order to reduce +# build time and to allow working offline. +# - The 'release' mode is tailored for creating builds that are give to other +# people, like the ones the build servers create. As much as possible is +# signed and timestamped. +# - The 'adhoc' mode is specific to building on macOS and is similar to 'test' +# mode but doesn't require any certificates but a host set up for development work. +# Binaries are signed in adhoc mode and include required entitlements as appropriate +# (something we would only do in the 'packing' target). This seem to be the only working +# way with newer versions of macOS (tested with Ventura) with 'test' not working anymore. +# +ifdef VBOX_SIGNING_MODE + VBOX_SIGNING_MODE := $(strip $(VBOX_SIGNING_MODE)) + ifn1of ($(VBOX_SIGNING_MODE), test release adhoc) + $(error VBOX_SIGNING_MODE must be either 'test', 'release' or 'adhoc'. The value '$(VBOX_SIGNING_MODE)' is not recognized.) + endif + if "$(VBOX_SIGNING_MODE)" == "adhoc" && "$(KBUILD_TARGET)" != "darwin" + $(error 'adhoc' signing mode is only available on macOS) + endif + VBOX_RETRY ?= $(ASH) $(KBUILD_DEVTOOLS)/bin/retry.sh + # temporary solution for a $(dir ...) equivalent which assumes that it gets a single path, possibly with spaces. + VBOX_DIRX = $(subst ?,$(SP),$(dir $(subst $(SP),?,$1))) + # Corp code signing client. + VBOX_CCS_CLIENT_JAR := $(firstword $(rsort \ + $(wildcard $(KBUILD_DEVTOOLS)/common/ccs/v*/Client.jar)) \ + $(KBUILD_DEVTOOLS)/common/ccs/notfound/Client.jar ) + VBOX_CCS_USER ?= virtualbox_grp + VBOX_CCS_GLOBAL_UID ?= non-of-your-business + VBOX_CCS_SERVER ?= UK + ## + # Corp Code Signing command line. + # @param $1 Signing method: solaris_elf, solaris_pkg, driver (microsoft), ... + # @param $2 The file to be submitted for signing. + # @param $3 The directory to put the signed file in. Defaults to $(dir $2). + # @param $4 Additional options. + VBOX_CCS_SIGN_CMD = $(VBOX_RETRY) $(VBOX_JAVA) -jar "$(VBOX_CCS_CLIENT_JAR)" \ + sign -user "$(VBOX_CCS_USER)" -global_uid "$(VBOX_CCS_GLOBAL_UID)" \ + -job_timeout 90 -server_timeout 75 -server "$(VBOX_CCS_SERVER)" \ + -sign_method "$1" -file_to_sign "$2" -signed_location "$(if $3,$3,$(call VBOX_DIRX,$2))" $4 + + ifeq ($(KBUILD_HOST),win) + # + # Windows + # + + # VBOX_PATH_SELFSIGN points to the Vista WDK bin/SelfSign directory. + ifndef VBOX_PATH_SELFSIGN + VBOX_PATH_SELFSIGN := $(firstword $(rsort $(wildcard $(KBUILD_DEVTOOLS)/win.x86/selfsign/*))) + ifeq ($(VBOX_PATH_SELFSIGN),) + VBOX_PATH_SELFSIGN := $(KBUILD_DEVTOOLS)/win.x86/selfsign/r1 + endif + endif + ifndef VBOX_PATH_SIGN_TOOLS + ifdef VBOX_WITH_NEW_WINDOWS_SDK + VBOX_PATH_SIGN_TOOLS = $(PATH_SDK_$(VBOX_WINPSDK)_BIN) + else + VBOX_PATH_SIGN_TOOLS := $(firstword $(rsort $(wildcard \ + $(addprefix $(KBUILD_DEVTOOLS)/win.x86/sdk/v8.1*/Bin/, x86 $(if-expr $(KBUILD_HOST_ARCH)=="amd64",x64,) ) ))) + ifeq ($(VBOX_PATH_SIGN_TOOLS),) + VBOX_PATH_SIGN_TOOLS := $(firstword $(rsort $(wildcard \ + $(addprefix $(KBUILD_DEVTOOLS)/win.x86/sdk/v10*/Bin/, x86 $(if-expr $(KBUILD_HOST_ARCH)=="amd64",x64,) ) ))) + ifeq ($(VBOX_PATH_SIGN_TOOLS),) + VBOX_PATH_SIGN_TOOLS := $(VBOX_PATH_SELFSIGN) + endif + endif + endif + endif + + VBOX_SIGNTOOL ?= $(VBOX_RETRY) "$(VBOX_PATH_SIGN_TOOLS)/signtool.exe" + VBOX_SIGNTOOL_SHA1 ?= $(VBOX_SIGNTOOL) + VBOX_SIGNTOOL_SHA1_ORDERDEPS ?= + VBOX_SIGNTOOL_SHA2 ?= $(VBOX_SIGNTOOL) + VBOX_SIGNTOOL_SHA2_ORDERDEPS ?= + VBOX_SIGNTOOL_ORDERDEPS ?= $(VBOX_SIGNTOOL_SHA1_ORDERDEPS) $(VBOX_SIGNTOOL_SHA2_ORDERDEPS) + VBOX_INF2CAT ?= $(VBOX_PATH_SELFSIGN)/inf2cat.exe + + ifeq ($(VBOX_SIGNING_MODE),test) + VBOX_CERTIFICATE_SUBJECT_NAME ?= MyTestCertificate + VBOX_CERTIFICATE_SUBJECT_NAME_ARGS ?= /n "$(VBOX_CERTIFICATE_SUBJECT_NAME)" + else # release + VBOX_CERTIFICATE_SUBJECT_NAME ?= VirtualBox 2022 + VBOX_CERTIFICATE_SUBJECT_NAME_ARGS ?= /n "$(VBOX_CERTIFICATE_SUBJECT_NAME)" /a + #VBOX_CERTIFICATE_FINGERPRINT ?= 7e 92 b6 6b e5 1b 79 d8 ce 3f f2 5c 15 c2 df 6a b8 c7 f2 f2 + #VBOX_CERTIFICATE_FINGERPRINT ?= 5b de fe 58 0a 81 66 61 cd b5 7a 57 10 7b f4 18 74 86 ef cc + #VBOX_CERTIFICATE_FINGERPRINT ?= 6f 47 42 06 bc bb 39 1b b8 2b a9 e5 dc 03 02 de f3 7a eb be + VBOX_CERTIFICATE_FINGERPRINT ?= 5f 0b fe c5 53 17 c1 25 5a a4 7f cd bc 49 a2 fb 61 09 03 cc + #VBOX_CROSS_CERTIFICATE_FILE ?= $(VBOX_PATH_SELFSIGN)/VeriSign Class 3 Public Primary Certification Authority - G5.cer + #VBOX_CROSS_CERTIFICATE_FILE ?= $(VBOX_PATH_SELFSIGN)/DigiCert Assured ID Root CA.crt + #VBOX_TSA_URL ?= http://timestamp.verisign.com/scripts/timstamp.dll - Appears to be broken between 2020-12-25 and 2020-12-30 (bugref:9849). + VBOX_TSA_URL ?= http://timestamp.digicert.com + endif + if !defined(VBOX_CROSS_CERTIFICATE_FILE_ARGS) && defined(VBOX_CROSS_CERTIFICATE_FILE) + VBOX_CROSS_CERTIFICATE_FILE_ARGS = /ac "$(VBOX_CROSS_CERTIFICATE_FILE)" + endif + if !defined(VBOX_TSA_URL_ARGS) && defined(VBOX_TSA_URL) + VBOX_TSA_URL_ARGS = /t "$(VBOX_TSA_URL)" + endif + VBOX_CERTIFICATE_STORE ?= my + VBOX_CERTIFICATE_STORE_ARGS ?= /s "$(VBOX_CERTIFICATE_STORE)" + VBOX_CERTIFICATE_FINGERPRINT_ARGS := $(if-expr "$(VBOX_CERTIFICATE_FINGERPRINT)" != "" \ + ,/sha1 "$(subst $(SP),,$(VBOX_CERTIFICATE_FINGERPRINT))",) + + ifeq ($(VBOX_SIGNING_MODE),test) + #VBOX_CERTIFICATE_SHA2_SUBJECT_NAME ?= MyTestCertificateSha2 + VBOX_CERTIFICATE_SHA2_SUBJECT_NAME_ARGS ?= /n "$(VBOX_CERTIFICATE_SHA2_SUBJECT_NAME)" + else # release + VBOX_CERTIFICATE_SHA2_SUBJECT_NAME ?= Oracle Corporation + VBOX_CERTIFICATE_SHA2_SUBJECT_NAME_ARGS ?= /n "$(VBOX_CERTIFICATE_SHA2_SUBJECT_NAME)" /a + #VBOX_CERTIFICATE_SHA2_FINGERPRINT ?= 31 31 bb 58 8b 19 9e 6e 85 0f d3 35 82 b0 c5 82 55 e1 6c 49 + #VBOX_CERTIFICATE_SHA2_FINGERPRINT ?= 22 05 6a 4d 46 2e 3d 2b b2 c3 2f bf b0 5b 84 c4 65 9c f7 fe + #VBOX_CERTIFICATE_SHA2_FINGERPRINT ?= 17 3a 19 bf 8e 62 72 be 25 04 d3 08 aa 68 b1 b0 0e 03 33 2c + VBOX_CERTIFICATE_SHA2_FINGERPRINT ?= 30 65 6f ca 8c 48 b1 d9 86 23 a9 4b 40 a6 bc 98 bd 87 bf ad + VBOX_CROSS_CERTIFICATE_SHA2_FILE ?= $(VBOX_PATH_SELFSIGN)/DigiCert Assured ID Root CA.crt + #VBOX_TSA_SHA2_URL ?= http://sha256timestamp.ws.symantec.com/sha256/timestamp - phase out for consistency reasons + VBOX_TSA_SHA2_URL ?= http://timestamp.digicert.com + endif + if !defined(VBOX_CROSS_CERTIFICATE_SHA2_FILE_ARGS) && defined(VBOX_CROSS_CERTIFICATE_SHA2_FILE) + VBOX_CROSS_CERTIFICATE_SHA2_FILE_ARGS = /ac "$(VBOX_CROSS_CERTIFICATE_SHA2_FILE)" + endif + if !defined(VBOX_TSA_SHA2_URL_ARGS) && defined(VBOX_TSA_SHA2_URL) + VBOX_TSA_SHA2_URL_ARGS = /tr "$(VBOX_TSA_SHA2_URL)" /td SHA256 + endif + VBOX_CERTIFICATE_SHA2_STORE ?= my + VBOX_CERTIFICATE_SHA2_STORE_ARGS ?= /s "$(VBOX_CERTIFICATE_SHA2_STORE)" + VBOX_CERTIFICATE_SHA2_FINGERPRINT_ARGS := $(if-expr "$(VBOX_CERTIFICATE_SHA2_FINGERPRINT)" != "" \ + ,/sha1 "$(subst $(SP),,$(VBOX_CERTIFICATE_SHA2_FINGERPRINT))",) # Still using SHA-1 for fingerprinting, it's good enough for that! + #VBOX_CERTIFICATE_EV_SUBJECT_NAME ?= MyEvCertificate + VBOX_CERTIFICATE_EV_SUBJECT_NAME_ARGS ?= /n "$(VBOX_CERTIFICATE_EV_SUBJECT_NAME)" + VBOX_CERTIFICATE_EV_STORE ?= my + VBOX_CERTIFICATE_EV_STORE_ARGS ?= /s "$(VBOX_CERTIFICATE_EV_STORE)" + #VBOX_CERTIFICATE_EV_FINGERPRINT ?= my ev cert fingerprint + VBOX_CERTIFICATE_EV_FINGERPRINT_ARGS := $(if-expr "$(VBOX_CERTIFICATE_EV_FINGERPRINT)" != "" \ + ,/sha1 "$(subst $(SP),,$(VBOX_CERTIFICATE_EV_FINGERPRINT))",) # Still using SHA-1 for fingerprinting, it's good enough for that! + + ## Sign a file (generic). + # @param 1 The file to sign. + # @param 2 File description. Optional. + # @param 3 Additional parameters. Optional. + # @param 4 Set to 2 if the expression will be expanded twice before chopped into commands (for _CMDS). + # @param 5 Disables dual signing if non-empty, picking the SHA2 signature (since 2022-07-18). + # @param 6 non-zero for alternative command separator. This is used for generating repacking scripts. + ifndef VBOX_SIGN_FILE_FN + if $(intersects win all 1,$(VBOX_WITH_CORP_CODE_SIGNING)) + VBOX_SIGN_FILE_FN = $(call VBOX_CCS_SIGN_CMD,driver$(if-expr "$3" == "/ph",_pagehash,),$1,,-digest_algo $(if-expr "$5" == "",SHA1,SHA2)) \ + $(if-expr "$5" == "", \ + $(if-expr "$6" == "",$(if-expr "$4" == "2",$$(NLTAB),$(NLTAB)),$6) \ + $(call VBOX_CCS_SIGN_CMD,driver$(if-expr "$3" == "/ph",_pagehash,),$1,,-dual_sign -digest_algo SHA2)) + else ifdef VBOX_CERTIFICATE_SHA2_SUBJECT_NAME + ifdef VBOX_CERTIFICATE_SUBJECT_NAME + VBOX_SIGN_FILE_FN = $(if-expr "$5" == "",$(VBOX_SIGNTOOL_SHA1) \ + sign /fd sha1 \ + $(VBOX_CROSS_CERTIFICATE_FILE_ARGS) \ + $(VBOX_CERTIFICATE_STORE_ARGS) \ + $(VBOX_CERTIFICATE_SUBJECT_NAME_ARGS) \ + $(VBOX_CERTIFICATE_FINGERPRINT_ARGS) \ + $(VBOX_TSA_URL_ARGS) \ + $(if $(strip $(2)),/d "$(strip $(2))",) \ + $(3) \ + "$(1)" \ + $(if-expr "$6" == "",$(if-expr "$4" == "2",$$(NLTAB),$(NLTAB)),$6))$(VBOX_SIGNTOOL_SHA2) \ + sign $(if-expr "$5" == "",/as,) /fd sha256 \ + $(VBOX_CROSS_CERTIFICATE_SHA2_FILE_ARGS) \ + $(VBOX_CERTIFICATE_SHA2_STORE_ARGS) \ + $(VBOX_CERTIFICATE_SHA2_SUBJECT_NAME_ARGS) \ + $(VBOX_CERTIFICATE_SHA2_FINGERPRINT_ARGS) \ + $(VBOX_TSA_SHA2_URL_ARGS) \ + $(if $(strip $(2)),/d "$(strip $(2))",) \ + $(3) \ + "$(1)" + else + VBOX_SIGN_FILE_FN = $(VBOX_SIGNTOOL_SHA2) \ + sign /fd sha256 \ + $(VBOX_CROSS_CERTIFICATE_SHA2_FILE_ARGS) \ + $(VBOX_CERTIFICATE_SHA2_STORE_ARGS) \ + $(VBOX_CERTIFICATE_SHA2_SUBJECT_NAME_ARGS) \ + $(VBOX_CERTIFICATE_SHA2_FINGERPRINT_ARGS) \ + $(VBOX_TSA_SHA2_URL_ARGS) \ + $(if $(strip $(2)),/d "$(strip $(2))",) \ + $(3) \ + "$(1)" + endif + else + VBOX_SIGN_FILE_FN = $(VBOX_SIGNTOOL) \ + sign /fd $(firstword $(VBOX_TEST_SIGN_ALGORITHM) sha256) \ + $(VBOX_CROSS_CERTIFICATE_FILE_ARGS) \ + $(VBOX_CERTIFICATE_STORE_ARGS) \ + $(VBOX_CERTIFICATE_SUBJECT_NAME_ARGS) \ + $(VBOX_CERTIFICATE_FINGERPRINT_ARGS) \ + $(VBOX_TSA_URL_ARGS) \ + $(if $(strip $(2)),/d "$(strip $(2))",) \ + $(3) \ + "$(1)" + endif + endif + + ## EV sign a file (generic). + # @param 1 The file to sign. + # @param 2 The directory to put the signed file in. Defaults to $(dir $1). + ifndef VBOX_SIGN_EV_FILE_FN + if $(intersects win_ev all 1,$(VBOX_WITH_CORP_CODE_SIGNING)) + VBOX_SIGN_EV_FILE_FN = $(call VBOX_CCS_SIGN_CMD,microsoftev,$1,$(if $2,$2,)) + else ifdef VBOX_CERTIFICATE_EV_SUBJECT_NAME + VBOX_SIGN_EV_FILE_FN = $(VBOX_SIGNTOOL_SHA2) \ + sign /fd sha256 \ + $(VBOX_CERTIFICATE_EV_STORE_ARGS) \ + $(VBOX_CERTIFICATE_EV_SUBJECT_NAME_ARGS) \ + $(VBOX_CERTIFICATE_EV_FINGERPRINT_ARGS) \ + $(VBOX_TSA_SHA2_URL_ARGS) \ + "$(1)" + endif + endif + + ## Local SHA-1 and SHA-256 signatures with EV SHA-256 signature from corp code signing. + # + # This builds on Plan B, since the corp code signing always replaces existing + # signatures. Since we're signing more, though, we do things slightly differently + # so we can apply this to VBOX_RTSIGNTOOL as well - only that didn't work because + # kmk tries to help windows caching images it executes. So HACK ALERT on that. + # + # So, here is what we do. + # 1. Sign $1 using the regular signing, probably dual signing it using local certs. + # 2. Make temporary copy of $1 as $1.dual + # 3. Do SHA-256 corp code signing of $1 + # 4. Add the SHA-256 signature from $1 to $1.dual using bldRTSignTool. + # 5. Replace $1 with $1.dual. + # + # @param 1 The file to sign. + # @param 2 File description. Optional. + # @param 3 Additional parameters. Optional. + # @param 4 Set to 2 if the expression will be expanded twice before chopped into commands (for _CMDS). + # @param 5 Disables dual & tripple signing if non-empty. + # @param 6 Disables tripple signing if non-empty. + # + # @remarks The parameters are the same as VBOX_SIGN_FILE_FN. + VBOX_SIGN_IMAGE_WITH_EV_FN = $(call VBOX_SIGN_FILE_FN,$1,$2,$3,$4,$5)$(if-expr "$5" == "" && "$(target)" != "bldRTSignTool", \ + $(if-expr "$4" == "2",$$(NLTAB),$(NLTAB))$(RM) -f -- "$1.dual" \ + $(if-expr "$4" == "2",$$(NLTAB),$(NLTAB))$(CP) -- "$1" "$1.dual" \ + $(if-expr "$4" == "2",$$(NLTAB),$(NLTAB))$(call VBOX_CCS_SIGN_CMD,microsoftev,$1,,-digest_algo SHA2) \ + $(if-expr "$4" == "2",$$(NLTAB),$(NLTAB))$(VBOX_RTSIGNTOOL) add-nested-$(if-expr "$(suffix $1)" == ".cat",cat,exe)-signature -v "$1.dual" "$1" \ + $(if-expr "$4" == "2",$$(NLTAB),$(NLTAB))$(MV) -f -- "$1.dual" "$1" \ + ,) + + + ## Corp code signing for drivers and catalogs, plan B. + # + # Since the corp code signing cannot dual signing and doesn't even have a + # SHA-1 cert, we have to get creative: + # 1. Sign $1 using local SHA-1 certificate. + # 2. Make temporary copy of $1 as $1.ccs + # 3. Do SHA-256 corp code signing of $1.ccs + # 4. Add the SHA-256 signature from $1.ccs to $1 using bldRTSignTool. + # 5. Delete $1.ccs. + # + # @param 1 The file to sign. + # @param 2 File description. Optional. + # @param 3 Additional parameters. Optional. + # @param 4 Set to 2 if the expression will be expanded twice before chopped into commands (for _CMDS). + # @param 5 Disables dual signing if non-empty. + # + # @remarks The parameters are the same as VBOX_SIGN_FILE_FN. + VBOX_SIGN_IMAGE_PLAN_B_FN = $(VBOX_SIGNTOOL_SHA1) \ + sign /fd sha1 \ + $(VBOX_CROSS_CERTIFICATE_FILE_ARGS) \ + $(VBOX_CERTIFICATE_STORE_ARGS) \ + $(VBOX_CERTIFICATE_SUBJECT_NAME_ARGS) \ + $(VBOX_CERTIFICATE_FINGERPRINT_ARGS) \ + $(VBOX_TSA_URL_ARGS) \ + $(if $(strip $(2)),/d "$(strip $(2))",) \ + $(3) \ + "$(1)" \ + $(if-expr "$5" == "", \ + $(if-expr "$4" == "2",$$(NLTAB),$(NLTAB))$(RM) -f -- "$1.ccs" \ + $(if-expr "$4" == "2",$$(NLTAB),$(NLTAB))$(CP) -- "$1" "$1.ccs" \ + $(if-expr "$4" == "2",$$(NLTAB),$(NLTAB))$(call VBOX_CCS_SIGN_CMD,driver$(if-expr "$3" == "/ph",_pagehash,),$1.ccs,,-digest_algo SHA2) \ + $(if-expr "$4" == "2",$$(NLTAB),$(NLTAB))$(VBOX_RTSIGNTOOL) add-nested-$(if-expr "$(suffix $1)" == ".cat",cat,exe)-signature -v "$1" "$1.ccs" \ + $(if-expr "$4" == "2",$$(NLTAB),$(NLTAB))$(RM) -f -- "$1.ccs" \ + ,) + + ## Sign an executable image. + # @param 1 The file to sign. + # @param 2 File description. Optional. + # @param 3 Set to 2 if the expression will be expanded twice before chopped into commands (for _CMDS). + if1of (win_with_ev, $(VBOX_WITH_CORP_CODE_SIGNING)) + VBOX_SIGN_IMAGE_FN ?= $(call VBOX_SIGN_IMAGE_WITH_EV_FN,$(1),$(2),/ph,$(3)) + VBOX_SIGN_IMAGE_ORDERDEPS ?= $(VBOX_RTSIGNTOOL) $(VBOX_SIGNTOOL_ORDERDEPS) + else + VBOX_SIGN_IMAGE_FN ?= $(call VBOX_SIGN_FILE_FN,$(1),$(2),/ph,$(3)) + VBOX_SIGN_IMAGE_ORDERDEPS ?= $(VBOX_SIGNTOOL_ORDERDEPS) + endif + + ## Commands for signing a driver image after link. + if $(intersects win_planb,$(VBOX_WITH_CORP_CODE_SIGNING)) + VBOX_SIGN_DRIVER_CMDS ?= $(if $(eq $(tool_do),LINK_LIBRARY),,$(call VBOX_SIGN_IMAGE_PLAN_B_FN,$(out),,/ph,2)) + VBOX_SIGN_DRIVER_ORDERDEPS ?= $(VBOX_RTSIGNTOOL) $(VBOX_SIGNTOOL_ORDERDEPS) + else + VBOX_SIGN_DRIVER_CMDS ?= $(if $(eq $(tool_do),LINK_LIBRARY),,$(call VBOX_SIGN_IMAGE_FN,$(out),,2)) + VBOX_SIGN_DRIVER_ORDERDEPS ?= $(if $(eq $(tool_do),LINK_LIBRARY),,$(VBOX_SIGN_IMAGE_ORDERDEPS)) + endif + + ## Create a security catalog file. + # @param 1 The directory containing the stuff to sign. + # @param 2 The expected .cat name. (Inf2Cat lowercases it) + # @param 3 The list of OSes, separated by ';'. + ifndef VBOX_MAKE_CAT_HLP_FN + VBOX_MAKE_CAT_HLP_FN = \ + $(RM) -f -- "$(2)" \ + $(NL)$(TAB)$(VBOX_INF2CAT) "/driver:$(strip $(1))" "/os:$(strip $(subst ;,$(COMMA),$(3)))" /verbose \ + $(NL)$(TAB)$(MV) -- "$(2)" "$(2)" + if $(intersects win_planb,$(VBOX_WITH_CORP_CODE_SIGNING)) + VBOX_MAKE_CAT_HLP_FN += $(NL)$(TAB)$(call VBOX_SIGN_IMAGE_PLAN_B_FN,$(2),,,$(NL)$(TAB)) + else + VBOX_MAKE_CAT_HLP_FN += $(NL)$(TAB)$(call VBOX_SIGN_FILE_FN,$(2),,,$(NL)$(TAB)) + endif + endif + VBOX_MAKE_CAT64_FN ?= $(call VBOX_MAKE_CAT_HLP_FN,$(1),$(2),XP_X64;Server2003_X64;Vista_X64) + VBOX_MAKE_CAT32_FN ?= $(call VBOX_MAKE_CAT_HLP_FN,$(1),$(2),2000;XP_X86;Server2003_X86;Vista_X86) + ifeq ($(KBUILD_TARGET_ARCH),x86) + VBOX_MAKE_CAT_FN ?= $(call VBOX_MAKE_CAT32_FN,$(1),$(2)) + else + VBOX_MAKE_CAT_FN ?= $(call VBOX_MAKE_CAT64_FN,$(1),$(2)) + endif + + # Go nuts, sign everything. + if "$(VBOX_SIGNING_MODE)" == "release" || defined(VBOX_WITH_HARDENING) + ## Commands for signing an executable or a dll image after link. + VBOX_SIGN_IMAGE_CMDS ?= $(if $(eq $(tool_do),LINK_LIBRARY),,$(call VBOX_SIGN_IMAGE_FN,$(out),,2)) + VBOX_SIGN_IMAGE_CMDS_ORDERDEPS ?= $(if $(eq $(tool_do),LINK_LIBRARY),,$(VBOX_SIGN_IMAGE_ORDERDEPS)) + endif + ## Enable signing of the additions drivers, i.e. create CAT files. + ## @todo r=bird: This bugger is entirely misplaced, as it belongs in the additions config section so it can be properly overriden. + VBOX_SIGN_ADDITIONS ?= 1 + ## Set if we should include the legacy timestamp CA. + ifndef VBOX_WITH_VBOX_LEGACY_TS_CA + if "$(findstring 805af82410a4827b71f59479a222670391bec2d5,$(VBOX_TSA_URL_ARGS))" != "" + VBOX_WITH_VBOX_LEGACY_TS_CA = 1 + endif + endif + + else ifeq ($(KBUILD_HOST),darwin) + + ## Sign a VM process binary with the given entitlements + # @param 1 The file to sign. + # @param 2 Identifier, optional. + ifeq ($(VBOX_SIGNING_MODE),adhoc) + if $(intersects darwin all 1,$(VBOX_WITH_CORP_CODE_SIGNING)) + ## @todo cannot handle $(2), the identifier. + VBOX_SIGN_IMAGE_FN = $(call MSG_TOOL,SIGNTOOL,,$(1),$(2))$(NLTAB) \ + $(call VBOX_CCS_SIGN_CMD,binary,$(1),,$(subst --entitlements=,-entitlement_file_path ,$(3)) \ + $(if $(VBOX_WITH_MACOS_HARDENED_RUNTIME),-hardened_runtime)) + else + VBOX_SIGN_IMAGE_FN = $(call MSG_TOOL,SIGNTOOL,,$(1),$(2))$(NLTAB)$(VBOX_CODESIGN) \ + --verbose=9 \ + --force \ + $(if-expr $(KBUILD_HOST_VERSION_MAJOR) <= 14,--digest-algorithm sha256,) \ + $(if $(VBOX_WITH_MACOS_HARDENED_RUNTIME),$(if-expr $(KBUILD_HOST_VERSION_MAJOR) <= 16,--options 0x10000,--options runtime)) \ + --file-list - \ + $(if-expr defined(VBOX_TSA_URL),--timestamp="$(VBOX_TSA_URL)") \ + $(VBOX_CERTIFICATE_SUBJECT_NAME_ARGS) \ + --entitlements="$(VBOX_DARWIN_ENTITLEMENTS_FILE)" \ + "$(1)" \ + $(if $(2),--identifier "$(2)",) + endif + else + VBOX_SIGN_IMAGE_FN = + endif + + # + # Darwin code signing. + # + # Currently release signing is done when packing. This may change later. + # (Installer package signing is done elsewhere (VBOX_MACOSX_INSTALLER_SIGN).) + # + if defined(VBOX_CERTIFICATE_FINGERPRINT) && !defined(VBOX_CERTIFICATE_SUBJECT_NAME) + VBOX_CERTIFICATE_SUBJECT_NAME = $(subst $(SP),,$(VBOX_CERTIFICATE_FINGERPRINT)) + endif + ifeq ($(VBOX_SIGNING_MODE),test) + VBOX_CERTIFICATE_SUBJECT_NAME ?= $(error You need to set VBOX_CERTIFICATE_SUBJECT_NAME in LocalConfig.kmk.) + VBOX_CERTIFICATE_SUBJECT_NAME_ARGS ?= --sign "$(VBOX_CERTIFICATE_SUBJECT_NAME)" + VBOX_TSA_URL ?= none + else ifeq ($(VBOX_SIGNING_MODE),adhoc) + ifdef VBOX_CERTIFICATE_SUBJECT_NAME + $(error VBOX_CERTIFICATE_SUBJECT_NAME must not be set in 'adhoc' signing mode) + endif + VBOX_CERTIFICATE_SUBJECT_NAME = - + VBOX_CERTIFICATE_SUBJECT_NAME_ARGS ?= --sign "$(VBOX_CERTIFICATE_SUBJECT_NAME)" + VBOX_TSA_URL ?= none + VBOX_SIGN_IMAGE_CMDS ?= $(if $(eq $(tool_do),LINK_LIBRARY),,$(call VBOX_SIGN_IMAGE_FN,$(out),,2)) + else + VBOX_CERTIFICATE_SUBJECT_NAME ?= Developer ID Application: Oracle America, Inc. + VBOX_CERTIFICATE_SUBJECT_NAME_ARGS ?= --sign "$(VBOX_CERTIFICATE_SUBJECT_NAME)" + endif + + VBOX_CODESIGN ?= codesign + if 0 + VBOX_DARWIN_KEXT_SIGN_FILES = CodeDirectory CodeRequirement CodeResources CodeSignature + else + VBOX_DARWIN_KEXT_SIGN_FILES = CodeResources + endif + + # Always enable the hardened runtime when signing. Can be disabled if + # trying to build on quite old macOS, which will likely need some effort. + VBOX_WITH_MACOS_HARDENED_RUNTIME ?= 1 + + ## + # Corp Code Notarization command line. Modifies the file because the tickets are stapled. + # @param 1 The file to be submitted for signing. + # @param 2 Identifier, mandatory. + # @param 3 The directory to put the notarized file in. Defaults to $(dir $1). + VBOX_CCS_NOTARIZE_CMD = $(VBOX_RETRY) $(VBOX_JAVA) -jar "$(VBOX_CCS_CLIENT_JAR)" \ + mac_notarize -user "$(VBOX_CCS_USER)" -global_uid "$(VBOX_CCS_GLOBAL_UID)" \ + -job_timeout 90 -server_timeout 75 -server "$(VBOX_CCS_SERVER)" \ + -file_to_notarize "$1" -bundle_id "$2" -download_location "$(if $3,$3,$(call VBOX_DIRX,$1))" + + ## Sign an application bundle, framework or kernel extension. + # @param 1 The bundle to sign. + # @param 2 Identifier, optional. + # @param 3 Additional codesign command line parameters, optional. + if $(intersects darwin all 1,$(VBOX_WITH_CORP_CODE_SIGNING)) + ## @todo cannot handle $(2), the identifier. + ## @todo $(3) is hopefully either empty, --deep or --entitlements=... + VBOX_SIGN_BUNDLE_FN = $(call MSG_TOOL,SIGNTOOL,,$(1),$(2))$(NLTAB) \ + ditto -c -k --keepParent "$(1)" "$(1).zip"$(NLTAB) \ + $(call VBOX_CCS_SIGN_CMD,apple,$(1).zip,,$(subst --entitlements=,-entitlement_file_path ,$(subst --deep,-deep,$(3))) \ + $(if $(VBOX_WITH_MACOS_HARDENED_RUNTIME),-hardened_runtime))$(NLTAB) \ + ditto -x -k "$(1).zip" "$(1)/../"$(NLTAB) \ + $(RM) -f -- "$(1).zip" + else + VBOX_SIGN_BUNDLE_FN = $(call MSG_TOOL,SIGNTOOL,,$(1),$(2))$(NLTAB)$(VBOX_CODESIGN) \ + --verbose=9 \ + --force \ + $(if-expr $(KBUILD_HOST_VERSION_MAJOR) <= 14,--digest-algorithm sha256,) \ + $(if $(VBOX_WITH_MACOS_HARDENED_RUNTIME),$(if-expr $(KBUILD_HOST_VERSION_MAJOR) <= 16,--options 0x10000,--options runtime)) \ + --file-list - \ + $(if-expr defined(VBOX_TSA_URL),--timestamp="$(VBOX_TSA_URL)") \ + $(3) \ + $(VBOX_CERTIFICATE_SUBJECT_NAME_ARGS) \ + "$(1)" $(if $(2),--identifier "$(2)",) + endif + + ## Sign a Mach-O image. + # @param 1 The file to sign. + # @param 2 Identifier, optional. + # @param 3 Additional codesign command line parameters, optional. + if $(intersects darwin all 1,$(VBOX_WITH_CORP_CODE_SIGNING)) + ## @todo cannot handle $(2), the identifier. + ## @todo $(3) is hopefully either empty or --entitlements=... + VBOX_SIGN_MACHO_FN = $(call MSG_TOOL,SIGNTOOL,,$(1),$(2))$(NLTAB) \ + $(call VBOX_CCS_SIGN_CMD,binary,$(1),,$(subst --entitlements=,-entitlement_file_path ,$(3)) \ + $(if $(VBOX_WITH_MACOS_HARDENED_RUNTIME),-hardened_runtime)) + else + VBOX_SIGN_MACHO_FN = $(call MSG_TOOL,SIGNTOOL,,$(1),$(2))$(NLTAB)$(VBOX_CODESIGN) \ + --verbose=9 \ + --force \ + $(if-expr $(KBUILD_HOST_VERSION_MAJOR) <= 14,--digest-algorithm sha256,) \ + $(if $(VBOX_WITH_MACOS_HARDENED_RUNTIME),$(if-expr $(KBUILD_HOST_VERSION_MAJOR) <= 16,--options 0x10000,--options runtime)) \ + --file-list - \ + $(if-expr defined(VBOX_TSA_URL),--timestamp="$(VBOX_TSA_URL)") \ + $(VBOX_CERTIFICATE_SUBJECT_NAME_ARGS) \ + $(3) \ + "$(1)" \ + $(if $(2),--identifier "$(2)",) + endif + + ## Commands for signing an extpack dylib file after link. + if $(intersects darwin all 1,$(VBOX_WITH_CORP_CODE_SIGNING)) + VBOX_SIGN_EXTPACK_DYLIB_CMDS ?= $(if $(eq $(tool_do),LINK_LIBRARY),, \ + $(call VBOX_CCS_SIGN_CMD,binary,$(out),, \ + $(if $(VBOX_WITH_MACOS_HARDENED_RUNTIME),-hardened_runtime)) ) + else + VBOX_SIGN_EXTPACK_DYLIB_CMDS ?= $(if $(eq $(tool_do),LINK_LIBRARY),, \ + $(VBOX_CODESIGN) \ + --verbose=9 \ + --force \ + $(if-expr $(KBUILD_HOST_VERSION_MAJOR) <= 14,--digest-algorithm sha256,) \ + $(if $(VBOX_WITH_MACOS_HARDENED_RUNTIME),$(if-expr $(KBUILD_HOST_VERSION_MAJOR) <= 16,--options 0x10000,--options runtime)) \ + --file-list - \ + $(if-expr defined(VBOX_TSA_URL),--timestamp="$(VBOX_TSA_URL)") \ + $(VBOX_CERTIFICATE_SUBJECT_NAME_ARGS) \ + $(out) ) + endif + + ## Sign a VMM Mach-O image. + # @param 1 The file to sign. + # @param 2 Identifier, optional. + VBOX_SIGN_VMM_MOD_FN = $(VBOX_SIGN_MACHO_FN) + + ## Sign a non-executable file. + # @param 1 The file to sign. + # @param 2 Identifier, optional. + if $(intersects darwin all 1,$(VBOX_WITH_CORP_CODE_SIGNING)) + ## @todo cannot handle $(2), the identifier. + VBOX_SIGN_FILE_FN = $(call MSG_TOOL,SIGNTOOL,,$(1),$(2))$(NLTAB) \ + $(call VBOX_CCS_SIGN_CMD,mac_dmg,$(1))$(NLTAB) \ + $(REDIRECT) -E 'LC_ALL=C' -we "$(1).tmp" -- ditto -x -k -V "$(1).zip" "$(call VBOX_DIRX,$(1))"$(NLTAB) \ + dirname="$(call VBOX_DIRX,$(1))$(DOLLAR)($(SED) -n -e 's+^copying file \([0-9]\{1,\}\)/.\{1,\}$(DOLLAR)+\1+p' "$(1).tmp")" ; \ + $(MV) -f -- "$(DOLLAR)dirname/$(DOLLAR)(basename "$(1)")" "$(call VBOX_DIRX,$(1))" ; \ + $(RM) -Rf -- "$(DOLLAR)dirname/"$(NLTAB) \ + $(RM) -f -- "$(1).zip" "$(1).tmp" + else + VBOX_SIGN_FILE_FN = $(call MSG_TOOL,SIGNTOOL,,$(1),$(2))$(NLTAB)$(VBOX_CODESIGN) \ + --verbose=9 \ + --force \ + $(if-expr $(KBUILD_HOST_VERSION_MAJOR) <= 14,--digest-algorithm sha256,) \ + --file-list=- \ + $(if-expr defined(VBOX_TSA_URL),--timestamp="$(VBOX_TSA_URL)") \ + $(if $(2),--identifier "$(2)",) \ + $(VBOX_CERTIFICATE_SUBJECT_NAME_ARGS) \ + "$(1)" + endif + + ## Sign a DMG image. + # @param 1 The file to sign. + # @param 2 Identifier, optional. + # @note Will segfault if --file-list is used on 10.15.2 (kSecCodeInfoChangedFiles -> NULL, outputter doesn't check for NULL). + if $(intersects darwin all 1,$(VBOX_WITH_CORP_CODE_SIGNING)) + VBOX_SIGN_DMG_FN = $(call MSG_TOOL,SIGNTOOL,,$(1),$(2))$(NLTAB)$(call VBOX_CCS_SIGN_CMD,binary,$(1)) + else + VBOX_SIGN_DMG_FN = $(filter-out --file-list=-,$(VBOX_SIGN_FILE_FN)) + endif + + ## Sign a PKG file. Used with corp code signing only. + # @param 1 The file to sign. + # @param 2 Identifier, optional. + if $(intersects darwin all 1,$(VBOX_WITH_CORP_CODE_SIGNING)) + ## @todo cannot handle $(2), the identifier. + VBOX_SIGN_PKG_FN = $(call MSG_TOOL,SIGNTOOL,,$(1),$(2))$(NLTAB)$(call VBOX_CCS_SIGN_CMD,mac_pkg,$(1)) + endif + + ## Notarize a file (usually DMG, can also be PKG). Used with corp code signing only. + # @param 1 The file to notarize. + # @param 2 Identifier, mandatory. + if $(intersects darwin darwin_notarize all 1,$(VBOX_WITH_CORP_CODE_SIGNING)) + VBOX_NOTARIZE_FILE_FN = $(call MSG_TOOL,SIGNTOOL,,$(1),$(2))$(NLTAB)$(call VBOX_CCS_NOTARIZE_CMD,$(1),$(2)) + endif + + ## @def VBOX_TEST_SIGN_KEXT + # Adds test signing to a $1.kext target (the plist installer target). + # + # After both targets has been defined: + # $(evalcall2 VBOX_TEST_SIGN_KEXT,VBoxDrv) + # + # @param 1 The kext name. Assumes there is a SYSMODS target of name $1 + # as well as an .plist installer by the name of '$1.kext'. + # @remarks Currently assumes only binary + Info.plist in the bundle, no + # other files. Should there be more, add them as a list in + # a 2nd parameter. + # @note This is only for the 'test' signing mode, we skip this in + # 'release' signing mode as to not waste time on the build boxes. + ifeq ($(VBOX_SIGNING_MODE),test) ## @todo when kBuild is updated to r2742+, this should be enabled for both modes. + define VBOX_TEST_SIGN_KEXT + $1_INSTTYPE.darwin = none + + $1.kext_SOURCES += $$($1.kext_0_OUTDIR)/Contents/MacOS/$1=>MacOS/$1 \ + $(foreach extfile, $(VBOX_DARWIN_KEXT_SIGN_FILES) \ + , $$($1.kext_0_OUTDIR)/Contents/_CodeSignature/$(extfile)=>_CodeSignature/$(extfile)) + $1.kext_SYMLINKS += $(foreach symfile, $(VBOX_DARWIN_KEXT_SIGN_SYMLINKS), $(symfile)=>_CodeSignature/$(symfile)) + $1.kext_CLEAN += \ + $(foreach extfile, $(VBOX_DARWIN_KEXT_SIGN_FILES) , $$($1.kext_0_OUTDIR)/Contents/_CodeSignature/$(extfile)) \ + $(foreach symfile, $(VBOX_DARWIN_KEXT_SIGN_SYMLINKS), $$($1.kext_0_OUTDIR)/Contents/$(symfile)) \ + $$($1.kext_0_OUTDIR)/Contents/MacOS/$1 \ + $$($1.kext_0_OUTDIR)/$1.kext/Contents/_CodeSignature/ + $1.kext_BLDDIRS += $$($1.kext_0_OUTDIR)/Contents/MacOS/ + + $$$$($1.kext_0_OUTDIR)/Contents/MacOS/$1 \ + + $(foreach file,$(VBOX_DARWIN_KEXT_SIGN_FILES), $$$$($1.kext_0_OUTDIR)/Contents/_CodeSignature/$(file)): \ + $$$$($1.kext_0_OUTDIR)/Contents/Info.plist $$$$($1_1_TARGET) | $$$$($1.kext_0_OUTDIR)/ + $(RM) -Rf -- "$$($1.kext_0_OUTDIR)/Contents/_CodeSignature/" "$$($1.kext_0_OUTDIR)/Contents/MacOS/" + $(MKDIR) -p -- "$$($1.kext_0_OUTDIR)/Contents/MacOS/" + $(INSTALL) -m 644 $$($1_1_TARGET) $$($1.kext_0_OUTDIR)/Contents/MacOS/$1 + $(call VBOX_SIGN_BUNDLE_FN,$$($1.kext_0_OUTDIR),org.virtualbox.app.kext.$1,) + endef + else + VBOX_TEST_SIGN_KEXT = + endif + + + else ifeq ($(KBUILD_HOST),solaris) + # + # Solaris code signing. + # + ifeq ($(VBOX_SIGNING_MODE),test) + VBOX_CERTIFICATE_FILE ?= $(error You need to set VBOX_CERTIFICATE_FILE in LocalConfig.kmk.) + VBOX_TOKEN_NAME ?= $(error You need to set VBOX_TOKEN_NAME in LocalConfig.kmk.) + VBOX_PIN_FILE ?= $(error You need to set VBOX_PIN_FILE in LocalConfig.kmk.) + else + VBOX_CERTIFICATE_FILE ?= $(PATH_ROOT)/oracle.pem + VBOX_TOKEN_NAME ?= "Sun Software PKCS\#11 softtoken" + VBOX_PIN_FILE ?= $(PATH_ROOT)/oracle.pin + endif + VBOX_CERTIFICATE_FILE_ARGS ?= -c $(VBOX_CERTIFICATE_FILE) + VBOX_TOKEN_NAME_ARGS ?= -T $(VBOX_TOKEN_NAME) + VBOX_PIN_ARGS ?= -P $(VBOX_PIN_FILE) + + VBOX_ELFSIGN ?= elfsign + + # Sign an ELF image. + # @param 1 The elf object file to sign. + VBOX_SIGN_ELF_FN ?= $(VBOX_ELFSIGN) \ + sign \ + $(VBOX_CERTIFICATE_FILE_ARGS) \ + $(VBOX_TOKEN_NAME_ARGS) \ + $(VBOX_PIN_ARGS) \ + -e "$(1)" + + ## Commands for signing a driver image after link. + if $(intersects solaris all 1,$(VBOX_WITH_CORP_CODE_SIGNING)) + VBOX_SIGN_DRIVER_CMDS ?= $(if $(eq $(tool_do),LINK_LIBRARY),,$(call VBOX_CCS_SIGN_CMD,solaris_elf,$(out))) + else + VBOX_SIGN_DRIVER_CMDS ?= $(if $(eq $(tool_do),LINK_LIBRARY),,$(call VBOX_SIGN_ELF_FN,$(out))) + endif + + else + # Not Windows, Mac OS X or Solaris build host, ignore. + VBOX_SIGNING_MODE := + endif + + # + # Complain if windows hardening is enabled but not code signing. + # +else if "$(KBUILD_TARGET)" == "win" && defined(VBOX_WITH_HARDENING) && !defined(VBOX_ONLY_BUILD) + $(error You need to enable code signing for a hardened windows build to work.) +endif + +# +# Windows .inf editing. +# +ifeq ($(KBUILD_TARGET_ARCH),x86) + VBOX_EDIT_INF_FN = $(call VBOX_EDIT_INF32_FN,$(1),$(2)) +else + VBOX_EDIT_INF_FN = $(call VBOX_EDIT_INF64_FN,$(1),$(2)) +endif +## Edit an inf file an x86 target. +# @param 1 The inf file to edit. +# @param 2 The output file. +VBOX_EDIT_INF32_FN = $(SED) $(if $(VBOX_SIGNING_MODE),-e 's/^;cat *//', -e '/^;cat /d') \ + -e 's/^;x86 *//' \ + -e '/^;amd64 /d' \ + -e 's/@DOT-NT-ARCH@/.NTx86/g' \ + -e 's/@COMMA-NT-ARCH@/,NTx86/g' \ + -e 's/^;edit-DriverVer.*/DriverVer = $(date-utc %m\/%d\/%Y),$(VBOX_VERSION_MAJOR).$(VBOX_VERSION_MINOR).$(VBOX_VERSION_BUILD).$(expr $(VBOX_SVN_REV) % 50000) ; r$(VBOX_SVN_REV)/' \ + --output $(2) \ + $(1) +## Edit an inf file an x86 target. +# @param 1 The inf file to edit. +# @param 2 The output file. +VBOX_EDIT_INF64_FN = $(SED) \ + $(if $(VBOX_SIGNING_MODE),-e 's/^;cat *//', -e '/^;cat /d') \ + -e 's/^;amd64 *//' \ + -e '/^;x86 /d' \ + -e 's/@DOT-NT-ARCH@/.NTAMD64/g' \ + -e 's/@COMMA-NT-ARCH@/,NTAMD64/g' \ + -e 's/^;edit-DriverVer.*/DriverVer = $(date-utc %m\/%d\/%Y),$(VBOX_VERSION_MAJOR).$(VBOX_VERSION_MINOR).$(VBOX_VERSION_BUILD).$(expr $(VBOX_SVN_REV) % 50000) ; r$(VBOX_SVN_REV)/' \ + --output $(2) \ + $(1) + +## @def VBOX_RE_SIGN_DLL_FN +# Helper macro for re-signing DLL images from tools that we ship so they won't +# cause trouble for the hardened build requirements. +# +# Invoke via $(call VBOX_RE_SIGN_DLL_FN) inside the SOURCES list. Necessary +# _CLEAN entry will be added to the target. If hardening is not enabled or +# we're not on windows, the source will be returned. +# +# @returns Name of the output file name. May have leading space, but no trailing. +# @param 1 Target name. +# @param 2 The source name. +# @param 3 Optional prefix to avoid name collisions. +# +if defined(VBOX_SIGNING_MODE) && "$(KBUILD_TARGET)" == "win" + if1of (quote, $(KMK_FEATURES)) + VBOX_RE_SIGN_DLL_FN = $(if-expr !defined($(1)_VBOX_RE_SIGNED_$(3)$(qnotdir ,$(2))), \ + $(evalcall VBOX_RE_SIGN_DLL_INTERNAL_FN,$1,$2,$3) \ + ,)$($(1)_0_OUTDIR)/$(3)$(qnotdir ,$2) + + define VBOX_RE_SIGN_DLL_INTERNAL_FN + local n = $(3)$(qnotdir ,$2) + ifndef $(1)_VBOX_RE_SIGNED_$(n) + $(1)_VBOX_RE_SIGNED_$(n) := 1 + $(eval $(1)_CLEAN += $$($(1)_0_OUTDIR)/$(n)) + + $$($(1)_0_OUTDIR)/$(n): $(2) $(VBOX_VERSION_STAMP) | $$(dir $$@) $(VBOX_SIGN_IMAGE_ORDERDEPS) + $(call MSG_TOOL,SIGNTOOL,,$<,$@) + $(RM) -f -- "$@" + $(CP) -- "$(quote-sh-dq $<)" "$@" + $(CHMOD) a+rw -- "$@" + $(VBOX_VCC_EDITBIN) /LargeAddressAware /DynamicBase /NxCompat /Release /IntegrityCheck \ + /Version:$(VBOX_VERSION_MAJOR)0$(VBOX_VERSION_MINOR).$(VBOX_VERSION_BUILD) \ + "$@" + $(call VBOX_SIGN_IMAGE_FN,$@) + endif + endef # VBOX_RE_SIGN_DLL_INTERNAL_FN + + else # old kmk: no quote feature + VBOX_RE_SIGN_DLL_FN = $(if-expr !defined($(1)_VBOX_RE_SIGNED_$(3)$(notdir $(2))), \ + $(evalcall VBOX_RE_SIGN_DLL_INTERNAL_FN,$1,$2,$3) \ + ,)$($(1)_0_OUTDIR)/$(3)$(notdir $2) + define VBOX_RE_SIGN_DLL_INTERNAL_FN + local n = $(3)$(notdir $2) + ifndef $(1)_VBOX_RE_SIGNED_$(n) + $(1)_VBOX_RE_SIGNED_$(n) := 1 + $(eval $(1)_CLEAN += $$($(1)_0_OUTDIR)/$(n)) + + $$($(1)_0_OUTDIR)/$(n): $(2) $(VBOX_VERSION_STAMP) | $$(dir $$@) $(VBOX_SIGN_IMAGE_ORDERDEPS) + $(call MSG_TOOL,SIGNTOOL,,$<,$@) + $(RM) -f -- "$@" + $(CP) -- "$<" "$@" + $(CHMOD) a+rw -- "$@" + $(VBOX_VCC_EDITBIN) /LargeAddressAware /DynamicBase /NxCompat /Release /IntegrityCheck \ + /Version:$(VBOX_VERSION_MAJOR)0$(VBOX_VERSION_MINOR).$(VBOX_VERSION_BUILD) \ + "$@" + $(call VBOX_SIGN_IMAGE_FN,$@) + endif + endef # VBOX_RE_SIGN_DLL_INTERNAL_FN + endif # old kmk: no quote feature +else + VBOX_RE_SIGN_DLL_FN = $(2) +endif + + +# +# File version info and description macros (ignored on most OSes). +# + +## +# Internal macro. +# +# @param 1 The target name. +# @param 2 The description +# @param 3 Optional icon file. +# @param 4 The template base name. +# @param 5 Additional RC options. +# @param 6 Original filename to use. +# +# @remarks ASSUMES RCFLAGS isn't a simple variable (var := value). +define VBOX_SET_VER_INFO_INTERNAL + ifeq ($(KBUILD_TARGET),win) + $(1)_SOURCES.win += $(PATH_ROOT)/src/VBox/Artwork/win/$(4) + $(1)_RCFLAGS += /nologo /dIN_INTERNAL_NAME="\"$(1)\"" /dIN_FILE_DESCRIPTION="\"$(2)\"" \ + /dIN_ORIGINAL_NAME="\"$(if $(6),$6,$$(notdir $$($(1)_1_INST_TARGET)))\"" \ + $(if $(3), /dIN_ICON_FILE="\"$(subst \\,/,$(strip $(3)))\"") $(5) + $$$$($(1)_0_OUTDIR)/src/VBox/Artwork/win/$(basename $(4)).res: \ + $(PATH_ROOT)/include/VBox/version.h $$$$(VBOX_VERSION_HEADER) + endif +endef + +## +# Macro for setting DLL/SO/DYLIB version information and description. +# +# The macro must be invoked using evalcall2 after the whole target has +# been declared. +# +# @param 1 The target name. +# @param 2 The description +# @param 3 Optional icon file. +VBOX_SET_VER_INFO_DLL = $(evalcall2 VBOX_SET_VER_INFO_INTERNAL,$1,$2,$3,TemplateDll.rc,) + +## +# Macro for setting EXE version information and description. +# +# The macro must be invoked using call after the whole target has been declared. +# +# @param 1 The target name. +# @param 2 The description +# @param 3 Optional icon file. +# @param 4 Optional OriginalFilename value to use. Defaults to target name w/o dir. +VBOX_SET_VER_INFO_EXE = $(evalcall2 VBOX_SET_VER_INFO_INTERNAL,$1,$2,$3,TemplateExe.rc,,$4) + +## +# Macro for setting driver version information and description. +# +# The macro must be invoked using call after the whole target has been declared. +# +# @param 1 The target name. +# @param 2 The description +# @param 3 Optional icon file. +# @param 4 Optional VFT2_DRV_xxx define for windows. Uses VFT2_UNKNOWN by default. +VBOX_SET_VER_INFO_DRV = $(evalcall2 VBOX_SET_VER_INFO_INTERNAL,$1,$2,$3,TemplateDrv.rc,$(if $(4), /dIN_FILE_SUBTYPE=$(4))) + +## +# Macro for setting the version information and description for a ring-0 module. +# +# The macro must be invoked using call after the whole target has been declared. +# +# @param 1 The target name. +# @param 2 The description +# @param 3 Optional icon file. +VBOX_SET_VER_INFO_R0 = $(evalcall2 VBOX_SET_VER_INFO_INTERNAL,$1,$2,$3,TemplateR0.rc,) + +## +# Macro for setting the version information and description for a raw-mode context module. +# +# The macro must be invoked using call after the whole target has been declared. +# +# @param 1 The target name. +# @param 2 The description +# @param 3 Optional icon file. +VBOX_SET_VER_INFO_RC = $(evalcall2 VBOX_SET_VER_INFO_INTERNAL,$1,$2,$3,TemplateRc.rc,) + + + +# +# Adjust kBuild defaults. +# +kBuildGlobalDefaults_DEBUG_NOSTAGE.win = true +kBuildGlobalDefaults_DEBUG_NOSTAGE.os2 = true +if1of ($(KBUILD_TARGET), darwin win) + kBuildGlobalDefaults_LD_DEBUG = split +endif + + +# +# Haiku resource and version generation. +# +ifeq ($(KBUILD_HOST),haiku) + VBOX_HAIKU_RCTOOL := rc + VBOX_HAIKU_XRESTOOL := xres + VBOX_HAIKU_SETVERSIONTOOL := setversion + # XXX: install won't preserve attributes... + VBOX_HAIKU_MIMESETTOOL := mimeset + + ## Add optional resources to the program, set its version info, and sniff its mime properties. + # @param 1 The file to add resources to. + # @param 2 The resource files. + # @param 3 The target name. + define VBOX_HAIKU_XRES_SETVER_FN + $(if $(2),$(call MSG_TOOL,HaikuAddResources,$(3),$(2)) + $(QUIET)$(VBOX_HAIKU_XRESTOOL) -o $(1) $(2),) + $(call MSG_TOOL,HaikuSetVersion,$(3)) + $(QUIET)$(VBOX_HAIKU_SETVERSIONTOOL) $(1) \ + -app $(VBOX_VERSION_MAJOR) $(VBOX_VERSION_MINOR) $(VBOX_VERSION_BUILD) d $(VBOX_SVN_REV) \ + -short "$(VBOX_PRODUCT)" \ + -long "$(VBOX_PRODUCT) $(VBOX_VERSION_STRING) $(shell /bin/echo -e '\xC2\xA9')2009-$(VBOX_C_YEAR) $(VBOX_VENDOR)" + $(call MSG_TOOL,HaikuMimeSet,$(3)) + $(QUIET)$(VBOX_HAIKU_MIMESETTOOL) -f $(1) + endef + + VBOX_HAIKU_XRES_SETVER_CMDS ?= $(if $(eq $(tool_do),LINK_PROGRAM),$(call VBOX_HAIKU_XRES_SETVER_FN,$(out),$($(target)_RSRCS),$(target)),) +endif + +# +# Default prefixes and suffixes. +# +VBOX_PREF_LIB = +if1of ($(KBUILD_TARGET), os2 win) + VBOX_SUFF_LIB = .lib +else + VBOX_SUFF_LIB = .a +endif +if1of ($(KBUILD_HOST), os2 win) + VBOX_HOSTSUFF_LIB = .lib +else + VBOX_HOSTSUFF_LIB = .a +endif +VBOX_SUFF_DLL = $(SUFF_DLL) +ifeq ($(KBUILD_TARGET),os2) # GXX3OMF produces out .o at the moment. + VBOX_SUFF_OBJ = .o +else + VBOX_SUFF_OBJ = $(SUFF_OBJ) +endif +VBOXW32GUEST_SUFF_LIB = .lib +VBOXLNX32GUEST_SUFF_LIB = .a + +# +# SDKs for external libraries. +# +ifdef VBOX_WITH_DXVK + SDK_VBoxDxVk := Direct3D 9/10/11 to Vulkan - for dll linking. + SDK_VBoxDxVk_DEFAULT_INCS := \ + $(PATH_ROOT)/src/libs/dxvk-native-1.9.2a/include/native/directx \ + $(PATH_ROOT)/src/libs/dxvk-native-1.9.2a/include/native/windows + SDK_VBoxDxVk_INCS ?= $(SDK_VBoxDxVk_DEFAULT_INCS) + # Loaded dynamically + SDK_VBoxDxVk_LIBS ?= +endif + +ifdef VBOX_WITH_LIBCURL + SDK_VBoxLibCurl := libcurl for dll linking. + SDK_VBoxLibCurl_INCS ?= $(PATH_ROOT)/src/libs/curl-8.4.0/include + SDK_VBoxLibCurl_LIBS ?= $(PATH_STAGE_LIB)/VBox-libcurl$(VBOX_SUFF_LIB) + SDK_VBoxLibCurl_DEFS ?= BUILDING_LIBCURL + + SDK_VBoxLibCurl-x86 = libcurl/x86 for dll linking. + SDK_VBoxLibCurl-x86_INCS ?= $(PATH_ROOT)/src/libs/curl-8.4.0/include + SDK_VBoxLibCurl-x86_LIBS.x86 ?= $(PATH_STAGE_LIB)/VBox-libcurl-x86$(VBOX_SUFF_LIB) + SDK_VBoxLibCurl-x86_DEFS ?= BUILDING_LIBCURL +endif + +SDK_VBoxLibPng := protable network graphics (png) library for dll linking. +SDK_VBoxLibPng_INCS ?= $(PATH_ROOT)/src/libs/libpng-1.6.37 +SDK_VBoxLibPng_LIBS ?= $(PATH_STAGE_LIB)/VBox-libpng$(VBOX_SUFF_LIB) + +# lzf +SDK_VBoxLzf := lzf compressor/decompressor for dll linking. +SDK_VBoxLzf_INCS ?= $(PATH_ROOT)/src/libs/liblzf-3.6 +SDK_VBoxLzf_LIBS ?= $(PATH_STAGE_LIB)/VBox-liblzf$(VBOX_SUFF_LIB) + +SDK_VBoxLzf-x86 := lzf/x86 compressor/decompressor for dll linking. +SDK_VBoxLzf-x86_EXTENDS := VBoxLzf +SDK_VBoxLzf_LIBS-x86 ?= $(PATH_STAGE_LIB)/VBox-liblzf-x86$(VBOX_SUFF_LIB) + +SDK_VBoxLzf_STATIC := lzf compressor/decompressor for static linking. +SDK_VBoxLzf_STATIC_EXTENDS := VBoxLzf +if1of ($(KBUILD_TARGET), os2 win) + SDK_VBoxLzf_STATIC_LIBS := $(PATH_STAGE_LIB)/VBox-liblzf-static$(VBOX_SUFF_LIB) +endif + +# openssl +SDK_VBoxOpenSslStatic := OpenSSL - Only for VBoxRT and/or statically linked programs. +SDK_VBoxOpenSslStatic_VBOX_DEFAULT_INCS := $(PATH_OUT)/obj/crypto-3.1.4-headers/include +SDK_VBoxOpenSslStatic_INCS ?= $(SDK_VBoxOpenSslStatic_VBOX_DEFAULT_INCS) +SDK_VBoxOpenSslStatic_ORDERDEPS ?= $(crypto-headers_1_TARGET) +if !defined(VBOX_ONLY_SDK) \ + && (!defined(VBOX_ONLY_ADDITIONS) || !defined(VBOX_ONLY_ADDITIONS_WITHOUT_RTISOMAKER)) \ + && (!defined(VBOX_ONLY_EXTPACKS) || !defined(VBOX_ONLY_EXTPACKS_USE_IMPLIBS)) \ + && ("$(SDK_VBoxOpenSslStatic_INCS)" == "$(SDK_VBoxOpenSslStatic_VBOX_DEFAULT_INCS)") + SDK_VBoxOpenSslStatic_DEPS ?= $(SDK_VBoxOpenSslStatic_INCS)/openssl/openssl-mangling.h +endif +SDK_VBoxOpenSslStatic_LIBS ?= \ + $(PATH_STAGE_LIB)/VBox-libssl$(VBOX_SUFF_LIB) \ + $(PATH_STAGE_LIB)/VBox-libcrypto$(VBOX_SUFF_LIB) + +SDK_VBoxOpenSslStatic-x86 := OpenSSL/x86 - Only for VBoxRT and/or statically linked programs. +SDK_VBoxOpenSslStatic-x86_VBOX_DEFAULT_INCS := $(PATH_OUT)/obj/crypto-3.1.4-headers/include +SDK_VBoxOpenSslStatic-x86_INCS ?= $(SDK_VBoxOpenSslStatic_VBOX_DEFAULT_INCS) +SDK_VBoxOpenSslStatic-x86_ORDERDEPS ?= $(crypto-headers_1_TARGET) +if ("$(SDK_VBoxOpenSslStatic_INCS)" == "$(SDK_VBoxOpenSslStatic_VBOX_DEFAULT_INCS)") + SDK_VBoxOpenSslStatic-x86_DEPS ?= $(SDK_VBoxOpenSslStatic_INCS)/openssl/openssl-mangling.h +endif +SDK_VBoxOpenSslStatic-x86_LIBS ?= \ + $(PATH_STAGE_LIB)/VBox-libssl-x86$(VBOX_SUFF_LIB) \ + $(PATH_STAGE_LIB)/VBox-libcrypto-x86$(VBOX_SUFF_LIB) + +ifdef VBOX_WITH_BLD_RTSIGNTOOL_SIGNING + SDK_VBoxOpenSslBldProg := OpenSSL - Build tools verison (i.e. bldRTSignTool) + SDK_VBoxOpenSslBldProg_INCS ?= $(SDK_VBoxOpenSslStatic_VBOX_DEFAULT_INCS) + SDK_VBoxOpenSslBldProg_ORDERDEPS ?= $(crypto-headers_1_TARGET) + if !defined(VBOX_ONLY_SDK) \ + && ("$(SDK_VBoxOpenSslStatic_INCS)" == "$(SDK_VBoxOpenSslStatic_VBOX_DEFAULT_INCS)") + SDK_VBoxOpenSslBldProg_DEPS ?= $(SDK_VBoxOpenSslStatic_INCS)/openssl/openssl-mangling.h + endif + SDK_VBoxOpenSslBldProg_LIBS ?= \ + $(PATH_STAGE_LIB)/VBoxBldProg-libssl$(VBOX_SUFF_LIB) \ + $(PATH_STAGE_LIB)/VBoxBldProg-libcrypto$(VBOX_SUFF_LIB) +endif + +SDK_VBoxOpenSsl := This is what you should be using! It links against VBoxRT. +SDK_VBoxOpenSsl_EXTENDS := VBoxOpenSslStatic +if "$(SDK_VBoxOpenSslStatic_INCS)" == "$(SDK_VBoxOpenSslStatic_VBOX_DEFAULT_INCS)" + SDK_VBoxOpenSsl_LIBS = $(NO_SUCH_VARIABLE) +endif + +ifdef VBOX_WITH_LIBOGG + SDK_VBoxLibOgg := libogg for dll linking. + SDK_VBoxLibOgg_DEFAULT_INCS := $(PATH_ROOT)/src/libs/libogg-1.3.5/include + SDK_VBoxLibOgg_INCS ?= $(SDK_VBoxLibOgg_DEFAULT_INCS) + SDK_VBoxLibOgg_LIBS ?= $(PATH_STAGE_LIB)/VBox-libogg$(VBOX_SUFF_LIB) +endif + +ifdef VBOX_WITH_LIBVORBIS + SDK_VBoxLibVorbis := libvorbis for dll linking. + SDK_VBoxLibVorbis_DEFAULT_INCS := $(PATH_ROOT)/src/libs/libvorbis-1.3.7/include + SDK_VBoxLibVorbis_INCS ?= $(SDK_VBoxLibVorbis_DEFAULT_INCS) + SDK_VBoxLibVorbis_LIBS ?= $(PATH_STAGE_LIB)/VBox-libvorbis$(VBOX_SUFF_LIB) +endif + +# Our SoftFloat 3e variant. +SDK_VBoxSoftFloatR3Shared := SoftFloat 3 for dll linking. +SDK_VBoxSoftFloatR3Shared_DEFS := SOFTFLOAT_FAST_INT64 +SDK_VBoxSoftFloatR3Shared_DEFS.amd64 := LITTLEENDIAN +SDK_VBoxSoftFloatR3Shared_DEFS.arm64 := LITTLEENDIAN +SDK_VBoxSoftFloatR3Shared_DEFS.x86 := LITTLEENDIAN +if1of ($(KBUILD_TARGET), win) + SDK_VBoxSoftFloatR3Shared_DEFS += THREAD_LOCAL=__declspec(thread) +else + SDK_VBoxSoftFloatR3Shared_DEFS += THREAD_LOCAL=__thread +endif +SDK_VBoxSoftFloatR3Shared_INCS = \ + $(PATH_ROOT)/src/libs/softfloat-3e/source/include +SDK_VBoxSoftFloatR3Shared_LIBS = \ + $(PATH_STAGE_LIB)/VBox-SoftFloat$(VBOX_SUFF_LIB) + +SDK_VBoxSoftFloatR0 := SoftFloat 3 for ring-0 linking. +SDK_VBoxSoftFloatR0_DEFS := SOFTFLOAT_FAST_INT64 +SDK_VBoxSoftFloatR0_DEFS.amd64 := LITTLEENDIAN +SDK_VBoxSoftFloatR0_DEFS.arm64 := LITTLEENDIAN +SDK_VBoxSoftFloatR0_DEFS.x86 := LITTLEENDIAN +SDK_VBoxSoftFloatR0_INCS = \ + $(PATH_ROOT)/src/libs/softfloat-3e/source/include +SDK_VBoxSoftFloatR0_LIBS = \ + $(PATH_STAGE_LIB)/VBox-SoftFloatR0$(VBOX_SUFF_LIB) + +SDK_VBoxSoftFloatGuestR3Shared := SoftFloat 3 for ring-0 linking. +SDK_VBoxSoftFloatGuestR3Shared_DEFS := SOFTFLOAT_FAST_INT64 +SDK_VBoxSoftFloatGuestR3Shared_DEFS.amd64 := LITTLEENDIAN +SDK_VBoxSoftFloatGuestR3Shared_DEFS.arm64 := LITTLEENDIAN +SDK_VBoxSoftFloatGuestR3Shared_DEFS.x86 := LITTLEENDIAN +SDK_VBoxSoftFloatGuestR3Shared_INCS = \ + $(PATH_ROOT)/src/libs/softfloat-3e/source/include +SDK_VBoxSoftFloatGuestR3Shared_LIBS.x86 = \ + $(VBOX_PATH_ADDITIONS_LIB)/VBox-SoftFloatGuestR3Shared-x86$(VBOX_SUFF_LIB) +SDK_VBoxSoftFloatGuestR3Shared_LIBS.$(KBUILD_TARGET_ARCH) = \ + $(VBOX_PATH_ADDITIONS_LIB)/VBox-SoftFloatGuestR3Shared$(VBOX_SUFF_LIB) + +ifdef VBOX_WITH_LIBSSH + SDK_VBoxLibSsh := libssh for dynamic dll loading with assembly stubs. + SDK_VBoxLibSsh_INCS ?= $(PATH_ROOT)/src/libs/libssh-0.10.5/include + # SDK_VBoxLibSsh_LIBS is not defined, as VBoxLibSsh dll is not linked, but loaded explicitly + # by auto-generated stub code (lazy loading) +endif + +ifdef VBOX_WITH_LIBTPMS + SDK_VBoxLibTpms := libtpms for dll linking. + SDK_VBoxLibTpms_DEFAULT_INCS := $(PATH_ROOT)/src/libs/libtpms-0.9.6/include + SDK_VBoxLibTpms_INCS ?= $(SDK_VBoxLibTpms_DEFAULT_INCS) + SDK_VBoxLibTpms_LIBS ?= $(PATH_STAGE_LIB)/VBox-libtpms$(VBOX_SUFF_LIB) +endif + +ifdef VBOX_WITH_LIBVPX + SDK_VBoxLibVpx := libvpx for dll linking. + SDK_VBoxLibVpx_DEFAULT_INCS := $(PATH_ROOT)/src/libs/libvpx-1.11.0 + SDK_VBoxLibVpx_INCS ?= $(SDK_VBoxLibVpx_DEFAULT_INCS) + SDK_VBoxLibVpx_LIBS ?= $(PATH_STAGE_LIB)/VBox-libvpx$(VBOX_SUFF_LIB) +endif + +ifdef VBOX_WITH_LIBLZMA + SDK_VBoxLibLzma := liblzma for dll linking. + SDK_VBoxLibLzma_DEFAULT_INCS := $(PATH_ROOT)/src/libs/liblzma-5.4.1/api + SDK_VBoxLibLzma_INCS ?= $(SDK_VBoxLibLzma_DEFAULT_INCS) + SDK_VBoxLibLzma_LIBS ?= $(PATH_STAGE_LIB)/VBox-liblzma$(VBOX_SUFF_LIB) + + SDK_VBoxLibLzma-x86 := liblzma/x86 compressor/decompressor for dll linking. + SDK_VBoxLibLzma-x86_EXTENDS := VBoxLibLzma + SDK_VBoxLibLzma-x86_LIBS ?= $(PATH_STAGE_LIB)/VBox-liblzma-x86$(VBOX_SUFF_LIB) + + SDK_VBoxLibLzmaStatic := liblzma for static linking + SDK_VBoxLibLzmaStatic_EXTENDS := VBoxLibLzma + SDK_VBoxLibLzmaStatic_LIBS ?= $(PATH_STAGE_LIB)/VBox-liblzma-static$(VBOX_SUFF_LIB) +endif + +# libxml2 +SDK_VBoxLibXml2 := libxml2 for dll linking. +SDK_VBoxLibXml2_INCS ?= $(PATH_ROOT)/src/libs/libxml2-2.9.14/include +SDK_VBoxLibXml2_DEFS ?= _REENTRANT LIBXML_STATIC LIBXML_STATIC_FOR_DLL +SDK_VBoxLibXml2_DEFS.win ?= WIN32 _WINDOWS _MBCS HAVE_WIN32_THREADS HAVE_COMPILER_TLS +# Note: no linking to LIB here, we do that explicitly in src/VBox/Runtime/Makefile.kmk to link +# libxml against VBoxRT + +# zlib +SDK_VBoxZlib := zlib for dll linking. +if1of ($(KBUILD_TARGET), os2 solaris win) + SDK_VBoxZlib_INCS ?= $(PATH_ROOT)/src/libs/zlib-1.2.13 + SDK_VBoxZlib_LIBS ?= $(PATH_STAGE_LIB)/VBox-zlib$(VBOX_SUFF_LIB) +else + SDK_VBoxZlib_INCS ?= + SDK_VBoxZlib_LIBS ?= z + SDK_VBoxZlib_DEFS.linux ?= _LARGEFILE64_SOURCE +endif + +SDK_VBoxZlib-x86 := zlib/x86 +SDK_VBoxZlib-x86_EXTENDS = VBoxZlib +if1of ($(KBUILD_TARGET), os2 solaris win) + SDK_VBoxZlib_LIBS-x86 ?= $(PATH_STAGE_LIB)/VBox-zlib-x86$(VBOX_SUFF_LIB) +endif + +SDK_VBoxZlibStatic := zlib for static linking +SDK_VBoxZlibStatic_EXTENDS := VBoxZlib +if1of ($(KBUILD_TARGET), os2 win) # Not required on solaris. + SDK_VBoxZlibStatic_LIBS ?= $(PATH_STAGE_LIB)/VBox-zlib-static$(VBOX_SUFF_LIB) +endif + +# +# Special SDK for the problematic NTDLL.LIB. +# +SDK_VBoxNtDll := Mini NTDLL import library, required by IPRT. +SDK_VBoxNtDll_LIBS.x86 ?= $(PATH_STAGE_LIB)/RuntimeR3NtDll-x86.lib +SDK_VBoxNtDll_LIBS.amd64 ?= $(PATH_STAGE_LIB)/RuntimeR3NtDll-amd64.lib + +# +# SDK for including newdev.lib. +# It conceptually moved from the WDK to the PSDK with W10, as it's now in the um subdir. +# +SDK_VBoxWinNewDevLib := Abstracts where to find newdev.lib. +ifn1of ($(VBOX_WINPSDK), WINPSDK71 WINPSDK80) + SDK_VBoxWinNewDevLib_LIBS.x86 = $(PATH_SDK_$(VBOX_WINPSDK)_LIB.x86)/newdev.lib + SDK_VBoxWinNewDevLib_LIBS.amd64 = $(PATH_SDK_$(VBOX_WINPSDK)_LIB.amd64)/newdev.lib +else + SDK_VBoxWinNewDevLib_LIBS.x86 = $(PATH_SDK_$(VBOX_WINDDK)_LIB.x86)/newdev.lib + SDK_VBoxWinNewDevLib_LIBS.amd64 = $(PATH_SDK_$(VBOX_WINDDK)_LIB.amd64)/newdev.lib +endif + +# +# SDK for including int64.lib for x86 targets. +# It conceptually moved from the WDK to the PSDK with W10, as it's now in the um subdir. +# +SDK_VBoxWinInt64Lib := Abstracts where to find int64.lib for x86 builds. +ifn1of ($(VBOX_WINPSDK), WINPSDK71 WINPSDK80) + SDK_VBoxWinInt64Lib_LIBS.x86 = $(PATH_SDK_$(VBOX_WINPSDK)_LIB.x86)/int64.lib + ifeq ($(KBUILD_TARGET),win) + include $(KBUILD_PATH)/sdks/$(VBOX_WINPSDK).kmk ## TODO: Add a kBuild feature for loading SDKs. + endif +else + SDK_VBoxWinInt64Lib_LIBS.x86 = $(PATH_SDK_$(VBOX_WINDDK)_LIB.x86)/int64.lib + ifeq ($(KBUILD_TARGET),win) + include $(KBUILD_PATH)/sdks/$(VBOX_WINDDK).kmk ## TODO: Add a kBuild feature for loading SDKs. + endif +endif + +# +# Determine Solaris version. +# +ifeq ($(KBUILD_TARGET),solaris) + VBOX_SOLARIS_VERSION := $(expr $(KBUILD_HOST_VERSION_MAJOR) * 100 + $(KBUILD_HOST_VERSION_MINOR)) + ifeq ($(VBOX_SOLARIS_VERSION),510) + DEFS.solaris += RT_OS_SOLARIS_10 + # Solaris 10 does not include crossbow. + VBOX_SOLARIS_10 = 1 + # We cannot compile additions on Solaris 10, due kernel interface deps + VBOX_WITHOUT_ADDITIONS := 1 + VBOX_WITH_ADDITIONS = + else ifeq ($(VBOX_SOLARIS_VERSION),511) + # OSS audio support for Solaris + VBOX_WITH_AUDIO_OSS := 1 + endif + + # XPCOM namespace cleanup issue with Solaris GCC 4.5.2 and newer, see @bugref{5838}. + if $(VBOX_GCC_VERSION_CXX) >= 40502 + VBOX_WITH_XPCOM_NAMESPACE_CLEANUP = + endif +endif + +# +# VBoxTpG tool. +# +TOOL_VBoxTpG = The VirtualBox Tracepoint Generator +TOOL_VBoxTpG_DTRACE_DEPORD = $(VBOX_VBOXTPG) +TOOL_VBoxTpG_DTRACE_HDR_FLAGS := \ + -h --host-$(VBOX_HC_ARCH_BITS)-bit #-vvv +define TOOL_VBoxTpG_DTRACE_HDR_CMDS + $(QUIET)$(VBOX_VBOXTPG) $(if-expr $(intersects $(bld_trg_arch),$(KBUILD_ARCHES_64)),-64,-32) \ + $(flags) -o "$(out)" -s "$(source)" +endef +TOOL_VBoxTpG_DTRACE_OBJ_NOT_NEEDED := +TOOL_VBoxTpG_DTRACE_OBJ_FLAGS := -G --host-$(VBOX_HC_ARCH_BITS)-bit #-vvv +define TOOL_VBoxTpG_DTRACE_OBJ_CMDS + $(QUIET)$(VBOX_VBOXTPG) --assembler "$(TOOL_$(VBOX_ASTOOL)_AS)" \ + $(if-expr $(intersects $(bld_trg_arch),$(KBUILD_ARCHES_64)),-64,-32) \ + $(flags) \ + -o "$(out)" -s "$(source)" +endef + + +# +# VBoxTpG tool - Disabled, only generate the header. +# +TOOL_VBoxTpG-Disabled = The VirtualBox Tracepoint Generator, disabled. +TOOL_VBoxTpG-Disabled_DTRACE_DEPORD = $(VBOX_VBOXTPG) +TOOL_VBoxTpG-Disabled_DTRACE_HDR_FLAGS := -h +define TOOL_VBoxTpG-Disabled_DTRACE_HDR_CMDS + $(QUIET)$(VBOX_VBOXTPG) $(flags) -o "$(out)" -s "$(source)" +endef +TOOL_VBoxTpG-Disabled_DTRACE_OBJ_NOT_NEEDED := $(KBUILD_OSES) + + +# +# dtrace+VBoxTpG tool for ring-3 to ring-0 pointer conversion. +# +TOOL_DTraceAndVBoxTpG = DTrace and the VirtualBox Tracepoint Generator working together on static ring-3 probes. +TOOL_DTraceAndVBoxTpG_EXTENDS = StandardDTrace +TOOL_DTraceAndVBoxTpG_DTRACE_DEPORD = $(VBOX_VBOXTPG) +TOOL_DTraceAndVBoxTpG_DTRACE_HDR_CMDS = +define TOOL_DTraceAndVBoxTpG_DTRACE_HDR_CMDS + $(TOOL_StandardDTrace_DTRACE_HDR_CMDS) + $(QUIET)$(VBOX_VBOXTPG) --generate-wrapper-header --host-$(VBOX_HC_ARCH_BITS)-bit --ring-3-context \ + $(filter-out -C, $(filter-out -h,$(flags))) \ + -o "$(out).tmp" -s "$(source)" + $(APPEND) "$(out).tmp" + $(SED) -e 's/\(#define.*\)(arg0/\1_ORIGINAL(arg0/' --append "$(out).tmp" "$(out)" + $(MV) -f -- "$(out).tmp" "$(out)" +endef +TOOL_DTraceAndVBoxTpG_DTRACE_OBJ_NOT_NEEDED = $(TOOL_StandardDTrace_DTRACE_OBJ_NOT_NEEDED) +TOOL_DTraceAndVBoxTpG_DTRACE_OBJ_CMDS = $(TOOL_StandardDTrace_DTRACE_OBJ_CMDS) + + +ifdef VBOX_WITH_RAW_MODE + # + # Template for building RC things. + # + # Disabled Visual C++ warnings: + # -wd4505: 'iemRaisePageFaultJmp' : unreferenced local function has been removed + # + TEMPLATE_VBoxRc = VBox Raw-Mode Context + TEMPLATE_VBoxRc_ASTOOL := $(VBOX_ASTOOL) + TEMPLATE_VBoxRc_ASFLAGS = $(VBOX_ASFLAGS32) + TEMPLATE_VBoxRc_DEFS = IN_RC IPRT_NO_CRT RT_WITH_NOCRT_ALIASES $(ARCH_BITS_DEFS) + TEMPLATE_VBoxRc_INCS = $(PATH_ROOT)/include/iprt/nocrt + TEMPLATE_VBoxRc_SYSSUFF = .rc + TEMPLATE_VBoxRc_BLD_TRG_ARCH = x86 + TEMPLATE_VBoxRc_MODE = a+r,u+w + + TEMPLATE_VBoxRc_USES += dtrace + TEMPLATE_VBoxRc_DTRACE_HDR_FLAGS = --raw-mode-context + TEMPLATE_VBoxRc_DTRACE_OBJ_FLAGS = --raw-mode-context --probe-fn-name "VMMRCProbeFire" + ifdef VBOX_WITH_DTRACE_RC + TEMPLATE_VBoxRc_DTRACETOOL = VBoxTpG + TEMPLATE_VBoxRc_DEFS += VBOX_WITH_DTRACE VBOX_WITH_DTRACE_RC + else + TEMPLATE_VBoxRc_DTRACETOOL = VBoxTpG-Disabled + endif + + ifeq ($(VBOX_LDR_FMT32),pe) + TEMPLATE_VBoxRc_TOOL = $(VBOX_VCC_TOOL_STEM)X86 + TEMPLATE_VBoxRc_RCDEFS = VBOX_SVN_REV=$(VBOX_SVN_REV) VBOX_SVN_REV_MOD_5K=$(expr $(VBOX_SVN_REV) % 50000) + TEMPLATE_VBoxRc_CXXFLAGS = -Zi -Zl -GR- -EHs- -GF -GS- -Zc:wchar_t- -Gs8192 $(VBOX_VCC_GC_OPT) $(VBOX_VCC_GC_FP) \ + -Gy $(VBOX_VCC_WARN_ALL) -wd4505 $(VBOX_VCC_WERR) + if "$(VBOX_VCC_TOOL_STEM)" >= "VCC120" + TEMPLATE_VBoxRc_CXXFLAGS += -Gw + endif + ifdef VBOX_WITH_MSC_ANALYZE_THIS + TEMPLATE_VBoxRc_CXXFLAGS += /analyze + endif + TEMPLATE_VBoxRc_CFLAGS = $(TEMPLATE_VBoxRc_CXXFLAGS) + TEMPLATE_VBoxRc_LDFLAGS = -Ignore:4197 \ + -Driver -Subsystem:NATIVE -Incremental:NO -Align:64 -MapInfo:Exports -NoD $(VBOX_VCC_LD_WERR) -Release -Debug -Opt:Ref -Opt:Icf \ + -Version:$(VBOX_VERSION_MAJOR)0$(VBOX_VERSION_MINOR).$(VBOX_VERSION_BUILD) \ + -Stub:$(PATH_ROOT)/src/VBox/HostDrivers/Support/win/winstub.com + ifdef VBOX_SIGNING_MODE + TEMPLATE_VBoxRc_LDFLAGS += -IntegrityCheck + endif + TEMPLATE_VBoxRc_SDKS.x86 += VBoxWinInt64Lib + TEMPLATE_VBoxRc_LIBS += \ + $(PATH_STAGE_LIB)/RuntimeRCStub$(VBOX_SUFF_LIB) + TEMPLATE_VBoxRc_POST_CMDS = $(VBOX_SIGN_IMAGE_CMDS) + TEMPLATE_VBoxRc_ORDERDEPS = $(VBOX_SIGN_IMAGE_CMDS_ORDERDEPS) + endif # pe + + ifeq ($(VBOX_LDR_FMT32),elf) + TEMPLATE_VBoxRc_TOOL = $(VBOX_GCC32_TOOL) + TEMPLATE_VBoxRc_CXXFLAGS = -fno-pie -nostdinc -g $(VBOX_GCC_pipe) $(VBOX_GCC_WERR) $(VBOX_GCC_PEDANTIC_CXX) $(VBOX_GCC32_Wno-variadic-macros) -fno-exceptions $(VBOX_GCC_GC_OPT) $(VBOX_GCC_GC_FP) -mno-sse -mno-mmx -mno-sse2 -mno-3dnow -fno-strict-aliasing $(VBOX_GCC_fno-stack-protector) $(VBOX_GCC_fvisibility-hidden) $(VBOX_GCC_fvisibility-inlines-hidden) -fno-rtti $(VBOX_GCC_IPRT_FMT_CHECK) + TEMPLATE_VBoxRc_CFLAGS = -fno-pie -nostdinc -g $(VBOX_GCC_pipe) $(VBOX_GCC_WERR) $(VBOX_GCC_PEDANTIC_C) $(VBOX_GCC32_Wno-variadic-macros) -fno-exceptions $(VBOX_GCC_GC_OPT) $(VBOX_GCC_GC_FP) -mno-sse -mno-mmx -mno-sse2 -mno-3dnow -fno-strict-aliasing $(VBOX_GCC_fno-stack-protector) $(VBOX_GCC_fvisibility-hidden) $(VBOX_GCC_IPRT_FMT_CHECK) + if $(VBOX_GCC32_VERSION_CC) < 30400 + TEMPLATE_VBoxRc_DEFS += RT_WITHOUT_PRAGMA_ONCE + endif + ifeq ($(KBUILD_TARGET),solaris) + TEMPLATE_VBoxRc_LDFLAGS = -r + else + TEMPLATE_VBoxRc_LDFLAGS = -nostdlib -Bsymbolic -g + ## @todo WTF doesn't the globals work? Debug info is supposed to be split everywhere. GRR + TEMPLATE_VBoxRc_LD_DEBUG = split + endif + ifn1of ($(KBUILD_TARGET), solaris freebsd) + TEMPLATE_VBoxRc_LIBS = \ + $(VBOX_GCC32_LIBGCC) # intrinsics + endif + if1of ($(KBUILD_TARGET), linux) + TEMPLATE_VBoxRc_POST_CMDS = $(if $(eq $(tool_do),LINK_SYSMOD),if readelf -S $(out)|grep -q "[cd]tors"; then echo "Found ctors/dtors in $(out)!"; exit 1; fi) + endif + endif + + ifeq ($(VBOX_LDR_FMT32),macho) + TEMPLATE_VBoxRc_TOOL = $(VBOX_GCC_TOOL) + TEMPLATE_VBoxRc_SDKS += $(VBOX_DARWIN_DEF_SDK_SDKS) + TEMPLATE_VBoxRc_DEFS += $(VBOX_DARWIN_DEF_SDK_DEFS) + TEMPLATE_VBoxRc_CXXFLAGS = $(VBOX_DARWIN_DEF_SDK_CXXFLAGS) -m32 -nostdinc -g $(VBOX_GCC_pipe) $(VBOX_GCC_WERR) $(VBOX_GCC_PEDANTIC_CXX) $(VBOX_GCC32_Wno-variadic-macros) -fno-common -msoft-float -static $(VBOX_GCC_fno-stack-protector) -fno-exceptions $(VBOX_GCC_GC_OPT) $(VBOX_GCC_GC_FP) -fno-strict-aliasing -fno-rtti $(VBOX_GCC_std) + TEMPLATE_VBoxRc_CFLAGS = $(VBOX_DARWIN_DEF_SDK_CFLAGS) -m32 -nostdinc -g $(VBOX_GCC_pipe) $(VBOX_GCC_WERR) $(VBOX_GCC_PEDANTIC_C) $(VBOX_GCC32_Wno-variadic-macros) -fno-common -msoft-float -static $(VBOX_GCC_fno-stack-protector) -fno-exceptions $(VBOX_GCC_GC_OPT) $(VBOX_GCC_GC_FP) -fno-strict-aliasing + TEMPLATE_VBoxRc_LDFLAGS = $(VBOX_DARWIN_DEF_SDK_LDFLAGS) -m32 -nostdlib + #TEMPLATE_VBoxRc_LDFLAGS.release = -Wl,-S ??? + endif + + ifeq ($(VBOX_LDR_FMT32),lx) + TEMPLATE_VBoxRc_TOOL = GXX3OMF + if $(VBOX_GCC_VERSION_CC) < 30400 + TEMPLATE_VBoxRc_DEFS += RT_WITHOUT_PRAGMA_ONCE + endif + TEMPLATE_VBoxRc_CXXFLAGS = -nostdinc -g $(VBOX_GCC_pipe) $(VBOX_GCC_WERR) $(VBOX_GCC_PEDANTIC_CXX) $(VBOX_GCC32_Wno-variadic-macros) $(VBOX_GCC_GC_OPT) $(VBOX_GCC_GC_FP) -fno-strict-aliasing -fno-exceptions -fno-rtti + TEMPLATE_VBoxRc_CFLAGS = -nostdinc -g $(VBOX_GCC_pipe) $(VBOX_GCC_WERR) $(VBOX_GCC_PEDANTIC_C) $(VBOX_GCC32_Wno-variadic-macros) $(VBOX_GCC_GC_OPT) $(VBOX_GCC_GC_FP) -fno-strict-aliasing -fno-exceptions + TEMPLATE_VBoxRc_LDFLAGS = -Zdll -nostdlib + TEMPLATE_VBoxRc_LIBS = \ + $(VBOX_GCC32_LIBGCC) \ + $(VBOX_OBJ_SYS0) \ + end + endif + + + # + # Template for building a RC ring-3 testcase (tstVMStructGC, tstDevStructGC). + # + TEMPLATE_VBoxRcExe = VBox Raw-Mode as ring-3 testcase + TEMPLATE_VBoxRcExe_EXTENDS = VBoxRc + TEMPLATE_VBoxRcExe_DEFS = $(filter-out IPRT_NO_CRT RT_WITH_NOCRT_ALIASES,$(TEMPLATE_VBoxRc_DEFS)) + TEMPLATE_VBoxRcExe_INCS = $(NO_SUCH_VARIABLE) + TEMPLATE_VBoxRcExe_MODE = $(NO_SUCH_VARIABLE) + + ifeq ($(VBOX_LDR_FMT32),pe) + TEMPLATE_VBoxRcExe_LDFLAGS = -Ignore:4197 \ + -Incremental:NO -MapInfo:Exports -NoD -Debug -Opt:Ref -Opt:Icf \ + -Version:$(VBOX_VERSION_MAJOR)0$(VBOX_VERSION_MINOR).$(VBOX_VERSION_BUILD) \ + -Stub:$(PATH_ROOT)/src/VBox/HostDrivers/Support/win/winstub.com + TEMPLATE_VBoxRcExe_SDKS = ReorderCompilerIncs $(VBOX_WINPSDK) + TEMPLATE_VBoxRcExe_LIBS = \ + $(PATH_TOOL_$(VBOX_VCC_TOOL_STEM)X86_LIB)/libcmt.lib \ + $(PATH_TOOL_$(VBOX_VCC_TOOL_STEM)X86_LIB)/oldnames.lib + endif + + ifeq ($(VBOX_LDR_FMT32),elf) + TEMPLATE_VBoxRcExe_CFLAGS = $(filter-out -nostdinc,$(TEMPLATE_VBoxRc_CFLAGS)) -O0 + TEMPLATE_VBoxRcExe_CXXFLAGS = $(filter-out -nostdinc,$(TEMPLATE_VBoxRc_CXXFLAGS)) -O0 + TEMPLATE_VBoxRcExe_LDFLAGS = -g + TEMPLATE_VBoxRcExe_LDFLAGS.dbgopt = -g + TEMPLATE_VBoxRcExe_LDFLAGS.strict = -g + TEMPLATE_VBoxRcExe_LDFLAGS.release = -g + if1of ($(KBUILD_TARGET).$(KBUILD_TARGET_ARCH), freebsd.amd64) + # The FreeBSD port of gcc isn't picking up -m32 where it should. + TEMPLATE_VBoxRcExe_DEFS.$(KBUILD_TARGET) = $(TEMPLATE_VBoxRc_DEFS.$(KBUILD_TARGET)) IPRT_DONT_USE_SYSTEM_STDINT_H + TEMPLATE_VBoxRcExe_LDFLAGS.$(KBUILD_TARGET) = /usr/lib32/crt1.o /usr/lib32/crti.o /usr/lib32/crtbegin.o $(TEMPLATE_VBoxRc_LDFLAGS.$(KBUILD_TARGET)) -nostdlib -v + TEMPLATE_VBoxRcExe_LIBPATH.$(KBUILD_TARGET) = /usr/lib32 + TEMPLATE_VBoxRcExe_LIBS.$(KBUILD_TARGET) = /usr/lib32/crtend.o /usr/lib32/crtn.o /usr/lib32/libc.so + endif + endif + + ifeq ($(VBOX_LDR_FMT32),macho) + TEMPLATE_VBoxRcExe_CFLAGS = $(filter-out -static -nostdinc,$(TEMPLATE_VBoxRc_CFLAGS)) + TEMPLATE_VBoxRcExe_CXXFLAGS = $(filter-out -static -nostdinc,$(TEMPLATE_VBoxRc_CXXFLAGS)) + TEMPLATE_VBoxRcExe_LDFLAGS = -g -m32 + endif + + ifeq ($(VBOX_LDR_FMT32),lx) + TEMPLATE_VBoxRcExe_CFLAGS = $(filter-out -nostdinc,$(TEMPLATE_VBoxRc_CFLAGS)) + TEMPLATE_VBoxRcExe_CXXFLAGS = $(filter-out -nostdinc,$(TEMPLATE_VBoxRc_CXXFLAGS)) + TEMPLATE_VBoxRcExe_LDFLAGS = -g + TEMPLATE_VBoxRcExe_LIBS = $(NO_SUCH_VARIABLE) + endif +endif # VBOX_WITH_RAW_MODE + + +# +# Template for building R0 things. +# +# Disabled Visual C++ warnings: +# -wd4505: 'iemRaisePageFaultJmp' : unreferenced local function has been removed +# +TEMPLATE_VBoxR0 = VBox Ring 0 +TEMPLATE_VBoxR0_ASTOOL := $(VBOX_ASTOOL) +TEMPLATE_VBoxR0_ASFLAGS = $(VBOX_ASFLAGS) +TEMPLATE_VBoxR0_DEFS = IN_RING0 IN_RING0_AGNOSTIC IPRT_NO_CRT RT_WITH_NOCRT_ALIASES $(ARCH_BITS_DEFS) +TEMPLATE_VBoxR0_INCS = $(PATH_ROOT)/include/iprt/nocrt +TEMPLATE_VBoxR0_SYSSUFF = .r0 +TEMPLATE_VBoxR0_MODE = a+r,u+w + +TEMPLATE_VBoxR0_USES += dtrace +TEMPLATE_VBoxR0_DTRACE_HDR_FLAGS = --ring-0-context-agnostic +TEMPLATE_VBoxR0_DTRACE_OBJ_FLAGS = --ring-0-context-agnostic +ifdef VBOX_WITH_DTRACE_R0 + TEMPLATE_VBoxR0_DTRACETOOL = VBoxTpG + TEMPLATE_VBoxR0_DEFS += VBOX_WITH_DTRACE VBOX_WITH_DTRACE_R0 +else + TEMPLATE_VBoxR0_DTRACETOOL = VBoxTpG-Disabled +endif +ifdef VBOX_WITH_R0_MOD_IBT_BRANCH_PROTECTION + TEMPLATE_VBoxR0_DEFS += RT_WITH_IBT_BRANCH_PROTECTION RT_WITH_IBT_BRANCH_PROTECTION_WITHOUT_NOTRACK +endif + +ifeq ($(VBOX_LDR_FMT),pe) + TEMPLATE_VBoxR0_TOOL = $(VBOX_VCC_TOOL) + TEMPLATE_VBoxR0_RCDEFS = VBOX_SVN_REV=$(VBOX_SVN_REV) VBOX_SVN_REV_MOD_5K=$(expr $(VBOX_SVN_REV) % 50000) + TEMPLATE_VBoxR0_CXXFLAGS = -Zi -Zl -GR- -EHs- -GF -GS- -Zc:wchar_t- $(VBOX_VCC_OPT) $(VBOX_VCC_FP) \ + -Gy $(VBOX_VCC_CC_GUARD_CF) $(VBOX_VCC_std) $(VBOX_VCC_WARN_ALL) -wd4505 $(VBOX_VCC_WERR) + if "$(VBOX_VCC_TOOL_STEM)" >= "VCC120" + TEMPLATE_VBoxR0_CXXFLAGS += -Gw + endif + if "$(VBOX_VCC_TOOL_STEM)" >= "VCC142" # Don't waste space on x86/amd64-on-arm emulation optimizations. + TEMPLATE_VBoxR0_CXXFLAGS += /volatileMetadata- + endif + ifdef VBOX_WITH_MSC_ANALYZE_THIS + TEMPLATE_VBoxR0_CXXFLAGS += /analyze + endif + TEMPLATE_VBoxR0_CFLAGS = $(filter-out $(VBOX_VCC_std),$(TEMPLATE_VBoxR0_CXXFLAGS)) + TEMPLATE_VBoxR0_LDFLAGS = -Ignore:4197 \ + -Driver -Subsystem:NATIVE -Incremental:NO -Align:4096 -MapInfo:Exports -NoD $(VBOX_VCC_LD_WERR) \ + -Release -Debug -Opt:Ref -Opt:Icf $(VBOX_VCC_LD_GUARD_CF) \ + -Version:$(VBOX_VERSION_MAJOR)0$(VBOX_VERSION_MINOR).$(VBOX_VERSION_BUILD) \ + -Stub:$(PATH_ROOT)/src/VBox/HostDrivers/Support/win/winstub.com + ifdef VBOX_WITH_DTRACE_R0 + TEMPLATE_VBoxR0_LDFLAGS += -Merge:VTGPrLc.Data=VTGPrLc.Begin -Merge:VTGPrLc.End=VTGPrLc.Begin -Merge:VTGPrLc.Begin=VTGObj + endif + ifdef VBOX_SIGNING_MODE + TEMPLATE_VBoxR0_LDFLAGS += -IntegrityCheck + endif + if "$(VBOX_VCC_TOOL_STEM)" >= "VCC142" # Don't waste space on x86/amd64-on-arm emulation optimizations. + TEMPLATE_VBoxR0_LDFLAGS += -EmitVolatileMetadata:NO + endif + TEMPLATE_VBoxR0_LDFLAGS.win.amd64 = $(VBOX_VCC_LD_HIGH_ENTRYOPY_VA) + ifneq ($(VBOX_VCC_CC_GUARD_CF),) + TEMPLATE_VBoxR0_LDFLAGS.win.amd64 += -Include:__security_init_cookie -Export:ModuleInitSecurityCookie=__security_init_cookie + TEMPLATE_VBoxR0_LDFLAGS.win.x86 += -Include:___security_init_cookie -Export:ModuleInitSecurityCookie=__security_init_cookie + endif + TEMPLATE_VBoxR0_LIBS = \ + $(PATH_STAGE_LIB)/RuntimeR0Stub$(VBOX_SUFF_LIB) + ifneq ($(VBOX_VCC_CC_GUARD_CF),) + TEMPLATE_VBoxR0_LIBS += \ + $(PATH_SDK_$(VBOX_WINDDK)_LIB)/BufferOverflowK.lib + include $(KBUILD_PATH)/sdks/$(VBOX_WINDDK).kmk ## TODO: Add a kBuild feature for loading SDKs. + endif + TEMPLATE_VBoxR0_SDKS.x86 += VBoxWinInt64Lib + TEMPLATE_VBoxR0_ORDERDEPS = $(VBOX_SIGN_DRIVER_ORDERDEPS) + TEMPLATE_VBoxR0_POST_CMDS = $(VBOX_SIGN_DRIVER_CMDS) +endif # pe + +ifeq ($(VBOX_LDR_FMT),elf) + TEMPLATE_VBoxR0_TOOL = $(VBOX_GCC_TOOL) + TEMPLATE_VBoxR0_CFLAGS = -fno-pie -nostdinc -g $(VBOX_GCC_pipe) $(VBOX_GCC_WERR) $(VBOX_GCC_PEDANTIC_C) \ + $(VBOX_GCC_Wno-variadic-macros) $(VBOX_GCC_R0_OPT) $(VBOX_GCC_R0_FP) -fno-strict-aliasing -fno-exceptions \ + $(VBOX_GCC_fno-stack-protector) -fno-common -ffreestanding $(VBOX_GCC_fvisibility-hidden) -std=gnu99 $(VBOX_GCC_IPRT_FMT_CHECK) + TEMPLATE_VBoxR0_CXXFLAGS = -fno-pie -nostdinc -g $(VBOX_GCC_pipe) $(VBOX_GCC_WERR) $(VBOX_GCC_PEDANTIC_CXX) \ + $(VBOX_GCC_Wno-variadic-macros) $(VBOX_GCC_R0_OPT) $(VBOX_GCC_R0_FP) -fno-strict-aliasing -fno-exceptions \ + $(VBOX_GCC_fno-stack-protector) -fno-common $(VBOX_GCC_fvisibility-inlines-hidden) $(VBOX_GCC_fvisibility-hidden) \ + -fno-rtti $(VBOX_GCC_std) $(VBOX_GCC_IPRT_FMT_CHECK) + if $(VBOX_GCC_VERSION_CC) >= 40500 # 4.1.2 complains, 4.5.2 is okay, didn't check which version inbetween made it okay with g++. + TEMPLATE_VBoxR0_CXXFLAGS += -ffreestanding + endif + TEMPLATE_VBoxR0_CFLAGS.amd64 = -m64 -mno-red-zone -mno-sse -mno-mmx -mno-sse2 -mno-3dnow -fasynchronous-unwind-tables -ffreestanding + TEMPLATE_VBoxR0_CXXFLAGS.amd64 = -m64 -mno-red-zone -mno-sse -mno-mmx -mno-sse2 -mno-3dnow -fasynchronous-unwind-tables + TEMPLATE_VBoxR0_CXXFLAGS.freebsd = -ffreestanding + if $(VBOX_GCC_VERSION_CC) < 30400 + TEMPLATE_VBoxR0_DEFS += RT_WITHOUT_PRAGMA_ONCE + endif + ifeq ($(KBUILD_TARGET),solaris) + TEMPLATE_VBoxR0_LDFLAGS = -r + TEMPLATE_VBoxR0_LDFLAGS.solaris = -u _init -u _info + TEMPLATE_VBoxR0_LDFLAGS.solaris.amd64 = -m64 + TEMPLATE_VBoxR0_LDFLAGS.solaris.x86 = -m32 + TEMPLATE_VBoxR0_LIBS.solaris = \ + $(PATH_STAGE_LIB)/RuntimeR0Stub$(VBOX_SUFF_LIB) + ifdef VBOX_GCC_USING_SOLARIS_AS + TEMPLATE_VBoxR0_CFLAGS.amd64 += -Wa,-xmodel=kernel + TEMPLATE_VBoxR0_CXXFLAGS.amd64 += -Wa,-xmodel=kernel + endif + # Solaris driver signing. + TEMPLATE_VBoxR0_POST_CMDS = $(VBOX_SIGN_DRIVER_CMDS) + else + TEMPLATE_VBoxR0_LDFLAGS = -nostdlib -Bsymbolic -g + ## @todo WTF doesn't the globals work? Debug info is supposed to be split everywhere. GRR + TEMPLATE_VBoxR0_LD_DEBUG = split + endif + if "$(KBUILD_TARGET)" == "linux" && !defined(VBOX_WITH_KMOD_WRAPPED_R0_MODS) + VBOX_WITH_VBOXR0_AS_DLL = 1 + TEMPLATE_VBoxR0_DLLSUFF = .r0 + TEMPLATE_VBoxR0_CFLAGS += -fPIC + TEMPLATE_VBoxR0_CXXFLAGS += -fPIC + TEMPLATE_VBoxR0_LDFLAGS += + TEMPLATE_VBoxR0_DTRACE_HDR_FLAGS += --pic + TEMPLATE_VBoxR0_DTRACE_OBJ_FLAGS += --pic + else + TEMPLATE_VBoxR0_CFLAGS.amd64 += -mcmodel=kernel + TEMPLATE_VBoxR0_CXXFLAGS.amd64 += -mcmodel=kernel + endif + ifdef VBOX_WITH_KMOD_WRAPPED_R0_MODS # For BTF/pahold issue we use -g1 + TEMPLATE_VBoxR0_DEFS += VBOX_WITH_KMOD_WRAPPED_R0_MODS + TEMPLATE_VBoxR0_LDFLAGS.linux += $(PATH_ROOT)/src/VBox/HostDrivers/Support/linux/VBoxR0-wrapped.lds + TEMPLATE_VBoxR0_LNK_DEPS.linux += $(PATH_ROOT)/src/VBox/HostDrivers/Support/linux/VBoxR0-wrapped.lds + TEMPLATE_VBoxR0_CFLAGS.linux += -g1 + TEMPLATE_VBoxR0_CXXFLAGS.linux += -g1 + endif + ifdef VBOX_WITH_R0_MOD_IBT_BRANCH_PROTECTION + TEMPLATE_VBoxR0_CFLAGS += $(VBOX_GCC_fcf-protection_branch) -fno-jump-tables + TEMPLATE_VBoxR0_CXXFLAGS += $(VBOX_GCC_fcf-protection_branch) -fno-jump-tables + TEMPLATE_VBoxR0_LDFLAGS += $(VBOX_GCC_fcf-protection_branch) $(VBOX_GCC_fcf-protection_check) + ifeq ($(VBOX_GCC_fcf-protection_branch),) + $(warning VBox: VBOX_WITH_R0_MOD_IBT_BRANCH_PROTECTION is set but gcc doesn't support branch protection) + endif + endif + ifn1of ($(KBUILD_TARGET), solaris freebsd) + TEMPLATE_VBoxR0_LIBS = \ + $(VBOX_GCC_LIBGCC) # intrinsics + endif + if1of ($(KBUILD_TARGET), linux) + TEMPLATE_VBoxR0_POST_CMDS += $(NLTAB) \ + $(if $(eq $(tool_do),LINK_SYSMOD),if readelf -S $(out)|grep -q "[cd]tors"; then echo "Found ctors/dtors in $(out)!"; exit 1; fi) + endif +endif # elf + +ifeq ($(VBOX_LDR_FMT),macho) + TEMPLATE_VBoxR0_TOOL = $(VBOX_GCC_TOOL) + TEMPLATE_VBoxR0_SDKS += $(VBOX_DARWIN_DEF_SDK_SDKS) + TEMPLATE_VBoxR0_DEFS += $(VBOX_DARWIN_DEF_SDK_DEFS) + TEMPLATE_VBoxR0_CXXFLAGS = $(VBOX_DARWIN_DEF_SDK_CXXFLAGS) -nostdinc -g $(VBOX_GCC_pipe) $(VBOX_GCC_WERR) $(VBOX_GCC_PEDANTIC_CXX) $(VBOX_GCC_Wno-variadic-macros) \ + -fno-common -static -fno-rtti -fno-exceptions $(VBOX_GCC_R0_OPT) $(VBOX_GCC_R0_FP) -fno-strict-aliasing \ + $(VBOX_GCC_fno-stack-protector) $(VBOX_GCC_std) + TEMPLATE_VBoxR0_CXXFLAGS.amd64 = -m64 -msoft-float -mno-sse -mno-mmx -mno-sse2 -mno-3dnow -mno-red-zone -mno-sse3 -mno-sse4 -mno-sse4.1 -mno-sse4.2 -mno-sse4a -fno-unwind-tables + TEMPLATE_VBoxR0_CXXFLAGS.x86 = -m32 -msoft-float -mno-sse -mno-mmx -mno-sse2 -mno-3dnow + TEMPLATE_VBoxR0_CXXFLAGS.arm64 = -m64 -target arm64e-apple-macos11.0 # Assembly fixup issues w/o the -target bit. Why? + TEMPLATE_VBoxR0_CFLAGS = $(VBOX_DARWIN_DEF_SDK_CFLAGS) -nostdinc -g $(VBOX_GCC_pipe) $(VBOX_GCC_WERR) $(VBOX_GCC_PEDANTIC_C) $(VBOX_GCC_Wno-variadic-macros) \ + -fno-common -static -fno-exceptions $(VBOX_GCC_R0_OPT) $(VBOX_GCC_R0_FP) -fno-strict-aliasing \ + $(VBOX_GCC_fno-stack-protector) + TEMPLATE_VBoxR0_CFLAGS.amd64 = -m64 -msoft-float -mno-sse -mno-mmx -mno-sse2 -mno-3dnow -mno-red-zone -mno-sse3 -mno-sse4 -mno-sse4.1 -mno-sse4.2 -mno-sse4a -fno-unwind-tables + TEMPLATE_VBoxR0_CFLAGS.x86 = -m32 -msoft-float -mno-sse -mno-mmx -mno-sse2 -mno-3dnow + TEMPLATE_VBoxR0_CFLAGS.arm64 = -m64 -target arm64e-apple-macos11.0 + TEMPLATE_VBoxR0_LDFLAGS = $(VBOX_DARWIN_DEF_SDK_LDFLAGS) -nostdlib + TEMPLATE_VBoxR0_LDFLAGS.amd64 = -m64 -static + TEMPLATE_VBoxR0_LDFLAGS.arm64 = -m64 -static + TEMPLATE_VBoxR0_LDFLAGS.x86 = -m32 + TEMPLATE_VBoxR0_CXXFLAGS.amd64 += -mkernel + TEMPLATE_VBoxR0_CFLAGS.amd64 += -mkernel + TEMPLATE_VBoxR0_CXXFLAGS.arm64 += -mkernel + TEMPLATE_VBoxR0_CFLAGS.arm64 += -mkernel + TEMPLATE_VBoxR0_LDFLAGS += -Wl,-kext -mkernel + TEMPLATE_VBoxR0_POST_CMDS = $(if $(eq $(tool_do),LINK_LIBRARY),,$(call VBOX_SIGN_VMM_MOD_FN,$(out),org.virtualbox.app.r0.$(target))) +endif + +ifeq ($(VBOX_LDR_FMT),lx) + TEMPLATE_VBoxR0_TOOL = GXX3OMF + TEMPLATE_VBoxR0_CFLAGS = -nostdinc -g $(VBOX_GCC_pipe) $(VBOX_GCC_WERR) $(VBOX_GCC_PEDANTIC_C) $(VBOX_GCC_Wno-variadic-macros) $(VBOX_GCC_R0_OPT) $(VBOX_GCC_R0_FP) -fno-strict-aliasing -fno-exceptions -fno-common + TEMPLATE_VBoxR0_CXXFLAGS = -nostdinc -g $(VBOX_GCC_pipe) $(VBOX_GCC_WERR) $(VBOX_GCC_PEDANTIC_CXX) $(VBOX_GCC_Wno-variadic-macros) $(VBOX_GCC_R0_OPT) $(VBOX_GCC_R0_FP) -fno-strict-aliasing -fno-exceptions -fno-common -fno-rtti + if $(VBOX_GCC_VERSION_CC) < 30400 + TEMPLATE_VBoxR0_DEFS += RT_WITHOUT_PRAGMA_ONCE + endif + TEMPLATE_VBoxR0_LDFLAGS = -nostdlib -Zdll + TEMPLATE_VBoxR0_LIBS = \ + $(VBOX_GCC_LIBGCC) \ + $(VBOX_OBJ_SYS0) \ + end +endif + + +# +# Template for building SUPDRV R0 things. +# +# Disabled Visual C++ warnings: +# -wd4996: deprecated / insecure. +# -wd4127: conditional expression is constant [level 4] +# -wd4201: nonstandard extension used : nameless struct/union [level 4] +# -wd4214: nonstandard extension used : bit field types other than int [level 4] +# -wd4706: assignment within conditional expression [level 4] +# -wd4324: '_TDI_PNP_CONTEXT_XP' : structure was padded due to __declspec(align()) +# +# -wd4100: 'identifier' : unreferenced formal parameter [level 4] --- TODO: Enable this one! +# +TEMPLATE_VBoxR0Drv = VBox SUPDRV Ring 0 +TEMPLATE_VBoxR0Drv_ASTOOL := $(VBOX_ASTOOL) +TEMPLATE_VBoxR0Drv_ASFLAGS = $(VBOX_ASFLAGS) +TEMPLATE_VBoxR0Drv_DEFS = IN_RING0 IN_RT_R0 $(ARCH_BITS_DEFS) +TEMPLATE_VBoxR0Drv_USES += dtrace +ifdef VBOX_WITH_DTRACE_R0DRV + TEMPLATE_VBoxR0Drv_DTRACETOOL = VBoxTpG + TEMPLATE_VBoxR0Drv_DEFS += VBOX_WITH_DTRACE VBOX_WITH_DTRACE_R0DRV + ifdef VBOX_WITH_NATIVE_DTRACE + TEMPLATE_VBoxR0Drv_DEFS += VBOX_WITH_NATIVE_DTRACE + endif +else + TEMPLATE_VBoxR0Drv_DTRACETOOL = VBoxTpG-Disabled +endif + +ifeq ($(KBUILD_TARGET),win) + TEMPLATE_VBoxR0Drv_TOOL = $(VBOX_VCC_TOOL) + if "$(VBOX_VCC_TOOL_STEM)" >= "VCC140" # for stddef.h ## @todo 8489: check if still needed + TEMPLATE_VBoxR0Drv_SDKS = WINSDK10-UCRT-INCS + endif + TEMPLATE_VBoxR0Drv_RCDEFS = VBOX_SVN_REV=$(VBOX_SVN_REV) VBOX_SVN_REV_MOD_5K=$(expr $(VBOX_SVN_REV) % 50000) + TEMPLATE_VBoxR0Drv_DEFS += _KERNEL_MODE=1 # Needed with W10 to access things like KeQueryInterruptTime + TEMPLATE_VBoxR0Drv_DEFS.x86 = _X86_ + TEMPLATE_VBoxR0Drv_DEFS.x86 += NO_INTERLOCKED_INTRINSICS # Avoids intrisic VC/WDK trouble + TEMPLATE_VBoxR0Drv_DEFS.x86 += WIN9X_COMPAT_SPINLOCK # Avoid multiply defined _KeInitializeSpinLock@4 + TEMPLATE_VBoxR0Drv_DEFS.amd64 = _AMD64_ + TEMPLATE_VBoxR0Drv_DEFS.amd64 += WIN9X_COMPAT_SPINLOCK # For Windows 8+ WDKs where it is no longer inlined but imported from ntoskrnl. + TEMPLATE_VBoxR0Drv_DEFS.amd64 += NT_INLINE_IRQL NT_INLINE_GET_CURRENT_IRQL # Prevent W10 WDK from importing KeLowerIrql and KeGetCurrentIrql. + TEMPLATE_VBoxR0Drv_DEFS.win = IPRT_NT_MAP_TO_ZW + TEMPLATE_VBoxR0Drv_CXXFLAGS = -Zi -Zl -GR- -EHs- -GF -Gz -GS- -Zc:wchar_t- $(VBOX_VCC_FP) -Gs4096 $(VBOX_VCC_OPT) \ + -Gy $(VBOX_VCC_CC_GUARD_CF) $(VBOX_VCC_WARN_ALL) $(VBOX_VCC_WERR) + if "$(VBOX_VCC_TOOL_STEM)" >= "VCC120" + TEMPLATE_VBoxR0Drv_CXXFLAGS += -Gw + endif + if "$(VBOX_VCC_TOOL_STEM)" >= "VCC142" # Don't waste space on x86/amd64-on-arm emulation optimizations. + TEMPLATE_VBoxR0Drv_CXXFLAGS += /volatileMetadata- + endif + ifdef VBOX_WITH_MSC_ANALYZE_THIS + TEMPLATE_VBoxR0Drv_CXXFLAGS += /analyze + endif + TEMPLATE_VBoxR0Drv_CFLAGS = $(TEMPLATE_VBoxR0Drv_CXXFLAGS) + TEMPLATE_VBoxR0Drv_LDFLAGS = -Ignore:4197 \ + -Driver -Subsystem:NATIVE -Incremental:NO -Align:4096 -MapInfo:Exports -NoD -Release -Debug -Opt:Ref -Opt:Icf \ + $(VBOX_VCC_LD_GUARD_CF) \ + -Version:$(VBOX_VERSION_MAJOR)0$(VBOX_VERSION_MINOR).$(VBOX_VERSION_BUILD) \ + -Stub:$(PATH_ROOT)/src/VBox/HostDrivers/Support/win/winstub.com + ifdef VBOX_WITH_DTRACE_R0DRV + TEMPLATE_VBoxR0Drv_LDFLAGS += -Merge:VTGPrLc.Data=VTGPrLc.Begin -Merge:VTGPrLc.End=VTGPrLc.Begin -Merge:VTGPrLc.Begin=VTGObj + endif + ifdef VBOX_SIGNING_MODE + TEMPLATE_VBoxR0Drv_LDFLAGS += -IntegrityCheck + endif + if "$(VBOX_VCC_TOOL_STEM)" >= "VCC142" # Don't waste space on x86/amd64-on-arm emulation optimizations. + TEMPLATE_VBoxR0Drv_LDFLAGS += -EmitVolatileMetadata:NO + endif + TEMPLATE_VBoxR0Drv_LDFLAGS.win.amd64 = $(VBOX_VCC_LD_HIGH_ENTRYOPY_VA) + TEMPLATE_VBoxR0Drv_ORDERDEPS = $(VBOX_SIGN_DRIVER_ORDERDEPS) + TEMPLATE_VBoxR0Drv_POST_CMDS = $(VBOX_SIGN_DRIVER_CMDS) +endif + +ifeq ($(KBUILD_TARGET),linux) + TEMPLATE_VBoxR0Drv_TOOL = $(NO_SUCH_VARIABLE) + + ifndef KERN_DIR + ifndef KERN_VER + KERN_VER := $(patsubst /lib/modules/%/build/.config,%,$(firstword $(shell LC_ALL=C ls -t /lib/modules/*/build/.config 2>/dev/null))) + endif + ifeq ($(KERN_VER),) + KERN_VER := $(shell uname -r) + endif + KERN_DIR := /lib/modules/$(KERN_VER)/build + endif + + ## + ## Generates a rule for test-building a linux kernel module (use evalcall2 to invoke). + ## + ## Since Linux KBuild will not abort due to undefined symbols when building + ## external modules we need to grep the error output ourselves. Since vboxdrv + ## and vboxguest respectively provide symbols that other modules use, we use + ## the rule target (tst*.run) to save those symbols so that KBuild can do its + ## checking. + ## + ## @param 1 Module name. + ## @param 2 The test build which symvers we need (empty if none) + ## @param 3 Save symvers if non-empty. + ## + ## @note Using the extra expansion to replace $(1), $(2) and $(3) before eval, + ## thus everything else needs escaped dollars. + ## + if defined(VBOX_WITH_TESTCASES) \ + && "$(KBUILD_HOST)" == "linux" \ + && "$(KBUILD_HOST_ARCH)" == "$(KBUILD_TARGET_ARCH)" \ + && !defined(VBOX_WITHOUT_LINUX_TEST_BUILDS) \ + && !defined(VBOX_ONLY_SDK) \ + && !defined(VBOX_ONLY_DOCS) \ + && !defined(VBOX_ONLY_VALIDATIONKIT) + define VBOX_LINUX_KMOD_TEST_BUILD_RULE_FN + ifneq ($(KERN_DIR),) + TESTING += $$(PATH_TARGET)/tst$(1)$(subst /,_,$(KERN_DIR))_mod.run + OTHERS += $$(PATH_TARGET)/tst$(1)$(subst /,_,$(KERN_DIR))_mod.run + OTHERS_CLEAN += $$(PATH_TARGET)/tst$(1)$(subst /,_,$(KERN_DIR))_mod.run + $$(PATH_TARGET)/tst$(1)$(subst /,_,$(KERN_DIR))_mod.run: \ + $$(if $(2),$$(PATH_TARGET)/tst$(2)$(subst /,_,$(KERN_DIR))_mod.run,) \ + $$$$($(1)_2_STAGE_TARGETS) + $(QUIET)$$(call MSG_L1,Doing a test build of the $(1) kernel module) + $(QUIET)$$(RM) -f -- "$$@" + $(QUIET)$$(TEST) -n "$$($(1)_INST)" + $(QUIET)$$(RM) -Rf -- "$$(PATH_TARGET)/tst$(1)_mod" + $(QUIET)$$(MKDIR) -p -- "$$(PATH_TARGET)/tst$(1)_mod" + $(QUIET)$$(CP) -R -- "$$(PATH_STAGE_BIN)/../$$($(1)_INST)" "$$(PATH_TARGET)/tst$(1)_mod/" + + $(QUIET)make KBUILD_VERBOSE=$(KBUILD_VERBOSE) KERN_DIR=$(KERN_DIR) VBOX_KERN_QUIET=1 \ + VBOX_KBUILD_TYPE=$(KBUILD_TYPE) VBOX_KBUILD_TARGET_ARCH=$(KBUILD_TARGET_ARCH) \ + KBUILD_TYPE= KBUILD_TARGET= KBUILD_TARGET_ARCH= KBUILD_TARGET_CPU= KBUILD_HOST= KBUILD_HOST_ARCH= KBUILD_HOST_CPU= \ + BUILD_TYPE= BUILD_TARGET= BUILD_TARGET_ARCH= BUILD_TARGET_CPU= BUILD_PLATFORM= BUILD_PLATFORM_ARCH= BUILD_PLATFORM_CPU= \ + -C $$(PATH_TARGET)/tst$(1)_mod clean + ifneq ($(2),) + $(QUIET)$$(CP) -f -- "$$<" "$$(PATH_TARGET)/tst$(1)_mod/Module.symvers" + endif + + $(QUIET)$(REDIRECT_EXT) -d2=1 -w1 "$$(PATH_TARGET)/tst$(1)_mod/make.err" -- \ + make KBUILD_VERBOSE=$(KBUILD_VERBOSE) KERN_DIR=$(KERN_DIR) VBOX_KERN_QUIET=1 $(if $(2),KBUILD_EXTRA_SYMBOLS="$$(PATH_TARGET)/tst$(1)_mod/Module.symvers",) $(if-expr $(KMK_OPTS_JOBS) != 0,JOBS=$(KMK_OPTS_JOBS),) \ + VBOX_KBUILD_TYPE=$(KBUILD_TYPE) VBOX_KBUILD_TARGET_ARCH=$(KBUILD_TARGET_ARCH) \ + KBUILD_TYPE= KBUILD_TARGET= KBUILD_TARGET_ARCH= KBUILD_TARGET_CPU= KBUILD_HOST= KBUILD_HOST_ARCH= KBUILD_HOST_CPU= \ + BUILD_TYPE= BUILD_TARGET= BUILD_TARGET_ARCH= BUILD_TARGET_CPU= BUILD_PLATFORM= BUILD_PLATFORM_ARCH= BUILD_PLATFORM_CPU= \ + -C $$(PATH_TARGET)/tst$(1)_mod + $(CAT) "$$(PATH_TARGET)/tst$(1)_mod/make.err" + $(QUIET)! grep "^WARNING: .* undefined!$$$$" "$$(PATH_TARGET)/tst$(1)_mod/make.err" + if1of ($(USERNAME), bird) + - nm -u "$$(PATH_TARGET)/tst$(1)_mod/"*.ko | sort + endif + ifneq ($(3),) + $(QUIET)$$(CP) -f -- "$$(PATH_TARGET)/tst$(1)_mod/Module.symvers" "$$@" + else + $(QUIET)$$(APPEND) -t "$$@" "done" + endif + $(QUIET)$$(RM) -Rf -- "$$(PATH_TARGET)/tst$(1)_mod" + vbox-linux-kmod-test-builds: $$(PATH_TARGET)/tst$(1)$(subst /,_,$(KERN_DIR))_mod.run + $$(foreach src,$$(notdir $$(filter %.c,$$(subst =>,/,$$($(1)_SOURCES)))),$$(patsubst %.c,%.o,$$(src))): $$(PATH_TARGET)/tst$(1)$(subst /,_,$(KERN_DIR))_mod.run + endif + endef # VBOX_LINUX_KMOD_TEST_BUILD_RULE_FN + else + VBOX_LINUX_KMOD_TEST_BUILD_RULE_FN = + endif +else + VBOX_LINUX_KMOD_TEST_BUILD_RULE_FN = +endif # linux target + +ifeq ($(KBUILD_TARGET),os2) + ifndef VBOX_USE_WATCOM_FOR_OS2 + TEMPLATE_VBoxR0Drv_TOOL = GXX3OMF + TEMPLATE_VBoxR0Drv_CXXFLAGS = -g $(VBOX_GCC_pipe) $(VBOX_GCC_PEDANTIC_CXX) $(VBOX_GCC_Wno-variadic-macros) $(VBOX_GCC_R0_OPT) $(VBOX_GCC_R0_FP) -fno-strict-aliasing -fno-exceptions -fno-rtti + TEMPLATE_VBoxR0Drv_CFLAGS = -g $(VBOX_GCC_pipe) $(VBOX_GCC_PEDANTIC_C) $(VBOX_GCC_Wno-variadic-macros) $(VBOX_GCC_R0_OPT) $(VBOX_GCC_R0_FP) -fno-strict-aliasing -fno-exceptions + TEMPLATE_VBoxR0Drv_LIBS = $(VBOX_GCC_LIBGCC) + # wlink thinks physdevice doesn't need fixups and should have a stack - stupid! + TEMPLATE_VBoxR0Drv_LDFLAGS = -Zlinker Option -Zlinker internalrelocs, -Zlinker togglerelocs + else + TEMPLATE_VBoxR0Drv_TOOL = OPENWATCOM + TEMPLATE_VBoxR0Drv_CTOOL = OPENWATCOM + TEMPLATE_VBoxR0Drv_CXXTOOL = OPENWATCOM + TEMPLATE_VBoxR0Drv_LDTOOL = OPENWATCOM-WL + TEMPLATE_VBoxR0Drv_ARTOOL = OPENWATCOM + TEMPLATE_VBoxR0Drv_ASTOOL = NASM + TEMPLATE_VBoxR0Drv_ASFLAGS = -fobj -DASM_FORMAT_OMF -D__NASM__ -w+orphan-labels #-g -F borland + TEMPLATE_VBoxR0Drv_DEFS.os2 = #_OS2EMX_H + TEMPLATE_VBoxR0Drv_INCS = \ + $(PATH_TOOL_OPENWATCOM)/h \ + $(PATH_TOOL_OPENWATCOM)/h/os2 \ + $(PATH_ROOT)/include \ + $(PATH_KLIBC_TRUNK)/libc/include # for os2ddk + TEMPLATE_VBoxR0Drv_CFLAGS = -s -ze -w4 -hd -d1+ -nt=TEXT32 -nc=CODE -4 -of+ + TEMPLATE_VBoxR0Drv_CXXFLAGS = -s -ze -w4 -hd -d2t -nt=TEXT32 -nc=CODE -4 -of+ + TEMPLATE_VBoxR0Drv_LDFLAGS = \ + form os2 lx physdevice \ + option NODefaultlibs, internalrelocs, togglerelocs \ + debug dwarf all #option symfile + # debug codeview all option symfile - wlink generates bad info, overwritten mod dir header. + endif +endif + +ifeq ($(KBUILD_TARGET),darwin) + TEMPLATE_VBoxR0Drv_TOOL = $(VBOX_GCC_TOOL) + TEMPLATE_VBoxR0Drv_SDKS += $(VBOX_DARWIN_DEF_SDK_SDKS) + TEMPLATE_VBoxR0Drv_DEFS += $(VBOX_DARWIN_DEF_SDK_DEFS) KERNEL KERNEL_PRIVATE DRIVER_PRIVATE APPLE NeXT + if1of ($(VBOX_GCC_TOOL), GXX4MACHO GXX42MACHO) + TEMPLATE_VBoxR0Drv_INCS += \ + $(VBOX_PATH_MACOSX_SDK)/System/Library/Frameworks/Kernel.framework/PrivateHeaders \ + $(VBOX_PATH_MACOSX_SDK)/System/Library/Frameworks/Kernel.framework/Headers + ## @todo try use VBOX_GCC_PEDANTIC_CXX + TEMPLATE_VBoxR0Drv_CXXFLAGS = $(VBOX_DARWIN_DEF_SDK_CXXFLAGS) \ + -g $(VBOX_GCC_pipe) $(VBOX_GCC_WARN) -Wno-long-long $(VBOX_GCC_fdiagnostics-show-option) \ + -fno-common -nostdinc -fno-builtin -finline $(VBOX_GCC_fvisibility-inlines-hidden) $(VBOX_GCC_fvisibility-hidden) \ + -fno-keep-inline-functions -fno-exceptions -msoft-float \ + -fapple-kext -fno-rtti -fcheck-new -force_cpusubtype_ALL \ + $(VBOX_GCC_R0_OPT) $(VBOX_GCC_R0_FP) -fno-strict-aliasing -fasm-blocks + TEMPLATE_VBoxR0Drv_CXXFLAGS.amd64 = -m64 -mkernel -mno-red-zone -gdwarf-2 + TEMPLATE_VBoxR0Drv_CXXFLAGS.x86 = -m32 -static + TEMPLATE_VBoxR0Drv_CFLAGS = $(VBOX_DARWIN_DEF_SDK_CFLAGS) \ + -g $(VBOX_GCC_pipe) $(VBOX_GCC_WARN) -Wno-long-long -fno-common -nostdinc -fno-builtin -finline \ + -fno-keep-inline-functions -fno-exceptions $(VBOX_GCC_fvisibility-hidden) -msoft-float \ + -Wmissing-prototypes -Wstrict-prototypes -Wmissing-declarations \ + -Werror-implicit-function-declaration -force_cpusubtype_ALL \ + $(VBOX_GCC_R0_OPT) $(VBOX_GCC_R0_FP) -fno-strict-aliasing -fasm-blocks + TEMPLATE_VBoxR0Drv_CFLAGS.amd64 = -m64 -mkernel -mno-red-zone -gdwarf-2 + TEMPLATE_VBoxR0Drv_CFLAGS.x86 = -m32 -static + TEMPLATE_VBoxR0Drv_LDFLAGS = $(filter-out $(VBOX_DARWIN_NO_COMPACT_LINKEDIT),$(VBOX_DARWIN_DEF_SDK_LDFLAGS)) \ + -nostdlib -Wl,-kext,-new_linker -Wl,-Y,1455 -keep_private_extern + TEMPLATE_VBoxR0Drv_LDFLAGS.amd64 = -m64 + TEMPLATE_VBoxR0Drv_LDFLAGS.x86 = -m32 + TEMPLATE_VBoxR0Drv_LIBS = kmodc++ kmod cc_kext cpp_kext $(VBOX_GCC_LIBGCC) + else + # Note xcode uses -fstrict-aliasing, we currently don't dare... We also add -mno-red-zone. + TEMPLATE_VBoxR0Drv_INCS += \ + $(VBOX_PATH_MACOSX_SDK)/System/Library/Frameworks/Kernel.framework/PrivateHeaders \ + $(VBOX_PATH_MACOSX_SDK)/System/Library/Frameworks/Kernel.framework/Headers + ## @todo try use VBOX_GCC_PEDANTIC_CXX + # -Wno-c++11-extensions -Wno-c99-extensions -Wno-extra-semi -Wno-zero-length-array + TEMPLATE_VBoxR0Drv_CXXFLAGS = $(VBOX_DARWIN_DEF_SDK_CXXFLAGS) -mkernel \ + -g $(VBOX_GCC_pipe) $(VBOX_GCC_PEDANTIC_CXX) -Wno-long-long $(VBOX_GCC_fdiagnostics-show-option) \ + -Wno-c++11-extensions -Wno-c99-extensions -Wno-extra-semi -Wno-zero-length-array \ + -Wno-gnu-zero-variadic-macro-arguments -Wno-four-char-constants \ + -fno-common -nostdinc -fno-builtin $(VBOX_GCC_fvisibility-inlines-hidden) $(VBOX_GCC_fvisibility-hidden) \ + -fno-exceptions -fapple-kext -fno-rtti -mkernel \ + -fmodules -fmodules-prune-interval=86400 -fmodules-prune-after=345600 -Wnon-modular-include-in-framework-module \ + -Werror=non-modular-include-in-framework-module \ + $(VBOX_GCC_Wno-nullability-extension) $(VBOX_GCC_Wno-gnu-statement-expression) \ + $(VBOX_GCC_Wno-import-preprocessor-directive-pedantic) $(VBOX_GCC_Wno-c11-extensions) \ + $(VBOX_GCC_R0_OPT) $(VBOX_GCC_R0_FP) -fasm-blocks -fno-strict-aliasing -stdlib=libc++ + # if1of ($(VBOX_GCC_TOOL), CLANGXXMACHO) ## @todo check if we can safely use $(VBOX_GCC_std) @bugref{9790}, good for noexcept. + #TEMPLATE_VBoxR0Drv_CXXFLAGS += $(VBOX_GCC_std) + # endif + # also used by xcode 6.2: \ + # -Werror=return-type \ + # -Werror=deprecated-objc-isa-usage \ + # -Werror=objc-root-class \ + # -Wno-missing-field-initializers -Wno-missing-prototypes -Wunreachable-code \ + # -Wno-overloaded-virtual -Wno-exit-time-destructors -Wno-missing-braces -Wparentheses -Wswitch -Wunused-function \ + # -Wno-unused-label -Wno-unused-parameter -Wunused-variable -Wunused-value -Wempty-body \ + # -Wconditional-uninitialized -Wno-unknown-pragmas -Wno-shadow -Wno-four-char-constants \ + # -Wno-conversion -Wconstant-conversion -Wint-conversion -Wbool-conversion -Wenum-conversion \ + # -Wshorten-64-to-32 -Wno-newline-eof -Wno-c++11-extensions -Wdeprecated-declarations -Winvalid-offsetof -Wno-sign-conversion + TEMPLATE_VBoxR0Drv_CXXFLAGS.amd64 = -m64 -msoft-float -mno-red-zone + TEMPLATE_VBoxR0Drv_CXXFLAGS.x86 = -m32 -msoft-float + TEMPLATE_VBoxR0Drv_CXXFLAGS.arm64 = -m64 -fno-sanitize=vptr -target arm64e-apple-macos11.0 + TEMPLATE_VBoxR0Drv_CFLAGS = $(VBOX_DARWIN_DEF_SDK_CFLAGS) -mkernel \ + -g $(VBOX_GCC_pipe) $(VBOX_GCC_PEDANTIC_C) -Wno-long-long $(VBOX_GCC_fdiagnostics-show-option) \ + -fno-common -nostdinc -fno-builtin $(VBOX_GCC_fvisibility-inlines-hidden) $(VBOX_GCC_fvisibility-hidden) \ + -fno-exceptions -fapple-kext -fno-rtti \ + -fmodules -fmodules-prune-interval=86400 -fmodules-prune-after=345600 -Wnon-modular-include-in-framework-module \ + -Werror=non-modular-include-in-framework-module $(VBOX_GCC_Wno-c11-extensions) \ + $(VBOX_GCC_R0_OPT) $(VBOX_GCC_R0_FP) -fasm-blocks -fno-strict-aliasing + TEMPLATE_VBoxR0Drv_CFLAGS.amd64 = -m64 -msoft-float -mno-red-zone + TEMPLATE_VBoxR0Drv_CFLAGS.x86 = -m32 -msoft-float + TEMPLATE_VBoxR0Drv_CFLAGS.arm64 = -m64 -fno-sanitize=vptr -target arm64e-apple-macos11.0 + if 1 + TEMPLATE_VBoxR0Drv_CFLAGS += $(VBOX_GCC_WERR) + TEMPLATE_VBoxR0Drv_CXXFLAGS += $(VBOX_GCC_WERR) + endif + TEMPLATE_VBoxR0Drv_LDFLAGS = $(filter-out $(VBOX_DARWIN_NO_COMPACT_LINKEDIT),$(VBOX_DARWIN_DEF_SDK_LDFLAGS)) \ + -nostdlib -stdlib=libc++ -Wl,-kext -Wl,-keep_private_externs + TEMPLATE_VBoxR0Drv_LDFLAGS.amd64 = -m64 + TEMPLATE_VBoxR0Drv_LDFLAGS.arm64 = -m64 + TEMPLATE_VBoxR0Drv_LDFLAGS.x86 = -m32 + TEMPLATE_VBoxR0Drv_LIBS = kmodc++ kmod cc_kext + endif +endif + +ifeq ($(KBUILD_TARGET),solaris) + ## The Solaris /usr/platform/i86pc/include and /usr/include directories. + VBOX_SOLARIS_SYS_INCS ?= /usr/platform/i86pc/include /usr/include + + TEMPLATE_VBoxR0Drv_TOOL = $(VBOX_GCC_TOOL) + TEMPLATE_VBoxR0Drv_DEFS += _MACHDEP _KERNEL _STRICT_STDC + if $(VBOX_GCC_VERSION_CC) < 30400 + TEMPLATE_VBoxR0Drv_DEFS += RT_WITHOUT_PRAGMA_ONCE + endif + TEMPLATE_VBoxR0Drv_INCS = $(VBOX_SOLARIS_SYS_INCS) + TEMPLATE_VBoxR0Drv_LDFLAGS = -r -dy + TEMPLATE_VBoxR0Drv_LDFLAGS.amd64 = $(if $(eq $(KBUILD_HOST),solaris),-64,-m elf_x86_64) + # Exclude -Wall because of solaris headers' pragma ident warnings that gcc refuses to supress. + TEMPLATE_VBoxR0Drv_CFLAGS = -Wpointer-arith -Winline $(VBOX_GCC_Wno-pointer-sign) \ + -Wmissing-prototypes -Wstrict-prototypes $(VBOX_GCC_fdiagnostics-show-option) \ + -Wshadow -Wuninitialized -Wunused-function -Wunused-label -Wunused-value -Wunused-variable \ + -Wformat -Wimplicit-int -Wimplicit-function-declaration -Werror-implicit-function-declaration -Wparentheses \ + -O2 -fno-omit-frame-pointer -ffreestanding -nodefaultlibs -fno-strict-aliasing -fno-common -std=c99 + TEMPLATE_VBoxR0Drv_CFLAGS.x86 = -m32 -mno-sse -mno-mmx -mno-sse2 -mno-3dnow + TEMPLATE_VBoxR0Drv_CFLAGS.amd64 = -m64 -mno-sse -mno-mmx -mno-sse2 -mno-3dnow $(VBOX_GCC_msave-args) \ + -mno-red-zone -mcmodel=kernel $(if-expr defined(VBOX_GCC_USING_SOLARIS_AS),-Wa$(COMMA)-xmodel=kernel,) \ + -fno-reorder-blocks -fno-asynchronous-unwind-tables -funit-at-a-time + TEMPLATE_VBoxR0Drv_CXXFLAGS = -Wpointer-arith \ + -Wshadow -Wuninitialized -Wunused-function -Wunused-label -Wunused-value -Wunused-variable -Wformat \ + -O2 -nodefaultlibs -fno-omit-frame-pointer -fno-strict-aliasing -fno-common -fno-exceptions -fno-rtti + TEMPLATE_VBoxR0Drv_CXXFLAGS.x86 = $(TEMPLATE_VBoxR0Drv_CFLAGS.x86) + TEMPLATE_VBoxR0Drv_CXXFLAGS.amd64 = $(TEMPLATE_VBoxR0Drv_CFLAGS.amd64) + TEMPLATE_VBoxR0Drv_POST_CMDS = $(VBOX_SIGN_DRIVER_CMDS) +endif # Solaris + +ifeq ($(KBUILD_TARGET),freebsd) + # x86 FreeBSD (6.2 or something): + # cc -O2 -fno-strict-aliasing -pipe -Werror -D_KERNEL -DKLD_MODULE \ + # -nostdinc -I- -I. -I@ -I@/contrib/altq -I@/../include -I/usr/include \ + # -finline-limit=8000 -fno-common -mno-align-long-strings -mpreferred-stack-boundary=2 \ + # -mno-mmx -mno-3dnow -mno-sse -mno-sse2 -ffreestanding -Wall -Wredundant-decls -Wnested-externs \ + # -Wstrict-prototypes -Wmissing-prototypes -Wpointer-arith -Winline -Wcast-qual -fformat-extensions \ + # -std=c99 -c ../my.c + # ld -d -warn-common -r -d -o my.kld my.o + # :> export_syms + # awk -f /usr/src/sys/modules/my/../../conf/kmod_syms.awk my.kld export_syms | xargs -J% objcopy % my.kld + # ld -Bsharable -d warn-commnon -o my.ko my.kld + # + # AMD64 FreeBSD (7.1): + # cc -O2 -fno-strict-aliasing -pipe -D_KERNEL -DKLD_MODULE -std=c99 -nostdinc -I. -I@ -I@/contrib/altq \ + # -finline-limit=8000 --param inline-unit-growth=100 --param large-function-growth=1000 -fno-common \ + # -fno-omit-frame-pointer -mcmodel=kernel -mno-red-zone -mfpmath=387 -mno-sse -mno-sse2 -mno-mmx \ + # -mno-3dnow -msoft-float -fno-asynchronous-unwind-tables -ffreestanding \ + # -Wall -Wredundant-decls -Wnested-externs -Wstrict-prototypes -Wmissing-prototypes -Wpointer-arith -Winline -Wcast-qual -Wundef -Wno-pointer-sign \ + # -fformat-extensions -c /usr/src/sys/modules/my/../../dev/my/if_my.c + # ld -d -warn-common -r -d -o if_my.ko if_my.o + # :> export_syms + # awk -f /usr/src/sys/modules/my/../../conf/kmod_syms.awk if_my.ko export_syms | xargs -J% objcopy % if_my.ko + + # Note: @ -> /usr/src/sys and machine -> /usr/src/sys/i386/include + + ## The location of the FreeBSD kernel source. + VBOX_FREEBSD_SRC ?= /usr/src/sys + ## The FreeBSD /usr/include. + VBOX_FREEBSD_SYS_INCS ?= /usr/include + + TEMPLATE_VBoxR0Drv_TOOL = $(VBOX_GCC_TOOL) + TEMPLATE_VBoxR0Drv_LDTOOL = FreeBsdKModLd + TEMPLATE_VBoxR0Drv_DEFS += _KERNEL KLD_MODULE + if $(VBOX_GCC_VERSION_CC) < 30400 + TEMPLATE_VBoxR0Drv_DEFS += RT_WITHOUT_PRAGMA_ONCE + endif + TEMPLATE_VBoxR0Drv_INCS = \ + $(VBOX_FREEBSD_SRC) \ + $(VBOX_FREEBSD_SRC)/contrib/altq \ + $(VBOX_FREEBSD_SRC)/contrib/ck/include \ + $(VBOX_FREEBSD_SRC)/../include \ + $(VBOX_FREEBSD_SYS_INCS) + # omitting: -Wcast-qual, -Wredundant-decls + TEMPLATE_VBoxR0Drv_CFLAGS = \ + $(VBOX_GCC_WARN) -Wpointer-arith -Winline $(VBOX_GCC_Wno-pointer-sign) $(VBOX_GCC_fdiagnostics-show-option) \ + -Wstrict-prototypes -Wmissing-prototypes -Wstrict-prototypes \ + -Wimplicit-function-declaration -Werror-implicit-function-declaration \ + -O2 -ffreestanding -fno-strict-aliasing -fno-common \ + $(VBOX_GCC_fno-stack-protector) $(VBOX_GCC_R0_OPT) $(VBOX_GCC_R0_FP) \ + -nostdinc -std=c99 + TEMPLATE_VBoxR0Drv_CFLAGS.x86 = -m32 -mno-align-long-strings -mno-mmx -mno-3dnow -mno-sse -mno-sse2 + TEMPLATE_VBoxR0Drv_CFLAGS.amd64 = -m64 -fno-omit-frame-pointer -mcmodel=kernel -mno-red-zone -mfpmath=387 \ + -mno-sse -mno-sse2 -mno-mmx -mno-3dnow -msoft-float -fno-asynchronous-unwind-tables -Wundef + TEMPLATE_VBoxR0Drv_CXXFLAGS = -fno-exceptions -fno-rtti \ + $(VBOX_GCC_WARN) -Wpointer-arith -Winline \ + -O2 -fno-strict-aliasing -fno-common \ + $(VBOX_GCC_fno-stack-protector) $(VBOX_GCC_R0_OPT) $(VBOX_GCC_R0_FP) \ + -nostdinc + TEMPLATE_VBoxR0Drv_CXXFLAGS.x86 = $(TEMPLATE_VBoxR0Drv_CFLAGS.x86) + TEMPLATE_VBoxR0Drv_CXXFLAGS.amd64 = $(TEMPLATE_VBoxR0Drv_CFLAGS.amd64) + TEMPLATE_VBoxR0Drv_SYSSUFF = .ko + TEMPLATE_VBoxR0Drv_LDFLAGS = -d --warn-common + TEMPLATE_VBoxR0Drv_LDFLAGS.x86 = -m elf_i386_fbsd + TEMPLATE_VBoxR0Drv_LDFLAGS.amd64 = -m elf_x86_64_fbsd + + TOOL_FreeBsdKModLd = FreeBSD kernel module linker. + # See kBuild/tools/GCC3.kmk for docs. + TOOL_FreeBsdKModLd_LINK_SYSMOD_OUTPUT_MAYBE = $(outbase).map + TOOL_FreeBsdKModLd_LINK_SYSMOD_DEPEND = $(foreach lib,$(libs),$(if $(findstring $(lib),$(subst /,x,$(lib))),, $(lib))) + TOOL_FreeBsdKModLd_LINK_SYSMOD_DEPORD = + ifeq ($(KBUILD_TARGET_ARCH),amd64) + TOOL_FreeBsdKModLd_LINK_SYSMOD_OUTPUT = + define TOOL_FreeBsdKModLd_LINK_SYSMOD_CMDS + # Link intermediate .kld (a relocatable object). + ld $(flags) -r -o $(out) $(objs) \ + $(foreach p,$(libpath), -L$(p))\ + $(foreach lib,$(libs), $(if $(findstring $(lib),$(subst /,x,$(lib))), -l$(patsubst lib%,%,$(basename $(lib))), $(lib))) + # Strip non-exported symbols private and localize the exported ones. + awk -f $(VBOX_FREEBSD_SRC)/conf/kmod_syms.awk $(out) $(if $(othersrc), $(othersrc),/dev/null) \ + | xargs -J% objcopy % $(out) + + ## Strip debug info (comment out if debugging or something). + objcopy --strip-debug $(out) + endef + else # x86 + TOOL_FreeBsdKModLd_LINK_SYSMOD_OUTPUT = $(outbase).kld + define TOOL_FreeBsdKModLd_LINK_SYSMOD_CMDS + # Link intermediate .kld (a relocatable object). + ld $(flags) -r -o $(outbase).kld $(objs) \ + $(foreach p,$(libpath), -L$(p))\ + $(foreach lib,$(libs), $(if $(findstring $(lib),$(subst /,x,$(lib))), -l$(patsubst lib%,%,$(basename $(lib))), $(lib))) + # Strip non-exported symbols private and localize the exported ones. + awk -f $(VBOX_FREEBSD_SRC)/conf/kmod_syms.awk $(outbase).kld $(if $(othersrc), $(othersrc),/dev/null) \ + | xargs -J% objcopy % $(outbase).kld + + # Link the final .ko (a shared object). + ld $(flags) -Bshareable -o $(out) $(outbase).kld + endef + endif # x86 + +endif # FreeBSD + +ifeq ($(KBUILD_TARGET),netbsd) + + # The location of the NetBSD sources. + VBOX_NETBSD_SRC ?= /usr/src + + # NetBSD uses "i386" for 32-bit, "x86" for common 32- and 64-bit code. + ifeq ($(KBUILD_TARGET_ARCH),amd64) + VBOX_NETBSD_TARGET_ARCH = amd64 + else + VBOX_NETBSD_TARGET_ARCH = i386 + endif + + VBOX_NETBSD_TARGET_SRC = $(VBOX_NETBSD_SRC)/sys/arch/$(VBOX_NETBSD_TARGET_ARCH) + + TEMPLATE_VBoxR0Drv_TOOL = $(VBOX_GCC_TOOL) + TEMPLATE_VBoxR0Drv_DEFS += _KERNEL _MODULE + if $(VBOX_GCC_VERSION_CC) < 30400 + TEMPLATE_VBoxR0Drv_DEFS += RT_WITHOUT_PRAGMA_ONCE + endif + TEMPLATE_VBoxR0Drv_INCS = \ + $(VBOX_NETBSD_SRC)/sys \ + $(VBOX_NETBSD_SRC)/common/include \ + $(PATH_OBJ)/netbsd/include + + TEMPLATE_VBoxR0Drv_CFLAGS = \ + $(VBOX_GCC_WARN) -Wpointer-arith -Winline $(VBOX_GCC_Wno-pointer-sign) \ + $(VBOX_GCC_fdiagnostics-show-option) \ + -Wstrict-prototypes -Wmissing-prototypes -Wstrict-prototypes \ + -Wimplicit-function-declaration -Werror-implicit-function-declaration \ + -O2 -ffreestanding -fno-strict-aliasing -fno-common -finline-limit=8000 \ + $(VBOX_GCC_fno-stack-protector) $(VBOX_GCC_R0_OPT) $(VBOX_GCC_R0_FP) \ + -nostdinc -std=c99 -msoft-float + TEMPLATE_VBoxR0Drv_CFLAGS.x86 = -m32 -mno-mmx -mno-sse -mno-avx \ + -mno-fp-ret-in-387 + TEMPLATE_VBoxR0Drv_CFLAGS.amd64 = -m64 --param inline-unit-growth=100 \ + --param large-function-growth=1000 -fno-omit-frame-pointer \ + -mcmodel=kernel -mno-red-zone -mno-sse -mno-mmx -mno-avx \ + -fno-asynchronous-unwind-tables -mno-fp-ret-in-387 + TEMPLATE_VBoxR0Drv_CXXFLAGS = -fno-exceptions -fno-rtti \ + $(VBOX_GCC_WARN) -Wpointer-arith -Winline \ + -O2 -fno-strict-aliasing -fno-common -finline-limit=8000 \ + $(VBOX_GCC_fno-stack-protector) $(VBOX_GCC_R0_OPT) $(VBOX_GCC_R0_FP) \ + -nostdinc -msoft-float + TEMPLATE_VBoxR0Drv_CXXFLAGS.x86 = $(TEMPLATE_VBoxR0Drv_CFLAGS.x86) + TEMPLATE_VBoxR0Drv_CXXFLAGS.amd64 = $(TEMPLATE_VBoxR0Drv_CFLAGS.amd64) + TEMPLATE_VBoxR0Drv_SYSSUFF = .kmod + TEMPLATE_VBoxR0Drv_LDFLAGS = -d --warn-common + TEMPLATE_VBoxR0Drv_LDFLAGS.x86 = -m elf_i386 + TEMPLATE_VBoxR0Drv_LDFLAGS.amd64 = -m elf_x86_64 + + # symlink kernel includes + TEMPLATE_VBoxR0Drv_ORDERDEPS += \ + $(PATH_OBJ)/netbsd/include/$(VBOX_NETBSD_TARGET_ARCH) \ + $(PATH_OBJ)/netbsd/include/x86 \ + $(PATH_OBJ)/netbsd/include/machine + + $$(PATH_OBJ)/netbsd/include/$(VBOX_NETBSD_TARGET_ARCH): + $(QUIET)$(MKDIR) -p $(@D) + $(QUIET)$(LN_SYMLINK) $(VBOX_NETBSD_TARGET_SRC)/include $@ + + $$(PATH_OBJ)/netbsd/include/x86: + $(QUIET)$(MKDIR) -p $(@D) + $(QUIET)$(LN_SYMLINK) $(VBOX_NETBSD_SRC)/sys/arch/x86/include $@ + + $$(PATH_OBJ)/netbsd/include/machine: + $(QUIET)$(MKDIR) -p $(@D) + $(QUIET)$(LN_SYMLINK) $(VBOX_NETBSD_TARGET_ARCH) $@ + +endif # NetBSD + +ifeq ($(KBUILD_TARGET),haiku) + ## The Haiku include directories + VBOX_HAIKU_SYS_INCS ?= /boot/develop/headers/os/kernel /boot/develop/headers/os/drivers + + TEMPLATE_VBoxR0Drv_TOOL = $(VBOX_GCC_TOOL) + TEMPLATE_VBoxR0Drv_LDTOOL = $(VBOX_GCC_TOOL) + TEMPLATE_VBoxR0Drv_DEFS = _KERNEL_MODE=1 _STRICT_STDC IN_RING0 IN_RT_R0 + if $(VBOX_GCC_VERSION_CC) < 30400 + TEMPLATE_VBoxR0Drv_DEFS += RT_WITHOUT_PRAGMA_ONCE + endif + TEMPLATE_VBoxR0Drv_INCS = $(VBOX_HAIKU_SYS_INCS) + #TODO: sort this out + TEMPLATE_VBoxR0Drv_LDFLAGS = -shared $(VBOX_GCC_NO_UNDEFINED_R0) -dc -dy -lroot -rpath-link /boot/system/develop/lib/x86 --no-add-needed /boot/system/develop/lib/_KERNEL_ --no-add-needed /boot/system/develop/lib/haiku_version_glue.o + TEMPLATE_VBoxR0Drv_CFLAGS = -fno-PIC \ + $(VBOX_GCC_WARN) -Wstrict-prototypes $(VBOX_GCC_Wno-pointer-sign) -Wno-sign-compare \ + $(VBOX_GCC_fno-stack-protector) $(VBOX_GCC_R0_OPT) $(VBOX_GCC_R0_FP) -fno-strict-aliasing -fno-common -Werror-implicit-function-declaration + TEMPLATE_VBoxR0Drv_CFLAGS.x86 = -mno-sse -mno-mmx -mno-sse2 -mno-3dnow + TEMPLATE_VBoxR0Drv_CFLAGS.x86 = -m32 -mno-sse -mno-mmx -mno-sse2 -mno-3dnow + TEMPLATE_VBoxR0Drv_CFLAGS.amd64 = -m64 -mno-sse -mno-mmx -mno-sse2 -mno-3dnow \ + -fno-reorder-blocks -ffreestanding -fno-asynchronous-unwind-tables -funit-at-a-time \ + -Wno-sign-compare + TEMPLATE_VBoxR0Drv_CXXFLAGS = -fno-PIC -Wpointer-arith \ + -Wshadow -Wuninitialized -Wunused-function -Wunused-label -Wunused-value -Wunused-variable \ + -Wformat \ + -O2 -nodefaultlibs -fno-omit-frame-pointer -fno-strict-aliasing -fno-common -fno-exceptions -fno-rtti + TEMPLATE_VBoxR0Drv_CXXFLAGS.x86 = $(TEMPLATE_VBoxR0Drv_CFLAGS.x86) -fno-exceptions -fno-rtti + TEMPLATE_VBoxR0Drv_CXXFLAGS.amd64 = $(TEMPLATE_VBoxR0Drv_CFLAGS.amd64) -fno-exceptions -fno-rtti +endif # Haiku + +ifdef VBOX_WITH_VBOXDRV + ifndef TEMPLATE_VBoxR0Drv_TOOL + $(warning Warning: VBox Build: Target $(KBUILD_HOST) is not officially supported!) + endif +endif + +ifn1of ($(KBUILD_TARGET), darwin os2 win solaris freebsd) + # This doesn't work if supdrv is natively loading VMMR0.r0 et al, but + # fortunately it isn't really necessary. + TEMPLATE_VBoxR0Drv_CFLAGS += -include $(PATH_ROOT)/include/VBox/SUPDrvMangling.h + TEMPLATE_VBoxR0Drv_CXXFLAGS += -include $(PATH_ROOT)/include/VBox/SUPDrvMangling.h + TEMPLATE_VBoxR0Drv_ASDEFS += RT_MANGLER_PREFIX=VBoxHost_ +endif + +ifeq ($(KBUILD_TARGET),darwin) + # + # A variant of VBoxR0Drv that uses the 10.10 SDK. + # + TEMPLATE_VBoxR0DrvOSX10.10 = VBoxR0Drv variant using the 10.10 SDK + TEMPLATE_VBoxR0DrvOSX10.10_EXTENDS = VBoxR0Drv + TEMPLATE_VBoxR0DrvOSX10.10_SDKS = MACOSX1010 + TEMPLATE_VBoxR0DrvOSX10.10_INCS = $(filter-out $(VBOX_PATH_MACOSX_SDK)/%,$(TEMPLATE_VBoxR0Drv_INCS)) \ + $(PATH_SDK_MACOSX1010)/System/Library/Frameworks/Kernel.framework/PrivateHeaders \ + $(PATH_SDK_MACOSX1010)/System/Library/Frameworks/Kernel.framework/Headers + TEMPLATE_VBoxR0DrvOSX10.10_DEFS = $(filter-out $(VBOX_DARWIN_DEF_SDK_DEFS),$(TEMPLATE_VBoxR0Drv_DEFS)) + +endif + +# +# Template for building libraries used by ring-0 drivers. +# +TEMPLATE_VBoxR0DrvLib = VBox Ring 0 Driver Library +TEMPLATE_VBoxR0DrvLib_EXTENDS = VBoxR0Drv +TEMPLATE_VBoxR0DrvLib_INSTTYPE = stage +TEMPLATE_VBoxR0DrvLib_INSTTYPE.linux = stage + +# +# Template for installing INF and CAT files. +# +TEMPLATE_VBoxR0DrvInfCat = VBox SUPDRV Ring 0 - Install .sys, .cat, .inf +TEMPLATE_VBoxR0DrvInfCat_INST = $(INST_BIN) +TEMPLATE_VBoxR0DrvInfCat_MODE = a+r,u+w +TEMPLATE_VBoxR0DrvInfCat_IFFLAGS = --no-hard-link-files-when-possible + + +# +# Template for building R3 executables and static libraries which are linked into executables. +# Note! This is the base template for a whole lot of other ones, so be careful when changing it. +# +# Disabled Visual C++ warnings: +# -wd4065: switch statement contains 'default' but no 'case' labels +# -wd4244: 'conversion' conversion from 'type1' to 'type2', possible loss of data +# -wd4996: deprecated / insecure. +# +TEMPLATE_VBoxR3Exe = VBox Ring 3 Exe +TEMPLATE_VBoxR3Exe_ASTOOL := $(VBOX_ASTOOL) +TEMPLATE_VBoxR3Exe_ASFLAGS.x86 = $(VBOX_ASFLAGS32) +TEMPLATE_VBoxR3Exe_ASFLAGS.sparc32 = $(VBOX_ASFLAGS32) +TEMPLATE_VBoxR3Exe_ASFLAGS.amd64 = $(VBOX_ASFLAGS64) +TEMPLATE_VBoxR3Exe_ASFLAGS.arm64 = $(VBOX_ASFLAGS64) +TEMPLATE_VBoxR3Exe_ASFLAGS.sparc64 = $(VBOX_ASFLAGS64) +TEMPLATE_VBoxR3Exe_DEFS = IN_RING3 $(VBOX_GC_ARCH_BITS_DEFS) +TEMPLATE_VBoxR3Exe_DEFS.x86 = HC_ARCH_BITS=32 +TEMPLATE_VBoxR3Exe_DEFS.arm32 = HC_ARCH_BITS=32 +TEMPLATE_VBoxR3Exe_DEFS.sparc32 = HC_ARCH_BITS=32 +TEMPLATE_VBoxR3Exe_DEFS.amd64 = HC_ARCH_BITS=64 +TEMPLATE_VBoxR3Exe_DEFS.arm64 = HC_ARCH_BITS=64 +TEMPLATE_VBoxR3Exe_DEFS.sparc64 = HC_ARCH_BITS=64 +TEMPLATE_VBoxR3Exe_DEFS.win = _CRT_SECURE_NO_DEPRECATE +TEMPLATE_VBoxR3Exe_USES = dtrace +if defined(VBOX_WITH_DTRACE_R3) && defined(VBOX_WITH_NATIVE_DTRACE) + TEMPLATE_VBoxR3Exe_DTRACETOOL = DTraceAndVBoxTpG + TEMPLATE_VBoxR3Exe_DTRACE_OBJ_FLAGS = -C + TEMPLATE_VBoxR3Exe_DTRACE_HDR_FLAGS = -C + TEMPLATE_VBoxR3Exe_DEFS += VBOX_WITH_DTRACE VBOX_WITH_DTRACE_R3 VBOX_WITH_NATIVE_DTRACE +else + TEMPLATE_VBoxR3Exe_DTRACE_HDR_FLAGS = --ring-3-context + TEMPLATE_VBoxR3Exe_DTRACE_OBJ_FLAGS = --ring-3-context --pic --probe-fn-imported --probe-fn-name "SUPTracerFireProbe" + if defined(VBOX_WITH_DTRACE_R3) + TEMPLATE_VBoxR3Exe_DTRACETOOL = VBoxTpG + TEMPLATE_VBoxR3Exe_DEFS += VBOX_WITH_DTRACE VBOX_WITH_DTRACE_R3 + else + TEMPLATE_VBoxR3Exe_DTRACETOOL = VBoxTpG-Disabled + endif +endif +TEMPLATE_VBoxR3Exe_LIBS.kprofile = $(LIB_KPROFILE) +ifeq ($(KBUILD_TARGET),win) + # TEMPLATE_VBoxR3Exe_TOOL = $(VBOX_VCC_TOOL) + TEMPLATE_VBoxR3Exe_TOOL.win.x86 = $(VBOX_VCC_TOOL_STEM)X86 + TEMPLATE_VBoxR3Exe_TOOL.win.amd64 = $(VBOX_VCC_TOOL_STEM)AMD64 + TEMPLATE_VBoxR3Exe_RCDEFS = VBOX_SVN_REV=$(VBOX_SVN_REV) VBOX_SVN_REV_MOD_5K=$(expr $(VBOX_SVN_REV) % 50000) + if "$(VBOX_VCC_TOOL_STEM)" >= "VCC140" + TEMPLATE_VBoxR3Exe_SDKS = ReorderCompilerIncs WINSDK10-UCRT $(VBOX_WINPSDK) + else + TEMPLATE_VBoxR3Exe_SDKS = ReorderCompilerIncs $(VBOX_WINPSDK) + endif + TEMPLATE_VBoxR3Exe_CXXFLAGS = -Zi -Zl -GR- -EHsc -GF -MD$(VBOX_VCC_CRT_TYPE) -Zc:wchar_t- $(VBOX_VCC_OPT) $(VBOX_VCC_FP) \ + -Gy $(VBOX_VCC_CC_GUARD_CF) $(VBOX_VCC_SANITIZER_FLAGS) $(VBOX_VCC_std) $(VBOX_VCC_WARN_ALL) $(VBOX_VCC_WERR) + if "$(VBOX_VCC_TOOL_STEM)" >= "VCC120" + TEMPLATE_VBoxR3Exe_CXXFLAGS += -Gw + endif + ifdef VBOX_WITH_MSC_ANALYZE_THIS + TEMPLATE_VBoxR3Exe_CXXFLAGS += /analyze + endif + if "$(VBOX_VCC_TOOL_STEM)" >= "VCC142" # Don't waste space on x86/amd64-on-arm emulation optimizations. + TEMPLATE_VBoxR3Exe_CXXFLAGS += /volatileMetadata- + endif + TEMPLATE_VBoxR3Exe_CXXFLAGS.debug = -RTCsu + TEMPLATE_VBoxR3Exe_CXXFLAGS.dbgopt = $(NO_SUCH_VARIABLE) + TEMPLATE_VBoxR3Exe_CXXFLAGS.kprofile = -Gh -GH + TEMPLATE_VBoxR3Exe_CFLAGS = $(filter-out $(VBOX_VCC_std),$(TEMPLATE_VBoxR3Exe_CXXFLAGS)) + TEMPLATE_VBoxR3Exe_CFLAGS.debug = $(TEMPLATE_VBoxR3Exe_CXXFLAGS.debug) + TEMPLATE_VBoxR3Exe_CFLAGS.dbgopt = $(TEMPLATE_VBoxR3Exe_CXXFLAGS.dbgopt) + TEMPLATE_VBoxR3Exe_CFLAGS.kprofile = $(TEMPLATE_VBoxR3Exe_CXXFLAGS.kprofile) + TEMPLATE_VBoxR3Exe_PCHFLAGS = $(TEMPLATE_VBoxR3Exe_CXXFLAGS) + TEMPLATE_VBoxR3Exe_PCHFLAGS.debug = $(TEMPLATE_VBoxR3Exe_CXXFLAGS.debug) + TEMPLATE_VBoxR3Exe_PCHFLAGS.dbgopt = $(TEMPLATE_VBoxR3Exe_CXXFLAGS.dbgopt) + TEMPLATE_VBoxR3Exe_PCHFLAGS.kprofile = $(TEMPLATE_VBoxR3Exe_CXXFLAGS.kprofile) + TEMPLATE_VBoxR3Exe_LDFLAGS = -Ignore:4197 \ + /NOD /INCREMENTAL:NO /MAPINFO:EXPORTS /LargeAddressAware /DynamicBase /NxCompat /Release /Debug /Opt:Ref /Opt:Icf \ + $(VBOX_VCC_LD_GUARD_CF) $(VBOX_VCC_SANITIZER_LDFLAGS) \ + /Version:$(VBOX_VERSION_MAJOR)0$(VBOX_VERSION_MINOR).$(VBOX_VERSION_BUILD) \ + /STUB:$(PATH_ROOT)/src/VBox/HostDrivers/Support/win/winstub.com \ + /DISALLOWLIB:libc.lib \ + /DISALLOWLIB:libcd.lib \ + /DISALLOWLIB:libcmt.lib \ + /DISALLOWLIB:libcmtd.lib \ + /DISALLOWLIB:msvcrt$(VBOX_VCC_CRT_TYPE_N).lib \ + /DISALLOWLIB:msvcprt$(VBOX_VCC_CRT_TYPE_N).lib + ifdef VBOX_WITH_DTRACE_R3 + TEMPLATE_VBoxR3Exe_LDFLAGS += -Merge:VTGPrLc.Data=VTGPrLc.Begin -Merge:VTGPrLc.End=VTGPrLc.Begin -Merge:VTGPrLc.Begin=VTGObj + endif + if defined(VBOX_SIGNING_MODE) && defined(VBOX_WITH_HARDENING) + TEMPLATE_VBoxR3Exe_LDFLAGS += -IntegrityCheck + endif + TEMPLATE_VBoxR3Exe_LDFLAGS.win.amd64 = $(VBOX_VCC_LD_HIGH_ENTRYOPY_VA) + if "$(VBOX_VCC_TOOL_STEM)" >= "VCC142" # Don't waste space on x86/amd64-on-arm emulation optimizations. + TEMPLATE_VBoxR3Exe_LDFLAGS += -EmitVolatileMetadata:NO + endif + + if "$(VBOX_VCC_TOOL_STEM)" >= "VCC140" + TEMPLATE_VBoxR3Exe_LIBS.x86 = \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3Exe_TOOL.win.x86)_LIB)/vcruntime$(VBOX_VCC_CRT_TYPE).lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3Exe_TOOL.win.x86)_LIB)/msvcrt$(VBOX_VCC_CRT_TYPE).lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3Exe_TOOL.win.x86)_LIB)/msvcprt$(VBOX_VCC_CRT_TYPE).lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3Exe_TOOL.win.x86)_LIB)/oldnames.lib + TEMPLATE_VBoxR3Exe_LIBS.amd64 = \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3Exe_TOOL.win.amd64)_LIB)/vcruntime$(VBOX_VCC_CRT_TYPE).lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3Exe_TOOL.win.amd64)_LIB)/msvcrt$(VBOX_VCC_CRT_TYPE).lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3Exe_TOOL.win.amd64)_LIB)/msvcprt$(VBOX_VCC_CRT_TYPE).lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3Exe_TOOL.win.amd64)_LIB)/oldnames.lib + ifeq ($(KBUILD_TYPE),asan) + TEMPLATE_VBoxR3Exe_LIBS.x86 += \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3Exe_TOOL.win.x86)_LIB)/clang_rt.asan_dynamic-i386.lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3Exe_TOOL.win.x86)_LIB)/clang_rt.asan_dynamic_runtime_thunk-i386.lib + TEMPLATE_VBoxR3Exe_LIBS.amd64 += \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3Exe_TOOL.win.amd64)_LIB)/clang_rt.asan_dynamic-x86_64.lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3Exe_TOOL.win.amd64)_LIB)/clang_rt.asan_dynamic_runtime_thunk-x86_64.lib + endif + else + TEMPLATE_VBoxR3Exe_LIBS.x86 = \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3Exe_TOOL.win.x86)_LIB)/msvcrt$(VBOX_VCC_CRT_TYPE).lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3Exe_TOOL.win.x86)_LIB)/msvcprt$(VBOX_VCC_CRT_TYPE).lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3Exe_TOOL.win.x86)_LIB)/oldnames.lib + TEMPLATE_VBoxR3Exe_LIBS.amd64 = \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3Exe_TOOL.win.amd64)_LIB)/msvcrt$(VBOX_VCC_CRT_TYPE).lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3Exe_TOOL.win.amd64)_LIB)/msvcprt$(VBOX_VCC_CRT_TYPE).lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3Exe_TOOL.win.amd64)_LIB)/oldnames.lib + endif + + TEMPLATE_VBoxR3Exe_POST_CMDS = $(VBOX_UTF8_MANIFEST_CMDS)$(NLTAB)$(VBOX_SIGN_IMAGE_CMDS) + TEMPLATE_VBoxR3Exe_ORDERDEPS = $(VBOX_SIGN_IMAGE_CMDS_ORDERDEPS) + if defined(VBOX_WITH_MORE_NT4_COMPAT_BINARIES) && "$(KBUILD_TARGET).$(KBUILD_TARGET_ARCH)" == "win.x86" + TEMPLATE_VBoxR3Exe_POST_CMDS.win.x86 = $(if $(eq $(tool_do),LINK_LIBRARY),,$(VBOX_PE_SET_VERSION) $(out)$$(NLTAB)$(TEMPLATE_VBoxR3Exe_POST_CMDS)) + TEMPLATE_VBoxR3Exe_LNK_DEPS.win.x86 = $(if $(eq $(tool_do),LINK_LIBRARY),,$(VBOX_PE_SET_VERSION)) + TEMPLATE_VBoxR3Exe_LDFLAGS.win.x86 = \ + -Include:_vcc100_kernel32_fakes_cpp \ + -Include:_vcc100_kernel32_fakes_asm + TEMPLATE_VBoxR3Exe_LIBS.win.x86 = \ + $(PATH_STAGE_LIB)/RuntimeR3VccTricks2$(VBOX_SUFF_LIB) + TEMPLATE_VBoxR3Exe_LIBS.x86 = \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3Exe_TOOL.win.x86)_LIB)/oldnames.lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3Exe_TOOL.win.x86)_LIB)/libcmt$(VBOX_VCC_CRT_TYPE).lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3Exe_TOOL.win.x86)_LIB)/libcpmt$(VBOX_VCC_CRT_TYPE).lib + endif + +else # the gcc guys + TEMPLATE_VBoxR3Exe_TOOL = $(VBOX_GCC_TOOL) + if $(VBOX_GCC_VERSION_CC) < 30400 + TEMPLATE_VBoxR3Exe_DEFS += RT_WITHOUT_PRAGMA_ONCE + endif + TEMPLATE_VBoxR3Exe_CXXFLAGS = -g $(VBOX_GCC_pipe) $(VBOX_GCC_PEDANTIC_CXX) $(VBOX_GCC_Wno-variadic-macros) $(VBOX_GCC_OPT) \ + $(VBOX_GCC_FP) -fno-strict-aliasing $(VBOX_GCC_fvisibility-hidden) $(VBOX_GCC_std) $(VBOX_GCC_fvisibility-inlines-hidden) \ + $(VBOX_GCC_IPRT_FMT_CHECK) $(VBOX_GCC_SANITIZER_FLAGS) + ifdef VBOX_WITH_NO_GCC_WARNING_POLICY + TEMPLATE_VBoxR3Exe_CXXFLAGS += $(VBOX_GCC_WERR) + endif + TEMPLATE_VBoxR3Exe_CXXFLAGS.x86 = -m32 + TEMPLATE_VBoxR3Exe_CXXFLAGS.amd64 = -m64 + TEMPLATE_VBoxR3Exe_CXXFLAGS.sparc32 = -m32 + TEMPLATE_VBoxR3Exe_CXXFLAGS.sparc64 = -m64 + TEMPLATE_VBoxR3Exe_CXXFLAGS.kprofile = -finstrument-functions + TEMPLATE_VBoxR3Exe_CFLAGS = -g $(VBOX_GCC_pipe) $(VBOX_GCC_PEDANTIC_C) $(VBOX_GCC_Wno-variadic-macros) $(VBOX_GCC_OPT) \ + $(VBOX_GCC_FP) -fno-strict-aliasing $(VBOX_GCC_fvisibility-hidden) $(VBOX_GCC_IPRT_FMT_CHECK) + ifdef VBOX_WITH_NO_GCC_WARNING_POLICY + TEMPLATE_VBoxR3Exe_CFLAGS += $(VBOX_GCC_WERR) + endif + TEMPLATE_VBoxR3Exe_CFLAGS.x86 = $(TEMPLATE_VBoxR3Exe_CXXFLAGS.x86) + TEMPLATE_VBoxR3Exe_CFLAGS.amd64 = $(TEMPLATE_VBoxR3Exe_CXXFLAGS.amd64) + TEMPLATE_VBoxR3Exe_CFLAGS.sparc32 = $(TEMPLATE_VBoxR3Exe_CXXFLAGS.sparc32) + TEMPLATE_VBoxR3Exe_CFLAGS.sparc64 = $(TEMPLATE_VBoxR3Exe_CXXFLAGS.sparc64) + TEMPLATE_VBoxR3Exe_CFLAGS.debug = $(TEMPLATE_VBoxR3Exe_CXXFLAGS.debug) + TEMPLATE_VBoxR3Exe_CFLAGS.kprofile = $(TEMPLATE_VBoxR3Exe_CXXFLAGS.kprofile) + TEMPLATE_VBoxR3Exe_OBJCFLAGS = $(TEMPLATE_VBoxR3Exe_CFLAGS) + TEMPLATE_VBoxR3Exe_OBJCFLAGS.x86 = $(TEMPLATE_VBoxR3Exe_CFLAGS.x86) + TEMPLATE_VBoxR3Exe_OBJCFLAGS.amd64 = $(TEMPLATE_VBoxR3Exe_CFLAGS.amd64) + TEMPLATE_VBoxR3Exe_OBJCFLAGS.debug = $(TEMPLATE_VBoxR3Exe_CFLAGS.debug) + TEMPLATE_VBoxR3Exe_OBJCFLAGS.kprofile = $(TEMPLATE_VBoxR3Exe_CFLAGS.kprofile) + TEMPLATE_VBoxR3Exe_OBJCXXFLAGS = $(TEMPLATE_VBoxR3Exe_CXXFLAGS) + TEMPLATE_VBoxR3Exe_OBJCXXFLAGS.x86 = $(TEMPLATE_VBoxR3Exe_CXXFLAGS.x86) + TEMPLATE_VBoxR3Exe_OBJCXXFLAGS.amd64 = $(TEMPLATE_VBoxR3Exe_CXXFLAGS.amd64) + TEMPLATE_VBoxR3Exe_OBJCXXFLAGS.debug = $(TEMPLATE_VBoxR3Exe_CXXFLAGS.debug) + TEMPLATE_VBoxR3Exe_OBJCXXFLAGS.kprofile = $(TEMPLATE_VBoxR3Exe_CXXFLAGS.kprofile) + TEMPLATE_VBoxR3Exe_PCHFLAGS = $(TEMPLATE_VBoxR3Exe_CXXFLAGS) + TEMPLATE_VBoxR3Exe_PCHFLAGS.x86 = $(TEMPLATE_VBoxR3Exe_CXXFLAGS.x86) + TEMPLATE_VBoxR3Exe_PCHFLAGS.amd64 = $(TEMPLATE_VBoxR3Exe_CXXFLAGS.amd64) + TEMPLATE_VBoxR3Exe_PCHFLAGS.debug = $(TEMPLATE_VBoxR3Exe_CXXFLAGS.debug) + TEMPLATE_VBoxR3Exe_PCHFLAGS.kprofile = $(TEMPLATE_VBoxR3Exe_CXXFLAGS.kprofile) + TEMPLATE_VBoxR3Exe_LDFLAGS = $(VBOX_GCC_SANITIZER_FLAGS) $(VBOX_GCC_SANITIZER_LDFLAGS) + TEMPLATE_VBoxR3Exe_LDFLAGS.x86 = -m32 + TEMPLATE_VBoxR3Exe_LDFLAGS.amd64 = -m64 + TEMPLATE_VBoxR3Exe_LDFLAGS.sparc32 = -m32 + TEMPLATE_VBoxR3Exe_LDFLAGS.sparc64 = -m64 + TEMPLATE_VBoxR3Exe_LDFLAGS.linux = -Wl,-z,noexecstack,-z,relro $(VBOX_LD_as_needed) + TEMPLATE_VBoxR3Exe_LDFLAGS.solaris = -Wl,-z,ignore # same as VBOX_LD_as_needed + + ifeq ($(KBUILD_TARGET),linux) + TEMPLATE_VBoxR3Exe_LIBS = pthread m rt dl + else ifeq ($(KBUILD_TARGET),os2) + TEMPLATE_VBoxR3Exe_TOOL = GXX3OMF + TEMPLATE_VBoxR3Exe_LIBS = socket iconv + else ifeq ($(KBUILD_TARGET),darwin) + TEMPLATE_VBoxR3Exe_TOOL = $(VBOX_GCC_TOOL) + TEMPLATE_VBoxR3Exe_LIBS = + TEMPLATE_VBoxR3Exe_DEFS += LIBICONV_PLUG # Avoid 3rd party libiconv (from macports). + TEMPLATE_VBoxR3Exe_SDKS.darwin = $(VBOX_DARWIN_DEF_SDK_SDKS) + TEMPLATE_VBoxR3Exe_DEFS.darwin = $(VBOX_DARWIN_DEF_SDK_DEFS) + TEMPLATE_VBoxR3Exe_CFLAGS.darwin = $(VBOX_DARWIN_DEF_SDK_CFLAGS) -fno-common + TEMPLATE_VBoxR3Exe_CXXFLAGS.darwin = $(VBOX_DARWIN_DEF_SDK_CXXFLAGS) + TEMPLATE_VBoxR3Exe_PCHFLAGS.darwin = $(VBOX_DARWIN_DEF_SDK_CXXFLAGS) + TEMPLATE_VBoxR3Exe_OBJCFLAGS.darwin = $(VBOX_DARWIN_DEF_SDK_OBJCFLAGS) + TEMPLATE_VBoxR3Exe_OBJCXXFLAGS.darwin = $(VBOX_DARWIN_DEF_SDK_OBJCXXFLAGS) + TEMPLATE_VBoxR3Exe_LDFLAGS.darwin = $(VBOX_DARWIN_DEF_SDK_LDFLAGS) -Wl,-headerpad_max_install_names + TEMPLATE_VBoxR3Exe_LDFLAGS.darwin.x86 = -read_only_relocs suppress + TEMPLATE_VBoxR3Exe_POST_CMDS.darwin = $(VBOX_SIGN_IMAGE_CMDS) + ifdef VBOX_WITH_DTRACE_R3 + TEMPLATE_VBoxR3Exe_CXXFLAGS := $(filter-out -pedantic,$(TEMPLATE_VBoxR3Exe_CXXFLAGS)) -fdollars-in-identifiers # annoying gcc option precedence. + endif + else ifeq ($(KBUILD_TARGET),haiku) + TEMPLATE_VBoxR3Exe_TOOL = GXX3 + TEMPLATE_VBoxR3Exe_POST_CMDS = $(VBOX_HAIKU_XRES_SETVER_CMDS) + TEMPLATE_VBoxR3Exe_LIBS = network iconv stdc++ supc++ + TEMPLATE_VBoxR3Exe_LIBPATH += \ + /boot/common/lib + # Haiku uses PIC by default... + TEMPLATE_VBoxR3Exe_CFLAGS += -fno-pic + TEMPLATE_VBoxR3Exe_CXXFLAGS += -fno-pic + TEMPLATE_VBoxR3Exe_LDFLAGS += -fno-pic + else if1of ($(KBUILD_TARGET), freebsd openbsd) + TEMPLATE_VBoxR3Exe_TOOL = GXX3 + TEMPLATE_VBoxR3Exe_LIBS = pthread + TEMPLATE_VBoxR3Exe_INCS += \ + /usr/include \ + /usr/X11R6/include \ + /usr/local/include + TEMPLATE_VBoxR3Exe_LIBPATH += \ + /usr/lib \ + /usr/X11R6/lib \ + /usr/local/lib + else ifeq ($(KBUILD_TARGET),netbsd) + TEMPLATE_VBoxR3Exe_TOOL = GXX3 + TEMPLATE_VBoxR3Exe_LIBS = pthread + TEMPLATE_VBoxR3Exe_INCS += \ + /usr/include \ + /usr/X11R7/include + TEMPLATE_VBoxR3Exe_LIBPATH += \ + /usr/lib \ + /usr/X11R7/lib + else ifeq ($(KBUILD_TARGET),solaris) + TEMPLATE_VBoxR3Exe_TOOL = GXX3PLAIN + TEMPLATE_VBoxR3Exe_DEFS += LIBICONV_PLUG _REENTRANT # Avoid the GNU libiconv, for now at least. + if $(VBOX_GCC_VERSION_CC) < 30500 + TEMPLATE_VBoxR3Exe_CFLAGS += -std=gnu99 + endif + TEMPLATE_VBoxR3Exe_LIBS = rt socket + else + $(warning Warning: VBOX Build: Target $(KBUILD_TARGET) is not officially supported!) + TEMPLATE_VBoxR3Exe_CXXFLAGS.profile = $(TEMPLATE_VBoxR3Exe_CXXFLAGS.release) + TEMPLATE_VBoxR3Exe_CXXFLAGS.kprofile = $(TEMPLATE_VBoxR3Exe_CXXFLAGS.krelease) + endif + ifdef VBOX_WITH_RUNPATH + TEMPLATE_VBoxR3Exe_LDFLAGS += '$(VBOX_GCC_RPATH_OPT)$(VBOX_WITH_RUNPATH)' + else ifdef VBOX_WITH_RELATIVE_RUNPATH + TEMPLATE_VBoxR3Exe_LDFLAGS += '$(VBOX_GCC_RPATH_OPT)$(VBOX_WITH_RELATIVE_RUNPATH)' + endif + ifdef VBOX_WITH_ORIGIN + TEMPLATE_VBoxR3Exe_LDFLAGS.linux += $(VBOX_GCC_ORIGIN_OPT) + endif +endif + +# +# Template for building R3 shared objects / DLLs - base template, don't use directly. +# This is mostly identical to the VBoxR3Exe template. (Avoid PIC if possible!) +# +## @todo Eliminate VBoxR3DllBase in favor of VBoxR3Dll. +TEMPLATE_VBoxR3DllBase = VBox Ring 3 SO/DLLs Base Template - do not use directly! +TEMPLATE_VBoxR3DllBase_EXTENDS = VBoxR3Exe +TEMPLATE_VBoxR3DllBase_DEFS.darwin = $(TEMPLATE_VBoxR3Exe_DEFS.darwin) PIC +TEMPLATE_VBoxR3DllBase_LDFLAGS.darwin = $(TEMPLATE_VBoxR3Exe_LDFLAGS.darwin) \ + -current_version $(VBOX_VERSION_MAJOR).$(VBOX_VERSION_MINOR).$(VBOX_VERSION_BUILD) \ + -compatibility_version $(VBOX_VERSION_MAJOR).$(VBOX_VERSION_MINOR).$(VBOX_VERSION_BUILD) +ifn1of ($(KBUILD_TARGET), darwin win os2) + TEMPLATE_VBoxR3DllBase_DEFS = $(TEMPLATE_VBoxR3Exe_DEFS) PIC + TEMPLATE_VBoxR3DllBase_CFLAGS = $(TEMPLATE_VBoxR3Exe_CFLAGS) -fPIC + TEMPLATE_VBoxR3DllBase_CXXFLAGS = $(TEMPLATE_VBoxR3Exe_CXXFLAGS) -fPIC + TEMPLATE_VBoxR3DllBase_PCHFLAGS = $(TEMPLATE_VBoxR3Exe_PCHFLAGS) -fPIC + TEMPLATE_VBoxR3DllBase_LDFLAGS = $(TEMPLATE_VBoxR3Exe_LDFLAGS) -fPIC +endif + +# +# Temporary: Renaming the template and warnings will be errors ("soon"). +# +TEMPLATE_VBoxR3Dll = VBox ring-3 SO/DLLs, no warnings +TEMPLATE_VBoxR3Dll_EXTENDS += VBoxR3DllBase +TEMPLATE_VBoxR3Dll_EXTENDS_BY += appending +ifeq ($(KBUILD_TARGET),win) + TEMPLATE_VBoxR3Dll_CFLAGS += $(VBOX_VCC_WERR) + TEMPLATE_VBoxR3Dll_CXXFLAGS += $(VBOX_VCC_WERR) + TEMPLATE_VBoxR3Dll_PCHFLAGS += $(VBOX_VCC_WERR) + TEMPLATE_VBoxR3Dll_LDFLAGS += $(VBOX_VCC_LD_WERR) +else + TEMPLATE_VBoxR3Dll_CFLAGS += $(VBOX_GCC_WERR) + TEMPLATE_VBoxR3Dll_CXXFLAGS += $(VBOX_GCC_WERR) + TEMPLATE_VBoxR3Dll_PCHFLAGS += $(VBOX_GCC_WERR) +endif + +# x86 edition of the above template for use on AMD64 targets. +TEMPLATE_VBoxR3Dll-x86 = 32-bit VBox ring-3 SO/DLLs, no warnings +TEMPLATE_VBoxR3Dll-x86_EXTENDS = VBoxR3Dll +TEMPLATE_VBoxR3Dll-x86_BLD_TRG_ARCH = x86 +TEMPLATE_VBoxR3Dll-x86_DEFS = $(filter-out HC_ARCH_BITS%,$(TEMPLATE_VBoxR3Dll_DEFS)) \ + HC_ARCH_BITS=32 ARCH_BITS=32 + + +# +# Template for building performance critical stuff with warnings-as-errors. +# +TEMPLATE_VBoxR3DllNoPic = VBox ring-3 SO/DLLs without PIC, without warnings. +TEMPLATE_VBoxR3DllNoPic_EXTENDS = VBoxR3DllBase +if1of ($(KBUILD_TARGET).$(KBUILD_TARGET_ARCH), linux.x86 freebsd.x86) + TEMPLATE_VBoxR3DllNoPic_DEFS = $(TEMPLATE_VBoxR3Exe_DEFS) + TEMPLATE_VBoxR3DllNoPic_CFLAGS = $(TEMPLATE_VBoxR3Exe_CFLAGS) $(VBOX_GCC_WERR) + TEMPLATE_VBoxR3DllNoPic_CXXFLAGS = $(TEMPLATE_VBoxR3Exe_CXXFLAGS) $(VBOX_GCC_WERR) + TEMPLATE_VBoxR3DllNoPic_PCHFLAGS = $(TEMPLATE_VBoxR3Exe_CXXFLAGS) $(VBOX_GCC_WERR) + TEMPLATE_VBoxR3DllNoPic_LDFLAGS = $(TEMPLATE_VBoxR3Exe_LDFLAGS) +else ifeq ($(KBUILD_TARGET),win) + TEMPLATE_VBoxR3DllNoPic_CFLAGS = $(filter-out -W3 -wd%,$(TEMPLATE_VBoxR3DllBase_CFLAGS)) $(VBOX_VCC_WARN_ALL) $(VBOX_VCC_WERR) + TEMPLATE_VBoxR3DllNoPic_CFLAGS.debug = $(filter-out -RTC%,$(TEMPLATE_VBoxR3DllBase_CFLAGS.debug)) + TEMPLATE_VBoxR3DllNoPic_CFLAGS.release = $(TEMPLATE_VBoxR3DllBase_CFLAGS.release) -GS- + TEMPLATE_VBoxR3DllNoPic_CXXFLAGS = $(filter-out -W3 -wd%,$(TEMPLATE_VBoxR3DllBase_CXXFLAGS)) $(VBOX_VCC_WARN_ALL) $(VBOX_VCC_WERR) + TEMPLATE_VBoxR3DllNoPic_CXXFLAGS.debug = $(filter-out -RTC%,$(TEMPLATE_VBoxR3DllBase_CXXFLAGS.debug)) # RTCsu Prevents IEM opt. + TEMPLATE_VBoxR3DllNoPic_CXXFLAGS.release = $(TEMPLATE_VBoxR3DllBase_CXXFLAGS.release) -GS- + TEMPLATE_VBoxR3DllNoPic_PCHFLAGS = $(filter-out -W3 -wd%,$(TEMPLATE_VBoxR3DllBase_PCHFLAGS)) $(VBOX_VCC_WARN_ALL) $(VBOX_VCC_WERR) + TEMPLATE_VBoxR3DllNoPic_PCHFLAGS.debug = $(filter-out -RTC%,$(TEMPLATE_VBoxR3DllBase_PCHFLAGS.debug)) # RTCsu Prevents IEM opt. + TEMPLATE_VBoxR3DllNoPic_PCHFLAGS.release = $(TEMPLATE_VBoxR3DllBase_PCHFLAGS.release) -GS- + TEMPLATE_VBoxR3DllNoPic_LDFLAGS = $(TEMPLATE_VBoxR3DllBase_LDFLAGS) $(VBOX_VCC_LD_WERR) +else + TEMPLATE_VBoxR3DllNoPic_CFLAGS = $(TEMPLATE_VBoxR3DllBase_CFLAGS) $(VBOX_GCC_WERR) + TEMPLATE_VBoxR3DllNoPic_CXXFLAGS = $(TEMPLATE_VBoxR3DllBase_CXXFLAGS) $(VBOX_GCC_WERR) + TEMPLATE_VBoxR3DllNoPic_PCHFLAGS = $(TEMPLATE_VBoxR3DllBase_PCHFLAGS) $(VBOX_GCC_WERR) +endif + +# x86 edition of the above template for use on AMD64 targets. +TEMPLATE_VBoxR3DllNoPic-x86 = 32-bit VBox ring-3 SO/DLLs without PIC, without warnings. +TEMPLATE_VBoxR3DllNoPic-x86_EXTENDS = VBoxR3DllNoPic +TEMPLATE_VBoxR3DllNoPic-x86_BLD_TRG_ARCH = x86 +TEMPLATE_VBoxR3DllNoPic-x86_DEFS = $(filter-out HC_ARCH_BITS%,$(TEMPLATE_VBoxR3DllNoPic_DEFS)) \ + HC_ARCH_BITS=32 ARCH_BITS=32 + + +# +# Template for building performance critical stuff without warnings-as-errors. +# +TEMPLATE_VBoxR3DllWarnNoPic = VBox ring-3 SO/DLLs without PIC, with warnings. +TEMPLATE_VBoxR3DllWarnNoPic_EXTENDS = VBoxR3DllBase +if1of ($(KBUILD_TARGET).$(KBUILD_TARGET_ARCH), linux.x86 freebsd.x86) + TEMPLATE_VBoxR3DllWarnNoPic_DEFS = $(TEMPLATE_VBoxR3Exe_DEFS) + TEMPLATE_VBoxR3DllWarnNoPic_CFLAGS = $(TEMPLATE_VBoxR3Exe_CFLAGS) + TEMPLATE_VBoxR3DllWarnNoPic_CXXFLAGS = $(TEMPLATE_VBoxR3Exe_CXXFLAGS) + TEMPLATE_VBoxR3DllWarnNoPic_PCHFLAGS = $(TEMPLATE_VBoxR3Exe_PCHFLAGS) + TEMPLATE_VBoxR3DllWarnNoPic_LDFLAGS = $(TEMPLATE_VBoxR3Exe_LDFLAGS) +else ifeq ($(KBUILD_TARGET),win) + TEMPLATE_VBoxR3DllWarnNoPic_CFLAGS.release = $(TEMPLATE_VBoxR3DllBase_CFLAGS.release) -GS- + TEMPLATE_VBoxR3DllWarnNoPic_CXXFLAGS.release = $(TEMPLATE_VBoxR3DllBase_CXXFLAGS.release) -GS- + TEMPLATE_VBoxR3DllWarnNoPic_PCHFLAGS.release = $(TEMPLATE_VBoxR3DllBase_PCHFLAGS.release) -GS- +endif + +# +# Base template for building static R3 executables and any static +# libraries they link with. Do _not_ use directly! +# +## @todo Bake this into VBoxR3Static. +TEMPLATE_VBoxR3StaticBase = VBox Static Ring 3 EXE +TEMPLATE_VBoxR3StaticBase_EXTENDS = VBoxR3Exe +TEMPLATE_VBoxR3StaticBase_DEFS = IN_RT_STATIC IN_RT_R3 IN_SUP_STATIC $(TEMPLATE_VBoxR3Exe_DEFS) +ifdef VBOX_WITH_NOCRT_STATIC + TEMPLATE_VBoxR3StaticBase_DEFS += IPRT_NO_CRT + TEMPLATE_VBoxR3StaticBase_INCS = $(PATH_ROOT)/include/iprt/nocrt $(TEMPLATE_VBoxR3Exe_INCS) +endif +ifeq ($(KBUILD_TARGET),win) + if "$(VBOX_VCC_TOOL_STEM)" >= "VCC140" + ifdef VBOX_WITH_NOCRT_STATIC + TEMPLATE_VBoxR3StaticBase_SDKS = $(subst WINSDK10-UCRT,,$(TEMPLATE_VBoxR3Exe_SDKS)) + TEMPLATE_VBoxR3StaticBase_SDKS.x86 = $(TEMPLATE_VBoxR3Exe_SDKS.x86) VBoxWinInt64Lib ## @todo drop this asap. @bugref{10261} + else + TEMPLATE_VBoxR3StaticBase_SDKS = $(subst WINSDK10-UCRT, WINSDK10-UCRT-STATIC,$(TEMPLATE_VBoxR3Exe_SDKS)) + endif + endif + ifdef VBOX_WITH_NOCRT_STATIC + TEMPLATE_VBoxR3StaticBase_CFLAGS = $(filter-out -MD$(VBOX_VCC_CRT_TYPE) -EHsc -GR, $(TEMPLATE_VBoxR3Exe_CFLAGS)) \ + -Zl -EHc-s- -Gy -GR- + TEMPLATE_VBoxR3StaticBase_CXXFLAGS = $(filter-out -MD$(VBOX_VCC_CRT_TYPE) -EHsc -GR, $(TEMPLATE_VBoxR3Exe_CXXFLAGS)) \ + -Zl -EHc-s- -Gy -GR- + TEMPLATE_VBoxR3StaticBase_PCHFLAGS = $(filter-out -MD$(VBOX_VCC_CRT_TYPE) -EHsc -GR, $(TEMPLATE_VBoxR3Exe_PCHFLAGS)) \ + -Zl -EHc-s- -Gy -GR- + else + TEMPLATE_VBoxR3StaticBase_CFLAGS = $(filter-out -MD$(VBOX_VCC_CRT_TYPE), $(TEMPLATE_VBoxR3Exe_CFLAGS)) \ + -MT$(VBOX_VCC_CRT_TYPE) -Gy + TEMPLATE_VBoxR3StaticBase_CXXFLAGS = $(filter-out -MD$(VBOX_VCC_CRT_TYPE), $(TEMPLATE_VBoxR3Exe_CXXFLAGS)) \ + -MT$(VBOX_VCC_CRT_TYPE) -Gy + TEMPLATE_VBoxR3StaticBase_PCHFLAGS = $(filter-out -MD$(VBOX_VCC_CRT_TYPE), $(TEMPLATE_VBoxR3Exe_PCHFLAGS)) \ + -MT$(VBOX_VCC_CRT_TYPE) -Gy + endif + + if "$(VBOX_VCC_TOOL_STEM)" >= "VCC120" # Do not use SSE so valkit stuff can run on NT4 w/o needing a separate runtime library. + TEMPLATE_VBoxR3StaticBase_CFLAGS.win.x86 = $(TEMPLATE_VBoxR3Exe_CFLAGS.win.86) /arch:IA32 + TEMPLATE_VBoxR3StaticBase_CXXFLAGS.win.x86 = $(TEMPLATE_VBoxR3Exe_CXXFLAGS.win.86) /arch:IA32 + TEMPLATE_VBoxR3StaticBase_PCHFLAGS.win.x86 = $(TEMPLATE_VBoxR3Exe_PCHFLAGS.win.86) /arch:IA32 + TEMPLATE_VBoxR3StaticBase_CFLAGS += -Gw + TEMPLATE_VBoxR3StaticBase_CXXFLAGS += -Gw + TEMPLATE_VBoxR3StaticBase_PCHFLAGS += -Gw + endif + + ifdef VBOX_WITH_NOCRT_STATIC + # .0000cfg normally merges into .idata, but the linker won't let us do so via /MERGE. Doesn't matter much, + # because .idata can be writable when targeting x86 (NT 3.1 fun) and we don't want .0000cfg to be writable. + TEMPLATE_VBoxR3StaticBase_LDFLAGS = $(TEMPLATE_VBoxR3Exe_LDFLAGS) /NODEFAULTLIB /Merge:.0000cfg=.rdata + else + TEMPLATE_VBoxR3StaticBase_LDFLAGS = $(filter-out /DISALLOWLIB:libcmt$(VBOX_VCC_CRT_TYPE).lib /DISALLOWLIB:libcpmt$(VBOX_VCC_CRT_TYPE).lib, $(TEMPLATE_VBoxR3Exe_LDFLAGS)) + endif + TEMPLATE_VBoxR3StaticBase_LDFLAGS += \ + /DISALLOWLIB:msvcrt.lib \ + /DISALLOWLIB:msvcrtd.lib \ + /DISALLOWLIB:msvcprt.lib \ + /DISALLOWLIB:msvcprtd.lib \ + /DISALLOWLIB:vcruntime.lib \ + /DISALLOWLIB:vcruntimed.lib \ + /DISALLOWLIB:ucrt.lib \ + /DISALLOWLIB:ucrtd.lib + if "$(VBOX_VCC_TOOL_STEM)" >= "VCC140" + ifdef VBOX_WITH_NOCRT_STATIC + TEMPLATE_VBoxR3StaticBase_LIBS.amd64 = $(NO_SUCH_VARIABLE) + TEMPLATE_VBoxR3StaticBase_LIBS.x86 = $(NO_SUCH_VARIABLE) + else + TEMPLATE_VBoxR3StaticBase_LIBS.x86 = \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3StaticBase_TOOL.win.x86)_LIB)/libvcruntime$(VBOX_VCC_CRT_TYPE).lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3StaticBase_TOOL.win.x86)_LIB)/libcmt$(VBOX_VCC_CRT_TYPE).lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3StaticBase_TOOL.win.x86)_LIB)/libcpmt$(VBOX_VCC_CRT_TYPE).lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3StaticBase_TOOL.win.x86)_LIB)/oldnames.lib + TEMPLATE_VBoxR3StaticBase_LIBS.amd64 = \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3StaticBase_TOOL.win.amd64)_LIB)/libvcruntime$(VBOX_VCC_CRT_TYPE).lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3StaticBase_TOOL.win.amd64)_LIB)/libcmt$(VBOX_VCC_CRT_TYPE).lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3StaticBase_TOOL.win.amd64)_LIB)/libcpmt$(VBOX_VCC_CRT_TYPE).lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3StaticBase_TOOL.win.amd64)_LIB)/oldnames.lib + endif + ifeq ($(KBUILD_TYPE),asan) + TEMPLATE_VBoxR3StaticBase_LIBS.x86 += \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3StaticBase_TOOL.win.x86)_LIB)/clang_rt.asan-i386.lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3StaticBase_TOOL.win.x86)_LIB)/clang_rt.asan_cxx-i386.lib + TEMPLATE_VBoxR3StaticBase_LIBS.amd64 += \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3StaticBase_TOOL.win.amd64)_LIB)/clang_rt.asan-x86_64.lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3StaticBase_TOOL.win.amd64)_LIB)/clang_rt.asan_cxx-x86_64.lib + endif + else + ifdef VBOX_WITH_NOCRT_STATIC + TEMPLATE_VBoxR3StaticBase_LIBS.amd64 = $(NO_SUCH_VARIABLE) + TEMPLATE_VBoxR3StaticBase_LIBS.x86 = $(NO_SUCH_VARIABLE) + else + TEMPLATE_VBoxR3StaticBase_LIBS.x86 = \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3StaticBase_TOOL.win.x86)_LIB)/oldnames.lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3StaticBase_TOOL.win.x86)_LIB)/libcmt$(VBOX_VCC_CRT_TYPE).lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3StaticBase_TOOL.win.x86)_LIB)/libcpmt$(VBOX_VCC_CRT_TYPE).lib + TEMPLATE_VBoxR3StaticBase_LIBS.amd64 = \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3StaticBase_TOOL.win.amd64)_LIB)/libcmt$(VBOX_VCC_CRT_TYPE).lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3StaticBase_TOOL.win.amd64)_LIB)/libcpmt$(VBOX_VCC_CRT_TYPE).lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3StaticBase_TOOL.win.amd64)_LIB)/oldnames.lib + endif + endif +else + ifdef VBOX_WITH_NOCRT_STATIC + TEMPLATE_VBoxR3StaticBase_DEFS += RT_WITH_NOCRT_WRAPPERS + endif + ifn1of ($(KBUILD_TARGET), darwin linux solaris) + # The gcc guys sans darwin, linux and solaris (don't depend on statically compiled system libs there) + TEMPLATE_VBoxR3StaticBase_CFLAGS = $(TEMPLATE_VBoxR3Exe_CFLAGS) -static + TEMPLATE_VBoxR3StaticBase_CXXFLAGS = $(TEMPLATE_VBoxR3Exe_CXXFLAGS) -static + TEMPLATE_VBoxR3StaticBase_PCHFLAGS = $(TEMPLATE_VBoxR3Exe_PCHFLAGS) -static + TEMPLATE_VBoxR3StaticBase_OBJCFLAGS = $(TEMPLATE_VBoxR3Exe_OBJCFLAGS) -static + TEMPLATE_VBoxR3StaticBase_OBJCXXFLAGS = $(TEMPLATE_VBoxR3Exe_OBJCXXFLAGS) -static + TEMPLATE_VBoxR3StaticBase_LDFLAGS = $(TEMPLATE_VBoxR3Exe_LDFLAGS) -static + else ifeq ($(KBUILD_TARGET),solaris) + TEMPLATE_VBoxR3StaticBase_LIBS = $(TEMPLATE_VBoxR3Exe_LIBS) nsl + TEMPLATE_VBoxR3StaticBase_LDFLAGS = $(filter-out '$(VBOX_GCC_RPATH_OPT)$(VBOX_WITH_RUNPATH)' '$(VBOX_GCC_RPATH_OPT)$(VBOX_WITH_RELATIVE_RUNPATH)',$(TEMPLATE_VBoxR3Exe_LDFLAGS)) + else + TEMPLATE_VBoxR3StaticBase_LDFLAGS = $(filter-out '$(VBOX_GCC_RPATH_OPT)$(VBOX_WITH_RUNPATH)' '$(VBOX_GCC_RPATH_OPT)$(VBOX_WITH_RELATIVE_RUNPATH)',$(TEMPLATE_VBoxR3Exe_LDFLAGS)) + endif + ifn1of ($(KBUILD_TARGET), darwin os2) # ELF only. Present in gcc 3.2.3 & binutils 2.15, possibly earlier. + ifdef VBOX_LD_gc_sections # Older solaris linker versions doesn't grok --gc-sections (e.g. add build box). + ifndef TEMPLATE_VBoxR3StaticBase_CXXFLAGS + TEMPLATE_VBoxR3StaticBase_CXXFLAGS = $(TEMPLATE_VBoxR3Exe_CXXFLAGS) + TEMPLATE_VBoxR3StaticBase_CFLAGS = $(TEMPLATE_VBoxR3Exe_CFLAGS) + endif + TEMPLATE_VBoxR3StaticBase_CXXFLAGS += -ffunction-sections -fdata-sections + TEMPLATE_VBoxR3StaticBase_CFLAGS += -ffunction-sections -fdata-sections + TEMPLATE_VBoxR3StaticBase_LDFLAGS += $(VBOX_LD_gc_sections) + endif + endif +endif + +# +# Temporary: Renaming the template and warnings will be errors (soon). +# Unlike VBoxR3StaticBase, this is strict wrt warnings and includes IPRT. +# +TEMPLATE_VBoxR3Static = New name for VBoxR3StaticBase +TEMPLATE_VBoxR3Static_EXTENDS = VBoxR3StaticBase +TEMPLATE_VBoxR3Static_EXTENDS_BY = appending +TEMPLATE_VBoxR3Static_SDKS.$(KBUILD_TARGET_ARCH) += VBoxOpenSslStatic +TEMPLATE_VBoxR3Static_SDKS.win += VBoxNtDll +ifeq ($(KBUILD_TARGET),win) + TEMPLATE_VBoxR3Static_CFLAGS += $(VBOX_VCC_WERR) + TEMPLATE_VBoxR3Static_CXXFLAGS += $(VBOX_VCC_WERR) + TEMPLATE_VBoxR3Static_PCHFLAGS += $(VBOX_VCC_WERR) + TEMPLATE_VBoxR3Static_LDFLAGS += $(VBOX_VCC_LD_WERR) +else + TEMPLATE_VBoxR3Static_CFLAGS += $(VBOX_GCC_WERR) + TEMPLATE_VBoxR3Static_CXXFLAGS += $(VBOX_GCC_WERR) + TEMPLATE_VBoxR3Static_PCHFLAGS += $(VBOX_GCC_WERR) + TEMPLATE_VBoxR3Static_LDFLAGS.darwin.arm64 += $(TEMPLATE_VBoxR3StaticBase_LDFLAGS.darwin.arm64) -framework IOKit +endif +TEMPLATE_VBoxR3Static_LIBS.$(KBUILD_TARGET_ARCH) += \ + $(VBOX_LIB_RUNTIME_STATIC) +ifneq ($(KBUILD_TARGET_ARCH),x86) + TEMPLATE_VBoxR3Static_LIBS.x86 += \ + $(VBOX_LIB_RUNTIME_STATIC_X86) +endif +ifndef SDK_VBoxLibXml2_LIBS + TEMPLATE_VBoxR3Static_LIBS.$(KBUILD_TARGET_ARCH) += \ + $(PATH_STAGE_LIB)/VBox-libxml2-static$(VBOX_SUFF_LIB) +endif +if1of ($(KBUILD_TARGET), os2 win) + TEMPLATE_VBoxR3Static_LIBS.$(KBUILD_TARGET_ARCH) += \ + $(SDK_VBoxLzf_STATIC_LIBS) \ + $(SDK_VBoxZlibStatic_LIBS) +else + TEMPLATE_VBoxR3Static_LIBS.$(KBUILD_TARGET_ARCH) += \ + $(SDK_VBoxLzf_LIBS) \ + $(SDK_VBoxZlib_LIBS) + if1of ($(KBUILD_TARGET), darwin freebsd) + TEMPLATE_VBoxR3Static_LIBS += iconv + else ifeq ($(KBUILD_TARGET),solaris) + TEMPLATE_VBoxR3Static_LIBS += kstat + endif +endif + +# +# A no-ASAN version of VBoxR3Static for things like that automatically executed tests. +# +TEMPLATE_VBoxR3StaticExeNoAsan = VBoxR3Static but w/o ASAN +TEMPLATE_VBoxR3StaticExeNoAsan_EXTENDS = VBoxR3Static +if "$(KBUILD_TARGET)" == "win" && "$(KBUILD_TYPE)" == "asan" + TEMPLATE_VBoxR3StaticExeNoAsan_CFLAGS = $(filter-out $(VBOX_VCC_SANITIZER_FLAGS) , $(TEMPLATE_VBoxR3Static_CFLAGS)) + TEMPLATE_VBoxR3StaticExeNoAsan_CXXFLAGS = $(filter-out $(VBOX_VCC_SANITIZER_FLAGS) , $(TEMPLATE_VBoxR3Static_CXXFLAGS)) + TEMPLATE_VBoxR3StaticExeNoAsan_PCHFLAGS = $(filter-out $(VBOX_VCC_SANITIZER_FLAGS) , $(TEMPLATE_VBoxR3Static_PCHFLAGS)) + TEMPLATE_VBoxR3StaticExeNoAsan_LDFLAGS = $(filter-out $(VBOX_VCC_SANITIZER_LDFLAGS), $(TEMPLATE_VBoxR3Static_LDFLAGS)) -InferAsanLibs:No + TEMPLATE_VBoxR3StaticExeNoAsan_LIBS.x86 = $(subst $(VBOX_LIB_RUNTIME_STATIC),$(VBOX_LIB_RUNTIME_STATIC_NO_ASAN),$(filter-out %clang_rt.asan-i386.lib %clang_rt.asan_cxx-i386.lib , $(TEMPLATE_VBoxR3Static_LIBS.x86))) + TEMPLATE_VBoxR3StaticExeNoAsan_LIBS.amd64 = $(subst $(VBOX_LIB_RUNTIME_STATIC),$(VBOX_LIB_RUNTIME_STATIC_NO_ASAN),$(filter-out %clang_rt.asan-x86_64.lib %clang_rt.asan_cxx-x86_64.lib, $(TEMPLATE_VBoxR3Static_LIBS.amd64))) +endif + +# +# A DLL capable version of VBoxR3Static +# +## @todo make VBoxR3StaticDll work on non-windows. +TEMPLATE_VBoxR3StaticDll = VBox Static Ring-3 DLL +TEMPLATE_VBoxR3StaticDll_EXTENDS = VBoxR3Static +if "$(KBUILD_TARGET)" == "win" && "$(KBUILD_TYPE)" == "asan" + TEMPLATE_VBoxR3StaticDll_LIBS.x86 = $(patsubst %clang_rt.asan-i386.lib, %clang_rt.asan_dll_thunk-i386.lib, $(filter-out %clang_rt.asan_cxx-i386.lib,$(TEMPLATE_VBoxR3Static_LIBS.x86))) + TEMPLATE_VBoxR3StaticDll_LIBS.amd64 = $(patsubst %clang_rt.asan-x86_64.lib, %clang_rt.asan_dll_thunk-x86_64.lib, $(filter-out %clang_rt.asan_cxx-x86_64.lib,$(TEMPLATE_VBoxR3Static_LIBS.amd64))) +endif + +# +# A no-ASAN version of VBoxR3StaticDll for the installer helper DLL. +# +# Note! Not compatible with BLD_TRG_ARCH overrides yet. +# +TEMPLATE_VBoxR3StaticDllNoAsan = VBoxR3StaticDll but w/o ASAN +TEMPLATE_VBoxR3StaticDllNoAsan_EXTENDS = VBoxR3StaticDll +if "$(KBUILD_TARGET)" == "win" && "$(KBUILD_TYPE)" == "asan" + TEMPLATE_VBoxR3StaticDllNoAsan_CFLAGS = $(filter-out $(VBOX_VCC_SANITIZER_FLAGS) , $(TEMPLATE_VBoxR3StaticDll_CFLAGS)) + TEMPLATE_VBoxR3StaticDllNoAsan_CXXFLAGS = $(filter-out $(VBOX_VCC_SANITIZER_FLAGS) , $(TEMPLATE_VBoxR3StaticDll_CXXFLAGS)) + TEMPLATE_VBoxR3StaticDllNoAsan_PCHFLAGS = $(filter-out $(VBOX_VCC_SANITIZER_FLAGS) , $(TEMPLATE_VBoxR3StaticDll_PCHFLAGS)) + TEMPLATE_VBoxR3StaticDllNoAsan_LDFLAGS = $(filter-out $(VBOX_VCC_SANITIZER_LDFLAGS), $(TEMPLATE_VBoxR3StaticDll_LDFLAGS)) -InferAsanLibs:No + TEMPLATE_VBoxR3StaticDllNoAsan_LIBS.x86 = $(subst $(VBOX_LIB_RUNTIME_STATIC),$(VBOX_LIB_RUNTIME_STATIC_NO_ASAN),$(filter-out %clang_rt.asan_dll_thunk-i386.lib, $(TEMPLATE_VBoxR3StaticDll_LIBS.x86))) + TEMPLATE_VBoxR3StaticDllNoAsan_LIBS.amd64 = $(subst $(VBOX_LIB_RUNTIME_STATIC),$(VBOX_LIB_RUNTIME_STATIC_NO_ASAN),$(filter-out %clang_rt.asan_dll_thunk-x86_64.lib, $(TEMPLATE_VBoxR3StaticDll_LIBS.amd64))) +endif + + +# +# Non-pedantic variation of VBoxR3Static +# +TEMPLATE_VBoxR3StaticNonPedantic = VBox Static Ring-3 EXE, non-pedantic. +TEMPLATE_VBoxR3StaticNonPedantic_EXTENDS = VBoxR3Static +ifeq ($(KBUILD_TARGET),win) + TEMPLATE_VBoxR3StaticNonPedantic_CFLAGS = $(TEMPLATE_VBoxR3Static_CFLAGS) $(VBOX_VCC_NON_PEDANTIC) + TEMPLATE_VBoxR3StaticNonPedantic_CXXFLAGS = $(TEMPLATE_VBoxR3Static_CXXFLAGS) $(VBOX_VCC_NON_PEDANTIC) + TEMPLATE_VBoxR3StaticNonPedantic_PCHFLAGS = $(TEMPLATE_VBoxR3Static_PCHFLAGS) $(VBOX_VCC_NON_PEDANTIC) +else # gcc: + TEMPLATE_VBoxR3StaticNonPedantic_TOOL = $(VBOX_GCC_TOOL) + TEMPLATE_VBoxR3StaticNonPedantic_CFLAGS = $(filter-out $(VBOX_GCC_WERR) $(VBOX_GCC_WARN_MASOCHISTIC) $(VBOX_GCC_PEDANTIC_C) ,$(TEMPLATE_VBoxR3Static_CFLAGS)) \ + $(VBOX_GCC_NON_PEDANTIC_CXX) + TEMPLATE_VBoxR3StaticNonPedantic_CXXFLAGS = $(filter-out $(VBOX_GCC_WERR) $(VBOX_GCC_WARN_MASOCHISTIC) $(VBOX_GCC_PEDANTIC_CXX),$(TEMPLATE_VBoxR3Static_CXXFLAGS)) \ + $(VBOX_GCC_NON_PEDANTIC_CXX) + TEMPLATE_VBoxR3StaticNonPedantic_PCHFLAGS = $(filter-out $(VBOX_GCC_WERR) $(VBOX_GCC_WARN_MASOCHISTIC) $(VBOX_GCC_PEDANTIC_CXX),$(TEMPLATE_VBoxR3Static_PCHFLAGS)) \ + $(VBOX_GCC_NON_PEDANTIC_CXX) +endif + +# +# VBoxR3Static w/o any CRT (windows only atm, experimental). +# Implies no fancy C++, no exceptions, no static constructors or destructors, ++. +# +# Note! Not compatible with BLD_TRG_ARCH overrides yet. +# +TEMPLATE_VBoxR3StaticNoCrt = Static +TEMPLATE_VBoxR3StaticNoCrt_EXTENDS = VBoxR3Static +TEMPLATE_VBoxR3StaticNoCrt_SDKS = $(subst WINSDK10-UCRT-STATIC,WINSDK10-UCRT-INCS, $(TEMPLATE_VBoxR3Static_SDKS)) +TEMPLATE_VBoxR3StaticNoCrt_SDKS.$(KBUILD_TARGET_ARCH) = $(filter-out VBoxOpenSslStatic,$(TEMPLATE_VBoxR3Static_SDKS.$(KBUILD_TARGET_ARCH))) +TEMPLATE_VBoxR3StaticNoCrt_DEFS = $(TEMPLATE_VBoxR3Static_DEFS) \ + RT_NO_CRT \ + IN_RT_STATIC +ifndef VBOX_WITH_NOCRT_STATIC + TEMPLATE_VBoxR3StaticNoCrt_DEFS.win = $(TEMPLATE_VBoxR3Static_DEFS.win) \ + RT_WITHOUT_NOCRT_WRAPPERS +endif +TEMPLATE_VBoxR3StaticNoCrt_LIBS = \ + $(PATH_STAGE_LIB)/RuntimeR3NoCrt$(VBOX_SUFF_LIB) +ifeq ($(KBUILD_TARGET),win) + TEMPLATE_VBoxR3StaticNoCrt_LIBS.x86 = $(NO_SUCH_VARIABLE) + TEMPLATE_VBoxR3StaticNoCrt_LIBS.amd64 = $(NO_SUCH_VARIABLE) + TEMPLATE_VBoxR3StaticNoCrt_LIBS.win = $(NO_SUCH_VARIABLE) + ifdef VBOX_WITH_NOCRT_STATIC + TEMPLATE_VBoxR3StaticNoCrt_LIBS.$(KBUILD_TARGET_ARCH) = \ + $(PATH_STAGE_LIB)/RuntimeR3NoCrt$(VBOX_SUFF_LIB) + ifneq ($(KBUILD_TARGET_ARCH),x86) + TEMPLATE_VBoxR3StaticNoCrt_LIBS.x86 = \ + $(PATH_STAGE_LIB)/RuntimeR3NoCrt-x86$(VBOX_SUFF_LIB) # place holder, we don't have this library + endif + else + TEMPLATE_VBoxR3StaticNoCrt_LIBS.win.x86 = \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3StaticNoCrt_TOOL.win.x86)_LIB)/chkstk.obj + endif + TEMPLATE_VBoxR3StaticNoCrt_SDKS.win.x86 += VBoxWinInt64Lib + TEMPLATE_VBoxR3StaticNoCrt_LDFLAGS = $(filter-out $(VBOX_VCC_LD_GUARD_CF) $(VBOX_VCC_SANITIZER_LDFLAGS), $(TEMPLATE_VBoxR3Static_LDFLAGS)) + TEMPLATE_VBoxR3StaticNoCrt_LDFLAGS.win.x86 = $(filter-out -Include%, $(TEMPLATE_VBoxR3Static_LDFLAGS.win.x86)) + TEMPLATE_VBoxR3StaticNoCrt_CFLAGS = $(filter-out -EH% -GS $(VBOX_VCC_CC_GUARD_CF) $(VBOX_VCC_SANITIZER_FLAGS),$(TEMPLATE_VBoxR3Static_CFLAGS)) /GS- -EHs- + TEMPLATE_VBoxR3StaticNoCrt_CXXFLAGS = $(filter-out -EH% -GS $(VBOX_VCC_CC_GUARD_CF) $(VBOX_VCC_SANITIZER_FLAGS),$(TEMPLATE_VBoxR3Static_CXXFLAGS)) /GS- -EHs- + TEMPLATE_VBoxR3StaticNoCrt_PCHFLAGS = $(filter-out -EH% -GS $(VBOX_VCC_CC_GUARD_CF) $(VBOX_VCC_SANITIZER_FLAGS),$(TEMPLATE_VBoxR3Static_PCHFLAGS)) /GS- -EHs- + TEMPLATE_VBoxR3StaticNoCrt_CXXFLAGS.debug = $(filter-out /RTC% -RTC%, $(TEMPLATE_VBoxR3Static_CXXFLAGS.debug)) +else + TEMPLATE_VBoxR3StaticNoCrt_CXXFLAGS = $(TEMPLATE_VBoxR3Static_CXXFLAGS) -fno-exceptions + TEMPLATE_VBoxR3StaticNoCrt_PCHFLAGS = $(TEMPLATE_VBoxR3Static_PCHFLAGS) -fno-exceptions +endif + + +# +# Executable w/o CRT (windows only atm, experimental). +# Implies no fancy C++, no exceptions, no static constructors or destructors, ++. +# +TEMPLATE_VBoxR3StaticNoCrtExe := VBoxR3StaticNoCrt with EXE startup code calling a main() function +TEMPLATE_VBoxR3StaticNoCrtExe_EXTENDS := VBoxR3StaticNoCrt +TEMPLATE_VBoxR3StaticNoCrtExe_EXTENDS_BY := appending +TEMPLATE_VBoxR3StaticNoCrtExe_LDFLAGS.win := /entry:CustomMainEntrypoint /subsystem:console + + +# +# Template for building hardened Ring-3 executables. +# These shall have no extra runpaths, esp. not origin ones. +# +TEMPLATE_VBoxR3HardenedExe := Hardened VBox Ring-3 EXE +TEMPLATE_VBoxR3HardenedExe_EXTENDS := VBoxR3Exe +TEMPLATE_VBoxR3HardenedExe_DEBUG_INST.win = $(INST_DEBUG)hardened-exes/ +TEMPLATE_VBoxR3HardenedExe_DEFS = $(TEMPLATE_VBoxR3Exe_DEFS) RTMEM_NO_WRAP_TO_EF_APIS +ifdef VBOX_WITH_HARDENING + TEMPLATE_VBoxR3HardenedExe_LIBS = $(VBOX_LIB_SUPHARDENED) $(TEMPLATE_VBoxR3Exe_LIBS) +else + TEMPLATE_VBoxR3HardenedExe_LIBS = $(TEMPLATE_VBoxR3Exe_LIBS) +endif +TEMPLATE_VBoxR3HardenedExe_LDFLAGS.darwin = $(TEMPLATE_VBoxR3Exe_LDFLAGS.darwin) -framework IOKit +ifeq ($(KBUILD_TARGET),linux) + # not necessary except USE_LIB_PCAP is defined in SUPR3HardenedMain.cpp + # TEMPLATE_VBoxR3HardenedExe_LIBS += cap +endif +ifeq ($(KBUILD_TARGET),win) # No CRT! + TEMPLATE_VBoxR3HardenedExe_SDKS = VBoxNtDll $(TEMPLATE_VBoxR3Exe_SDKS) + TEMPLATE_VBoxR3HardenedExe_SDKS.x86 = VBoxWinInt64Lib + ifneq ($(VBOX_VCC_LD_GUARD_CF),) + TEMPLATE_VBoxR3HardenedExe_CXXFLAGS = $(filter-out -RTC% -GZ $(VBOX_VCC_SANITIZER_FLAGS),$(TEMPLATE_VBoxR3Exe_CXXFLAGS)) + TEMPLATE_VBoxR3HardenedExe_CXXFLAGS.debug = $(filter-out -RTC% -GZ $(VBOX_VCC_SANITIZER_FLAGS),$(TEMPLATE_VBoxR3Exe_CXXFLAGS.debug)) #-O2 -Oy- + TEMPLATE_VBoxR3HardenedExe_PCHFLAGS = $(filter-out -RTC% -GZ $(VBOX_VCC_SANITIZER_FLAGS),$(TEMPLATE_VBoxR3Exe_PCHFLAGS)) + TEMPLATE_VBoxR3HardenedExe_PCHFLAGS.debug = $(filter-out -RTC% -GZ $(VBOX_VCC_SANITIZER_FLAGS),$(TEMPLATE_VBoxR3Exe_PCHFLAGS.debug)) #-O2 -Oy- + TEMPLATE_VBoxR3HardenedExe_CFLAGS = $(filter-out -RTC% -GZ $(VBOX_VCC_SANITIZER_FLAGS),$(TEMPLATE_VBoxR3Exe_CFLAGS)) + TEMPLATE_VBoxR3HardenedExe_CFLAGS.debug = $(filter-out -RTC% -GZ $(VBOX_VCC_SANITIZER_FLAGS),$(TEMPLATE_VBoxR3Exe_CFLAGS.debug)) -O2 -Oy- + else + TEMPLATE_VBoxR3HardenedExe_CXXFLAGS = $(filter-out -RTC% -GZ $(VBOX_VCC_SANITIZER_FLAGS) -GS,$(TEMPLATE_VBoxR3Exe_CXXFLAGS)) -GS- + TEMPLATE_VBoxR3HardenedExe_CXXFLAGS.debug = $(filter-out -RTC% -GZ $(VBOX_VCC_SANITIZER_FLAGS) -GS,$(TEMPLATE_VBoxR3Exe_CXXFLAGS.debug)) -GS- #-O2 -Oy- + TEMPLATE_VBoxR3HardenedExe_PCHFLAGS = $(filter-out -RTC% -GZ $(VBOX_VCC_SANITIZER_FLAGS) -GS,$(TEMPLATE_VBoxR3Exe_PCHFLAGS)) -GS- + TEMPLATE_VBoxR3HardenedExe_PCHFLAGS.debug = $(filter-out -RTC% -GZ $(VBOX_VCC_SANITIZER_FLAGS) -GS,$(TEMPLATE_VBoxR3Exe_PCHFLAGS.debug)) -GS- #-O2 -Oy- + TEMPLATE_VBoxR3HardenedExe_CFLAGS = $(filter-out -RTC% -GZ $(VBOX_VCC_SANITIZER_FLAGS) -GS,$(TEMPLATE_VBoxR3Exe_CFLAGS)) -GS- + TEMPLATE_VBoxR3HardenedExe_CFLAGS.debug = $(filter-out -RTC% -GZ $(VBOX_VCC_SANITIZER_FLAGS) -GS,$(TEMPLATE_VBoxR3Exe_CFLAGS.debug)) -GS- -O2 -Oy- + endif + TEMPLATE_VBoxR3HardenedExe_LDFLAGS = $(filter-out $(VBOX_VCC_SANITIZER_LDFLAGS), $(TEMPLATE_VBoxR3Exe_LDFLAGS)) \ + /DISALLOWLIB:msvcrt$(VBOX_VCC_CRT_TYPE).lib \ + /DISALLOWLIB:msvcprt$(VBOX_VCC_CRT_TYPE).lib \ + /DISALLOWLIB:vcruntime$(VBOX_VCC_CRT_TYPE).lib \ + /DISALLOWLIB:ucrt$(VBOX_VCC_CRT_TYPE).lib + TEMPLATE_VBoxR3HardenedExe_LDFLAGS.win.x86 = $(TEMPLATE_VBoxR3Exe_LDFLAGS.win.x86) /entry:suplibHardenedWindowsMain + TEMPLATE_VBoxR3HardenedExe_LDFLAGS.win.amd64 = $(TEMPLATE_VBoxR3Exe_LDFLAGS.win.amd64) /entry:suplibHardenedWindowsMain + TEMPLATE_VBoxR3HardenedExe_LIBS.x86 = $(NOT_SUCH_VARIABLE) + TEMPLATE_VBoxR3HardenedExe_LIBS.amd64 = $(NOT_SUCH_VARIABLE) + TEMPLATE_VBoxR3HardenedExe_USES.win = $(TEMPLATE_VBoxR3Exe_USES.win) vboximportchecker + TEMPLATE_VBoxR3HardenedExe_VBOX_IMPORT_CHECKER.win = noimports +else ifn1of ($(KBUILD_TARGET), os2) + ifneq ($(KBUILD_TYPE),asan) # Keep RPATH in asan builds so we can find libasan.so.X and libubsan.so.Y. + TEMPLATE_VBoxR3HardenedExe_LDFLAGS = $(filter-out '$(VBOX_GCC_RPATH_OPT)%,$(TEMPLATE_VBoxR3Exe_LDFLAGS)) + TEMPLATE_VBoxR3HardenedExe_LDFLAGS.linux = $(filter-out $(VBOX_GCC_ORIGIN_OPT),$(TEMPLATE_VBoxR3Exe_LDFLAGS.linux)) + endif +endif + +# +# Template for building hardened Ring-3 libraries. +# +TEMPLATE_VBoxR3HardenedLib = Hardened VBox Ring-3 LIB +TEMPLATE_VBoxR3HardenedLib_EXTENDS = VBoxR3HardenedExe +TEMPLATE_VBoxR3HardenedLib_LIBS = $(NO_SUCH_VARIABLE) +TEMPLATE_VBoxR3HardenedLib_USES.win = $(NO_SUCH_VARIABLE) +TEMPLATE_VBoxR3HardenedLib_POST_CMDS = $(NO_SUCH_VARIABLE) + + +# +# Template for building hardened Ring-3 testcase executables. +# +TEMPLATE_VBoxR3HardenedTstExe = VBox Ring-3 Hardened Testcase Exe (currently windows only!) +TEMPLATE_VBoxR3HardenedTstExe_EXTENDS = VBoxR3HardenedExe +TEMPLATE_VBoxR3HardenedTstExe_INST = $(INST_TESTCASE) + +# +# Template for building hardened Ring-3 testcase DLLs (pairs with VBoxR3HardenedTstExe). +# +TEMPLATE_VBoxR3HardenedTstDll = VBox Ring-3 Hardened Testcase Dll (currently windows only!) +TEMPLATE_VBoxR3HardenedTstDll_EXTENDS = VBoxR3TstDll +TEMPLATE_VBoxR3HardenedTstDll_INST = $(INST_TESTCASE) +TEMPLATE_VBoxR3HardenedTstDll_LDFLAGS.win = $(TEMPLATE_VBoxR3TstDll_LDFLAGS.win) -IntegrityCheck +ifn1of ($(KBUILD_TARGET), win os2) + TEMPLATE_VBoxR3HardenedTstDll_LDFLAGS = $(filter-out '$(VBOX_GCC_RPATH_OPT)%,$(TEMPLATE_VBoxR3TstDll_LDFLAGS)) + TEMPLATE_VBoxR3HardenedTstDll_LDFLAGS.linux = $(filter-out $(VBOX_GCC_ORIGIN_OPT),$(TEMPLATE_VBoxR3TstDll_LDFLAGS.linux)) +endif + +# +# Template for building set-uid-to-root helper programs. +# In hardened builds, these may only contain absolute runpaths! +# +TEMPLATE_VBoxR3SetUidToRoot = Set-uid-to-root helper program. +if1of ($(KBUILD_TARGET), win) + TEMPLATE_VBoxR3SetUidToRoot_EXTENDS = VBoxR3Exe +else + TEMPLATE_VBoxR3SetUidToRoot_EXTENDS = VBoxR3HardenedExe + TEMPLATE_VBoxR3SetUidToRoot_LDFLAGS = $(VBOX_GCC_SANITIZER_FLAGS) $(VBOX_GCC_SANITIZER_LDFLAGS) +endif +TEMPLATE_VBoxR3SetUidToRoot_LIBS = $(NO_SUCH_VARIABLE) +ifdef VBOX_WITH_RUNPATH + TEMPLATE_VBoxR3SetUidToRoot_LDFLAGS += '$(VBOX_GCC_RPATH_OPT)$(VBOX_WITH_RUNPATH)' +endif +ifndef VBOX_WITH_HARDENING + ifdef VBOX_WITH_RELATIVE_RUNPATH + TEMPLATE_VBoxR3SetUidToRoot_LDFLAGS += '$(VBOX_GCC_RPATH_OPT)$(VBOX_WITH_RELATIVE_RUNPATH)' + endif + ifdef VBOX_WITH_ORIGIN + TEMPLATE_VBoxR3SetUidToRoot_LDFLAGS.linux += $(VBOX_GCC_ORIGIN_OPT) + endif +endif + +# +# Template for building R3 tools. +# +TEMPLATE_VBoxR3Tool = VBox Ring 3 Tools +TEMPLATE_VBoxR3Tool_EXTENDS = VBoxR3Exe +TEMPLATE_VBoxR3Tool_INST = $(VBOX_INST_TOOLS) +ifeq ($(KBUILD_TARGET),win) + TEMPLATE_VBoxR3Tool_CFLAGS = $(TEMPLATE_VBoxR3Exe_CFLAGS) $(VBOX_VCC_WERR) + TEMPLATE_VBoxR3Tool_CXXFLAGS = $(TEMPLATE_VBoxR3Exe_CXXFLAGS) $(VBOX_VCC_WERR) + TEMPLATE_VBoxR3Tool_PCHFLAGS = $(TEMPLATE_VBoxR3Exe_PCHFLAGS) $(VBOX_VCC_WERR) + TEMPLATE_VBoxR3Tool_LDFLAGS = $(TEMPLATE_VBoxR3Exe_LDFLAGS) $(VBOX_VCC_LD_WERR) +else + TEMPLATE_VBoxR3Tool_CFLAGS = $(TEMPLATE_VBoxR3Exe_CFLAGS) $(VBOX_GCC_WERR) + TEMPLATE_VBoxR3Tool_CXXFLAGS = $(TEMPLATE_VBoxR3Exe_CXXFLAGS) $(VBOX_GCC_WERR) + TEMPLATE_VBoxR3Tool_PCHFLAGS = $(TEMPLATE_VBoxR3Exe_PCHFLAGS) $(VBOX_GCC_WERR) + ifdef VBOX_WITH_RUNPATH + TEMPLATE_VBoxR3Tool_LDFLAGS = '$(VBOX_GCC_RPATH_OPT)$(VBOX_WITH_RUNPATH)' $(TEMPLATE_VBoxR3Exe_LDFLAGS) + else ifdef VBOX_WITH_RELATIVE_RUNPATH + TEMPLATE_VBoxR3Tool_LDFLAGS = '$(VBOX_GCC_RPATH_OPT)$(VBOX_WITH_RELATIVE_RUNPATH)/..' $(TEMPLATE_VBoxR3Exe_LDFLAGS) + endif +endif +TEMPLATE_VBoxR3Tool_LIBS = $(LIB_RUNTIME) $(TEMPLATE_VBoxR3Exe_LIBS) +if defined(VBOX_WITH_MORE_NT4_COMPAT_BINARIES) && "$(KBUILD_TARGET).$(KBUILD_TARGET_ARCH)" == "win.x86" + TEMPLATE_VBoxR3Tool_LIBS.x86 = \ + $(PATH_STAGE_LIB)/RuntimeR3VccTricks2$(VBOX_SUFF_LIB) \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3Exe_TOOL.win.x86)_LIB)/oldnames.lib +endif + + +# +# Ring-3 testcase, running automatically during the build. +# This is the VBoxR3Exe template only with a different install dir. +# +TEMPLATE_VBoxR3AutoTest = VBox Ring 3 Testcase Exe +TEMPLATE_VBoxR3AutoTest_EXTENDS := VBoxR3Static +TEMPLATE_VBoxR3AutoTest_SDKS.$(KBUILD_TARGET_ARCH) = $(filter-out VBoxOpenSslStatic,$(TEMPLATE_$(TEMPLATE_VBoxR3AutoTest_EXTENDS)_SDKS.$(KBUILD_TARGET_ARCH))) +ifeq ($(KBUILD_TARGET),win) + if "$(KBUILD_HOST_VERSION)" vlt "10.0.0.0.10240" # The windows ASAN requires windows 10 APIs to work. + TEMPLATE_VBoxR3AutoTest_EXTENDS := VBoxR3StaticExeNoAsan + endif + ifdef VBOX_SIGNING_MODE + TEMPLATE_VBoxR3AutoTest_LDFLAGS = $(filter-out -IntegrityCheck, $(TEMPLATE_$(TEMPLATE_VBoxR3AutoTest_EXTENDS)_LDFLAGS)) + TEMPLATE_VBoxR3AutoTest_POST_CMDS = $(NO_SUCH_VARIABLE) + endif +endif +TEMPLATE_VBoxR3AutoTest_INST = $(INST_TESTCASE) +TEMPLATE_VBoxR3AutoTest_LIBS.$(KBUILD_TARGET_ARCH) = $(filter-out \ + $(if-expr !defined(SDK_VBoxLibXml2_LIBS),$(PATH_STAGE_LIB)/VBox-libxml2-static$(VBOX_SUFF_LIB),) \ + $(if-expr "$(KBUILD_TARGET)" == "win" || "$(KBUILD_TARGET)" == "os2" \ + ,$(SDK_VBoxLzf_STATIC_LIBS) $(SDK_VBoxZlibStatic_LIBS) \ + ,$(SDK_VBoxLzf_LIBS) $(SDK_VBoxZlib_LIBS)) \ + ,$(TEMPLATE_$(TEMPLATE_VBoxR3AutoTest_EXTENDS)_LIBS.$(KBUILD_TARGET_ARCH))) + +# +# Ring-3 testcase. +# This is the VBoxR3Exe template only with a different install dir. +# +TEMPLATE_VBoxR3TstExe = VBox Ring 3 Testcase Exe +TEMPLATE_VBoxR3TstExe_EXTENDS = VBoxR3Exe +TEMPLATE_VBoxR3TstExe_LIBS = $(LIB_RUNTIME) $(TEMPLATE_VBoxR3Exe_LIBS) +TEMPLATE_VBoxR3TstExe_INST = $(INST_TESTCASE) +ifdef VBOX_WITH_RUNPATH + TEMPLATE_VBoxR3TstExe_LDFLAGS = '$(VBOX_GCC_RPATH_OPT)$(VBOX_WITH_RUNPATH)' $(TEMPLATE_VBoxR3Exe_LDFLAGS) +else ifdef VBOX_WITH_RELATIVE_RUNPATH + TEMPLATE_VBoxR3TstExe_LDFLAGS = '$(VBOX_GCC_RPATH_OPT)$(VBOX_WITH_RELATIVE_RUNPATH)/..' $(TEMPLATE_VBoxR3Exe_LDFLAGS) +endif +if "$(KBUILD_TARGET)" == "win" && defined(VBOX_SIGNING_MODE) + TEMPLATE_VBoxR3TstExe_POST_CMDS = + TEMPLATE_VBoxR3TstExe_LDFLAGS = $(filter-out -IntegrityCheck, $(TEMPLATE_VBoxR3Exe_LDFLAGS)) +endif +if defined(VBOX_WITH_MORE_NT4_COMPAT_BINARIES) && "$(KBUILD_TARGET).$(KBUILD_TARGET_ARCH)" == "win.x86" + TEMPLATE_VBoxR3TstExe_POST_CMDS.win.x86 = $(if $(eq $(tool_do),LINK_LIBRARY),,$(VBOX_PE_SET_VERSION) $(out)) + TEMPLATE_VBoxR3TstExe_LIBS.x86 = \ + $(PATH_STAGE_LIB)/RuntimeR3VccTricks2$(VBOX_SUFF_LIB) \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3Exe_TOOL.win.x86)_LIB)/oldnames.lib +endif + + +# +# Ring-3 testcase DLL. +# +TEMPLATE_VBoxR3TstDll = VBox Ring-3 Testcase Dll +TEMPLATE_VBoxR3TstDll_EXTENDS = VBoxR3TstExe +ifn1of ($(KBUILD_TARGET), darwin win os2) + TEMPLATE_VBoxR3TstDll_DEFS = $(TEMPLATE_VBoxR3TstExe_DEFS) PIC + TEMPLATE_VBoxR3TstDll_CFLAGS = $(TEMPLATE_VBoxR3TstExe_CFLAGS) -fPIC + TEMPLATE_VBoxR3TstDll_CXXFLAGS = $(TEMPLATE_VBoxR3TstExe_CXXFLAGS) -fPIC + TEMPLATE_VBoxR3TstDll_PCHFLAGS = $(TEMPLATE_VBoxR3TstExe_PCHFLAGS) -fPIC + TEMPLATE_VBoxR3TstDll_LDFLAGS = $(TEMPLATE_VBoxR3TstExe_LDFLAGS) -fPIC +endif + + +# +# Template for building bad C/C++ style R3 shared libraries / Dlls (no -pedantic). +# (Same transformation as for VBoxR3ExeNonPedantic.) +# +TEMPLATE_VBoxR3DllNonPedantic = VBox ring-3 Non-pedantic, with warnings. +TEMPLATE_VBoxR3DllNonPedantic_EXTENDS = VBoxR3DllBase +ifeq ($(KBUILD_TARGET),win) + TEMPLATE_VBoxR3DllNonPedantic_CFLAGS = $(TEMPLATE_VBoxR3DllBase_CFLAGS) $(VBOX_VCC_NON_PEDANTIC) + TEMPLATE_VBoxR3DllNonPedantic_CXXFLAGS = $(TEMPLATE_VBoxR3DllBase_CXXFLAGS) $(VBOX_VCC_NON_PEDANTIC) + TEMPLATE_VBoxR3DllNonPedantic_PCHFLAGS = $(TEMPLATE_VBoxR3DllBase_PCHFLAGS) $(VBOX_VCC_NON_PEDANTIC) +else # gcc: + TEMPLATE_VBoxR3DllNonPedantic_TOOL = $(VBOX_GCC_TOOL) + TEMPLATE_VBoxR3DllNonPedantic_CFLAGS = $(filter-out $(VBOX_GCC_WERR) $(VBOX_GCC_WARN_MASOCHISTIC) $(VBOX_GCC_PEDANTIC_C) ,$(TEMPLATE_VBoxR3DllBase_CFLAGS)) \ + $(VBOX_GCC_NON_PEDANTIC_C) + TEMPLATE_VBoxR3DllNonPedantic_CXXFLAGS = $(filter-out $(VBOX_GCC_WERR) $(VBOX_GCC_WARN_MASOCHISTIC) $(VBOX_GCC_PEDANTIC_CXX),$(TEMPLATE_VBoxR3DllBase_CXXFLAGS)) \ + $(VBOX_GCC_NON_PEDANTIC_CXX) + TEMPLATE_VBoxR3DllNonPedantic_PCHFLAGS = $(filter-out $(VBOX_GCC_WERR) $(VBOX_GCC_WARN_MASOCHISTIC) $(VBOX_GCC_PEDANTIC_CXX),$(TEMPLATE_VBoxR3DllBase_PCHFLAGS)) \ + $(VBOX_GCC_NON_PEDANTIC_CXX) +endif + +# x86 edition of the above template for use on AMD64 targets. +TEMPLATE_VBoxR3DllNonPedantic-x86 = 32-bit VBox ring-3 SO/DLLs, no warnings +TEMPLATE_VBoxR3DllNonPedantic-x86_EXTENDS = VBoxR3DllNonPedantic +TEMPLATE_VBoxR3DllNonPedantic-x86_BLD_TRG_ARCH = x86 +TEMPLATE_VBoxR3DllNonPedantic-x86_DEFS = $(filter-out HC_ARCH_BITS%,$(TEMPLATE_VBoxR3DllNonPedantic_DEFS)) \ + HC_ARCH_BITS=32 ARCH_BITS=32 + + +# +# Same as VBoxR3DllNonPedantic, only it optimizes debug builds. +# +TEMPLATE_VBoxR3DllNonPedanticFast = VBox ring-3 Non-pedantic, with warnings, optimized debug. +TEMPLATE_VBoxR3DllNonPedanticFast_EXTENDS = VBoxR3DllNonPedantic +ifeq ($(KBUILD_TYPE),debug) + ifeq ($(KBUILD_TARGET),win) + TEMPLATE_VBoxR3DllNonPedanticFast_CFLAGS = $(filter-out -O0, $(TEMPLATE_VBoxR3DllNonPedantic_CFLAGS)) -O2 -Oy- + TEMPLATE_VBoxR3DllNonPedanticFast_CFLAGS.debug = $(filter-out -RTC%, $(TEMPLATE_VBoxR3DllNonPedantic_CFLAGS.debug)) + TEMPLATE_VBoxR3DllNonPedanticFast_CXXFLAGS = $(filter-out -O0, $(TEMPLATE_VBoxR3DllNonPedantic_CXXFLAGS)) -O2 -Oy- + TEMPLATE_VBoxR3DllNonPedanticFast_CXXFLAGS.debug = $(filter-out -RTC%, $(TEMPLATE_VBoxR3DllNonPedantic_CXXFLAGS.debug)) + TEMPLATE_VBoxR3DllNonPedanticFast_PCHFLAGS = $(filter-out -O0, $(TEMPLATE_VBoxR3DllNonPedantic_PCHFLAGS)) -O2 -Oy- + TEMPLATE_VBoxR3DllNonPedanticFast_PCHFLAGS.debug = $(filter-out -RTC%, $(TEMPLATE_VBoxR3DllNonPedantic_PCHFLAGS.debug)) + else + TEMPLATE_VBoxR3DllNonPedanticFast_CFLAGS = $(TEMPLATE_VBoxR3DllNonPedantic_CFLAGS) -O2 -fno-omit-frame-pointer + TEMPLATE_VBoxR3DllNonPedanticFast_CXXFLAGS = $(TEMPLATE_VBoxR3DllNonPedantic_CXXFLAGS) -O2 -fno-omit-frame-pointer + TEMPLATE_VBoxR3DllNonPedanticFast_PCHFLAGS = $(TEMPLATE_VBoxR3DllNonPedantic_PCHFLAGS) -O2 -fno-omit-frame-pointer + endif +endif + + +# +# Template for building libraries that are linked into VBoxRT.dll +# and it's variations, pedantic variation. +# +TEMPLATE_VBoxR3RuntimeDll = For libraries that are linked into VBoxRT. +TEMPLATE_VBoxR3RuntimeDll_EXTENDS = VBoxR3Dll +TEMPLATE_VBoxR3RuntimeDll_DEFS = $(TEMPLATE_VBoxR3Dll_DEFS) IN_RT_R3 +if defined(VBOX_WITH_MORE_NT4_COMPAT_BINARIES) && "$(KBUILD_TARGET).$(KBUILD_TARGET_ARCH)" == "win.x86" + TEMPLATE_VBoxR3RuntimeDll_CFLAGS = $(filter-out -MD$(VBOX_VCC_CRT_TYPE), $(TEMPLATE_VBoxR3Dll_CFLAGS)) -MT$(VBOX_VCC_CRT_TYPE) + TEMPLATE_VBoxR3RuntimeDll_CXXFLAGS = $(filter-out -MD$(VBOX_VCC_CRT_TYPE), $(TEMPLATE_VBoxR3Dll_CXXFLAGS)) -MT$(VBOX_VCC_CRT_TYPE) + TEMPLATE_VBoxR3RuntimeDll_PCHFLAGS = $(filter-out -MD$(VBOX_VCC_CRT_TYPE), $(TEMPLATE_VBoxR3Dll_PCHFLAGS)) -MT$(VBOX_VCC_CRT_TYPE) + TEMPLATE_VBoxR3RuntimeDll_LIBS.x86 = $(filter-out $(PATH_TOOL_$(TEMPLATE_VBoxR3Exe_TOOL.win.x86)_LIB)/%, $(TEMPLATE_VBoxR3Dll_LIBS.x86)) \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3RuntimeDll_TOOL.win.x86)_LIB)/oldnames.lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3RuntimeDll_TOOL.win.x86)_LIB)/libcmt$(VBOX_VCC_CRT_TYPE).lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxR3RuntimeDll_TOOL.win.x86)_LIB)/libcpmt$(VBOX_VCC_CRT_TYPE).lib +endif + +# +# Template for building libraries that are linked into VBoxRT.dll +# and it's variations, non-pedantic variation. +# +TEMPLATE_VBoxR3RuntimeDllNonPedantic = For libraries that are linked into VBoxRT, but must be excluded from -pedantic warnings. +TEMPLATE_VBoxR3RuntimeDllNonPedantic_EXTENDS = VBoxR3DllNonPedantic +TEMPLATE_VBoxR3RuntimeDllNonPedantic_DEFS = $(TEMPLATE_VBoxR3DllNonPedantic_DEFS) IN_RT_R3 +if defined(VBOX_WITH_MORE_NT4_COMPAT_BINARIES) && $(KBUILD_TARGET_ARCH) == "x86" + TEMPLATE_VBoxR3RuntimeDllNonPedantic_CFLAGS = $(filter-out -MD$(VBOX_VCC_CRT_TYPE), $(TEMPLATE_VBoxR3DllNonPedantic_CFLAGS)) -MT$(VBOX_VCC_CRT_TYPE) + TEMPLATE_VBoxR3RuntimeDllNonPedantic_CXXFLAGS = $(filter-out -MD$(VBOX_VCC_CRT_TYPE), $(TEMPLATE_VBoxR3DllNonPedantic_CXXFLAGS)) -MT$(VBOX_VCC_CRT_TYPE) + TEMPLATE_VBoxR3RuntimeDllNonPedantic_PCHFLAGS = $(filter-out -MD$(VBOX_VCC_CRT_TYPE), $(TEMPLATE_VBoxR3DllNonPedantic_PCHFLAGS)) -MT$(VBOX_VCC_CRT_TYPE) +endif + +# +# Same as VBoxR3RuntimeDllNonPedantic, only it optimized debug builds too. +# +TEMPLATE_VBoxR3RuntimeDllNonPedanticFast = For libraries that are linked into VBoxRT, but must be excluded from -pedantic warnings, optmized debug. +TEMPLATE_VBoxR3RuntimeDllNonPedanticFast_EXTENDS = VBoxR3RuntimeDllNonPedantic +ifeq ($(KBUILD_TYPE),debug) + ifeq ($(KBUILD_TARGET),win) + TEMPLATE_VBoxR3RuntimeDllNonPedanticFast_CFLAGS = $(filter-out -O0, $(TEMPLATE_VBoxR3RuntimeDllNonPedantic_CFLAGS)) -O2 -Oy- + TEMPLATE_VBoxR3RuntimeDllNonPedanticFast_CFLAGS.debug = $(filter-out -RTC%, $(TEMPLATE_VBoxR3RuntimeDllNonPedantic_CFLAGS.debug)) + TEMPLATE_VBoxR3RuntimeDllNonPedanticFast_CXXFLAGS = $(filter-out -O0, $(TEMPLATE_VBoxR3RuntimeDllNonPedantic_CXXFLAGS)) -O2 -Oy- + TEMPLATE_VBoxR3RuntimeDllNonPedanticFast_CXXFLAGS.debug = $(filter-out -RTC%, $(TEMPLATE_VBoxR3RuntimeDllNonPedantic_CXXFLAGS.debug)) + TEMPLATE_VBoxR3RuntimeDllNonPedanticFast_PCHFLAGS = $(filter-out -O0, $(TEMPLATE_VBoxR3RuntimeDllNonPedantic_PCHFLAGS)) -O2 -Oy- + TEMPLATE_VBoxR3RuntimeDllNonPedanticFast_PCHFLAGS.debug = $(filter-out -RTC%, $(TEMPLATE_VBoxR3RuntimeDllNonPedantic_PCHFLAGS.debug)) + else + TEMPLATE_VBoxR3RuntimeDllNonPedanticFast_CFLAGS = $(TEMPLATE_VBoxR3RuntimeDllNonPedantic_CFLAGS) -O2 -fno-omit-frame-pointer + TEMPLATE_VBoxR3RuntimeDllNonPedanticFast_CXXFLAGS = $(TEMPLATE_VBoxR3RuntimeDllNonPedantic_CXXFLAGS) -O2 -fno-omit-frame-pointer + TEMPLATE_VBoxR3RuntimeDllNonPedanticFast_PCHFLAGS = $(TEMPLATE_VBoxR3RuntimeDllNonPedantic_PCHFLAGS) -O2 -fno-omit-frame-pointer + endif +endif + + +# +# Template for building executables that are part of the VBox Main component +# (COM/XPCOM interface to VirtualBox). +# +TEMPLATE_VBoxMainExe = VBox Main Executable +TEMPLATE_VBoxMainExe_ASTOOL := $(VBOX_ASTOOL) +TEMPLATE_VBoxMainExe_ASFLAGS = $(VBOX_ASFLAGS) +TEMPLATE_VBoxMainExe_DEFS = IN_RING3 UNICODE NDEBUG=1 +TEMPLATE_VBoxMainExe_DEFS.win = _UNICODE +TEMPLATE_VBoxMainExe_RCDEFS = $(TEMPLATE_VBoxR3Exe_RCDEFS) +TEMPLATE_VBoxMainExe_LIBS.kprofile = $(LIB_KPROFILE) +TEMPLATE_VBoxMainExe_USES = dtrace +if defined(VBOX_WITH_DTRACE_R3_MAIN) && defined(VBOX_WITH_NATIVE_DTRACE) + TEMPLATE_VBoxMainExe_DTRACETOOL = DTraceAndVBoxTpG + TEMPLATE_VBoxMainExe_DTRACE_OBJ_FLAGS = -C + TEMPLATE_VBoxMainExe_DTRACE_HDR_FLAGS = -C + TEMPLATE_VBoxMainExe_DEFS += VBOX_WITH_DTRACE VBOX_WITH_DTRACE_R3 VBOX_WITH_DTRACE_R3_MAIN VBOX_WITH_NATIVE_DTRACE +else + TEMPLATE_VBoxMainExe_DTRACE_HDR_FLAGS = --ring-3-context + TEMPLATE_VBoxMainExe_DTRACE_OBJ_FLAGS = --ring-3-context --pic --probe-fn-imported --probe-fn-name "SUPTracerFireProbe" + if defined(VBOX_WITH_DTRACE_R3_MAIN) + TEMPLATE_VBoxMainExe_DTRACETOOL = VBoxTpG + TEMPLATE_VBoxMainExe_DEFS += VBOX_WITH_DTRACE VBOX_WITH_DTRACE_R3 VBOX_WITH_DTRACE_R3_MAIN + else + TEMPLATE_VBoxMainExe_DTRACETOOL = VBoxTpG-Disabled + endif +endif + +ifeq ($(KBUILD_TARGET),win) + #TEMPLATE_VBoxMainExe_TOOL = $(VBOX_VCC_TOOL) + TEMPLATE_VBoxMainExe_TOOL.win.x86 = $(VBOX_VCC_TOOL_STEM)X86 + TEMPLATE_VBoxMainExe_TOOL.win.amd64 = $(VBOX_VCC_TOOL_STEM)AMD64 + if "$(VBOX_VCC_TOOL_STEM)" >= "VCC140" + TEMPLATE_VBoxMainExe_SDKS = ReorderCompilerIncs WINSDK10-UCRT $(VBOX_WINPSDK) $(VBOX_WINDDK) + else + TEMPLATE_VBoxMainExe_SDKS = ReorderCompilerIncs $(VBOX_WINPSDK) $(VBOX_WINDDK) + endif + TEMPLATE_VBoxMainExe_CXXFLAGS = -Zi -Zl -GR -EHsc -GF -MD$(VBOX_VCC_CRT_TYPE) -Zc:wchar_t- \ + $(VBOX_VCC_OPT) $(VBOX_VCC_FP) $(VBOX_VCC_CC_GUARD_CF) $(VBOX_VCC_SANITIZER_FLAGS) $(VBOX_VCC_std) + # -wd4625: 'DisplaySourceBitmap' : copy constructor could not be generated because a base class copy constructor is inaccessible + # -wd4626: 'DisplaySourceBitmap' : assignment operator could not be generated because a base class assignment operator is inaccessible + # The two above can be cured by adding private: DECLARE_CLS_COPY_CTOR_ASSIGN_NOOP(xxxx); but too much work. + # -wd4355: 'this' : used in base member initializer list (e.g. VirtualBoxBase.cpp) + TEMPLATE_VBoxMainExe_CXXFLAGS += $(VBOX_VCC_WARN_ALL) -wd4625 -wd4626 -wd4355 $(VBOX_VCC_WERR) + TEMPLATE_VBoxMainExe_CXXFLAGS += -Gy + if "$(VBOX_VCC_TOOL_STEM)" >= "VCC120" + TEMPLATE_VBoxMainExe_CXXFLAGS += -Gw + endif + ifdef VBOX_WITH_MSC_ANALYZE_THIS + TEMPLATE_VBoxMainExe_CXXFLAGS += /analyze + endif + TEMPLATE_VBoxMainExe_CXXFLAGS.debug = -RTCsu + TEMPLATE_VBoxMainExe_CXXFLAGS.dbgopt = $(NO_SUCH_VARIABLE) + TEMPLATE_VBoxMainExe_CXXFLAGS.kprofile = -Gh -GH + TEMPLATE_VBoxMainExe_CFLAGS = $(filter-out $(VBOX_VCC_std),$(TEMPLATE_VBoxMainExe_CXXFLAGS)) + TEMPLATE_VBoxMainExe_CFLAGS.debug = $(TEMPLATE_VBoxMainExe_CXXFLAGS.debug) + TEMPLATE_VBoxMainExe_CFLAGS.dbgopt = $(TEMPLATE_VBoxMainExe_CXXFLAGS.dbgopt) + TEMPLATE_VBoxMainExe_CFLAGS.kprofile = $(TEMPLATE_VBoxMainExe_CXXFLAGS.kprofile) + TEMPLATE_VBoxMainExe_PCHFLAGS = $(TEMPLATE_VBoxMainExe_CXXFLAGS) + TEMPLATE_VBoxMainExe_PCHFLAGS.debug = $(TEMPLATE_VBoxMainExe_CXXFLAGS.debug) + TEMPLATE_VBoxMainExe_PCHFLAGS.dbgopt = $(TEMPLATE_VBoxMainExe_CXXFLAGS.dbgopt) + TEMPLATE_VBoxMainExe_PCHFLAGS.kprofile = $(TEMPLATE_VBoxMainExe_CXXFLAGS.kprofile) + TEMPLATE_VBoxMainExe_LDFLAGS = -Ignore:4197 \ + /NOD /INCREMENTAL:NO /MAPINFO:EXPORTS /LargeAddressAware /DynamicBase /NxCompat /Release /Debug /Opt:Ref /Opt:Icf \ + $(VBOX_VCC_LD_GUARD_CF) $(VBOX_VCC_SANITIZER_LDFLAGS) \ + /Version:$(VBOX_VERSION_MAJOR)0$(VBOX_VERSION_MINOR).$(VBOX_VERSION_BUILD) \ + /STUB:$(PATH_ROOT)/src/VBox/HostDrivers/Support/win/winstub.com \ + /DISALLOWLIB:libc.lib \ + /DISALLOWLIB:libcd.lib \ + /DISALLOWLIB:libcmt.lib \ + /DISALLOWLIB:libcmtd.lib \ + /DISALLOWLIB:msvcrt$(VBOX_VCC_CRT_TYPE_N).lib \ + /DISALLOWLIB:msvcprt$(VBOX_VCC_CRT_TYPE_N).lib \ + /DISALLOWLIB:vcruntime$(VBOX_VCC_CRT_TYPE_N).lib \ + /DISALLOWLIB:ucrt$(VBOX_VCC_CRT_TYPE_N).lib \ + /DISALLOWLIB:libvcruntime.lib \ + /DISALLOWLIB:libvcruntimed.lib \ + /DISALLOWLIB:libucrt.lib \ + /DISALLOWLIB:libucrtd.lib + if defined(VBOX_SIGNING_MODE) && defined(VBOX_WITH_HARDENING) + TEMPLATE_VBoxMainExe_LDFLAGS += -IntegrityCheck + endif + ifdef VBOX_WITH_DTRACE_R3_MAIN + TEMPLATE_VBoxMainExe_LDFLAGS += -Merge:VTGPrLc.Data=VTGPrLc.Begin -Merge:VTGPrLc.End=VTGPrLc.Begin -Merge:VTGPrLc.Begin=VTGObj + endif + TEMPLATE_VBoxMainExe_LDFLAGS.win.amd64 = $(VBOX_VCC_LD_HIGH_ENTRYOPY_VA) + TEMPLATE_VBoxMainExe_LIBS = \ + $(LIB_RUNTIME) + if "$(VBOX_VCC_TOOL_STEM)" >= "VCC140" + TEMPLATE_VBoxMainExe_LIBS.x86 = \ + $(PATH_TOOL_$(TEMPLATE_VBoxMainExe_TOOL.win.x86)_LIB)/vcruntime$(VBOX_VCC_CRT_TYPE).lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxMainExe_TOOL.win.x86)_LIB)/msvcrt$(VBOX_VCC_CRT_TYPE).lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxMainExe_TOOL.win.x86)_LIB)/msvcprt$(VBOX_VCC_CRT_TYPE).lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxMainExe_TOOL.win.x86)_LIB)/oldnames.lib + TEMPLATE_VBoxMainExe_LIBS.amd64 = \ + $(PATH_TOOL_$(TEMPLATE_VBoxMainExe_TOOL.win.amd64)_LIB)/vcruntime$(VBOX_VCC_CRT_TYPE).lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxMainExe_TOOL.win.amd64)_LIB)/msvcrt$(VBOX_VCC_CRT_TYPE).lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxMainExe_TOOL.win.amd64)_LIB)/msvcprt$(VBOX_VCC_CRT_TYPE).lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxMainExe_TOOL.win.amd64)_LIB)/oldnames.lib + ifeq ($(KBUILD_TYPE),asan) + TEMPLATE_VBoxMainExe_LIBS.x86 += \ + $(PATH_TOOL_$(TEMPLATE_VBoxMainExe_TOOL.win.x86)_LIB)/clang_rt.asan_dynamic-i386.lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxMainExe_TOOL.win.x86)_LIB)/clang_rt.asan_dynamic_runtime_thunk-i386.lib + TEMPLATE_VBoxMainExe_LIBS.amd64 += \ + $(PATH_TOOL_$(TEMPLATE_VBoxMainExe_TOOL.win.amd64)_LIB)/clang_rt.asan_dynamic-x86_64.lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxMainExe_TOOL.win.amd64)_LIB)/clang_rt.asan_dynamic_runtime_thunk-x86_64.lib + endif + else + TEMPLATE_VBoxMainExe_LIBS.x86 = \ + $(PATH_TOOL_$(TEMPLATE_VBoxMainExe_TOOL.win.x86)_LIB)/msvcrt$(VBOX_VCC_CRT_TYPE).lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxMainExe_TOOL.win.x86)_LIB)/msvcprt$(VBOX_VCC_CRT_TYPE).lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxMainExe_TOOL.win.x86)_LIB)/oldnames.lib + TEMPLATE_VBoxMainExe_LIBS.amd64 = \ + $(PATH_TOOL_$(TEMPLATE_VBoxMainExe_TOOL.win.amd64)_LIB)/msvcrt$(VBOX_VCC_CRT_TYPE).lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxMainExe_TOOL.win.amd64)_LIB)/msvcprt$(VBOX_VCC_CRT_TYPE).lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxMainExe_TOOL.win.amd64)_LIB)/oldnames.lib + endif + TEMPLATE_VBoxMainExe_POST_CMDS = $(VBOX_UTF8_MANIFEST_CMDS)$(NLTAB)$(VBOX_SIGN_IMAGE_CMDS) + TEMPLATE_VBoxMainExe_ORDERDEPS = $(VBOX_SIGN_IMAGE_CMDS_ORDERDEPS) + +else # the GCC guys: + + TEMPLATE_VBoxMainExe_TOOL = $(VBOX_GCC_TOOL) + if $(VBOX_GCC_VERSION_CC) < 30400 + TEMPLATE_VBoxMainExe_DEFS += RT_WITHOUT_PRAGMA_ONCE + endif + TEMPLATE_VBoxMainExe_CXXFLAGS = -g $(VBOX_GCC_pipe) \ + $(VBOX_GCC_PEDANTIC_CXX) $(VBOX_GCC_Wno-variadic-macros) $(VBOX_GCC_Wno-multistatement-macros) $(VBOX_GCC_Wno-class-memaccess) -Wshadow \ + -fshort-wchar -fpermissive -fexceptions -frtti $(VBOX_GCC_OPT) $(VBOX_GCC_FP) -fno-strict-aliasing \ + $(VBOX_GCC_fvisibility-inlines-hidden) $(VBOX_GCC_fvisibility-hidden) $(VBOX_GCC_std) $(VBOX_GCC_IPRT_FMT_CHECK) \ + $(VBOX_GCC_SANITIZER_FLAGS) + if !defined("VBOX_GCC_Wno-delete-non-virtual-dtor") && defined("VBOX_GCC_Wno-non-virtual-dtor") + TEMPLATE_VBoxMainExe_CXXFLAGS += $(VBOX_GCC_Wno-non-virtual-dtor) + endif + ifdef VBOX_WITH_NO_GCC_WARNING_POLICY + TEMPLATE_VBoxMainExe_CXXFLAGS += $(VBOX_GCC_WERR) + endif + ifdef VBOX_WITH_DTRACE_R3_MAIN + TEMPLATE_VBoxMainExe_CXXFLAGS := $(filter-out -pedantic,$(TEMPLATE_VBoxMainExe_CXXFLAGS)) -fdollars-in-identifiers # annoying gcc option precedence. + endif + TEMPLATE_VBoxMainExe_CXXFLAGS.x86 = -m32 + TEMPLATE_VBoxMainExe_CXXFLAGS.amd64 = -m64 + TEMPLATE_VBoxMainExe_CXXFLAGS.kprofile = -finstrument-functions + TEMPLATE_VBoxMainExe_CFLAGS = -g $(VBOX_GCC_pipe) $(VBOX_GCC_PEDANTIC_C) $(VBOX_GCC_Wno-variadic-macros) \ + $(VBOX_GCC_OPT) $(VBOX_GCC_FP) -fno-strict-aliasing $(VBOX_GCC_fvisibility-hidden) $(VBOX_GCC_IPRT_FMT_CHECK) \ + $(VBOX_GCC_SANITIZER_FLAGS) + ifdef VBOX_WITH_NO_GCC_WARNING_POLICY + TEMPLATE_VBoxMainExe_CFLAGS += $(VBOX_GCC_WERR) + endif + TEMPLATE_VBoxMainExe_CFLAGS.x86 = -m32 + TEMPLATE_VBoxMainExe_CFLAGS.amd64 = -m64 + TEMPLATE_VBoxMainExe_CFLAGS.kprofile = $(TEMPLATE_VBoxMainExe_CXXFLAGS.kprofile) + TEMPLATE_VBoxMainExe_CFLAGS.debug = $(TEMPLATE_VBoxMainExe_CXXFLAGS.debug) + TEMPLATE_VBoxMainExe_OBJCFLAGS = $(TEMPLATE_VBoxMainExe_CFLAGS) + TEMPLATE_VBoxMainExe_OBJCFLAGS.x86 = $(TEMPLATE_VBoxMainExe_CFLAGS.x86) + TEMPLATE_VBoxMainExe_OBJCFLAGS.amd64 = $(TEMPLATE_VBoxMainExe_CFLAGS.amd64) + TEMPLATE_VBoxMainExe_OBJCFLAGS.debug = $(TEMPLATE_VBoxMainExe_CFLAGS.debug) + TEMPLATE_VBoxMainExe_OBJCFLAGS.kprofile = $(TEMPLATE_VBoxMainExe_CFLAGS.kprofile) + TEMPLATE_VBoxMainExe_OBJCXXFLAGS = $(TEMPLATE_VBoxMainExe_CXXFLAGS) + TEMPLATE_VBoxMainExe_OBJCXXFLAGS.x86 = $(TEMPLATE_VBoxMainExe_CXXFLAGS.x86) + TEMPLATE_VBoxMainExe_OBJCXXFLAGS.amd64 = $(TEMPLATE_VBoxMainExe_CXXFLAGS.amd64) + TEMPLATE_VBoxMainExe_OBJCXXFLAGS.debug = $(TEMPLATE_VBoxMainExe_CXXFLAGS.debug) + TEMPLATE_VBoxMainExe_OBJCXXFLAGS.kprofile = $(TEMPLATE_VBoxMainExe_CXXFLAGS.kprofile) + TEMPLATE_VBoxMainExe_PCHFLAGS = $(TEMPLATE_VBoxMainExe_CXXFLAGS) + TEMPLATE_VBoxMainExe_PCHFLAGS.x86 = $(TEMPLATE_VBoxMainExe_CXXFLAGS.x86) + TEMPLATE_VBoxMainExe_PCHFLAGS.amd64 = $(TEMPLATE_VBoxMainExe_CXXFLAGS.amd64) + TEMPLATE_VBoxMainExe_PCHFLAGS.debug = $(TEMPLATE_VBoxMainExe_CXXFLAGS.debug) + TEMPLATE_VBoxMainExe_PCHFLAGS.kprofile = $(TEMPLATE_VBoxMainExe_CXXFLAGS.kprofile) + TEMPLATE_VBoxMainExe_LDFLAGS = $(VBOX_GCC_SANITIZER_FLAGS) $(VBOX_GCC_SANITIZER_LDFLAGS) + TEMPLATE_VBoxMainExe_LDFLAGS.x86 = -m32 + TEMPLATE_VBoxMainExe_LDFLAGS.amd64 = -m64 + ifeq ($(KBUILD_TARGET),linux) + TEMPLATE_VBoxMainExe_LIBS = pthread m rt $(LIB_RUNTIME) dl + TEMPLATE_VBoxMainExe_LDFLAGS.linux = -Wl,-z,noexecstack,-z,relro $(VBOX_LD_as_needed) + else ifeq ($(KBUILD_TARGET),os2) + TEMPLATE_VBoxMainExe_TOOL = GXX3OMF + TEMPLATE_VBoxMainExe_LIBS = $(LIB_RUNTIME) + else ifeq ($(KBUILD_TARGET),darwin) + TEMPLATE_VBoxMainExe_TOOL = $(VBOX_GCC_TOOL) + TEMPLATE_VBoxMainExe_SDKS += $(VBOX_DARWIN_DEF_SDK_SDKS) + TEMPLATE_VBoxMainExe_DEFS += $(VBOX_DARWIN_DEF_SDK_DEFS) + TEMPLATE_VBoxMainExe_CFLAGS += $(VBOX_DARWIN_DEF_SDK_CFLAGS) + TEMPLATE_VBoxMainExe_CXXFLAGS += $(VBOX_DARWIN_DEF_SDK_CXXFLAGS) + TEMPLATE_VBoxMainExe_OBJCFLAGS += $(VBOX_DARWIN_DEF_SDK_OBJCFLAGS) + TEMPLATE_VBoxMainExe_OBJCXXFLAGS += $(VBOX_DARWIN_DEF_SDK_OBJCXXFLAGS) + TEMPLATE_VBoxMainExe_LDFLAGS.darwin += -bind_at_load + TEMPLATE_VBoxMainExe_LDFLAGS += $(VBOX_DARWIN_DEF_SDK_LDFLAGS) -framework Carbon -Wl,-headerpad_max_install_names + TEMPLATE_VBoxMainExe_LIBS = $(LIB_RUNTIME) + TEMPLATE_VBoxMainExe_POST_CMDS.darwin = $(VBOX_SIGN_IMAGE_CMDS) + else ifeq ($(KBUILD_TARGET),haiku) + TEMPLATE_VBoxMainExe_TOOL = GXX3 + TEMPLATE_VBoxMainExe_LIBS = $(LIB_RUNTIME) network stdc++ supc++ + else if1of ($(KBUILD_TARGET), freebsd openbsd) + TEMPLATE_VBoxMainExe_TOOL = GXX3 + TEMPLATE_VBoxMainExe_LIBS = $(LIB_RUNTIME) + TEMPLATE_VBoxMainExe_INCS += \ + /usr/include \ + /usr/X11R6/include \ + /usr/local/include + TEMPLATE_VBoxMainExe_LIBPATH += \ + /usr/lib \ + /usr/X11R6/lib \ + /usr/local/lib + else ifeq ($(KBUILD_TARGET),netbsd) + TEMPLATE_VBoxMainExe_TOOL = GXX3 + TEMPLATE_VBoxMainExe_LIBS = $(LIB_RUNTIME) + TEMPLATE_VBoxMainExe_INCS += \ + /usr/include \ + /usr/X11R7/include + TEMPLATE_VBoxMainExe_LIBPATH += \ + /usr/lib \ + /usr/X11R7/lib + else ifeq ($(KBUILD_TARGET),solaris) + TEMPLATE_VBoxMainExe_TOOL = GXX3PLAIN + TEMPLATE_VBoxMainExe_DEFS += _REENTRANT + TEMPLATE_VBoxMainExe_LIBS = $(LIB_RUNTIME) rt thread + else + $(warning Warning: VBOX Build: Target $(KBUILD_TARGET) is not officially supported!) + TEMPLATE_VBoxMainExe_LIBS = + endif + TEMPLATE_VBoxMainExe_LDFLAGS.solaris = -Wl,-z,ignore # Same as VBOX_LD_as_needed. + ifdef VBOX_WITH_RUNPATH + TEMPLATE_VBoxMainExe_LDFLAGS += '$(VBOX_GCC_RPATH_OPT)$(VBOX_WITH_RUNPATH)' + else ifdef VBOX_WITH_RELATIVE_RUNPATH + TEMPLATE_VBoxMainExe_LDFLAGS += '$(VBOX_GCC_RPATH_OPT)$(VBOX_WITH_RELATIVE_RUNPATH)' + endif + ifdef VBOX_WITH_ORIGIN + TEMPLATE_VBoxMainExe_LDFLAGS.linux += $(VBOX_GCC_ORIGIN_OPT) + endif + +endif # !win + +# Add COM/XPCOM stuff +TEMPLATE_VBoxMainExe_LIBS += \ + $(PATH_STAGE_LIB)/VBoxCOM$(VBOX_SUFF_LIB) +ifdef VBOX_WITH_XPCOM + ## @todo may be worth creating the VBOX_XPCOM SDK def + TEMPLATE_VBoxMainExe_DEFS += VBOX_WITH_XPCOM + ifdef VBOX_WITH_XPCOM_NAMESPACE_CLEANUP + TEMPLATE_VBoxMainExe_DEFS += VBOX_WITH_XPCOM_NAMESPACE_CLEANUP + endif + TEMPLATE_VBoxMainExe_INCS += \ + $(VBOX_XPCOM_INCS) + TEMPLATE_VBoxMainExe_LIBS += \ + $(LIB_XPCOM) + TEMPLATE_VBoxMainExe_INTERMEDIATES += \ + $(VBOX_PATH_SDK)/bindings/xpcom/include/VirtualBox_XPCOM.h + +else # COM + TEMPLATE_VBoxMainExe_INCS += \ + $(VBOX_PATH_SDK)/bindings/mscom/include + TEMPLATE_VBoxMainExe_INTERMEDIATES += \ + $(VBOX_PATH_SDK)/bindings/mscom/include/VirtualBox.h +endif # COM + +# +# Template for building the Main DLL modules (such as in-process COM/XPCOM +# components for Main). +# +# This differs from VBoxMainExe only in PIC handling and similar DLL stuff. +# +TEMPLATE_VBoxMainDll = VBox Main Component (shared library) +TEMPLATE_VBoxMainDll_EXTENDS = VBoxMainExe +ifn1of ($(KBUILD_TARGET), darwin haiku os2 win) + TEMPLATE_VBoxMainDll_DEFS = PIC $(TEMPLATE_VBoxMainExe_DEFS) + TEMPLATE_VBoxMainDll_CFLAGS = -fPIC $(TEMPLATE_VBoxMainExe_CFLAGS) + TEMPLATE_VBoxMainDll_CXXFLAGS = -fPIC $(TEMPLATE_VBoxMainExe_CXXFLAGS) + TEMPLATE_VBoxMainDll_PCHFLAGS = -fPIC $(TEMPLATE_VBoxMainExe_PCHFLAGS) + TEMPLATE_VBoxMainDll_LDFLAGS = -fPIC $(TEMPLATE_VBoxMainExe_LDFLAGS) +endif +TEMPLATE_VBoxMainDll_LDFLAGS.darwin = $(filter-out -bind_at_load,$(TEMPLATE_VBoxMainExe_LDFLAGS.darwin)) \ + -current_version $(VBOX_VERSION_MAJOR).$(VBOX_VERSION_MINOR).$(VBOX_VERSION_BUILD) \ + -compatibility_version $(VBOX_VERSION_MAJOR).$(VBOX_VERSION_MINOR).$(VBOX_VERSION_BUILD) + +# +# Template identical to VBoxMainDll except for where the stuff is +# installed when using XPCOM (components/). +# +# Note! In the hardened build this gets a bit ugly since $ORIGIN/.. +# doesn't work. So, we keep the $ORIGIN from VBoxMainExe and let +# the installers do the necessary .so symlinking. +# +# (No difference when building against COM on Windows.) +# +TEMPLATE_VBoxMainComp = VBox Main COM/XPCOM Component (shared library) +TEMPLATE_VBoxMainComp_EXTENDS = VBoxMainExe +ifn1of ($(KBUILD_TARGET), win) + TEMPLATE_VBoxMainComp_INST = $(INST_BIN)components/ +endif +ifneq ($(KBUILD_TARGET),win) + ifeq ($(filter-out solaris.x86 %.amd64 %.sparc32 %.sparc64,$(KBUILD_TARGET).$(KBUILD_TARGET_ARCH)),) ## TODO: cleanup! + TEMPLATE_VBoxMainComp_DEFS = PIC $(TEMPLATE_VBoxMainExe_DEFS) + TEMPLATE_VBoxMainComp_CFLAGS = -fPIC $(TEMPLATE_VBoxMainExe_CFLAGS) + TEMPLATE_VBoxMainComp_CXXFLAGS = -fPIC $(TEMPLATE_VBoxMainExe_CXXFLAGS) + TEMPLATE_VBoxMainComp_PCHFLAGS = -fPIC $(TEMPLATE_VBoxMainExe_PCHFLAGS) + if defined(VBOX_WITH_RELATIVE_RUNPATH) && !defined(VBOX_WITH_HARDENING) + TEMPLATE_VBoxMainComp_LDFLAGS = -fPIC $(filter-out '$(VBOX_GCC_RPATH_OPT)%',$(TEMPLATE_VBoxMainExe_LDFLAGS)) '$(VBOX_GCC_RPATH_OPT)$(VBOX_WITH_RELATIVE_RUNPATH)/..' + else + TEMPLATE_VBoxMainComp_LDFLAGS = -fPIC $(TEMPLATE_VBoxMainExe_LDFLAGS) + endif + else ifndef VBOX_WITH_HARDENING + ifdef VBOX_WITH_RELATIVE_RUNPATH + TEMPLATE_VBoxMainComp_LDFLAGS = $(filter-out '$(VBOX_GCC_RPATH_OPT)%',$(TEMPLATE_VBoxMainExe_LDFLAGS)) '$(VBOX_GCC_RPATH_OPT)$(VBOX_WITH_RELATIVE_RUNPATH)/..' + endif + endif +endif +TEMPLATE_VBoxMainComp_LDFLAGS.darwin = $(filter-out -bind_at_load,$(TEMPLATE_VBoxMainExe_LDFLAGS.darwin)) \ + -current_version $(VBOX_VERSION_MAJOR).$(VBOX_VERSION_MINOR).$(VBOX_VERSION_BUILD) \ + -compatibility_version $(VBOX_VERSION_MAJOR).$(VBOX_VERSION_MINOR).$(VBOX_VERSION_BUILD) + +# x86 version of VBoxMainComp +TEMPLATE_VBoxMainComp-x86 = 32-bit VBox Main Component (shared library) +TEMPLATE_VBoxMainComp-x86_EXTENDS = VBoxMainComp +TEMPLATE_VBoxMainComp-x86_BLD_TRG_ARCH = x86 +TEMPLATE_VBoxMainComp-x86_INST.win = $(INST_DLL)x86/ +TEMPLATE_VBoxMainComp-x86_DEFS = $(filter-out HC_ARCH_BITS%,$(TEMPLATE_VBoxMainComp_DEFS)) HC_ARCH_BIT=32 ARCH_BITS=32 \ + VBOX_IN_32_ON_64_MAIN_API +TEMPLATE_VBoxMainComp-x86_LIBS = \ + $(subst $(PATH_STAGE_LIB)/VBoxCOM$(VBOX_SUFF_LIB),$(PATH_STAGE_LIB)/VBoxCOM-x86$(VBOX_SUFF_LIB), \ + $(subst $(LIB_RUNTIME),$(VBOX_LIB_RUNTIME_X86), \ + $(subst $(LIB_XPCOM),$(VBOX_LIB_XPCOM_X86), \ + $(TEMPLATE_VBoxMainComp_LIBS)))) + + +# +# Template for building the Main static libraries. +# +# This differs from VBoxMainDll only that it zeroes out the _LIBS definition. +# +TEMPLATE_VBoxMainLib = VBox Main Component (static library) +TEMPLATE_VBoxMainLib_EXTENDS = VBoxMainDll +TEMPLATE_VBoxMainLib_LIBS = + +TEMPLATE_VBoxMainLib-x86 = 32-bit VBox Main Component (static library) +TEMPLATE_VBoxMainLib-x86_EXTENDS = VBoxMainLib +TEMPLATE_VBoxMainLib-x86_BLD_TRG_ARCH = x86 +TEMPLATE_VBoxMainLib-x86_DEFS = $(filter-out HC_ARCH_BITS%,$(TEMPLATE_VBoxMainLib_DEFS)) HC_ARCH_BIT=32 ARCH_BITS=32 \ + VBOX_IN_32_ON_64_MAIN_API + +# +# Main unit testing, for compiling API implementation files into a testcase. +# This is the VBoxMainExe template only with a different install dir. +# +TEMPLATE_VBoxMainTstExe = VBox Main Testcase Exe +TEMPLATE_VBoxMainTstExe_EXTENDS = VBoxMainExe +TEMPLATE_VBoxMainTstExe_INST = $(INST_TESTCASE) +ifdef VBOX_WITH_RUNPATH + TEMPLATE_VBoxMainTstExe_LDFLAGS = '$(VBOX_GCC_RPATH_OPT)$(VBOX_WITH_RUNPATH)' $(TEMPLATE_VBoxMainExe_LDFLAGS) +else ifdef VBOX_WITH_RELATIVE_RUNPATH + TEMPLATE_VBoxMainTstExe_LDFLAGS = '$(VBOX_GCC_RPATH_OPT)$(VBOX_WITH_RELATIVE_RUNPATH)/..' $(TEMPLATE_VBoxMainExe_LDFLAGS) +endif +if "$(KBUILD_TARGET)" == "win" && defined(VBOX_SIGNING_MODE) + TEMPLATE_VBoxMainTstExe_POST_CMDS = +endif + +# +# Template for building executables that use the VBox Main component. +# +TEMPLATE_VBoxMainClientExe = VBox Main Client (executable) +TEMPLATE_VBoxMainClientExe_EXTENDS = VBoxMainExe +ifeq ($(KBUILD_TARGET),win) + TEMPLATE_VBoxMainClientExe_DEPS = $(VBOX_PATH_SDK)/bindings/mscom/include/VirtualBox.h + TEMPLATE_VBoxMainClientExe_LIBS.win = $(TEMPLATE_VBoxMainExe_LIBS.win) \ + $(PATH_SDK_$(VBOX_WINPSDK)_LIB)/User32.Lib \ + $(PATH_SDK_$(VBOX_WINPSDK)_LIB)/Shell32.Lib \ + $(PATH_SDK_$(VBOX_WINPSDK)_LIB)/ShLwApi.Lib \ + $(PATH_SDK_$(VBOX_WINPSDK)_LIB)/Ole32.Lib \ + $(PATH_SDK_$(VBOX_WINPSDK)_LIB)/OleAut32.Lib \ + $(PATH_SDK_$(VBOX_WINPSDK)_LIB)/Uuid.Lib +else + TEMPLATE_VBoxMainClientExe_DEPS = $(VBOX_PATH_SDK)/bindings/xpcom/include/VirtualBox_XPCOM.h + TEMPLATE_VBoxMainClientExe_DEFS = $(TEMPLATE_VBoxMainExe_DEFS) \ + NDEBUG TRIMMED + TEMPLATE_VBoxMainClientExe_CXXFLAGS.linux = $(TEMPLATE_VBoxMainExe_CXXFLAGS.linux) -pthread + TEMPLATE_VBoxMainClientExe_PCHFLAGS.linux = $(TEMPLATE_VBoxMainExe_PCHFLAGS.linux) -pthread +endif + +# +# Template for building shared libraries / DLLs that use the VBox Main component. +# +# This differs from VBoxMainClientExe only in PIC handling and similar DLL stuff. +# +TEMPLATE_VBoxMainClientDll = VBox MAIN Client (shared library) +TEMPLATE_VBoxMainClientDll_EXTENDS = VBoxMainClientExe +ifn1of ($(KBUILD_TARGET), darwin os2 win) + TEMPLATE_VBoxMainClientDll_DEFS = PIC $(TEMPLATE_VBoxMainClientExe_DEFS) + TEMPLATE_VBoxMainClientDll_CFLAGS = -fPIC $(TEMPLATE_VBoxMainClientExe_CFLAGS) + TEMPLATE_VBoxMainClientDll_CXXFLAGS = -fPIC $(TEMPLATE_VBoxMainClientExe_CXXFLAGS) + TEMPLATE_VBoxMainClientDll_PCHFLAGS = -fPIC $(TEMPLATE_VBoxMainClientExe_PCHFLAGS) + TEMPLATE_VBoxMainClientDll_LDFLAGS = -fPIC $(TEMPLATE_VBoxMainClientExe_LDFLAGS) +endif +TEMPLATE_VBoxMainClientDll_LDFLAGS.darwin = $(filter-out -bind_at_load,$(TEMPLATE_VBoxMainClientExe_LDFLAGS.darwin)) + +# +# Template for building testcases which are API clients. +# +TEMPLATE_VBoxMainClientTstExe = VBox Main Client Testcase (executable) +TEMPLATE_VBoxMainClientTstExe_EXTENDS = VBoxMainClientExe +TEMPLATE_VBoxMainClientTstExe_INST = $(INST_TESTCASE) +ifdef VBOX_WITH_RUNPATH + TEMPLATE_VBoxMainClientTstExe_LDFLAGS = '$(VBOX_GCC_RPATH_OPT)$(VBOX_WITH_RUNPATH)' $(TEMPLATE_VBoxMainClientExe_LDFLAGS) +else ifdef VBOX_WITH_RELATIVE_RUNPATH + TEMPLATE_VBoxMainClientTstExe_LDFLAGS = '$(VBOX_GCC_RPATH_OPT)$(VBOX_WITH_RELATIVE_RUNPATH)/..' $(TEMPLATE_VBoxMainClientExe_LDFLAGS) +endif +if "$(KBUILD_TARGET)" == "win" && defined(VBOX_SIGNING_MODE) + TEMPLATE_VBoxMainClientTstExe_POST_CMDS = +endif + + + +# +# Templates used for building the extension packs. +# +ifdef VBOX_WITH_EXTPACK + # Base templates (native or portable). + TEMPLATE_VBoxR3ExtPack = For the ring-3 context extension pack modules. + if 1 # Native for now. + TEMPLATE_VBoxR3ExtPack_EXTENDS = VBoxR3Dll + TEMPLATE_VBoxR3ExtPack_DEFS = $(TEMPLATE_VBoxR3Dll_DEFS) VBOX_IN_EXTPACK VBOX_IN_EXTPACK_R3 + else + TEMPLATE_VBoxR3ExtPack_EXTENDS = VBoxNoCrtGccLib + TEMPLATE_VBoxR3ExtPack_DEFS = $(TEMPLATE_VBoxNoCrtGccLib_DEFS) VBOX_IN_EXTPACK VBOX_IN_EXTPACK_R3 IPRT_NO_CRT IN_RING3 + TEMPLATE_VBoxR3ExtPack_INCS = $(PATH_ROOT)/include/iprt/nocrt $(TEMPLATE_VBoxR3Dll_INCS) + endif + ifneq ($(KBUILD_TARGET),win) + TEMPLATE_VBoxR3ExtPack_CXXFLAGS = $(TEMPLATE_VBoxR3Dll_CXXFLAGS) -fno-rtti + TEMPLATE_VBoxR3ExtPack_PCHFLAGS = $(TEMPLATE_VBoxR3Dll_PCHFLAGS) -fno-rtti + endif + TEMPLATE_VBoxR3ExtPack_INST = $(INST_EXTPACK)YouShallOverrideThis/ + ifeq ($(KBUILD_TARGET),linux) + TEMPLATE_VBoxR3ExtPack_LDFLAGS = $(filter-out '$(VBOX_GCC_RPATH_OPT)$(VBOX_WITH_RUNPATH)' '$(VBOX_GCC_RPATH_OPT)$(VBOX_WITH_RELATIVE_RUNPATH)', $(TEMPLATE_VBoxR3Dll_LDFLAGS)) + else if !defined(VBOX_WITH_RUNPATH) && defined(VBOX_WITH_RELATIVE_RUNPATH) + TEMPLATE_VBoxR3ExtPack_LDFLAGS = '$(VBOX_GCC_RPATH_OPT)$(VBOX_WITH_RELATIVE_RUNPATH)/../../..' $(filter-out '$(VBOX_GCC_RPATH_OPT)$(VBOX_WITH_RELATIVE_RUNPATH)', $(TEMPLATE_VBoxR3Dll_LDFLAGS)) + endif + ifdef VBOX_ONLY_EXTPACKS_USE_IMPLIBS + if1of ($(KBUILD_TARGET), win os2) + TEMPLATE_VBoxR3ExtPack_LIBS = \ + $(PATH_STAGE_LIB)/VBoxRTImp$(VBOX_SUFF_LIB) + else + TEMPLATE_VBoxR3ExtPack_LIBS = \ + $(PATH_STAGE_LIB)/VBoxRTImp$(VBOX_SUFF_DLL) + endif + else + TEMPLATE_VBoxR3ExtPack_LIBS = \ + $(LIB_RUNTIME) + endif + ifeq ($(KBUILD_TARGET),darwin) + TEMPLATE_VBoxR3ExtPack_POST_CMDS = $(VBOX_SIGN_EXTPACK_DYLIB_CMDS) + endif + + TEMPLATE_VBoxR3ExtPackApi = For the ring-3 context extension pack modules using the Main API. + TEMPLATE_VBoxR3ExtPackApi_EXTENDS = VBoxMainDll + TEMPLATE_VBoxR3ExtPackApi_DEFS = $(TEMPLATE_VBoxMainDll_DEFS) VBOX_IN_EXTPACK VBOX_IN_EXTPACK_R3 + TEMPLATE_VBoxR3ExtPackApi_INST = $(INST_EXTPACK)YouShallOverrideThis/ + ifeq ($(KBUILD_TARGET),linux) + TEMPLATE_VBoxR3ExtPackApi_LDFLAGS = $(filter-out '$(VBOX_GCC_RPATH_OPT)$(VBOX_WITH_RUNPATH)' '$(VBOX_GCC_RPATH_OPT)$(VBOX_WITH_RELATIVE_RUNPATH)', $(TEMPLATE_VBoxMainDll_LDFLAGS)) + else if !defined(VBOX_WITH_RUNPATH) && defined(VBOX_WITH_RELATIVE_RUNPATH) + TEMPLATE_VBoxR3ExtPackApi_LDFLAGS = '$(VBOX_GCC_RPATH_OPT)$(VBOX_WITH_RELATIVE_RUNPATH)/../../..' $(filter-out '$(VBOX_GCC_RPATH_OPT)$(VBOX_WITH_RELATIVE_RUNPATH)', $(TEMPLATE_VBoxMainDll_LDFLAGS)) + endif + ifdef VBOX_ONLY_EXTPACKS_USE_IMPLIBS + if1of ($(KBUILD_TARGET), win os2) + TEMPLATE_VBoxR3ExtPackApi_LIBS = \ + $(PATH_STAGE_LIB)/VBoxRTImp$(VBOX_SUFF_LIB) + else + TEMPLATE_VBoxR3ExtPackApi_LIBS = \ + $(PATH_STAGE_LIB)/VBoxRTImp$(VBOX_SUFF_DLL) + endif + else + TEMPLATE_VBoxR3ExtPackApi_LIBS = \ + $(LIB_RUNTIME) + endif + ifeq ($(KBUILD_TARGET),darwin) + TEMPLATE_VBoxR3ExtPackApi_POST_CMDS = $(VBOX_SIGN_EXTPACK_DYLIB_CMDS) + endif + + TEMPLATE_VBoxR0ExtPack = For the ring-0 context extension pack modules. + TEMPLATE_VBoxR0ExtPack_EXTENDS = VBoxR0 + TEMPLATE_VBoxR0ExtPack_EXTENDS_BY = appending + TEMPLATE_VBoxR0ExtPack_INST = $(INST_EXTPACK)YouShallOverrideThis/ + TEMPLATE_VBoxR0ExtPack_DEFS = VBOX_IN_EXTPACK VBOX_IN_EXTPACK_R0 + if1of ($(VBOX_LDR_FMT), pe lx) + TEMPLATE_VBoxR0ExtPack_LIBS = \ + $(PATH_STAGE_LIB)/VMMR0Imp$(VBOX_SUFF_LIB) + endif + TEMPLATE_VBoxR0ExtPack_LIBS += \ + $(VBOX_LIB_SUPR0) + + TEMPLATE_VBoxRcExtPack = For the raw-mode context extension pack modules. + TEMPLATE_VBoxRcExtPack_EXTENDS = VBoxRc + TEMPLATE_VBoxRcExtPack_EXTENDS_BY = appending + TEMPLATE_VBoxRcExtPack_SYSSUFF = .rc + TEMPLATE_VBoxRcExtPack_INST = $(INST_EXTPACK)YouShallOverrideThis/ + TEMPLATE_VBoxRcExtPack_DEFS = VBOX_IN_EXTPACK VBOX_IN_EXTPACK_RC + if1of ($(VBOX_LDR_FMT32), pe lx) + TEMPLATE_VBoxRcExtPack_LIBS = \ + $(PATH_STAGE_LIB)/VMMRCBuiltin$(VBOX_SUFF_LIB) \ + $(PATH_STAGE_LIB)/VMMRCImp$(VBOX_SUFF_LIB) + endif + + TEMPLATE_VBoxInsExtPack = For the install targets of an extension pack. + TEMPLATE_VBoxInsExtPack_MODE = 0644 + TEMPLATE_VBoxInsExtPack_INST = $(INST_EXTPACK)YouShallOverrideThis/ + + # For each individual extension pack + ifdef VBOX_WITH_EXTPACK_PUEL + TEMPLATE_VBoxR3ExtPackPuel = For the ring-3 context modules in the PUEL extension pack. + TEMPLATE_VBoxR3ExtPackPuel_EXTENDS = VBoxR3ExtPack + TEMPLATE_VBoxR3ExtPackPuel_INST = $(INST_EXTPACK_PUEL)$(KBUILD_TARGET).$(KBUILD_TARGET_ARCH)/ + TEMPLATE_VBoxR3ExtPackPuel_DEFS = $(TEMPLATE_VBoxR3ExtPack_DEFS) VBOX_IN_PUEL_EXTPACK + TEMPLATE_VBoxR3ExtPackPuel_LD_DEBUG = split + + TEMPLATE_VBoxR3ExtPackApiPuel = For the ring-3 context modules in the PUEL extension pack. + TEMPLATE_VBoxR3ExtPackApiPuel_EXTENDS = VBoxR3ExtPackApi + TEMPLATE_VBoxR3ExtPackApiPuel_INST = $(INST_EXTPACK_PUEL)$(KBUILD_TARGET).$(KBUILD_TARGET_ARCH)/ + TEMPLATE_VBoxR3ExtPackApiPuel_DEFS = $(TEMPLATE_VBoxR3ExtPackApi_DEFS) VBOX_IN_PUEL_EXTPACK + TEMPLATE_VBoxR3ExtPackApiPuel_LD_DEBUG = split + + TEMPLATE_VBoxR3ExtPackPuelWithOpenSsl = For the ring-3 context modules in the PUEL extension pack using ExtPack OpenSSL. + TEMPLATE_VBoxR3ExtPackPuelWithOpenSsl_EXTENDS = VBoxR3ExtPackPuel + + TEMPLATE_VBoxR0ExtPackPuel = For the ring-0 context modules in the PUEL extension pack. + TEMPLATE_VBoxR0ExtPackPuel_EXTENDS = VBoxR0ExtPack + TEMPLATE_VBoxR0ExtPackPuel_INST = $(INST_EXTPACK_PUEL)$(KBUILD_TARGET).$(KBUILD_TARGET_ARCH)/ + TEMPLATE_VBoxR0ExtPackPuel_DEFS = $(TEMPLATE_VBoxR0ExtPack_DEFS) VBOX_IN_PUEL_EXTPACK + + TEMPLATE_VBoxRcExtPackPuel = For the raw-mode context modules in the PUEL extension pack. + TEMPLATE_VBoxRcExtPackPuel_EXTENDS = VBoxRcExtPack + TEMPLATE_VBoxRcExtPackPuel_INST = $(INST_EXTPACK_PUEL)$(KBUILD_TARGET).$(KBUILD_TARGET_ARCH)/ + TEMPLATE_VBoxRcExtPackPuel_DEFS = $(TEMPLATE_VBoxRcExtPack_DEFS) VBOX_IN_PUEL_EXTPACK + + TEMPLATE_VBoxInsExtPackPuel = For the install targets of an extension pack. + TEMPLATE_VBoxInsExtPackPuel_EXTENDS = VBoxR0ExtPack + TEMPLATE_VBoxInsExtPackPuel_INST = $(INST_EXTPACK_PUEL) + endif + +endif # VBOX_WITH_EXTPACK + + +# +# Qt +# Qt +# Qt +# +if defined(VBOX_WITH_QTGUI) || defined(VBOX_WITH_NLS) + + # Guess VBOX_WITH_ORACLE_QT + ifndef VBOX_WITH_ORACLE_QT + ifndef VBOX_OSE + if1of ($(KBUILD_TARGET), darwin solaris win) + VBOX_WITH_ORACLE_QT := 1 + endif + endif + endif + + # + # Handmade configuration of Qt - very annoying, this needs to + # be cleaned up properly later some time (not important now). + # + ifeq ($(VBOX_PATH_QT),) + ifeq ($(KBUILD_TARGET),darwin) + VBOX_PATH_QT := $(lastword $(sort $(wildcard $(KBUILD_DEVTOOLS_TRG)/qt/v5*))) + ifeq ($(VBOX_PATH_QT),) + ifneq ($(wildcard /Library/Frameworks/QtCore.framework),) + # Using the global installation (for OSE). + VBOX_PATH_QT ?= /usr + VBOX_PATH_QT_FRAMEWORKS ?= /Library/Frameworks + endif + endif + else if1of ($(KBUILD_TARGET), win) + VBOX_PATH_QT := $(rsort $(wildcard $(KBUILD_DEVTOOLS_TRG)/qt/v5*)) + VBOX_PATH_QT := $(firstword $(filter %-$(tolower $(VBOX_VCC_TOOL_STEM)),$(VBOX_PATH_QT)) \ + $(filter-out %-vcc100 %-vcc110 %-vcc120 %-vcc140 %-vcc141 %-vcc142 %-vcc143 %-vcc150, $(VBOX_PATH_QT))) + ifdef VBOX_PATH_QT + PATH_SDK_QT5 := $(VBOX_PATH_QT) + PATH_TOOL_QT5 := $(VBOX_PATH_QT) + endif + else if1of ($(KBUILD_TARGET), linux solaris) + VBOX_PATH_QT ?= $(lastword $(sort $(wildcard $(KBUILD_DEVTOOLS_TRG)/qt/v5*))) + ifneq ($(VBOX_PATH_QT),) + VBOX_WITH_ORACLE_QT = 1 + endif + endif + endif + ifeq ($(VBOX_PATH_QT),) + if1of ($(USERNAME), bird) + # gentoo (64-bit) + VBOX_PATH_QT ?= /usr + VBOX_PATH_QT_LIB ?= /usr/lib/qt5 + endif + endif + VBOX_PATH_QT ?= /usr + VBOX_PATH_QT_LIB ?= $(VBOX_PATH_QT)/lib + + if defined(VBOX_WITH_ORACLE_QT) && (!defined(VBOX_WITH_QT6) || "$(KBUILD_TARGET)" != "darwin") + VBOX_QT_INFIX := VBox + endif + + ifeq ($(KBUILD_TARGET),darwin) + VBOX_QT_MOD := QtCore QtGui QtWidgets QtPrintSupport + ifdef VBOX_WITH_QT6 + VBOX_QT_MOD += QtStateMachine QtCore5Compat + else + VBOX_QT_MOD += QtMacExtras + endif + ifdef VBOX_GUI_USE_QGL + VBOX_QT_MOD += QtOpenGL + endif + else if1of ($(KBUILD_TARGET), linux freebsd netbsd openbsd solaris win) + VBOX_QT_MOD += Qt5Core Qt5Gui Qt5Widgets Qt5PrintSupport $(if $(VBOX_GUI_USE_QGL),Qt5OpenGL,) + if1of ($(KBUILD_TARGET), linux freebsd netbsd openbsd solaris) + VBOX_QT_MOD += Qt5DBus Qt5Xml Qt5XcbQpa Qt5X11Extras + VBOX_QT_PLUGINS = \ + plugins/platforms/libqxcb.so \ + plugins/platformthemes/libqgtk2.so \ + plugins/platformthemes/libqgtk3.so \ + plugins/sqldrivers/libqsqlite.so \ + plugins/styles/libqgtk2style.so \ + plugins/xcbglintegrations/libqxcb-glx-integration.so + else ifeq ($(KBUILD_TARGET),win) + VBOX_QT_MOD += Qt5WinExtras + endif # win + endif # linux freebsd netbsd openbsd solaris win + + ifdef VBOX_WITH_QHELP_VIEWER + ifeq ($(KBUILD_TARGET),darwin) + VBOX_QT_MOD += QtHelp QtNetwork QtSql + else if1of ($(KBUILD_TARGET), linux freebsd netbsd openbsd solaris win) + VBOX_QT_MOD += Qt5Help Qt5Network Qt5Sql + endif + endif + + VBOX_QT_MOD_NAMES = $(foreach qtmod,$(VBOX_QT_MOD),$(qtmod)$(VBOX_QT_INFIX)) + + # Hack LD_LIBRARY_PATH for stuff in tools. + ifdef VBOX_WITH_ORACLE_QT + if1of ($(KBUILD_TARGET), linux solaris) + export LD_LIBRARY_PATH := $(VBOX_PATH_QT_LIB):$(LD_LIBRARY_PATH) + endif + endif + + # WORKAROUND: + # Both files included automatically, 1st include is included from 2nd one, + # but moc can't include it due to problem with parsing framework structure, + # as a result QT_VERSION can't be calculated and it's not only used in our + # GUI but by the moc itself to parse modern signal/slot definitions. + # We were hardcoding QT_VERSION for TEMPLATE_VBoxQtGuiExe below for quite + # a long, but this have to end. Instead we can pass both includes manually. + TOOL_QT5_MOCFLAGS.darwin += --include qconfig.h --include qglobal.h +endif # defined(VBOX_WITH_QTGUI) || defined(VBOX_WITH_NLS) + +ifdef VBOX_WITH_QTGUI + # + # Template for building Qt GUI executables. + # + TEMPLATE_VBoxQtGuiExe = VBox Qt GUI Executable + ifndef VBOX_WITH_QT6 + TEMPLATE_VBoxQtGuiExe_USES := qt5 + TEMPLATE_VBoxQtGuiExe_QTTOOL := QT5 + TEMPLATE_VBoxQtGuiExe_MOCTOOL := QT5 + TEMPLATE_VBoxQtGuiExe_UICTOOL := QT5 + TEMPLATE_VBoxQtGuiExe_RCCTOOL := QT5 + TEMPLATE_VBoxQtGuiExe_LRCTOOL := QT5 + TEMPLATE_VBoxQtGuiExe_SDKS := QT5 + else + TEMPLATE_VBoxQtGuiExe_USES := qt6 + TEMPLATE_VBoxQtGuiExe_QTTOOL := QT6 + TEMPLATE_VBoxQtGuiExe_MOCTOOL := QT6 + TEMPLATE_VBoxQtGuiExe_UICTOOL := QT6 + TEMPLATE_VBoxQtGuiExe_RCCTOOL := QT6 + TEMPLATE_VBoxQtGuiExe_LRCTOOL := QT6 + TEMPLATE_VBoxQtGuiExe_SDKS := QT6 + TEMPLATE_VBoxQtGuiExe_QT_MODULES := Core5Compat + endif + TEMPLATE_VBoxQtGuiExe_QT_INFIX = $(VBOX_QT_INFIX) + TEMPLATE_VBoxQtGuiExe_DEFS = IN_RING3 QT_NO_DEBUG QT_THREAD_SUPPORT QT_SHARED HAVE_CONFIG_H $(ARCH_BITS_DEFS) + TEMPLATE_VBoxQtGuiExe_RCDEFS = $(TEMPLATE_VBoxR3Exe_RCDEFS) + + ifeq ($(KBUILD_TARGET),win) + # Note! No use of VBOX_VCC_CRT_TYPE here yet as it requires a /MDd build of Qt as well. + TEMPLATE_VBoxQtGuiExe_TOOL = $(VBOX_VCC_TOOL) + if "$(VBOX_VCC_TOOL_STEM)" >= "VCC140" + TEMPLATE_VBoxQtGuiExe_SDKS = WINSDK10-UCRT + endif + TEMPLATE_VBoxQtGuiExe_DEFS += \ + _WIN32_WINNT=0x0500 UNICODE _UNICODE \ + QT_DLL _CRT_SECURE_NO_DEPRECATE \ + $(QMAKE_PRL_DEFINES) + TEMPLATE_VBoxQtGuiExe_CXXFLAGS = -nologo -Zm200 -MD -Zi -EHsc -Zc:wchar_t- $(VBOX_VCC_CC_GUARD_CF) $(VBOX_VCC_SANITIZER_FLAGS) $(VBOX_VCC_std) + # -wd4481: nonstandard extension used: override specifier 'override' + # -wd4625: 'QRubberBand' : copy constructor could not be generated because a base class copy constructor is inaccessible + # -wd4626: 'QRubberBand' : assignment operator could not be generated because a base class assignment operator is inaccessible + # -wd4640: qmetatype.h(2210): warning C4640: 'f' : construction of local static object is not thread-safe [too bad] + # -wd4350: behavior change: 'int QStringList::indexOf(const QRegExp &,int) const' called instead of 'int QStringList::indexOf(QRegExp &,int) const' + # -wd4121: UIActionPool.h(393) : warning C4121: 'UIActionPool::PointerToFunction' : alignment of a member was sensitive to packing + # -wd4718: qmap.h(222) : warning C4718: 'QMapNode<enum DetailsElementType,bool>::destroySubTree' : recursive call has no side effects, deleting + # -wd5204: pplwin.h(78): warning C5204: 'Concurrency::details::_DefaultPPLTaskScheduler': class has virtual functions + TEMPLATE_VBoxQtGuiExe_CXXFLAGS += $(VBOX_VCC_WARN_ALL) -wd4481 -wd4625 -wd4626 -wd4640 -wd4350 -wd4371 -wd4121 -wd4718 -wd5204 $(VBOX_VCC_WERR) + if "$(VBOX_VCC_TOOL_STEM)" >= "VCC120" + # -wd4619: qvectro.h(305 : warning C4619: #pragma warning : there is no warning number '4345' + TEMPLATE_VBoxQtGuiExe_CXXFLAGS += -wd4619 + endif + if "$(VBOX_VCC_TOOL_STEM)" >= "VCC140" + # -wd4774: string(530): warning C4774: '_scprintf' : format string expected in argument 1 is not a string literal + # -wd4456: UICommon.cpp(1471): warning C4456: declaration of '_container_' hides previous local declaration [nested foreach] + # -wd4458: UISettingsDialogSpecific.cpp(416): warning C4458: declaration of 'data' hides class member + # qwidget.h(730): note: see declaration of 'QWidget::data' + # -wd4946: qmap.h(213): warning C4946: reinterpret_cast used between related classes: 'QMapNodeBase' and 'QMapNode<Key,T>' + TEMPLATE_VBoxQtGuiExe_CXXFLAGS += -wd4774 -wd4456 -wd4458 -wd4946 + endif + if "$(VBOX_VCC_TOOL_STEM)" >= "VCC141" + # -wd4866: UIVirtualBoxManager.cpp(221) : warning C4866: compiler may not enforce left-to-right evaluation order for call to 'QStringList::operator<<' + # Only with -std=c++17 and later. + TEMPLATE_VBoxQtGuiExe_CXXFLAGS += -wd4866 + endif + if "$(VBOX_VCC_TOOL_STEM)" >= "VCC142" # With v16.11.9, not with v16.6.0 4242 + # -wd5219: qpoint.h(187): warning C5219: implicit conversion from 'const int' to 'float', possible loss of data + # -wd5240: qcolor.h(235): warning C5240: 'nodiscard': attribute is ignored in this syntactic position + TEMPLATE_VBoxQtGuiExe_CXXFLAGS += -wd5219 -wd5240 + TEMPLATE_VBoxQtGuiExe_CXXFLAGS += /volatileMetadata- # Don't waste space on x86/amd64-on-arm emulation optimizations. + endif + TEMPLATE_VBoxQtGuiExe_CXXFLAGS += -Gy + if "$(VBOX_VCC_TOOL_STEM)" >= "VCC120" + TEMPLATE_VBoxQtGuiExe_CXXFLAGS += -Gw + endif + ifdef VBOX_WITH_MSC_ANALYZE_THIS + TEMPLATE_VBoxQtGuiExe_CXXFLAGS += /analyze + endif + + TEMPLATE_VBoxQtGuiExe_CXXFLAGS.debug = -RTCsu + TEMPLATE_VBoxQtGuiExe_CXXFLAGS.debug = -RTCsu + TEMPLATE_VBoxQtGuiExe_CXXFLAGS.dbgopt = $(NO_SUCH_VARIABLE) + TEMPLATE_VBoxQtGuiExe_PCHFLAGS = $(TEMPLATE_VBoxQtGuiExe_CXXFLAGS) + TEMPLATE_VBoxQtGuiExe_PCHFLAGS.debug = $(TEMPLATE_VBoxQtGuiExe_CXXFLAGS.debug) + TEMPLATE_VBoxQtGuiExe_PCHFLAGS.dbgopt = $(TEMPLATE_VBoxQtGuiExe_CXXFLAGS.dbgopt) + TEMPLATE_VBoxQtGuiExe_LDFLAGS = -Ignore:4197 \ + /NOD /INCREMENTAL:NO /MAPINFO:EXPORTS /LargeAddressAware /DynamicBase /NxCompat /Release /Debug /Opt:Ref /Opt:Icf \ + $(VBOX_VCC_LD_GUARD_CF) $(VBOX_VCC_SANITIZER_LDFLAGS) \ + /Version:$(VBOX_VERSION_MAJOR)0$(VBOX_VERSION_MINOR).$(VBOX_VERSION_BUILD) \ + /STUB:$(PATH_ROOT)/src/VBox/HostDrivers/Support/win/winstub.com + if defined(VBOX_SIGNING_MODE) && defined(VBOX_WITH_HARDENING) + TEMPLATE_VBoxQtGuiExe_LDFLAGS += -IntegrityCheck + endif + if "$(VBOX_VCC_TOOL_STEM)" >= "VCC142" # Don't waste space on x86/amd64-on-arm emulation optimizations. + TEMPLATE_VBoxQtGuiExe_LDFLAGS += -EmitVolatileMetadata:NO + endif + TEMPLATE_VBoxQtGuiExe_LDFLAGS.win.amd64 = $(VBOX_VCC_LD_HIGH_ENTRYOPY_VA) + + TEMPLATE_VBoxQtGuiExe_SDKS += $(VBOX_WINPSDK) + if "$(VBOX_VCC_TOOL_STEM)" >= "VCC140" + TEMPLATE_VBoxQtGuiExe_LIBS = \ + $(VBOX_LIBS_QT) \ + $(LIB_RUNTIME) \ + $(PATH_TOOL_$(VBOX_VCC_TOOL)_LIB)/vcruntime.lib \ + $(PATH_TOOL_$(VBOX_VCC_TOOL)_LIB)/msvcrt.lib \ + $(PATH_TOOL_$(VBOX_VCC_TOOL)_LIB)/msvcprt.lib \ + $(PATH_TOOL_$(VBOX_VCC_TOOL)_LIB)/oldnames.lib \ + $(PATH_TOOL_$(VBOX_VCC_TOOL)_LIB)/delayimp.lib + ifeq ($(KBUILD_TYPE),asan) + TEMPLATE_VBoxQtGuiExe_LIBS += \ + $(PATH_TOOL_$(VBOX_VCC_TOOL)_LIB)/clang_rt.asan_dynamic-x86_64.lib \ + $(PATH_TOOL_$(VBOX_VCC_TOOL)_LIB)/clang_rt.asan_dynamic_runtime_thunk-x86_64.lib + endif + else + TEMPLATE_VBoxQtGuiExe_LIBS = \ + $(VBOX_LIBS_QT) \ + $(LIB_RUNTIME) \ + $(PATH_TOOL_$(VBOX_VCC_TOOL)_LIB)/msvcprt.lib \ + $(PATH_TOOL_$(VBOX_VCC_TOOL)_LIB)/msvcrt.lib \ + $(PATH_TOOL_$(VBOX_VCC_TOOL)_LIB)/oldnames.lib \ + $(PATH_TOOL_$(VBOX_VCC_TOOL)_LIB)/delayimp.lib + endif + TEMPLATE_VBoxQtGuiExe_POST_CMDS = $(VBOX_UTF8_MANIFEST_CMDS)$(NLTAB)$(VBOX_SIGN_IMAGE_CMDS) + TEMPLATE_VBoxQtGuiExe_ORDERDEPS = $(VBOX_SIGN_IMAGE_CMDS_ORDERDEPS) + + else # the gcc guys: + TEMPLATE_VBoxQtGuiExe_TOOL = $(VBOX_GCC_TOOL) + if $(VBOX_GCC_VERSION_CC) < 30400 + TEMPLATE_VBoxQtGuiExe_DEFS += RT_WITHOUT_PRAGMA_ONCE + endif + TEMPLATE_VBoxQtGuiExe_DEFS.linux = _REENTRANT + TEMPLATE_VBoxQtGuiExe_DEFS.solaris = _REENTRANT + + ## @todo Use VBOX_GCC_PEDANTIC_CXX? + TEMPLATE_VBoxQtGuiExe_CXXFLAGS = \ + -g $(VBOX_GCC_pipe) $(filter-out -Wno-unused $(VBOX_GCC_Wno-unused-parameter),$(VBOX_GCC_WARN)) -frtti -fno-exceptions \ + -Wno-long-long -fshort-wchar -fno-strict-aliasing \ + $(VBOX_GCC_fvisibility-hidden) $(VBOX_GCC_fvisibility-inlines-hidden) $(VBOX_GCC_Wno-multistatement-macros) $(VBOX_GCC_Wno-ignored-qualifiers) \ + $(VBOX_GCC_Wno-return-type-c-linkage) $(VBOX_GCC_std) $(VBOX_GCC_IPRT_FMT_CHECK) $(VBOX_GCC_SANITIZER_FLAGS) + ifdef VBOX_WITH_NO_GCC_WARNING_POLICY + TEMPLATE_VBoxQtGuiExe_CXXFLAGS += $(VBOX_GCC_WERR) + endif + ifn1of ($(USERNAME), dsen serkan) # Bunch of stuff deprecated after 5.6.*. These guys knows how to deal with it. :) + TEMPLATE_VBoxQtGuiExe_CXXFLAGS += $(VBOX_GCC_Wno-deprecated-declarations) + endif + ifdef VBOX_WITH_QT6 + TEMPLATE_VBoxQtGuiExe_CXXFLAGS += -std=gnu++17 + endif + TEMPLATE_VBoxQtGuiExe_CXXFLAGS.x86 = -m32 + TEMPLATE_VBoxQtGuiExe_CXXFLAGS.amd64 = -m64 + TEMPLATE_VBoxQtGuiExe_CXXFLAGS.linux = -pthread + TEMPLATE_VBoxQtGuiExe_PCHFLAGS = $(TEMPLATE_VBoxQtGuiExe_CXXFLAGS) + TEMPLATE_VBoxQtGuiExe_PCHFLAGS.x86 = $(TEMPLATE_VBoxQtGuiExe_CXXFLAGS.x86) + TEMPLATE_VBoxQtGuiExe_PCHFLAGS.amd64 = $(TEMPLATE_VBoxQtGuiExe_CXXFLAGS.amd64) + TEMPLATE_VBoxQtGuiExe_PCHFLAGS.linux = $(TEMPLATE_VBoxQtGuiExe_CXXFLAGS.linux) + TEMPLATE_VBoxQtGuiExe_PCHFLAGS.debug = $(TEMPLATE_VBoxQtGuiExe_CXXFLAGS.debug) + TEMPLATE_VBoxQtGuiExe_PCHFLAGS.dbgopt = $(TEMPLATE_VBoxQtGuiExe_CXXFLAGS.dbgopt) + TEMPLATE_VBoxQtGuiExe_OBJCFLAGS = -g $(VBOX_GCC_pipe) $(VBOX_GCC_PEDANTIC_C) -fno-exceptions $(VBOX_GCC_IPRT_FMT_CHECK) + TEMPLATE_VBoxQtGuiExe_OBJCFLAGS.x86 = $(TEMPLATE_VBoxQtGuiExe_CXXFLAGS.x86) + TEMPLATE_VBoxQtGuiExe_OBJCFLAGS.amd64 = $(TEMPLATE_VBoxQtGuiExe_CXXFLAGS.amd64) + TEMPLATE_VBoxQtGuiExe_OBJCXXFLAGS = \ + -g $(VBOX_GCC_pipe) $(VBOX_GCC_PEDANTIC_CXX) \ + -frtti -fno-exceptions $(VBOX_GCC_fvisibility-hidden) $(VBOX_GCC_fvisibility-inlines-hidden) $(VBOX_GCC_IPRT_FMT_CHECK) + ifdef VBOX_WITH_NO_GCC_WARNING_POLICY + TEMPLATE_VBoxQtGuiExe_OBJCXXFLAGS += $(VBOX_GCC_WERR) + endif + ifdef VBOX_WITH_QT6 + TEMPLATE_VBoxQtGuiExe_OBJCXXFLAGS += -std=gnu++17 + endif + TEMPLATE_VBoxQtGuiExe_OBJCXXFLAGS.x86 = $(TEMPLATE_VBoxQtGuiExe_CXXFLAGS.x86) + TEMPLATE_VBoxQtGuiExe_OBJCXXFLAGS.amd64 = $(TEMPLATE_VBoxQtGuiExe_CXXFLAGS.amd64) + TEMPLATE_VBoxQtGuiExe_LDFLAGS = $(VBOX_GCC_SANITIZER_FLAGS) $(VBOX_GCC_SANITIZER_LDFLAGS) + TEMPLATE_VBoxQtGuiExe_LDFLAGS.x86 = -m32 + TEMPLATE_VBoxQtGuiExe_LDFLAGS.amd64 = -m64 + TEMPLATE_VBoxQtGuiExe_LIBS = \ + $(VBOX_LIBS_QT) \ + $(LIB_RUNTIME) + + ifeq ($(KBUILD_TARGET),linux) + TEMPLATE_VBoxQtGuiExe_LDFLAGS += -Wl,-z,noexecstack,-z,relro $(VBOX_LD_as_needed) + TEMPLATE_VBoxQtGuiExe_LIBS += \ + $(VBOX_XCURSOR_LIBS) \ + Xext \ + X11 + TEMPLATE_VBoxQtGuiExe_LIBPATH += \ + $(VBOX_LIBPATH_X11) + else ifeq ($(KBUILD_TARGET),darwin) + TEMPLATE_VBoxQtGuiExe_SDKS.darwin += $(VBOX_DARWIN_DEF_SDK_SDKS) + TEMPLATE_VBoxQtGuiExe_DEFS.darwin += $(VBOX_DARWIN_DEF_SDK_DEFS) + TEMPLATE_VBoxQtGuiExe_CFLAGS.darwin += $(VBOX_DARWIN_DEF_SDK_CFLAGS) + TEMPLATE_VBoxQtGuiExe_CXXFLAGS.darwin += $(VBOX_DARWIN_DEF_SDK_CXXFLAGS) + TEMPLATE_VBoxQtGuiExe_PCHFLAGS.darwin += $(TEMPLATE_VBoxQtGuiExe_CXXFLAGS.darwin) + TEMPLATE_VBoxQtGuiExe_OBJCFLAGS.darwin += $(VBOX_DARWIN_DEF_SDK_OBJCFLAGS) + ifdef VBOX_WITH_QT6 + TEMPLATE_VBoxQtGuiExe_OBJCXXFLAGS.darwin += $(VBOX_DARWIN_DEF_SDK_OBJCXXFLAGS) + else + TEMPLATE_VBoxQtGuiExe_OBJCXXFLAGS.darwin += $(VBOX_DARWIN_DEF_SDK_OBJCXXFLAGS) $(VBOX_GCC_std) + endif + TEMPLATE_VBoxQtGuiExe_LDFLAGS.darwin += $(VBOX_DARWIN_DEF_SDK_LDFLAGS) -bind_at_load -Wl,-headerpad_max_install_names + TEMPLATE_VBoxQtGuiExe_LIBS += + TEMPLATE_VBoxQtGuiExe_LIBPATH += + TEMPLATE_VBoxQtGuiExe_POST_CMDS.darwin = $(VBOX_SIGN_IMAGE_CMDS) + else + TEMPLATE_VBoxQtGuiExe_INCS += \ + $(VBOX_XCURSOR_INCS) + TEMPLATE_VBoxQtGuiExe_LIBS += \ + $(VBOX_XCURSOR_LIBS) \ + Xext \ + X11 \ + m \ + $(LIB_PTHREAD) + TEMPLATE_VBoxQtGuiExe_LIBPATH += \ + $(VBOX_LIBPATH_X11) + ifeq ($(KBUILD_TARGET),freebsd) + TEMPLATE_VBoxQtGuiExe_INCS += \ + /usr/include \ + /usr/X11R6/include \ + /usr/local/include + TEMPLATE_VBoxQtGuiExe_LIBPATH += \ + /usr/lib \ + /usr/X11R6/lib \ + /usr/local/lib + endif + ifeq ($(KBUILD_TARGET),solaris) + TEMPLATE_VBoxQtGuiExe_LDFLAGS.solaris = -Wl,-z,ignore # Same as VBOX_LD_as_needed. + TEMPLATE_VBoxQtGuiExe_LIBS += \ + rt socket nsl + endif + endif + # Assume the Qt shared objects are in the same directory as the executable, on Solaris too. + ifdef VBOX_WITH_RUNPATH + TEMPLATE_VBoxQtGuiExe_LDFLAGS += '$(VBOX_GCC_RPATH_OPT)$(VBOX_WITH_RUNPATH)' + else ifdef VBOX_WITH_RELATIVE_RUNPATH + TEMPLATE_VBoxQtGuiExe_LDFLAGS += '$(VBOX_GCC_RPATH_OPT)$(VBOX_WITH_RELATIVE_RUNPATH)' + endif + + endif + + # Add COM/XPCOM stuff + TEMPLATE_VBoxQtGuiExe_LIBS += \ + $(PATH_STAGE_LIB)/VBoxCOM$(if-expr defined(VBOX_WITH_DEBUG_VCC_CRT) && $(KBUILD_TARGET) == win,-GUI,)$(VBOX_SUFF_LIB) + ifdef VBOX_WITH_XPCOM + ## @todo may be worth creating the VBOX_XPCOM SDK def, or just a SDK_VBOXXPCOM. + TEMPLATE_VBoxQtGuiExe_DEFS += VBOX_WITH_XPCOM + ifdef VBOX_WITH_XPCOM_NAMESPACE_CLEANUP + TEMPLATE_VBoxQtGuiExe_DEFS += VBOX_WITH_XPCOM_NAMESPACE_CLEANUP + endif + TEMPLATE_VBoxQtGuiExe_INCS += \ + $(VBOX_XPCOM_INCS) + TEMPLATE_VBoxQtGuiExe_LIBS += \ + $(LIB_XPCOM) + TEMPLATE_VBoxQtGuiExe_INTERMEDIATES += \ + $(VBOX_PATH_SDK)/bindings/xpcom/include/VirtualBox_XPCOM.h + else # COM + TEMPLATE_VBoxQtGuiExe_INCS += \ + $(VBOX_PATH_SDK)/bindings/mscom/include + TEMPLATE_VBoxQtGuiExe_INTERMEDIATES += \ + $(VBOX_PATH_SDK)/bindings/mscom/include/VirtualBox.h + endif # COM + + ifn1of ($(KBUILD_TARGET), darwin os2 win) + TEMPLATE_VBoxQtGuiExe_DEFS += PIC + TEMPLATE_VBoxQtGuiExe_CFLAGS += -fPIC + TEMPLATE_VBoxQtGuiExe_CXXFLAGS += -fPIC + # Needed for GCC 9. Even system's Qt 5.12.4 (on Ubuntu 19.10) did not have this fixed yet. + TEMPLATE_VBoxQtGuiExe_CXXFLAGS.linux = $(VBOX_GCC_Wno-deprecated-copy) $(TEMPLATE_VBoxQtGuiExe_CXXFLAGS) + TEMPLATE_VBoxQtGuiExe_LDFLAGS += -fPIC + endif # not darwin, os2 or win + + ifeq ($(KBUILD_TARGET),darwin) + ifndef VBOX_WITH_QT6 + TEMPLATE_VBoxQtGuiExe_POST_CMDS = $(QUIET)install_name_tool $(foreach qtmod, $(VBOX_QT_MOD_NAMES), \ + $(foreach prefix, @executable_path/../Frameworks/ $(VBOX_PATH_QT)/Frameworks/ $(PATH_SDK_QT5)/, \ + -change "$(prefix)$(qtmod).framework/Versions/5/$(qtmod)" \ + "$(if $(VBOX_WITH_HARDENING),/Applications/VirtualBox.app/Contents/Frameworks,@rpath)/$(qtmod).framework/Versions/5/$(qtmod)" ) ) "$(out)" + else + TEMPLATE_VBoxQtGuiExe_POST_CMDS = $(QUIET)install_name_tool $(foreach qtmod, $(VBOX_QT_MOD_NAMES), \ + $(foreach prefix, @executable_path/../Frameworks/ $(VBOX_PATH_QT)/Frameworks/ $(PATH_SDK_QT6)/, \ + -change "$(prefix)$(qtmod).framework/Versions/A/$(qtmod)" \ + "$(if $(VBOX_WITH_HARDENING),/Applications/VirtualBox.app/Contents/Frameworks,@rpath)/$(qtmod).framework/Versions/A/$(qtmod)" ) ) "$(out)" + endif + endif + + # + # Template for building Qt GUI components. + # + TEMPLATE_VBoxQtGuiDll = VBox Qt GUI Components + TEMPLATE_VBoxQtGuiDll_EXTENDS = VBoxQtGuiExe + TEMPLATE_VBoxQtGuiDll_LIBS = $(filter-out $(QTMAIN),$(TEMPLATE_VBoxQtGuiExe_LIBS)) + ifeq ($(KBUILD_TARGET),darwin) + TEMPLATE_VBoxQtGuiDll_LDFLAGS.darwin += $(filter-out -bind_at_load,$(TEMPLATE_VBoxQtGuiExe_LDFLAGS.darwin)) \ + -current_version $(VBOX_VERSION_MAJOR).$(VBOX_VERSION_MINOR).$(VBOX_VERSION_BUILD) \ + -compatibility_version $(VBOX_VERSION_MAJOR).$(VBOX_VERSION_MINOR).$(VBOX_VERSION_BUILD) + endif + ifn1of ($(KBUILD_TARGET), darwin os2 win) + TEMPLATE_VBoxQtGuiDll_DEFS = PIC $(TEMPLATE_VBoxQtGuiExe_DEFS) + TEMPLATE_VBoxQtGuiDll_CFLAGS = -fPIC $(TEMPLATE_VBoxQtGuiExe_CFLAGS) + TEMPLATE_VBoxQtGuiDll_CXXFLAGS = -fPIC $(TEMPLATE_VBoxQtGuiExe_CXXFLAGS) + TEMPLATE_VBoxQtGuiDll_PCHFLAGS = $(TEMPLATE_VBoxQtGuiDll_CXXFLAGS) + TEMPLATE_VBoxQtGuiDll_LDFLAGS = -fPIC $(TEMPLATE_VBoxQtGuiExe_LDFLAGS) + endif +endif # VBOX_WITH_QTGUI + +ifdef VBOX_WITH_NLS + # + # Template for translation compilation. + # Made as simple program without installing itself. + # To archive it, the dummy code without runtime is used, + # i.e. only compiler and system standard libs are linked. + # + TEMPLATE_VBoxNLS = VBox NLS template for installing translation files + TEMPLATE_VBoxNLS_EXTENDS = VBoxR3Static + ifndef VBOX_WITH_QT6 + TEMPLATE_VBoxNLS_USES := qt5 + TEMPLATE_VBoxNLS_QTTOOL := QT5 + else + TEMPLATE_VBoxNLS_USES := qt6 + TEMPLATE_VBoxNLS_QTTOOL := QT6 + endif + TEMPLATE_VBoxNLS_QT_INFIX = $(VBOX_QT_INFIX) + TEMPLATE_VBoxNLS_INSTTYPE = none + TEMPLATE_VBoxNLS_LRCFLAGS += -silent + TEMPLATE_VBoxNLS_QT_TRANSLATIONS_INST = $(INST_BIN)nls/ + TEMPLATE_VBoxNLS_SOURCES = \ + $(PATH_ROOT)/src/VBox/Main/nls/dummy.c + TEMPLATE_VBoxNLS_SDKS.$(KBUILD_TARGET_ARCH) = $(filter-out VBoxOpenSslStatic,$(TEMPLATE_VBoxR3Static_SDKS.$(KBUILD_TARGET_ARCH))) + ifdef VBOX_WITH_NOCRT_STATIC + TEMPLATE_VBoxNLS_LIBS.$(KBUILD_TARGET_ARCH) = $(filter-out \ + $(PATH_STAGE_LIB)/VBox-libxml2-static$(VBOX_SUFF_LIB), \ + $(TEMPLATE_VBoxR3Static_LIBS.$(KBUILD_TARGET_ARCH))) + else + TEMPLATE_VBoxNLS_LIBS.$(KBUILD_TARGET_ARCH) = $(filter-out \ + $(VBOX_LIB_RUNTIME_STATIC) \ + $(PATH_STAGE_LIB)/VBox-libxml2-static$(VBOX_SUFF_LIB), \ + $(TEMPLATE_VBoxR3Static_LIBS.$(KBUILD_TARGET_ARCH))) + endif +endif # !VBOX_WITH_NLS + + +# +# Template for installing symbol files that we wish to ship. +# +TEMPLATE_VBoxDbgSyms = Symbol files for VBoxDbg and gurus. +TEMPLATE_VBoxDbgSyms_INST = $(INST_VBOXDBG_SYMS) + + +# +# Template for building build bldprogs. +# HACK ALERT! The BLD_TRG_* is a hack to allow building libraries as well. +# +TEMPLATE_VBoxBldProg = VBox Build Program +TEMPLATE_VBoxBldProg_BLD_TRG := $(KBUILD_HOST) +TEMPLATE_VBoxBldProg_BLD_TRG_ARCH := $(KBUILD_HOST_ARCH) +TEMPLATE_VBoxBldProg_BLD_TRG_CPU := $(KBUILD_HOST_CPU) +TEMPLATE_VBoxBldProg_DEFS := IN_RING3 LOG_DISABLED IN_BLD_PROG +TEMPLATE_VBoxBldProg_DEFS.win := _CRT_SECURE_NO_DEPRECATE +ifeq ($(KBUILD_TARGET),$(KBUILD_HOST)) + TEMPLATE_VBoxBldProg_ASTOOL := $(VBOX_ASTOOL) + TEMPLATE_VBoxBldProg_ASFLAGS.x86 := $(VBOX_ASFLAGS32) + TEMPLATE_VBoxBldProg_ASFLAGS.arm32 := $(VBOX_ASFLAGS32) + TEMPLATE_VBoxBldProg_ASFLAGS.sparc32 := $(VBOX_ASFLAGS32) + TEMPLATE_VBoxBldProg_ASFLAGS.amd64 := $(VBOX_ASFLAGS64) + TEMPLATE_VBoxBldProg_ASFLAGS.arm64 := $(VBOX_ASFLAGS64) + TEMPLATE_VBoxBldProg_ASFLAGS.sparc64 := $(VBOX_ASFLAGS64) +else if1of ($(KBUILD_TARGET_ARCH), amd64 x86) + TEMPLATE_VBoxBldProg_ASTOOL := YASM + TEMPLATE_VBoxBldProg_ASFLAGS := -D__YASM__ -Worphan-labels $(VBOX_YASM_Wno-segreg-in-64bit) + if1of ($(KBUILD_HOST), win) + TEMPLATE_VBoxBldProg_ASFLAGS += -g cv8 -DASM_FORMAT_ELF + TEMPLATE_VBoxBldProg_ASFLAGS.x86 := -f win32 + TEMPLATE_VBoxBldProg_ASFLAGS.amd64 := -f win64 + else if1of ($(KBUILD_HOST), darwin) + TEMPLATE_VBoxBldProg_ASFLAGS += -DASM_FORMAT_MACHO + TEMPLATE_VBoxBldProg_ASFLAGS.x86 := -f macho32 + TEMPLATE_VBoxBldProg_ASFLAGS.amd64 := -f macho64 + else + TEMPLATE_VBoxBldProg_ASFLAGS += -g dwarf2 -DASM_FORMAT_ELF + TEMPLATE_VBoxBldProg_ASFLAGS.x86 := -f elf32 + TEMPLATE_VBoxBldProg_ASFLAGS.amd64 := -f elf64 + endif +endif +ifeq ($(KBUILD_HOST),win) + TEMPLATE_VBoxBldProg_TOOL := $(VBOX_VCC_TOOL_STEM)$(toupper $(KBUILD_HOST_ARCH)) + if "$(VBOX_VCC_TOOL_STEM)" >= "VCC140" + TEMPLATE_VBoxBldProg_SDKS := ReorderCompilerIncs WINSDK10-UCRT-STATIC $(VBOX_WINPSDK) + else + TEMPLATE_VBoxBldProg_SDKS := ReorderCompilerIncs $(VBOX_WINPSDK) + endif + TEMPLATE_VBoxBldProg_CXXFLAGS := -Zi -Zl -GR- -EHsc -GF -Zc:wchar_t- $(VBOX_VCC_OPT) $(VBOX_VCC_FP) \ + -MT$(VBOX_VCC_CRT_TYPE) -Gy $(VBOX_VCC_CC_GUARD_CF) $(VBOX_VCC_std) $(VBOX_VCC_WARN_ALL) $(VBOX_VCC_WERR) + if "$(VBOX_VCC_TOOL_STEM)" >= "VCC120" + TEMPLATE_VBoxBldProg_CXXFLAGS += -Gw + endif + if "$(VBOX_VCC_TOOL_STEM)" >= "VCC142" # Don't waste space on x86/amd64-on-arm emulation optimizations. + TEMPLATE_VBoxBldProg_CXXFLAGS += /volatileMetadata- + endif + ifdef VBOX_WITH_MSC_ANALYZE_THIS + TEMPLATE_VBoxBldProg_CXXFLAGS += /analyze + endif + TEMPLATE_VBoxBldProg_CXXFLAGS.debug := -RTCsu + TEMPLATE_VBoxBldProg_CXXFLAGS.dbgopt = $(NO_SUCH_VARIABLE) + TEMPLATE_VBoxBldProg_CXXFLAGS.profile = $(TEMPLATE_VBoxBldProg_CXXFLAGS.release) + TEMPLATE_VBoxBldProg_CXXFLAGS.kprofile = $(TEMPLATE_VBoxBldProg_CXXFLAGS.release) + TEMPLATE_VBoxBldProg_CFLAGS = $(filter-out $(VBOX_VCC_std),$(TEMPLATE_VBoxBldProg_CXXFLAGS)) + TEMPLATE_VBoxBldProg_CFLAGS.debug = $(TEMPLATE_VBoxBldProg_CXXFLAGS.debug) + TEMPLATE_VBoxBldProg_CFLAGS.dbgopt = $(TEMPLATE_VBoxBldProg_CXXFLAGS.dbgopt) + TEMPLATE_VBoxBldProg_CFLAGS.release = $(TEMPLATE_VBoxBldProg_CXXFLAGS.release) + TEMPLATE_VBoxBldProg_CFLAGS.profile = $(TEMPLATE_VBoxBldProg_CXXFLAGS.profile) + TEMPLATE_VBoxBldProg_CFLAGS.kprofile = $(TEMPLATE_VBoxBldProg_CXXFLAGS.kprofile) + TEMPLATE_VBoxBldProg_PCHFLAGS = $(TEMPLATE_VBoxBldProg_CXXFLAGS) + TEMPLATE_VBoxBldProg_PCHFLAGS.debug = $(TEMPLATE_VBoxBldProg_CXXFLAGS.debug) + TEMPLATE_VBoxBldProg_PCHFLAGS.dbgopt = $(TEMPLATE_VBoxBldProg_CXXFLAGS.dbgopt) + TEMPLATE_VBoxBldProg_PCHFLAGS.release = $(TEMPLATE_VBoxBldProg_CXXFLAGS.release) + TEMPLATE_VBoxBldProg_PCHFLAGS.profile = $(TEMPLATE_VBoxBldProg_CXXFLAGS.profile) + TEMPLATE_VBoxBldProg_PCHFLAGS.kprofile = $(TEMPLATE_VBoxBldProg_CXXFLAGS.kprofile) + TEMPLATE_VBoxBldProg_LDFLAGS = -Ignore:4197 \ + /NOD /INCREMENTAL:NO /MAPINFO:EXPORTS /LargeAddressAware /DynamicBase /NxCompat /Release /Debug /Opt:Ref /Opt:Icf \ + $(VBOX_VCC_LD_GUARD_CF) \ + /Version:$(VBOX_VERSION_MAJOR)0$(VBOX_VERSION_MINOR).$(VBOX_VERSION_BUILD) \ + /DISALLOWLIB:libc$(VBOX_VCC_CRT_TYPE_N).lib \ + /DISALLOWLIB:libcmt$(VBOX_VCC_CRT_TYPE_N).lib \ + /DISALLOWLIB:msvcrt.lib \ + /DISALLOWLIB:msvcrtd.lib \ + /DISALLOWLIB:msvcprt.lib \ + /DISALLOWLIB:msvcprtd.lib \ + /DISALLOWLIB:libvcruntime$(VBOX_VCC_CRT_TYPE_N).lib \ + /DISALLOWLIB:libucrt$(VBOX_VCC_CRT_TYPE_N).lib \ + /DISALLOWLIB:vcruntime.lib \ + /DISALLOWLIB:vcruntimed.lib \ + /DISALLOWLIB:ucrt.lib \ + /DISALLOWLIB:ucrtd.lib + TEMPLATE_VBoxBldProg_LDFLAGS.win.amd64 = $(VBOX_VCC_LD_HIGH_ENTRYOPY_VA) + if "$(VBOX_VCC_TOOL_STEM)" >= "VCC142" # Don't waste space on x86/amd64-on-arm emulation optimizations. + TEMPLATE_VBoxBldProg_LDFLAGS += -EmitVolatileMetadata:NO + endif + if "$(VBOX_VCC_TOOL_STEM)" >= "VCC140" + TEMPLATE_VBoxBldProg_LIBS = \ + $(PATH_TOOL_$(TEMPLATE_VBoxBldProg_TOOL)_LIB)/libvcruntime$(VBOX_VCC_CRT_TYPE).lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxBldProg_TOOL)_LIB)/libcmt$(VBOX_VCC_CRT_TYPE).lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxBldProg_TOOL)_LIB)/libcpmt$(VBOX_VCC_CRT_TYPE).lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxBldProg_TOOL)_LIB)/oldnames.lib + else + TEMPLATE_VBoxBldProg_LIBS = \ + $(PATH_TOOL_$(TEMPLATE_VBoxBldProg_TOOL)_LIB)/oldnames.lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxBldProg_TOOL)_LIB)/libcmt$(VBOX_VCC_CRT_TYPE).lib \ + $(PATH_TOOL_$(TEMPLATE_VBoxBldProg_TOOL)_LIB)/libcpmt$(VBOX_VCC_CRT_TYPE).lib + endif + +else + # (gcc of some kind ) + TEMPLATE_VBoxBldProg_TOOL = GXX3 + if $(VBOX_GCC_VERSION_CC) < 30400 + TEMPLATE_VBoxBldProg_DEFS += RT_WITHOUT_PRAGMA_ONCE + endif + TEMPLATE_VBoxBldProg_CFLAGS = -g $(VBOX_GCC_pipe) $(VBOX_GCC_PEDANTIC_C) $(VBOX_GCC_Wno-variadic-macros) + ifdef VBOX_WITH_NO_GCC_WARNING_POLICY + TEMPLATE_VBoxBldProg_CFLAGS += $(VBOX_GCC_WERR) + endif + TEMPLATE_VBoxBldProg_CFLAGS.x86 = -m32 + TEMPLATE_VBoxBldProg_CFLAGS.sparc32 = -m32 + TEMPLATE_VBoxBldProg_CFLAGS.amd64 = -m64 + TEMPLATE_VBoxBldProg_CFLAGS.sparc64 = -m64 + TEMPLATE_VBoxBldProg_CFLAGS.release = -O2 -fno-omit-frame-pointer -fno-strict-aliasing + TEMPLATE_VBoxBldProg_CFLAGS.profile = $(TEMPLATE_VBoxBldProg_CXXFLAGS.profile) + TEMPLATE_VBoxBldProg_CFLAGS.kprofile = $(TEMPLATE_VBoxBldProg_CXXFLAGS.kprofile) + TEMPLATE_VBoxBldProg_CXXFLAGS = -g $(VBOX_GCC_pipe) $(VBOX_GCC_PEDANTIC_CXX) $(VBOX_GCC_Wno-variadic-macros) $(VBOX_GCC_std) + ifdef VBOX_WITH_NO_GCC_WARNING_POLICY + TEMPLATE_VBoxBldProg_CXXFLAGS += $(VBOX_GCC_WERR) + endif + TEMPLATE_VBoxBldProg_CXXFLAGS.x86 = -m32 + TEMPLATE_VBoxBldProg_CXXFLAGS.sparc32 = -m32 + TEMPLATE_VBoxBldProg_CXXFLAGS.amd64 = -m64 + TEMPLATE_VBoxBldProg_CXXFLAGS.sparc64 = -m64 + TEMPLATE_VBoxBldProg_CXXFLAGS.release = -O2 -fno-omit-frame-pointer -fno-strict-aliasing + TEMPLATE_VBoxBldProg_CXXFLAGS.profile = $(TEMPLATE_VBoxBldProg_CXXFLAGS.release) + TEMPLATE_VBoxBldProg_CXXFLAGS.kprofile = $(TEMPLATE_VBoxBldProg_CXXFLAGS.release) + TEMPLATE_VBoxBldProg_OBJCFLAGS = $(TEMPLATE_VBoxBldProg_CFLAGS) + TEMPLATE_VBoxBldProg_OBJCFLAGS.x86 = $(TEMPLATE_VBoxBldProg_CFLAGS.x86) + TEMPLATE_VBoxBldProg_OBJCFLAGS.amd64 = $(TEMPLATE_VBoxBldProg_CFLAGS.amd64) + TEMPLATE_VBoxBldProg_OBJCFLAGS.release = $(TEMPLATE_VBoxBldProg_CFLAGS.release) + TEMPLATE_VBoxBldProg_OBJCFLAGS.profile = $(TEMPLATE_VBoxBldProg_CFLAGS.profile) + TEMPLATE_VBoxBldProg_OBJCFLAGS.kprofile = $(TEMPLATE_VBoxBldProg_CFLAGS.kprofile) + TEMPLATE_VBoxBldProg_OBJCXXFLAGS = $(TEMPLATE_VBoxBldProg_CXXFLAGS) + TEMPLATE_VBoxBldProg_OBJCXXFLAGS.x86 = $(TEMPLATE_VBoxBldProg_CXXFLAGS.x86) + TEMPLATE_VBoxBldProg_OBJCXXFLAGS.amd64 = $(TEMPLATE_VBoxBldProg_CXXFLAGS.amd64) + TEMPLATE_VBoxBldProg_OBJCXXFLAGS.release = $(TEMPLATE_VBoxBldProg_CXXFLAGS.release) + TEMPLATE_VBoxBldProg_OBJCXXFLAGS.profile = $(TEMPLATE_VBoxBldProg_CXXFLAGS.profile) + TEMPLATE_VBoxBldProg_OBJCXXFLAGS.kprofile = $(TEMPLATE_VBoxBldProg_CXXFLAGS.kprofile) + TEMPLATE_VBoxBldProg_PCHFLAGS = $(TEMPLATE_VBoxBldProg_CXXFLAGS) + TEMPLATE_VBoxBldProg_PCHFLAGS.x86 = $(TEMPLATE_VBoxBldProg_CXXFLAGS.x86) + TEMPLATE_VBoxBldProg_PCHFLAGS.amd64 = $(TEMPLATE_VBoxBldProg_CXXFLAGS.amd64) + TEMPLATE_VBoxBldProg_PCHFLAGS.release = $(TEMPLATE_VBoxBldProg_CXXFLAGS.release) + TEMPLATE_VBoxBldProg_PCHFLAGS.profile = $(TEMPLATE_VBoxBldProg_CXXFLAGS.profile) + TEMPLATE_VBoxBldProg_PCHFLAGS.kprofile = $(TEMPLATE_VBoxBldProg_CXXFLAGS.kprofile) + TEMPLATE_VBoxBldProg_LDFLAGS.x86 = -m32 + TEMPLATE_VBoxBldProg_LDFLAGS.sparc32 = -m32 + TEMPLATE_VBoxBldProg_LDFLAGS.amd64 = -m64 + TEMPLATE_VBoxBldProg_LDFLAGS.sparc64 = -m64 + ifeq ($(KBUILD_HOST),linux) + TEMPLATE_VBoxBldProg_LIBS = pthread m rt dl + else ifeq ($(KBUILD_HOST),os2) + TEMPLATE_VBoxBldProg_TOOL = GXX3OMF + TEMPLATE_VBoxBldProg_LIBS = socket iconv + else ifeq ($(KBUILD_HOST),darwin) + TEMPLATE_VBoxBldProg_TOOL = $(VBOX_GCC_TOOL) + if "$(VBOX_DEF_MACOSX_VERSION_MIN)" == "10.7" || "$(VBOX_DARWIN_HOST_VERSION_MAJOR)" == "7" + TEMPLATE_VBoxBldProg_DEFS.darwin = $(VBOX_DARWIN_DEF_SDK_10_7_DEFS) + TEMPLATE_VBoxBldProg_CFLAGS.darwin = $(VBOX_DARWIN_DEF_SDK_10_7_CFLAGS) -fno-common + TEMPLATE_VBoxBldProg_CXXFLAGS.darwin = $(VBOX_DARWIN_DEF_SDK_10_7_CXXFLAGS) + TEMPLATE_VBoxBldProg_PCHFLAGS.darwin = $(VBOX_DARWIN_DEF_SDK_10_7_CXXFLAGS) + TEMPLATE_VBoxBldProg_OBJCFLAGS.darwin = $(VBOX_DARWIN_DEF_SDK_10_7_OBJCFLAGS) $(VBOX_GCC_PEDANTIC_C) + TEMPLATE_VBoxBldProg_OBJCXXFLAGS.darwin = $(VBOX_DARWIN_DEF_SDK_10_7_OBJCXXFLAGS) $(VBOX_GCC_PEDANTIC_CXX) + TEMPLATE_VBoxBldProg_LDFLAGS.darwin = $(VBOX_DARWIN_DEF_SDK_10_7_LDFLAGS) + else if "$(VBOX_DEF_MACOSX_VERSION_MIN)" == "10.6" || "$(VBOX_DARWIN_HOST_VERSION_MAJOR)" == "6" + TEMPLATE_VBoxBldProg_DEFS.darwin = $(VBOX_DARWIN_DEF_SDK_10_6_DEFS) + TEMPLATE_VBoxBldProg_CFLAGS.darwin = $(VBOX_DARWIN_DEF_SDK_10_6_CFLAGS) -fno-common + TEMPLATE_VBoxBldProg_CXXFLAGS.darwin = $(VBOX_DARWIN_DEF_SDK_10_6_CXXFLAGS) + TEMPLATE_VBoxBldProg_PCHFLAGS.darwin = $(VBOX_DARWIN_DEF_SDK_10_6_CXXFLAGS) + TEMPLATE_VBoxBldProg_OBJCFLAGS.darwin = $(VBOX_DARWIN_DEF_SDK_10_6_OBJCFLAGS) $(VBOX_GCC_PEDANTIC_C) + TEMPLATE_VBoxBldProg_OBJCXXFLAGS.darwin = $(VBOX_DARWIN_DEF_SDK_10_6_OBJCXXFLAGS) $(VBOX_GCC_PEDANTIC_CXX) + TEMPLATE_VBoxBldProg_LDFLAGS.darwin = $(VBOX_DARWIN_DEF_SDK_10_6_LDFLAGS) + else if "$(VBOX_DEF_MACOSX_VERSION_MIN)" == "10.5" || "$(VBOX_DARWIN_HOST_VERSION_MAJOR)" == "5" || defined(VBOX_MACOS_10_5_WORKAROUND) + TEMPLATE_VBoxBldProg_DEFS.darwin = $(VBOX_DARWIN_DEF_SDK_10_5_DEFS) + TEMPLATE_VBoxBldProg_CFLAGS.darwin = $(VBOX_DARWIN_DEF_SDK_10_5_CFLAGS) -fno-common + TEMPLATE_VBoxBldProg_CXXFLAGS.darwin = $(VBOX_DARWIN_DEF_SDK_10_5_CXXFLAGS) + TEMPLATE_VBoxBldProg_PCHFLAGS.darwin = $(VBOX_DARWIN_DEF_SDK_10_5_CXXFLAGS) + TEMPLATE_VBoxBldProg_OBJCFLAGS.darwin = $(VBOX_DARWIN_DEF_SDK_10_5_OBJCFLAGS) $(VBOX_GCC_PEDANTIC_C) + TEMPLATE_VBoxBldProg_OBJCXXFLAGS.darwin = $(VBOX_DARWIN_DEF_SDK_10_5_OBJCXXFLAGS) $(VBOX_GCC_PEDANTIC_CXX) + TEMPLATE_VBoxBldProg_LDFLAGS.darwin = $(VBOX_DARWIN_DEF_SDK_10_5_LDFLAGS) + else + TEMPLATE_VBoxBldProg_SDKS.darwin = $(VBOX_DARWIN_DEF_SDK_SDKS) + TEMPLATE_VBoxBldProg_DEFS.darwin = $(VBOX_DARWIN_DEF_SDK_DEFS) + TEMPLATE_VBoxBldProg_CFLAGS.darwin = $(VBOX_DARWIN_DEF_SDK_CFLAGS) -fno-common + TEMPLATE_VBoxBldProg_CXXFLAGS.darwin = $(VBOX_DARWIN_DEF_SDK_CXXFLAGS) + TEMPLATE_VBoxBldProg_PCHFLAGS.darwin = $(VBOX_DARWIN_DEF_SDK_CXXFLAGS) + TEMPLATE_VBoxBldProg_OBJCFLAGS.darwin = $(VBOX_DARWIN_DEF_SDK_OBJCFLAGS) $(VBOX_GCC_PEDANTIC_C) + TEMPLATE_VBoxBldProg_OBJCXXFLAGS.darwin = $(VBOX_DARWIN_DEF_SDK_OBJCXXFLAGS) $(VBOX_GCC_PEDANTIC_CXX) + TEMPLATE_VBoxBldProg_LDFLAGS.darwin = $(VBOX_DARWIN_DEF_SDK_LDFLAGS) + endif + TEMPLATE_VBoxBldProg_LIBS = + else ifeq ($(KBUILD_HOST),haiku) + TEMPLATE_VBoxBldProg_TOOL = GXX3 + TEMPLATE_VBoxBldProg_LIBS = network iconv + TEMPLATE_VBoxBldProg_LIBPATH += \ + /boot/common/lib + else if1of ($(KBUILD_HOST), freebsd openbsd) + TEMPLATE_VBoxBldProg_TOOL = $(VBOX_GCC_TOOL) + TEMPLATE_VBoxBldProg_LIBS = pthread + TEMPLATE_VBoxBldProg_INCS += \ + /usr/include \ + /usr/X11R6/include \ + /usr/local/include + TEMPLATE_VBoxBldProg_LIBPATH += \ + /usr/lib \ + /usr/X11R6/lib \ + /usr/local/lib + else ifeq ($(KBUILD_HOST),netbsd) + TEMPLATE_VBoxBldProg_TOOL = GXX3 + TEMPLATE_VBoxBldProg_LIBS = pthread + TEMPLATE_VBoxBldProg_INCS += \ + /usr/include \ + /usr/X11R7/include + TEMPLATE_VBoxBldProg_LIBPATH += \ + /usr/lib \ + /usr/X11R7/lib + else ifeq ($(KBUILD_HOST),solaris) + TEMPLATE_VBoxBldProg_TOOL = GXX3PLAIN + TEMPLATE_VBoxBldProg_LIBS = rt + else + $(warning Warning: VBOX Build: Target $(KBUILD_HOST) is not officially supported!) + endif + +endif # !win + + +# +# Advanced build programs using IPRT and stuff. +# +TEMPLATE_VBoxAdvBldProg = Advanced VBox Build Program +TEMPLATE_VBoxAdvBldProg_EXTENDS = VBoxBldProg +TEMPLATE_VBoxAdvBldProg_SDKS = $(TEMPLATE_VBoxBldProg_SDKS) +TEMPLATE_VBoxAdvBldProg_SDKS.win = $(TEMPLATE_VBoxBldProg_SDKS.win) VBoxNtDll +TEMPLATE_VBoxAdvBldProg_DEFS = $(TEMPLATE_VBoxBldProg_DEFS) IN_RT_R3 IN_ADV_BLD_PROG +ifeq ($(KBUILD_HOST),win) + TEMPLATE_VBoxAdvBldProg_CFLAGS = $(TEMPLATE_VBoxBldProg_CFLAGS) $(VBOX_VCC_WERR) + TEMPLATE_VBoxAdvBldProg_CXXFLAGS = $(TEMPLATE_VBoxBldProg_CXXFLAGS) $(VBOX_VCC_WERR) + TEMPLATE_VBoxAdvBldProg_PCHFLAGS = $(TEMPLATE_VBoxAdvBldProg_CXXFLAGS) +endif +TEMPLATE_VBoxAdvBldProg_LDFLAGS.darwin.arm64 = \ + $(TEMPLATE_VBoxBldProg_LDFLAGS.darwin.arm64) -framework IOKit +TEMPLATE_VBoxAdvBldProg_LIBS = \ + $(PATH_STAGE_LIB)/RuntimeBldProg$(VBOX_HOSTSUFF_LIB) \ + $(TEMPLATE_VBoxBldProg_LIBS) +TEMPLATE_VBoxAdvBldProg_LIBS.darwin = \ + $(TEMPLATE_VBoxAdvBldProg_LIBS) \ + iconv \ + $(TEMPLATE_VBoxBldProg_LIBS.darwin) +TEMPLATE_VBoxAdvBldProg_LIBS.freebsd = \ + $(TEMPLATE_VBoxAdvBldProg_LIBS) \ + iconv \ + rt \ + $(TEMPLATE_VBoxBldProg_LIBS.freebsd) +TEMPLATE_VBoxAdvBldProg_LIBS.linux = \ + $(TEMPLATE_VBoxAdvBldProg_LIBS) \ + $(TEMPLATE_VBoxBldProg_LIBS.linux) +TEMPLATE_VBoxAdvBldProg_LIBS.solaris = \ + $(TEMPLATE_VBoxAdvBldProg_LIBS) \ + contract \ + kstat \ + rt \ + socket \ + nsl \ + $(TEMPLATE_VBoxBldProg_LIBS.solaris) + + +# +# Windows rc workaround for crosscompiling. +# (Some (old) Wine versions fails loading msvcrt.dll from the VCC bin directory.) +# +ifneq ($(KBUILD_HOST),win) + TOOL_VCC80X86_RC := $(EXEC_X86_WIN32) $(KBUILD_DEVTOOLS)/win.x86/bin/rc.exe + TOOL_VCC80AMD64_RC := $(EXEC_X86_WIN32) $(KBUILD_DEVTOOLS)/win.x86/bin/rc.exe + TOOL_VCC70_RC := $(EXEC_X86_WIN32) $(KBUILD_DEVTOOLS)/win.x86/bin/rc.exe + WIN32_MC = $(EXEC_X86_WIN32) $(KBUILD_DEVTOOLS)/win.x86/bin/mc.exe +else + WIN32_MC = $(EXEC_X86_WIN32) $(firstword $(wildcard \ + $(PATH_SDK_$(VBOX_WINPSDK)_BIN)/MC.Exe \ + $(PATH_SDK_WINPSDK_BIN)/MC.Exe \ + $(PATH_SDK_WINPSDK)/Bin/MC.Exe \ + $(PATH_SDK_WIN32SDK_BIN)/MC.Exe \ + $(PATH_SDK_WIN64SDK_BIN)/MC.Exe \ + $(KBUILD_DEVTOOLS)/win.x86/bin/mc.exe \ + ) Sorry_Cannot_find_mc_in_the_PSDK) +endif + + +# +# Base template for building R3 programs for the guest additions. +# Do _note_ use directly! +# +## @todo bake it into VBoxGuestR3Exe. +TEMPLATE_VBoxGuestR3ExeBase = VBox Guest Program +ifeq ($(KBUILD_TARGET),win) + TEMPLATE_VBoxGuestR3ExeBase_EXTENDS = VBoxR3StaticBase + if "$(VBOX_VCC_TOOL_STEM)" >= "VCC140" + ifdef VBOX_WITH_NOCRT_STATIC + TEMPLATE_VBoxGuestR3ExeBase_SDKS = ReorderCompilerIncs $(VBOX_WINPSDK_GST) VBoxNtDll + else + TEMPLATE_VBoxGuestR3ExeBase_SDKS = ReorderCompilerIncs WINSDK10-UCRT-STATIC $(VBOX_WINPSDK_GST) VBoxNtDll + endif + else + TEMPLATE_VBoxGuestR3ExeBase_SDKS = ReorderCompilerIncs $(VBOX_WINPSDK_GST) VBoxNtDll + endif + # Hack for running on NT3x, NT4, W2K and XP w/o SP: + # 1. Change OS and subsystem version in the image. + # 2. NT 3.1 requires the IAT to be writable. To avoid making all of .rdata + # writable we use the undocumented -NoOptIData option to prevent .idata$* + # from being merged into .rdata. + # 3. NT 3.1 doesn't support merging initialized and uninitialized section + # because it doesn't recognize Misc.VirtualSize. So, we set the uncached + # flag (!K) on the .bss section make it incompatible with .data. + # VBOX_PE_SET_VERSION will clear the !K flag. (Not needed in no-CRT mode, + # as the init code zeros uninitialized data there when running on NT 3.1.) + # Similarly, for XP64 and 64-bit W2K3 we need to make sure the subsystem version + # in the binaries are set to 5.2. The Visual C++ 2019 linker defaults to 6.0. + # HACK ALERT! Double expansion of $$(NLTAB). + TEMPLATE_VBoxGuestR3ExeBase_USES.win = $(TEMPLATE_VBoxR3StaticBase_USES.win) vboximportchecker + TEMPLATE_VBoxGuestR3ExeBase_VBOX_IMPORT_CHECKER.win.x86 = nt31 + TEMPLATE_VBoxGuestR3ExeBase_VBOX_IMPORT_CHECKER.win.amd64 = xp64 + TEMPLATE_VBoxGuestR3ExeBase_POST_CMDS.win.x86 = $(if $(eq $(tool_do),LINK_LIBRARY),,$(VBOX_PE_SET_VERSION) $(out)$$(NLTAB)$(TEMPLATE_$(TEMPLATE_VBoxGuestR3ExeBase_EXTENDS)_POST_CMDS)) + TEMPLATE_VBoxGuestR3ExeBase_LNK_DEPS.win.x86 = $(if $(eq $(tool_do),LINK_LIBRARY),,$(VBOX_PE_SET_VERSION)) + TEMPLATE_VBoxGuestR3ExeBase_POST_CMDS.win.amd64 = $(if $(eq $(tool_do),LINK_LIBRARY),,$(VBOX_PE_SET_VERSION) $(out)$$(NLTAB)$(TEMPLATE_$(TEMPLATE_VBoxGuestR3ExeBase_EXTENDS)_POST_CMDS)) + TEMPLATE_VBoxGuestR3ExeBase_LNK_DEPS.win.amd64 = $(if $(eq $(tool_do),LINK_LIBRARY),,$(VBOX_PE_SET_VERSION)) + ifdef VBOX_WITH_NOCRT_STATIC + TEMPLATE_VBoxGuestR3ExeBase_LDFLAGS.win.x86 = $(TEMPLATE_$(TEMPLATE_VBoxGuestR3ExeBase_EXTENDS)_LDFLAGS.win.x86) -NoOptIData + else + TEMPLATE_VBoxGuestR3ExeBase_LDFLAGS.win.x86 = -NoOptIData -Section:.bss,RW!K $(TEMPLATE_$(TEMPLATE_VBoxGuestR3ExeBase_EXTENDS)_LDFLAGS.win.x86) + endif + + if defined(VBOX_WITH_MORE_NT4_COMPAT_BINARIES) && "$(KBUILD_TARGET).$(KBUILD_TARGET_ARCH)" == "win.x86" + TEMPLATE_VBoxGuestR3ExeBase_LIBS.win.x86 = $(NO_SUCH_VARIABLE)# Ditch RuntimeR3VccTricks2 + endif + +else # the gcc guys + TEMPLATE_VBoxGuestR3ExeBase_EXTENDS = VBoxR3Exe + ifn1of ($(KBUILD_TARGET), darwin) + TEMPLATE_VBoxGuestR3ExeBase_TOOL := $(subst GXX,GCC,$(TEMPLATE_$(TEMPLATE_VBoxGuestR3ExeBase_EXTENDS)_TOOL)) + endif + TEMPLATE_VBoxGuestR3ExeBase_CXXFLAGS = $(TEMPLATE_$(TEMPLATE_VBoxGuestR3ExeBase_EXTENDS)_CXXFLAGS) -fno-exceptions -fno-rtti + # Do not inherit sanitizer flags from VBoxR3Exe in guest executables. Deal with them separately. + TEMPLATE_VBoxGuestR3ExeBase_CXXFLAGS.debug = $(NO_SUCH_VARIABLE) + TEMPLATE_VBoxGuestR3ExeBase_CFLAGS.debug = $(NO_SUCH_VARIABLE) + TEMPLATE_VBoxGuestR3ExeBase_LDFLAGS.linux = $(filter-out $(VBOX_GCC_ORIGIN_OPT),$(TEMPLATE_$(TEMPLATE_VBoxGuestR3ExeBase_EXTENDS)_LDFLAGS.linux)) + TEMPLATE_VBoxGuestR3ExeBase_LDFLAGS.debug = $(NO_SUCH_VARIABLE) + TEMPLATE_VBoxGuestR3ExeBase_LDFLAGS = $(filter-out '$(VBOX_GCC_RPATH_OPT)%,$(TEMPLATE_$(TEMPLATE_VBoxGuestR3ExeBase_EXTENDS)_LDFLAGS)) + ifn1of ($(KBUILD_TARGET), darwin os2) # ELF only. Present in gcc 3.2.3 & binutils 2.15, possibly earlier. + ifdef VBOX_LD_gc_sections # Older solaris linker versions doesn't grok --gc-sections (e.g. add build box). + TEMPLATE_VBoxGuestR3ExeBase_CXXFLAGS += -ffunction-sections -fdata-sections + TEMPLATE_VBoxGuestR3ExeBase_CFLAGS += -ffunction-sections -fdata-sections + TEMPLATE_VBoxGuestR3ExeBase_LDFLAGS += $(VBOX_LD_gc_sections) + endif + endif +endif +TEMPLATE_VBoxGuestR3ExeBase_INST = $(INST_ADDITIONS) +TEMPLATE_VBoxGuestR3ExeBase_DEFS := \ + $(filter-out $(ARCH_BITS_DEFS) VBOX_WITH_DTRACE VBOX_WITH_DTRACE_R3, $(TEMPLATE_$(TEMPLATE_VBoxGuestR3ExeBase_EXTENDS)_DEFS)) \ + IN_GUEST \ + IN_GUEST_R3 \ + IN_RT_R3 \ + IN_RT_STATIC \ + $(VBOX_GC_ARCH_BITS_DEFS) \ + RT_NEED_NEW_AND_DELETE +ifeq ($(KBUILD_TARGET),linux) # As few libs as possible on linux. + TEMPLATE_VBoxGuestR3ExeBase_LIBS = pthread rt m dl +else if1of ($(KBUILD_TARGET), darwin freebsd openbsd) + TEMPLATE_VBoxGuestR3ExeBase_LIBS = $(TEMPLATE_$(TEMPLATE_VBoxGuestR3ExeBase_EXTENDS)_LIBS) iconv +else ifeq ($(KBUILD_TARGET),solaris) + TEMPLATE_VBoxGuestR3ExeBase_LIBS = $(TEMPLATE_$(TEMPLATE_VBoxGuestR3ExeBase_EXTENDS)_LIBS) nsl +endif + +# Use older versions of APIs which were improved in versions of glibc later +# than what we are targetting, and do not use the stack protector, which +# needs glibc 2.4 or later. +TEMPLATE_VBoxGuestR3ExeBase_CXXFLAGS.linux = \ + -include $(PATH_ROOT)/include/iprt/linux/symvers.h \ + $(VBOX_GCC_fno-stack-protector) +TEMPLATE_VBoxGuestR3ExeBase_CFLAGS.linux = $(TEMPLATE_VBoxGuestR3ExeBase_CXXFLAGS.linux) +# The GNU_HASH ELF tag is not supported by older systems. +TEMPLATE_VBoxGuestR3ExeBase_LDFLAGS.linux += $(VBOX_LD_hash_style_sysv) + + +# +# Template for building normal R3 programs for the guest additions, strict. +# +TEMPLATE_VBoxGuestR3Exe = VBox Guest Program w/ IPRT and VBGL. +TEMPLATE_VBoxGuestR3Exe_EXTENDS = VBoxGuestR3ExeBase +ifeq ($(KBUILD_TARGET),win) + TEMPLATE_VBoxGuestR3Exe_CFLAGS = $(TEMPLATE_VBoxGuestR3ExeBase_CFLAGS) $(VBOX_VCC_WERR) + TEMPLATE_VBoxGuestR3Exe_CXXFLAGS = $(TEMPLATE_VBoxGuestR3ExeBase_CXXFLAGS) $(VBOX_VCC_WERR) + if1of ($(VBOX_VCC_TOOL_STEM), VCC120) + # VBoxDrvInst.cpp(520) : warning C4313: 'wprintf' : '%d' in format string conflicts with argument 1 of type 'const TCHAR *' [false positive - buggy compiler?] + TEMPLATE_VBoxGuestR3Exe_CXXFLAGS += -wd4313 + endif + TEMPLATE_VBoxGuestR3Exe_LDFLAGS = $(TEMPLATE_VBoxGuestR3ExeBase_LDFLAGS) $(VBOX_VCC_LD_WERR) + ifndef VBOX_WITH_NOCRT_STATIC # Temporary kludge to deal with some link order issues. + TEMPLATE_VBoxGuestR3Exe_LDFLAGS.win.x86 = $(TEMPLATE_VBoxGuestR3ExeBase_LDFLAGS.win.x86) -Include:_vcc100_kernel32_fakes_asm + endif + TEMPLATE_VBoxGuestR3Exe_LIBS.x86 = \ + $(VBOX_LIB_IPRT_GUEST_R3_X86) \ + $(VBOX_LIB_VBGL_R3_X86) \ + $(VBOX_LIB_IPRT_GUEST_R3_X86) \ + $(TEMPLATE_VBoxGuestR3ExeBase_LIBS.x86) + TEMPLATE_VBoxGuestR3Exe_LIBS.$(KBUILD_TARGET_ARCH) = \ + $(VBOX_LIB_IPRT_GUEST_R3) \ + $(VBOX_LIB_VBGL_R3) \ + $(VBOX_LIB_IPRT_GUEST_R3) \ + $(TEMPLATE_VBoxGuestR3ExeBase_LIBS.$(KBUILD_TARGET_ARCH)) +else + TEMPLATE_VBoxGuestR3Exe_CFLAGS = $(TEMPLATE_VBoxGuestR3ExeBase_CFLAGS) $(VBOX_GCC_WERR) + TEMPLATE_VBoxGuestR3Exe_CXXFLAGS = $(TEMPLATE_VBoxGuestR3ExeBase_CXXFLAGS) $(VBOX_GCC_WERR) + TEMPLATE_VBoxGuestR3Exe_LIBS = \ + $(VBOX_LIB_IPRT_GUEST_R3) \ + $(VBOX_LIB_VBGL_R3) \ + $(VBOX_LIB_IPRT_GUEST_R3) \ + $(TEMPLATE_VBoxGuestR3ExeBase_LIBS) + ifeq ($(KBUILD_TARGET),solaris) + TEMPLATE_VBoxGuestR3Exe_LIBS += contract + endif +endif + +# +# Template for building R3 (dynamic) libraries for the guest additions, relaxed. +# +TEMPLATE_VBoxGuestR3DllNonPedantic := VBox Guest User Dynamic Libraries w/ IPRT and VBGL, non-pedantic. +TEMPLATE_VBoxGuestR3DllNonPedantic_EXTENDS := VBoxGuestR3ExeBase +## @todo add a INSTFUN that separates dlls and libs. +ifeq ($(KBUILD_TARGET),win) + ifeq ($(KBUILD_TYPE),asan) + TEMPLATE_VBoxGuestR3DllNonPedantic_LIBS.x86 = $(patsubst %clang_rt.asan-i386.lib, %clang_rt.asan_dll_thunk-i386.lib, $(filter-out %clang_rt.asan_cxx-i386.lib,$(TEMPLATE_VBoxGuestR3ExeBase_LIBS.x86))) + TEMPLATE_VBoxGuestR3DllNonPedantic_LIBS.amd64 = $(patsubst %clang_rt.asan-x86_64.lib, %clang_rt.asan_dll_thunk-x86_64.lib, $(filter-out %clang_rt.asan_cxx-x86_64.lib,$(TEMPLATE_VBoxGuestR3ExeBase_LIBS.amd64))) + endif +else ifn1of ($(KBUILD_TARGET), darwin os2 win) + TEMPLATE_VBoxGuestR3DllNonPedantic_DEFS = $(TEMPLATE_VBoxGuestR3ExeBase_DEFS) PIC + TEMPLATE_VBoxGuestR3DllNonPedantic_CFLAGS = $(TEMPLATE_VBoxGuestR3ExeBase_CFLAGS) -fPIC + TEMPLATE_VBoxGuestR3DllNonPedantic_CXXFLAGS = $(TEMPLATE_VBoxGuestR3ExeBase_CXXFLAGS) -fPIC -fno-exceptions + TEMPLATE_VBoxGuestR3DllNonPedantic_LDFLAGS = $(TEMPLATE_VBoxGuestR3ExeBase_LDFLAGS) -fPIC +endif +TEMPLATE_VBoxGuestR3DllNonPedantic_LIBS = \ + $(VBOX_LIB_IPRT_GUEST_R3_SHARED) \ + $(VBOX_LIB_VBGL_R3_SHARED) \ + $(VBOX_LIB_IPRT_GUEST_R3_SHARED) \ + $(TEMPLATE_VBoxGuestR3ExeBase_LIBS) + +# +# Template for building normal R3 (dynamic) libraries for the guest additions, strict. +# +TEMPLATE_VBoxGuestR3Dll := VBox Guest User Dynamic Libraries w/ IPRT and VBGL. +TEMPLATE_VBoxGuestR3Dll_EXTENDS := VBoxGuestR3DllNonPedantic +ifeq ($(KBUILD_TARGET),win) + TEMPLATE_VBoxGuestR3Dll_CFLAGS = $(TEMPLATE_VBoxGuestR3DllNonPedantic_CFLAGS) $(VBOX_VCC_WERR) + TEMPLATE_VBoxGuestR3Dll_CXXFLAGS = $(TEMPLATE_VBoxGuestR3DllNonPedantic_CXXFLAGS) $(VBOX_VCC_WERR) + TEMPLATE_VBoxGuestR3Dll_LDFLAGS = $(TEMPLATE_VBoxGuestR3DllNonPedantic_LDFLAGS) $(VBOX_VCC_LD_WERR) +else + TEMPLATE_VBoxGuestR3Dll_CFLAGS = $(TEMPLATE_VBoxGuestR3DllNonPedantic_CFLAGS) $(VBOX_GCC_WERR) + TEMPLATE_VBoxGuestR3Dll_CXXFLAGS = $(TEMPLATE_VBoxGuestR3DllNonPedantic_CXXFLAGS) $(VBOX_GCC_WERR) +endif + +# +# Variant of VBoxGuestR3Dll that requires Windows 2000 or later for x86, and W2K3 for AMD64. +# +TEMPLATE_VBoxGuestR3DllMinW2K = VBox Guest User Dynamic Libraries w/ IPRT and VBGL. +TEMPLATE_VBoxGuestR3DllMinW2K_EXTENDS = VBoxGuestR3Dll +TEMPLATE_VBoxGuestR3DllMinW2K_VBOX_IMPORT_CHECKER.win.x86 = w2k +ifeq ($(KBUILD_TARGET),win) + ifdef VBOX_WITH_NOCRT_STATIC + TEMPLATE_VBoxGuestR3DllMinW2K_LDFLAGS.win.x86 = $(filter-out -NoOptIData,$(TEMPLATE_VBoxGuestR3Dll_LDFLAGS.win.x86)) + else + TEMPLATE_VBoxGuestR3DllMinW2K_LDFLAGS.win.x86 = $(filter-out -NoOptIData -Section:.bss$(COMMA)RW!K,$(TEMPLATE_VBoxGuestR3Dll_LDFLAGS.win.x86)) + endif + TEMPLATE_VBoxGuestR3DllMinW2K_POST_CMDS.win.x86 = $(subst $(VBOX_PE_SET_VERSION), $(VBOX_PE_SET_VERSION) --w2k,$(TEMPLATE_VBoxGuestR3Dll_POST_CMDS.win.x86)) +endif + +# +# Variant of VBoxGuestR3Dll that requires Windows Vista or later. +# +TEMPLATE_VBoxGuestR3DllMinVista = VBox Guest User Dynamic Libraries w/ IPRT and VBGL. +TEMPLATE_VBoxGuestR3DllMinVista_EXTENDS = VBoxGuestR3Dll +TEMPLATE_VBoxGuestR3DllMinVista_VBOX_IMPORT_CHECKER.win.x86 = vista +TEMPLATE_VBoxGuestR3DllMinVista_VBOX_IMPORT_CHECKER.win.amd64 = vista +ifeq ($(KBUILD_TARGET),win) + ifdef VBOX_WITH_NOCRT_STATIC + TEMPLATE_VBoxGuestR3DllMinVista_LDFLAGS.win.x86 = $(filter-out -NoOptIData,$(TEMPLATE_VBoxGuestR3Dll_LDFLAGS.win.x86)) + else + TEMPLATE_VBoxGuestR3DllMinVista_LDFLAGS.win.x86 = $(filter-out -NoOptIData -Section:.bss$(COMMA)RW!K,$(TEMPLATE_VBoxGuestR3Dll_LDFLAGS.win.x86)) + endif + TEMPLATE_VBoxGuestR3DllMinVista_POST_CMDS.win.x86 = $(subst $(VBOX_PE_SET_VERSION), $(VBOX_PE_SET_VERSION) --vista,$(TEMPLATE_VBoxGuestR3Dll_POST_CMDS.win.x86)) + TEMPLATE_VBoxGuestR3DllMinVista_POST_CMDS.win.amd64 = $(subst $(VBOX_PE_SET_VERSION), $(VBOX_PE_SET_VERSION) --vista,$(TEMPLATE_VBoxGuestR3Dll_POST_CMDS.win.amd64)) +endif + +# +# Template for building normal R3 (dynamic) libraries for the guest additions with Visual C++ 2013 or later, strict. +# +TEMPLATE_NewerVccVBoxGuestR3Dll = VBoxGuestR3DllNonPedantic with the newer Visual C++ version (2013 or later). +TEMPLATE_NewerVccVBoxGuestR3Dll_EXTENDS = VBoxGuestR3DllNonPedantic +if "$(KBUILD_TARGET)" == "win" && "$(VBOX_NEWER_VCC_TOOL_STEM)" != "$(VBOX_VCC_TOOL_STEM)" + TEMPLATE_NewerVccVBoxGuestR3Dll_TOOL.win.x86 = $(VBOX_NEWER_VCC_TOOL_STEM)X86 + TEMPLATE_NewerVccVBoxGuestR3Dll_TOOL.win.amd64 = $(VBOX_NEWER_VCC_TOOL_STEM)AMD64 + TEMPLATE_NewerVccVBoxGuestR3Dll_CXXFLAGS = \ + $(filter-out $(VBOX_VCC_WARN_ALL) $(VBOX_VCC_WERR), $(TEMPLATE_VBoxGuestR3DllNonPedantic_CXXFLAGS)) \ + $(VBOX_NEWER_VCC_WARN_ALL) $(VBOX_VCC_WERR) + TEMPLATE_NewerVccVBoxGuestR3Dll_CFLAGS = $(TEMPLATE_NewerVccVBoxGuestR3DllNonPedantic_CXXFLAGS) + ifndef VBOX_WITH_NOCRT_STATIC + # Hack begin + # Does not work when building x86 for amd64 build (No rule to make target /oldnames.lib). + # TEMPLATE_NewerVccVBoxGuestR3Dll_LIBS.x86 = \ + # $(subst $(PATH_TOOL_$(TEMPLATE_VBoxGuestR3DllNonPedantic_TOOL.win.x86)_LIB),$(PATH_TOOL_$(TEMPLATE_NewerVccVBoxGuestR3Dll_TOOL.win.x86)_LIB), $(TEMPLATE_VBoxGuestR3DllNonPedantic_LIBS.x86)) + # TEMPLATE_NewerVccVBoxGuestR3Dll_LIBS.amd64 = \ + # $(subst $(PATH_TOOL_$(TEMPLATE_VBoxGuestR3DllNonPedantic_TOOL.win.amd64)_LIB),$(PATH_TOOL_$(TEMPLATE_NewerVccVBoxGuestR3Dll_TOOL.win.amd64)_LIB), $(TEMPLATE_VBoxGuestR3DllNonPedantic_LIBS.amd64)) + # Directly assign TEMPLATE_NewerVccVBoxGuestR3Dll_LIBS. + TEMPLATE_NewerVccVBoxGuestR3Dll_LIBS.x86 = \ + $(PATH_TOOL_$(TEMPLATE_NewerVccVBoxGuestR3Dll_TOOL.win.x86)_LIB)/oldnames.lib \ + $(PATH_TOOL_$(TEMPLATE_NewerVccVBoxGuestR3Dll_TOOL.win.x86)_LIB)/libcmt$(VBOX_VCC_CRT_TYPE).lib \ + $(PATH_TOOL_$(TEMPLATE_NewerVccVBoxGuestR3Dll_TOOL.win.x86)_LIB)/libcpmt$(VBOX_VCC_CRT_TYPE).lib + TEMPLATE_NewerVccVBoxGuestR3Dll_LIBS.amd64 = \ + $(PATH_TOOL_$(TEMPLATE_NewerVccVBoxGuestR3Dll_TOOL.win.amd64)_LIB)/oldnames.lib \ + $(PATH_TOOL_$(TEMPLATE_NewerVccVBoxGuestR3Dll_TOOL.win.amd64)_LIB)/libcmt$(VBOX_VCC_CRT_TYPE).lib \ + $(PATH_TOOL_$(TEMPLATE_NewerVccVBoxGuestR3Dll_TOOL.win.amd64)_LIB)/libcpmt$(VBOX_VCC_CRT_TYPE).lib + endif # !VBOX_WITH_NOCRT_STATIC + # Hack end +endif +TEMPLATE_NewerVccVBoxGuestR3Dll_LIBS = \ + $(TEMPLATE_VBoxGuestR3ExeBase_LIBS) + +# +# Variant of NewerVccVBoxGuestR3Dll that requires Windows Vista or later. +# +TEMPLATE_NewerVccVBoxGuestR3DllMinVista = NewerVccVBoxGuestR3Dll with the newer Visual C++ version (2013 or later). +TEMPLATE_NewerVccVBoxGuestR3DllMinVista_EXTENDS := NewerVccVBoxGuestR3Dll +ifeq ($(KBUILD_TARGET),win) + ifdef VBOX_WITH_NOCRT_STATIC + TEMPLATE_NewerVccVBoxGuestR3DllMinVista_LDFLAGS.win.x86 = $(filter-out -NoOptIData,$(TEMPLATE_NewerVccVBoxGuestR3Dll_LDFLAGS.win.x86)) + else + TEMPLATE_NewerVccVBoxGuestR3DllMinVista_LDFLAGS.win.x86 = $(filter-out -NoOptIData -Section:.bss$(COMMA)RW!K,$(TEMPLATE_NewerVccVBoxGuestR3Dll_LDFLAGS.win.x86)) + endif + TEMPLATE_NewerVccVBoxGuestR3DllMinVista_POST_CMDS.win.x86 = $(subst $(VBOX_PE_SET_VERSION), $(VBOX_PE_SET_VERSION) --vista,$(TEMPLATE_NewerVccVBoxGuestR3Dll_POST_CMDS.win.x86)) + TEMPLATE_NewerVccVBoxGuestR3DllMinVista_POST_CMDS.win.amd64 = $(subst $(VBOX_PE_SET_VERSION), $(VBOX_PE_SET_VERSION) --vista,$(TEMPLATE_NewerVccVBoxGuestR3Dll_POST_CMDS.win.amd64)) +endif + +# +# Template for building R3 (static) libraries for the guest additions, strict. +# +TEMPLATE_VBoxGuestR3Lib := VBox Guest User Dynamic Libraries w/ IPRT and VBGL. +TEMPLATE_VBoxGuestR3Lib_EXTENDS := VBoxGuestR3ExeBase +TEMPLATE_VBoxGuestR3Lib_EXTENDS_BY := appending +TEMPLATE_VBoxGuestR3Lib_INST = $(INST_ADDITIONS_LIB) +ifeq ($(KBUILD_TARGET),win) + TEMPLATE_VBoxGuestR3Lib_CFLAGS += $(VBOX_VCC_WERR) + TEMPLATE_VBoxGuestR3Lib_CXXFLAGS += $(VBOX_VCC_WERR) + TEMPLATE_VBoxGuestR3Lib_LDFLAGS += $(VBOX_VCC_LD_WERR) +else + TEMPLATE_VBoxGuestR3Lib_CFLAGS += $(VBOX_GCC_WERR) + TEMPLATE_VBoxGuestR3Lib_CXXFLAGS += $(VBOX_GCC_WERR) +endif + + +# +# Guest version of VBoxR3StaticNoCrtExe. +# +TEMPLATE_VBoxGuestR3NoCrtExe := ... +TEMPLATE_VBoxGuestR3NoCrtExe_EXTENDS := VBoxGuestR3Exe +TEMPLATE_VBoxGuestR3NoCrtExe_SDKS = $(subst WINSDK10-UCRT-STATIC,WINSDK10-UCRT-INCS, $(TEMPLATE_VBoxGuestR3Exe_SDKS)) +TEMPLATE_VBoxGuestR3NoCrtExe_SDKS.$(KBUILD_TARGET_ARCH) = $(filter-out VBoxOpenSslStatic,$(TEMPLATE_VBoxGuestR3Exe_SDKS.$(KBUILD_TARGET_ARCH))) +TEMPLATE_VBoxGuestR3NoCrtExe_DEFS = $(TEMPLATE_VBoxGuestR3Exe_DEFS) \ + RT_NO_CRT \ + IN_RT_STATIC +ifndef VBOX_WITH_NOCRT_STATIC + TEMPLATE_VBoxGuestR3NoCrtExe_DEFS.win = $(TEMPLATE_VBoxGuestR3Exe_DEFS.win) \ + RT_WITHOUT_NOCRT_WRAPPERS +endif +TEMPLATE_VBoxGuestR3NoCrtExe_LIBS = \ + $(PATH_STAGE_LIB)/RuntimeR3NoCrt$(VBOX_SUFF_LIB) +ifeq ($(KBUILD_TARGET),win) + TEMPLATE_VBoxGuestR3NoCrtExe_LIBS.x86 = $(NO_SUCH_VARIABLE) + TEMPLATE_VBoxGuestR3NoCrtExe_LIBS.amd64 = $(NO_SUCH_VARIABLE) + TEMPLATE_VBoxGuestR3NoCrtExe_LIBS.win = $(NO_SUCH_VARIABLE) + TEMPLATE_VBoxGuestR3NoCrtExe_LIBS.win.x86 = \ + $(PATH_TOOL_$(TEMPLATE_VBoxGuestR3NoCrtExe_TOOL.win.x86)_LIB)/chkstk.obj + TEMPLATE_VBoxGuestR3NoCrtExe_SDKS.win.x86 = VBoxWinInt64Lib + TEMPLATE_VBoxGuestR3NoCrtExe_LDFLAGS = $(filter-out $(VBOX_VCC_LD_GUARD_CF) $(VBOX_VCC_SANITIZER_LDFLAGS), $(TEMPLATE_VBoxGuestR3Exe_LDFLAGS)) + TEMPLATE_VBoxGuestR3NoCrtExe_LDFLAGS.win.x86 = $(filter-out -Include%, $(TEMPLATE_VBoxGuestR3Exe_LDFLAGS.win.x86)) + TEMPLATE_VBoxGuestR3NoCrtExe_LDFLAGS.win = $(TEMPLATE_VBoxGuestR3Exe_LDFLAGS.win) /entry:CustomMainEntrypoint /subsystem:console + TEMPLATE_VBoxGuestR3NoCrtExe_CFLAGS = $(filter-out -EH% -GS $(VBOX_VCC_CC_GUARD_CF) $(VBOX_VCC_SANITIZER_FLAGS),$(TEMPLATE_VBoxGuestR3Exe_CFLAGS)) /GS- -EHs- + TEMPLATE_VBoxGuestR3NoCrtExe_CXXFLAGS = $(filter-out -EH% -GS $(VBOX_VCC_CC_GUARD_CF) $(VBOX_VCC_SANITIZER_FLAGS),$(TEMPLATE_VBoxGuestR3Exe_CXXFLAGS)) /GS- -EHs- + TEMPLATE_VBoxGuestR3NoCrtExe_PCHFLAGS = $(filter-out -EH% -GS $(VBOX_VCC_CC_GUARD_CF) $(VBOX_VCC_SANITIZER_FLAGS),$(TEMPLATE_VBoxGuestR3Exe_PCHFLAGS)) /GS- -EHs- + TEMPLATE_VBoxGuestR3NoCrtExe_CXXFLAGS.debug = $(filter-out /RTC% -RTC%, $(TEMPLATE_VBoxGuestR3Exe_CXXFLAGS.debug)) +else + TEMPLATE_VBoxGuestR3NoCrtExe_CXXFLAGS = $(TEMPLATE_VBoxGuestR3Exe_CXXFLAGS) -fno-exceptions + TEMPLATE_VBoxGuestR3NoCrtExe_PCHFLAGS = $(TEMPLATE_VBoxGuestR3Exe_PCHFLAGS) -fno-exceptions +endif + + +# +# Template for XFree86 guest modules (relocatable module, i.e. sysmod). +# This mostly about zapping the VBoxR3Exe linker flags and libraries. +# +TEMPLATE_VBoxGuestR3XFree86Mod := VBox XFree86 Guest Module +TEMPLATE_VBoxGuestR3XFree86Mod_EXTENDS := VBoxGuestR3ExeBase +TEMPLATE_VBoxGuestR3XFree86Mod_SYSSUFF := .o +TEMPLATE_VBoxGuestR3XFree86Mod_DEFS = $(TEMPLATE_VBoxGuestR3ExeBase_DEFS) VBOX_GUESTR3XF86MOD RTMEM_NO_WRAP_TO_EF_APIS +TEMPLATE_VBoxGuestR3XFree86Mod_CFLAGS = $(filter-out $(VBOX_GCC_SANITIZER_FLAGS),$(TEMPLATE_VBoxGuestR3ExeBase_CFLAGS)) \ + -fno-pie -fno-merge-constants -std=c99 -ffreestanding +TEMPLATE_VBoxGuestR3XFree86Mod_CXXFLAGS = $(filter-out $(VBOX_GCC_SANITIZER_FLAGS),$(TEMPLATE_VBoxGuestR3ExeBase_CXXFLAGS)) \ + -fno-pie -fno-merge-constants -ffreestanding +TEMPLATE_VBoxGuestR3XFree86Mod_CFLAGS.linux = $(VBOX_GCC_fno-stack-protector) # Remove symvers.h +TEMPLATE_VBoxGuestR3XFree86Mod_CXXFLAGS.linux = $(VBOX_GCC_fno-stack-protector) # Remove symvers.h +TEMPLATE_VBoxGuestR3XFree86Mod_LDFLAGS.$(KBUILD_TARGET) = $(NO_SUCH_VARIABLE) +# The GNU_HASH ELF tag is not supported by older glibc dynamic linkers. +TEMPLATE_VBoxGuestR3XFree86Mod_LDFLAGS.linux = $(subst -Wl$(COMMA),,$(VBOX_LD_hash_style_sysv)) +TEMPLATE_VBoxGuestR3XFree86Mod_LDFLAGS.$(KBUILD_TYPE) = $(NO_SUCH_VARIABLE) +TEMPLATE_VBoxGuestR3XFree86Mod_LDFLAGS := -r +if1of ($(KBUILD_TARGET), dragonfly freebsd linux netbsd openbsd) # the gnu ld guys. + TEMPLATE_VBoxGuestR3XFree86Mod_LDFLAGS.release := -S + TEMPLATE_VBoxGuestR3XFree86Mod_LDFLAGS.x86 := -m elf_i386 + TEMPLATE_VBoxGuestR3XFree86Mod_LDFLAGS.amd64 := -m elf_x86_64 +endif +TEMPLATE_VBoxGuestR3XFree86Mod_LIBS = $(VBOX_LIB_VBGL_R3_XFREE86) +TEMPLATE_VBoxGuestR3XFree86Mod_LIBS.$(KBUILD_TYPE) = $(NO_SUCH_VARIABLE) +TEMPLATE_VBoxGuestR3XFree86Mod_LIBS.$(KBUILD_TARGET) = $(NO_SUCH_VARIABLE) + + +# +# Template for XFree86 guest libraries. +# +TEMPLATE_VBoxGuestR3XFree86Lib := VBox XFree86 Guest Library +TEMPLATE_VBoxGuestR3XFree86Lib_EXTENDS := VBoxGuestR3XFree86Mod +TEMPLATE_VBoxGuestR3XFree86Lib_INST = $(INST_ADDITIONS_LIB) +TEMPLATE_VBoxGuestR3XFree86Lib_LIBS = $(INST_ADDITIONS_LIB) + + +# +# Template for X.Org guest modules (shared libs). +# This mostly about zapping unnecessary LIBS from VBoxGuestR3DllNonPedantic and adding some flags. +# +TEMPLATE_VBoxGuestR3XOrgMod := VBox X.Org Guest Module +TEMPLATE_VBoxGuestR3XOrgMod_EXTENDS := VBoxGuestR3DllNonPedantic +TEMPLATE_VBoxGuestR3XOrgMod_DEFS = $(TEMPLATE_VBoxGuestR3DllNonPedantic_DEFS) VBOX_GUESTR3XORGMOD RTMEM_NO_WRAP_TO_EF_APIS +ifeq ($(KBUILD_TARGET_ARCH),amd64) + TEMPLATE_VBoxGuestR3XOrgMod_DEFS += _XSERVER64 +endif +TEMPLATE_VBoxGuestR3XOrgMod_CFLAGS = $(filter-out $(VBOX_GCC_SANITIZER_FLAGS),$(TEMPLATE_VBoxGuestR3DllNonPedantic_CFLAGS)) -std=c99 +TEMPLATE_VBoxGuestR3XOrgMod_CXXFLAGS = $(filter-out $(VBOX_GCC_SANITIZER_FLAGS),$(TEMPLATE_VBoxGuestR3DllNonPedantic_CXXFLAGS)) +if1of ($(KBUILD_TARGET), linux) + TEMPLATE_VBoxGuestR3XOrgMod_CFLAGS += -Wno-conversion -Wno-unused-parameter +endif +TEMPLATE_VBoxGuestR3XOrgMod_LDFLAGS = $(filter-out $(VBOX_GCC_SANITIZER_FLAGS) $(VBOX_GCC_SANITIZER_LDFLAGS),$(TEMPLATE_VBoxGuestR3DllNonPedantic_LDFLAGS)) +TEMPLATE_VBoxGuestR3XOrgMod_LIBS = $(VBOX_LIB_VBGL_R3_XORG) +TEMPLATE_VBoxGuestR3XOrgMod_LIBS.$(KBUILD_TYPE) = $(NO_SUCH_VARIABLE) +TEMPLATE_VBoxGuestR3XOrgMod_LIBS.$(KBUILD_TARGET) = $(NO_SUCH_VARIABLE) +TEMPLATE_VBoxGuestR3XOrgMod_LIBS.freebsd += iconv + + +# +# Template for X.Org guest libraries. +# +TEMPLATE_VBoxGuestR3XOrgLib := VBox X.Org Guest Library +TEMPLATE_VBoxGuestR3XOrgLib_EXTENDS := VBoxGuestR3XOrgMod +TEMPLATE_VBoxGuestR3XOrgLib_INST = $(INST_ADDITIONS_LIB) + + +# +# Template for building R0 drivers for the guest additions. +# +TEMPLATE_VBoxGuestR0Drv = VBox Guest Driver +TEMPLATE_VBoxGuestR0Drv_EXTENDS = VBoxR0Drv +TEMPLATE_VBoxGuestR0Drv_INST = $(INST_ADDITIONS) +TEMPLATE_VBoxGuestR0Drv_SDKS.win.x86 = ReorderCompilerIncs $(VBOX_WINDDK_GST) $(VBOX_WINPSDK_GST_INCS) VBoxWinInt64Lib +TEMPLATE_VBoxGuestR0Drv_SDKS.win.amd64 = ReorderCompilerIncs $(VBOX_WINDDK_GST) $(VBOX_WINPSDK_GST_INCS) +TEMPLATE_VBoxGuestR0Drv_DEFS = $(TEMPLATE_VBoxR0Drv_DEFS) IN_GUEST IN_GUEST_R0 +TEMPLATE_VBoxGuestR0Drv_DEFS.linux = RT_NO_EXPORT_SYMBOL +ifeq ($(KBUILD_TARGET),solaris) + TEMPLATE_VBoxGuestR0Drv_LDFLAGS = -r -dy +endif +ifn1of ($(KBUILD_TARGET), darwin os2 win) + TEMPLATE_VBoxGuestR0Drv_CFLAGS = $(patsubst %/VBox/SUPDrvMangling.h,%/VBox/VBoxGuestMangling.h,$(TEMPLATE_VBoxR0Drv_CFLAGS)) + TEMPLATE_VBoxGuestR0Drv_CXXFLAGS = $(patsubst %/VBox/SUPDrvMangling.h,%/VBox/VBoxGuestMangling.h,$(TEMPLATE_VBoxR0Drv_CXXFLAGS)) + TEMPLATE_VBoxGuestR0Drv_ASDEFS = $(patsubst RT_MANGLER_PREFIX=%,RT_MANGLER_PREFIX=VBoxGuest_,$(TEMPLATE_VBoxR0Drv_ASDEFS)) +endif +if "$(VBOX_VCC_TOOL_STEM)" >= "VCC120" # Do not use SSE so the binaries might works on NT4 and earlier. + TEMPLATE_VBoxGuestR0Drv_CFLAGS.win.x86 = $(TEMPLATE_VBoxR0Drv_CFLAGS.win.x86) /arch:IA32 + TEMPLATE_VBoxGuestR0Drv_CXXFLAGS.win.x86 = $(TEMPLATE_VBoxR0Drv_CXXFLAGS.win.x86) /arch:IA32 +endif + + +# +# Template for building R0 libraries for the guest additions. +# +TEMPLATE_VBoxGuestR0DrvLib = VBox Guest Driver Libraries +TEMPLATE_VBoxGuestR0DrvLib_EXTENDS = VBoxGuestR0Drv +TEMPLATE_VBoxGuestR0DrvLib_INSTTYPE = stage +TEMPLATE_VBoxGuestR0DrvLib_INSTTYPE.linux = stage +TEMPLATE_VBoxGuestR0DrvLib_INST = $(INST_ADDITIONS_LIB) +ifeq ($(KBUILD_TARGET),haiku) + TEMPLATE_VBoxGuestR0DrvLib_LDFLAGS = -r -dy +endif + + +# +# Guest additions libraries (all static). +# The _SHARED variants are compiled as PIC and intended for linking into a .so/.dll/.dylib. +# +VBOX_LIB_IPRT_GUEST_R3 = $(VBOX_PATH_ADDITIONS_LIB)/RuntimeGuestR3$(VBOX_SUFF_LIB) +VBOX_LIB_IPRT_GUEST_R3_SHARED = $(VBOX_PATH_ADDITIONS_LIB)/RuntimeGuestR3Shared$(VBOX_SUFF_LIB) +VBOX_LIB_IPRT_GUEST_R0 = $(VBOX_PATH_ADDITIONS_LIB)/RuntimeGuestR0$(VBOX_SUFF_LIB) +#ifeq ($(KBUILD_TARGET_ARCH),x86) +# VBOX_LIB_IPRT_GUEST_R0_NT4 = $(VBOX_PATH_ADDITIONS_LIB)/RuntimeGuestR0NT4$(VBOX_SUFF_LIB) +#else +VBOX_LIB_IPRT_GUEST_R0_NT4 = $(VBOX_LIB_IPRT_GUEST_R0) +#endif +VBOX_LIB_VBGL_R3 = $(VBOX_PATH_ADDITIONS_LIB)/VBoxGuestR3Lib$(VBOX_SUFF_LIB) +VBOX_LIB_VBGL_R3_XFREE86 = $(VBOX_PATH_ADDITIONS_LIB)/VBoxGuestR3LibXFree86$(VBOX_SUFF_LIB) +VBOX_LIB_VBGL_R3_XORG = $(VBOX_PATH_ADDITIONS_LIB)/VBoxGuestR3LibXOrg$(VBOX_SUFF_LIB) +VBOX_LIB_VBGL_R3_SHARED = $(VBOX_PATH_ADDITIONS_LIB)/VBoxGuestR3LibShared$(VBOX_SUFF_LIB) +VBOX_LIB_VBGL_R0BASE = $(VBOX_PATH_ADDITIONS_LIB)/VBoxGuestR0LibBase$(VBOX_SUFF_LIB) +VBOX_LIB_VBGL_R0 = $(VBOX_PATH_ADDITIONS_LIB)/VBoxGuestR0Lib$(VBOX_SUFF_LIB) +ifeq ($(KBUILD_TARGET_ARCH),x86) + VBOX_LIB_IPRT_GUEST_R3_X86 = $(VBOX_LIB_IPRT_GUEST_R3) + VBOX_LIB_IPRT_GUEST_R3_SHARED_X86 = $(VBOX_LIB_IPRT_GUEST_R3_SHARED) + VBOX_LIB_VBGL_R3_X86 = $(VBOX_LIB_VBGL_R3) + VBOX_LIB_VBGL_R3_SHARED_X86 = $(VBOX_LIB_VBGL_R3_SHARED) +else + VBOX_LIB_IPRT_GUEST_R3_X86 = $(VBOX_PATH_ADDITIONS_LIB)/RuntimeGuestR3-x86$(VBOX_SUFF_LIB) + VBOX_LIB_IPRT_GUEST_R3_SHARED_X86 = $(VBOX_PATH_ADDITIONS_LIB)/RuntimeGuestR3Shared-x86$(VBOX_SUFF_LIB) + VBOX_LIB_VBGL_R3_X86 = $(VBOX_PATH_ADDITIONS_LIB)/VBoxGuestR3Lib-x86$(VBOX_SUFF_LIB) + VBOX_LIB_VBGL_R3_SHARED_X86 = $(VBOX_PATH_ADDITIONS_LIB)/VBoxGuestR3LibShared-x86$(VBOX_SUFF_LIB) +endif + + +# +# Check the publisher and version string. +# +# We are being very strict because the version string is visible in various +# APIs and logs and must be machine readable. +# +VBOX_VERSION_COMP_VALID_CHAR_SET = ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789abcdefghijklmnopqrstuvwxyz()[]{}+-., +ifneq ($(VBOX_BUILD_PUBLISHER),) + if !defined(VBOX_BUILD_TAG) && $(length $(VBOX_BUILD_PUBLISHER)) > 10 + $(error VBox: VBOX_BUILD_PUBLISHER must not be longer than 10 characters!) + else if defined(VBOX_BUILD_TAG) && $(length $(VBOX_BUILD_PUBLISHER)) > 48 + $(error VBox: VBOX_BUILD_PUBLISHER must not be longer than 48 characters!) + endif + if "$(substr $(VBOX_BUILD_PUBLISHER), 1, 1)" != "_" + $(error VBox: VBOX_BUILD_PUBLISHER must start with an underscore!) + endif + if "$(translate $(substr $(VBOX_BUILD_PUBLISHER),2),$(VBOX_VERSION_COMP_VALID_CHAR_SET),)" != "" + $(error VBox: VBOX_BUILD_PUBLISHER='$(VBOX_BUILD_PUBLISHER)' contains bad characters! Valid set is:$(NLTAB)$(VBOX_VERSION_COMP_VALID_CHAR_SET)) + endif +endif + +if $(words $(VBOX_VERSION_STRING)) != 1 + $(error VBox: VBOX_VERSION_STRING='$(VBOX_VERSION_STRING)' contains spaces or is empty.) +endif +if "$(subst __,-,$(VBOX_VERSION_STRING))" != "$(VBOX_VERSION_STRING)" + $(error VBox: VBOX_VERSION_STRING='$(VBOX_VERSION_STRING)' contains double underscores.) +endif + +VBOX_VER_TMP1 := $(subst _,$(SP),$(VBOX_VERSION_STRING)) + +if $(words $(VBOX_VER_TMP1)) > 3 + $(error VBox: VBOX_VERSION_STRING='$(VBOX_VERSION_STRING)' contains too many parts (underscores), max 3!) +endif +if "$(translate $(word 1,$(VBOX_VER_TMP1)),0123456789,)" != ".." + $(error VBox: The x.y.z part of VBOX_VERSION_STRING='$(VBOX_VERSION_STRING)' is malformed: '$(word 1,$(VBOX_VER_TMP1))') +endif +if "$(word 1,$(VBOX_VER_TMP1))" != "$(VBOX_VERSION_STRING_RAW)" + $(error VBox: VBOX_VERSION_STRING='$(VBOX_VERSION_STRING)' does not start with VBOX_VERSION_STRING_RAW='$(VBOX_VERSION_STRING_RAW)') +endif + +if $(words $(VBOX_VER_TMP1)) == 3 || ($(words $(VBOX_VER_TMP1)) == 2 && "$(VBOX_BUILD_PUBLISHER)" == "") + if "$(substr $(word 2,$(VBOX_VER_TMP1)),1,4)" == "BETA" + VBOX_VER_TMP2 = 5 + else if "$(substr $(word 2,$(VBOX_VER_TMP1)),1,5)" == "ALPHA" + VBOX_VER_TMP2 = 6 + else if "$(substr $(word 2,$(VBOX_VER_TMP1)),1,2)" == "RC" + VBOX_VER_TMP2 = 3 + else + $(error VBox: VBOX_VERSION_STRING='$(VBOX_VERSION_STRING)' uses an unknown build type: '$(word 2,$(VBOX_VER_TMP1))') + endif + if "$(translate $(substr $(word 2,$(VBOX_VER_TMP1)),$(VBOX_VER_TMP2)),0123456789)" != "" + $(error VBox: VBOX_VERSION_STRING='$(VBOX_VERSION_STRING)' uses an unknown build type: '$(word 2,$(VBOX_VER_TMP1))') + endif +endif + +VBOX_VER_TMP1 := +VBOX_VER_TMP2 := + + +# +# Two targets to coordinate version number changes properly. Note that the +# only way to get a really consistent build is to run 'kmk' in the top-level +# directory. If you don't run it there, you get a consistent sub-tree only. +# +VBOX_BAD_CHAR_SET = ,;:/\$(SP)$(TAB)$(HASH)=![]@%&''()*""<>?^{}|~ +VBOX_VERSION_STAMP = $(PATH_OUT)/version-stamp-raw-api-$(translate $(VBOX_VERSION_STRING)-$(VBOX_C_YEAR)-$(VBOX_VENDOR)-$(VBOX_PRODUCT)-$(VBOX_API_VERSION)-$(VBOX_BUILD_PUBLISHER)-$(USERNAME),$(VBOX_BAD_CHAR_SET),,_) +VBOX_VERSION_HEADER = $(PATH_OUT)/version-generated.h +VBOX_VERSION_MK = $(PATH_OUT)/version-generated.mk + +$(VBOX_VERSION_STAMP): | $(PATH_ROOT)/Config.kmk + $(call MSG_GENERATE,,$@) + $(QUIET)$(MKDIR) -p $(@D) + $(QUIET)$(RM) -f $(wildcard $(PATH_OUT)/version-stamp-*) + $(QUIET)$(APPEND) $@ $(VBOX_VERSION_STRING) + +$(VBOX_VERSION_HEADER): $(VBOX_VERSION_STAMP) + $(call MSG_GENERATE,,$@) + $(QUIET)$(MKDIR) -p $(@D) + $(QUIET)$(RM) -f $@ $@.tmp + $(QUIET)$(APPEND) $@.tmp '#ifndef ___version_generated_h___' + $(QUIET)$(APPEND) $@.tmp '#define ___version_generated_h___' + $(QUIET)$(APPEND) $@.tmp '' + $(QUIET)$(APPEND) $@.tmp '#define VBOX_VERSION_MAJOR $(VBOX_VERSION_MAJOR)' + $(QUIET)$(APPEND) $@.tmp '#define VBOX_VERSION_MINOR $(VBOX_VERSION_MINOR)' + $(QUIET)$(APPEND) $@.tmp '#define VBOX_VERSION_BUILD $(VBOX_VERSION_BUILD)' +ifneq ($(VBOX_VERSION_PRERELEASE),) + $(QUIET)$(APPEND) $@.tmp '#define VBOX_VERSION_PRERELEASE "$(strip $(VBOX_VERSION_PRERELEASE))"' +endif + $(QUIET)$(APPEND) $@.tmp '#define VBOX_VERSION_STRING_RAW "$(VBOX_VERSION_STRING_RAW)"' + $(QUIET)$(APPEND) $@.tmp '#define VBOX_VERSION_STRING "$(VBOX_VERSION_STRING)"' + $(QUIET)$(APPEND) $@.tmp '#define VBOX_API_VERSION_STRING "$(VBOX_API_VERSION)"' + $(QUIET)$(APPEND) $@.tmp '' +ifdef VBOX_BUILD_SERVER_BUILD + $(QUIET)$(APPEND) $@.tmp '#define VBOX_BUILD_SERVER_BUILD 1' +else + $(QUIET)$(APPEND) $@.tmp '#define VBOX_PRIVATE_BUILD_DESC "Private build by $(USERNAME)"' +endif + $(QUIET)$(APPEND) $@.tmp '' + $(QUIET)$(APPEND) $@.tmp '#endif' + $(QUIET)$(MV) -f $@.tmp $@ + + +VBOX_PACKAGE_HEADER = $(PATH_OUT)/package-generated.h + +$(VBOX_PACKAGE_HEADER): + $(call MSG_GENERATE,,$@) + $(QUIET)$(MKDIR) -p $(@D) + $(QUIET)$(RM) -f $@ $@.tmp + $(QUIET)$(APPEND) $@.tmp '#ifndef ___package_generated_h___' + $(QUIET)$(APPEND) $@.tmp '#define ___package_generated_h___' + $(QUIET)$(APPEND) $@.tmp '' + $(QUIET)$(APPEND) $@.tmp '#define VBOX_PACKAGE_STRING "$(VBOX_PACKAGE_STRING)"' + $(QUIET)$(APPEND) $@.tmp '' + $(QUIET)$(APPEND) $@.tmp '#endif' + $(QUIET)$(MV) -f $@.tmp $@ + +VBOX_PRODUCT_HEADER = $(PATH_OUT)/product-generated.h + +$(VBOX_PRODUCT_HEADER): $(VBOX_VERSION_STAMP) + $(call MSG_GENERATE,,$@) + $(QUIET)$(MKDIR) -p $(@D) + $(QUIET)$(RM) -f $@ $@.tmp + $(QUIET)$(APPEND) $@.tmp '#ifndef ___product_generated_h___' + $(QUIET)$(APPEND) $@.tmp '#define ___product_generated_h___' + $(QUIET)$(APPEND) $@.tmp '' + $(QUIET)$(APPEND) $@.tmp '#define VBOX_VENDOR "$(VBOX_VENDOR)"' + $(QUIET)$(APPEND) $@.tmp '#define VBOX_VENDOR_SHORT "$(VBOX_VENDOR_SHORT)"' + $(QUIET)$(APPEND) $@.tmp '#define VBOX_PRODUCT "$(VBOX_PRODUCT)"' + $(QUIET)$(APPEND) $@.tmp '#define VBOX_BUILD_PUBLISHER "$(VBOX_BUILD_PUBLISHER)"' + $(QUIET)$(APPEND) $@.tmp '#define VBOX_C_YEAR "$(VBOX_C_YEAR)"' + $(QUIET)$(APPEND) $@.tmp '' + $(QUIET)$(APPEND) $@.tmp '#endif' + $(QUIET)$(MV) -f $@.tmp $@ + +# +# Used for external makefiles which cannot include Config.kmk +# +$(VBOX_VERSION_MK): $(VBOX_VERSION_STAMP) + $(call MSG_GENERATE,,$@) + $(QUIET)$(RM) -f $@ $@.tmp + $(QUIET)$(MKDIR) -p $(@D) + $(QUIET)$(APPEND) $@.tmp 'VBOX_VERSION_MAJOR = $(VBOX_VERSION_MAJOR)' + $(QUIET)$(APPEND) $@.tmp 'VBOX_VERSION_MINOR = $(VBOX_VERSION_MINOR)' + $(QUIET)$(APPEND) $@.tmp 'VBOX_VERSION_BUILD = $(VBOX_VERSION_BUILD)' + $(QUIET)$(APPEND) $@.tmp 'VBOX_VERSION_STRING = $(VBOX_VERSION_STRING)' +ifneq ($(VBOX_VERSION_PRERELEASE),) + $(QUIET)$(APPEND) $@.tmp 'VBOX_VERSION_PRERELEASE = $(strip $(VBOX_VERSION_PRERELEASE))' +endif + $(QUIET)$(APPEND) $@.tmp 'VBOX_VENDOR = $(VBOX_VENDOR)' + $(QUIET)$(APPEND) $@.tmp 'VBOX_VENDOR_SHORT = $(VBOX_VENDOR_SHORT)' + $(QUIET)$(APPEND) $@.tmp 'VBOX_PRODUCT = $(VBOX_PRODUCT)' + $(QUIET)$(APPEND) $@.tmp 'VBOX_C_YEAR = $(VBOX_C_YEAR)' +ifdef VBOX_BUILD_SERVER_BUILD + $(QUIET)$(APPEND) $@.tmp 'VBOX_BUILD_SERVER_BUILD = 1' +else + $(QUIET)$(APPEND) $@.tmp 'VBOX_PRIVATE_BUILD_DESC = Private build by $(USERNAME)' +endif + $(QUIET)$(MV) -f $@.tmp $@ + +if !defined(VBOX_OSE) && !defined(VBOX_NOINC_LICENSE_VER_KMK) + if1of ($(KBUILD_TARGET), freebsd linux netbsd openbsd solaris) + # VBOX_LICENSE_VER is used in several Makefiles + VBOX_LICENSE_VER_KMK = $(PATH_OUT)/license-version.kmk + $(VBOX_LICENSE_VER_KMK): $(VBOX_BRAND_LICENSE_HTML) + $(call MSG_GENERATE,,$(VBOX_LICENSE_VER_KMK)) + $(QUIET)$(MKDIR) -p $(@D) + ifdef VBOX_BRAND_LICENSE_VER + $(QUIET)$(RM) -f '$@' + $(APPEND) '$@' 'VBOX_LICENSE_VER=$(VBOX_BRAND_LICENSE_VER)' + else + $(QUIET)$(SED) -e "s/.*License version \([0-9.]*\) *[,&].*/VBOX_LICENSE_VER=\1/;t;d" --output $@ $(VBOX_BRAND_LICENSE_HTML) + endif + -include $(VBOX_LICENSE_VER_KMK) + ifdef VBOX_LICENSE_VER + VBOX_LICENSE_FILES = \ + License-$(VBOX_LICENSE_VER).html \ + $(foreach f,$(VBOX_INSTALLER_ADD_LANGUAGES),License-$(VBOX_LICENSE_VER)-$(f).html) + VBOX_LICENSE_BINS = $(addprefix $(PATH_STAGE_BIN)/,$(VBOX_LICENSE_FILES)) + endif + endif +endif + + +ifeq ($(KBUILD_TARGET),darwin) + $(VBOX_DARWIN_ENTITLEMENTS_FILE): + $(call MSG_GENERATE,,$@) + $(QUIET)$(MKDIR) -p $(@D) + $(QUIET)$(RM) -f $@ $@.tmp + $(QUIET)$(APPEND) $@.tmp '<?xml version="1.0" encoding="UTF-8"?>' + $(QUIET)$(APPEND) $@.tmp '<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">' + $(QUIET)$(APPEND) $@.tmp '<plist version="1.0">' + $(QUIET)$(APPEND) $@.tmp '<dict>' + $(QUIET)$(APPEND) -n $@.tmp $(foreach entitlement,$(VBOX_DARWIN_ENTITLEMENTS_LIST), ' <key>$(entitlement)</key><true/>') + $(QUIET)$(APPEND) $@.tmp '</dict>' + $(QUIET)$(APPEND) $@.tmp '</plist>' + $(QUIET)$(MV) -f $@.tmp $@ +endif + +ifndef VBOX_NOINC_MISC + # Force building of the version header file as the first thing anywhere in + # the tree. This eliminates the need for manual dependencies on it. + ## @todo there gotta be a better way of doing this. + Makefile.kmk: | $(VBOX_VERSION_HEADER) $(VBOX_VERSION_MK) $(VBOX_PRODUCT_HEADER) $(VBOX_PACKAGE_HEADER) + ifeq ($(KBUILD_TARGET),darwin) + Makefile.kmk: | $(VBOX_DARWIN_ENTITLEMENTS_FILE) + endif +endif + + +# +# Subversion tree revision. +# +# The VBOX_SVN_REV contains our best guess. Use svn info on the root of the +# tree to determine this it if .svn/wc.db or .svn/entries is found (the former +# also up to two directory levels higher to allow for checkouts of the entire +# repository), otherwise fall back on maximum value of Config.kmk and +# Version.kmk revision. +# +# Makefile rules using this information shall list $(VBOX_SVN_REV_KMK) as a +# prerequisite. +# +SVN ?= svn$(HOSTSUFF_EXE) +VBOX_SVN_REV_KMK = $(PATH_OUT)/revision.kmk +ifndef VBOX_SVN_REV + VBOX_SVN_REV_CONFIG_FALLBACK := $(patsubst %:,, $Rev: 161085 $ ) + VBOX_SVN_REV_FALLBACK := $(if-expr $(VBOX_SVN_REV_CONFIG_FALLBACK) > $(VBOX_SVN_REV_VERSION_FALLBACK),$(VBOX_SVN_REV_CONFIG_FALLBACK),$(VBOX_SVN_REV_VERSION_FALLBACK)) + VBOX_SVN_DEP := $(firstword $(wildcard $(PATH_ROOT)/.svn/wc.db $(abspath $(PATH_ROOT)/../.svn/wc.db) $(abspath $(PATH_ROOT)/../../.svn/wc.db) $(PATH_ROOT)/.svn/entries)) + ifeq ($(which $(SVN)),) + VBOX_SVN_DEP := + endif + + # Rule for generating a timestamp and updating the real thing on change. + $(VBOX_SVN_REV_KMK).ts +| $(VBOX_SVN_REV_KMK): $(if $(VBOX_SVN_DEP), $(VBOX_SVN_DEP), $(PATH_ROOT)/Config.kmk) + $(call MSG_GENERATE,,$(VBOX_SVN_REV_KMK)) + $(QUIET)$(RM) -f $@ $@.tmp + $(QUIET)$(MKDIR) -p $(@D) + ifneq ($(VBOX_SVN_DEP),) + -$(REDIRECT) -E 'LC_ALL=C' -wo $@.tmp -- $(SVN) info $(PATH_ROOT) + # Append fallback. Will be ignored if "svn info" provides meaningful data. + $(QUIET)$(APPEND) $@.tmp 'Last Changed Rev: $(VBOX_SVN_REV_FALLBACK)' + $(SED) -e '/^Last Changed Rev/!d' -e 's/Last Changed Rev\: */export VBOX_SVN_REV=/; t a; :a q' --output $@ $@.tmp + $(QUIET)$(RM) -f $@.tmp + else + $(QUIET)$(APPEND) $@ 'export VBOX_SVN_REV=$(VBOX_SVN_REV_FALLBACK)' + endif + $(QUIET)$(CP) --changed -fv $@ $(VBOX_SVN_REV_KMK) + + ifndef VBOX_NOINC_SVN_REV_KMK + include $(VBOX_SVN_REV_KMK) + endif +else + # allow to overwrite VBOX_SVN_REV externally (mainly for building .debs/.rpms) + $(VBOX_SVN_REV_KMK): + $(call MSG_GENERATE,,$(VBOX_SVN_REV_KMK)) + $(QUIET)$(RM) -f $@ + $(QUIET)$(MKDIR) -p $(@D) + $(QUIET)$(APPEND) $@ 'export VBOX_SVN_REV=$(VBOX_SVN_REV)' + $(QUIET)echo '* $(VBOX_SVN_REV_KMK) was externally overwritten:' + $(QUIET)$(CAT) $(VBOX_SVN_REV_KMK) +endif + +# only needed for VBoxGuest for Linux/FreeBSD guests +VBOX_SVN_REV_HEADER = $(PATH_OUT)/revision-generated.h +$(VBOX_SVN_REV_HEADER): $(VBOX_SVN_REV_KMK) + $(call MSG_GENERATE,,$@) + $(QUIET)$(RM) -f $@ $@.tmp + $(QUIET)$(MKDIR) -p $(@D) + $(QUIET)$(APPEND) $@.tmp '#define VBOX_SVN_REV $(VBOX_SVN_REV)' + $(QUIET)$(MV) -f $@.tmp $@ + +# +# Shared definitions of the XIDL file to use as a source for +# generating various other files (VBoxSVC, webservice, docs, front-ends, ...) +# + +# Real XIDL source file; from this we strip the <desc> elements to generate +# a second XIDL file, from which the COM/XPCOM IDL files are then generated: +VBOX_XIDL_FILE_SRC = $(PATH_ROOT)/src/VBox/Main/idl/VirtualBox.xidl +# second XIDL file to use as source for COM/XPCOM IDL (with stripped docs): +VBOX_XIDL_FILE = $(PATH_OUT)/obj/VirtualBox_stripped.xidl + + +# +# VBOX_SEP needs to be quoted when used on the shell command line. +# +if1of ($(KBUILD_TARGET), os2 win) + VBOX_SEP = $(SEMICOLON) +else + VBOX_SEP = $(COLON) +endif + +# Java compiler options, needs some version checking. +if defined(VBOX_JAVA_VERSION) && $(VBOX_JAVA_VERSION) >= 110000 + VBOX_JAVA_WS_PATH ?= /usr/share/java + VBOX_JAVA_WS_EXTRA_JARS ?= $(VBOX_JAVA_WS_PATH)/jws-api.jar$(VBOX_SEP)$(VBOX_JAVA_WS_PATH)/jaxb-api.jar$(VBOX_SEP)$(VBOX_JAVA_WS_PATH)/jaxws-api.jar +else if defined(VBOX_JAVA_VERSION) && $(VBOX_JAVA_VERSION) >= 10900 + VBOX_JAVA_WS_OPTS ?= --add-modules java.xml.ws +endif +if defined(VBOX_JAVA_VERSION) && $(VBOX_JAVA_VERSION) >= 110000 + VBOX_JAVAC_OPTS = -encoding UTF-8 -source 9 -target 9 -Xlint:unchecked +else if defined(VBOX_JAVA_VERSION) && $(VBOX_JAVA_VERSION) >= 90000 + VBOX_JAVAC_OPTS = -encoding UTF-8 -source 6 -target 6 -Xlint:unchecked +else + VBOX_JAVAC_OPTS = -encoding UTF-8 -source 1.5 -target 1.5 -Xlint:unchecked +endif +VBOX_JAVADOC_OPTS = -encoding UTF-8 + + +# +# Legacy. +# +## @todo try remove this. +ifneq ($(LOCALCFG),) + include $(LOCALCFG) +endif + + +# +# For efficiently build serveral build types / archs. +# +both-debug-release both-release-debug: \ + build-release-$(KBUILD_TARGET_ARCH) \ + build-debug-$(KBUILD_TARGET_ARCH) +both-x86-amd64 both-amd64-x86: \ + build-$(KBUILD_TYPE)-x86 \ + build-$(KBUILD_TYPE)-x86 +both-types-archs both-archs-types: \ + build-debug-x86 \ + build-release-x86 \ + build-debug-amd64 \ + build-release-amd64 + +build-release-x86: + +$(MAKE) KBUILD_TYPE=release KBUILD_TARGET_ARCH=x86 + +build-debug-x86: + +$(MAKE) KBUILD_TYPE=debug KBUILD_TARGET_ARCH=x86 + +build-release-amd64: + +$(MAKE) KBUILD_TYPE=release KBUILD_TARGET_ARCH=amd64 + +build-debug-amd64: + +$(MAKE) KBUILD_TYPE=debug KBUILD_TARGET_ARCH=amd64 + + +# +# Some extra goals. +# +.PHONY: up update st stat status +up update:: + $(SVN) up + +up2 update2:: + $(SVN) up --ignore-externals + +st stat status: + $(SVN) status |