summaryrefslogtreecommitdiffstats
path: root/src/VBox/Devices/Makefile.kmk
diff options
context:
space:
mode:
Diffstat (limited to 'src/VBox/Devices/Makefile.kmk')
-rw-r--r--src/VBox/Devices/Makefile.kmk1761
1 files changed, 1761 insertions, 0 deletions
diff --git a/src/VBox/Devices/Makefile.kmk b/src/VBox/Devices/Makefile.kmk
new file mode 100644
index 00000000..0c5fc4df
--- /dev/null
+++ b/src/VBox/Devices/Makefile.kmk
@@ -0,0 +1,1761 @@
+# $Id: Makefile.kmk $
+## @file
+# Top-level sub-makefile for the devices, drivers and services.
+#
+
+#
+# Copyright (C) 2006-2022 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
+#
+
+SUB_DEPTH = ../../..
+include $(KBUILD_PATH)/subheader.kmk
+
+# Make sure our Config.kmk is included.
+ifndef VBOX_DEVICES_CONFIG_KMK_INCLUDED
+ include $(PATH_SUB_CURRENT)/Config.kmk
+endif
+
+# Include sub-makefiles.
+if1of ($(KBUILD_TARGET_ARCH), $(VBOX_SUPPORTED_HOST_ARCHS))
+ include $(PATH_SUB_CURRENT)/testcase/Makefile.kmk
+ include $(PATH_SUB_CURRENT)/Audio/testcase/Makefile.kmk
+ include $(PATH_SUB_CURRENT)/Input/testcase/Makefile.kmk
+ ifdef VBOX_WITH_TESTCASES
+ include $(PATH_SUB_CURRENT)/Samples/Makefile.kmk
+ endif
+ if defined(VBOX_WITH_INTEL_PXE) || defined(VBOX_ONLY_EXTPACKS)
+ include $(PATH_SUB_CURRENT)/PC/PXE/Makefile.kmk
+ else if defined(VBOX_WITH_PXE_ROM)
+ if !defined(VBOX_WITHOUT_IPXE)
+ include $(PATH_SUB_CURRENT)/PC/ipxe/Makefile.kmk
+ endif
+ endif
+endif
+if !defined(VBOX_ONLY_EXTPACKS)
+ if1of ($(KBUILD_TARGET_ARCH), $(VBOX_SUPPORTED_HOST_ARCHS))
+ include $(PATH_SUB_CURRENT)/BiosCommonCode/Makefile.kmk
+ include $(PATH_SUB_CURRENT)/PC/BIOS/Makefile.kmk
+ include $(PATH_SUB_CURRENT)/Graphics/BIOS/Makefile.kmk
+ endif
+
+ #
+ # Main targets.
+ #
+ if1of ($(KBUILD_TARGET_ARCH), $(VBOX_SUPPORTED_HOST_ARCHS))
+ DLLS += VBoxDDU VBoxDD VBoxDD2
+ ifdef VBOX_WITH_R0_MODULES
+ LIBRARIES += ServicesR0
+ ifdef VBOX_WITH_VBOXR0_AS_DLL
+ DLLS += VBoxDDR0
+ else
+ SYSMODS += VBoxDDR0
+ endif
+ endif
+ ifdef VBOX_WITH_RAW_MODE
+ SYSMODS += VBoxDDRC
+ endif
+ else
+ DLLS += VBoxDDU
+ endif
+
+
+ #
+ # VBoxDDU (shared object)
+ #
+ VBoxDDU_TEMPLATE = VBoxR3DllWarnNoPic
+ VBoxDDU_NAME = $(basename $(notdir $(LIB_DDU)))
+ VBoxDDU_INST.darwin = $(INST_DLL) $(INST_TESTCASE)
+ VBoxDDU_DEFS = IN_VBOXDDU
+ if defined(VBOX_WITH_VUSB) && "$(intersects $(KBUILD_TARGET_ARCH),$(VBOX_SUPPORTED_HOST_ARCHS))" != ""
+ VBoxDDU_DEFS += VBOX_WITH_VUSB
+ endif
+ if defined(VBOX_WITH_USB) && "$(intersects $(KBUILD_TARGET_ARCH),$(VBOX_SUPPORTED_HOST_ARCHS))" != ""
+ VBoxDDU_DEFS += VBOX_WITH_USB IN_USBLIB
+ VBoxDDU_SDKS.win = ReorderCompilerIncs $(VBOX_WINPSDK) $(VBOX_WINDDK)
+ if defined(VBOX_WITH_EHCI_IMPL) && !defined(VBOX_WITH_EXTPACK_PUEL)
+ VBoxDDU_DEFS += VBOX_WITH_EHCI_IMPL
+ endif
+ if defined(VBOX_WITH_XHCI_IMPL) && !defined(VBOX_WITH_EXTPACK_PUEL)
+ VBoxDDU_DEFS += VBOX_WITH_XHCI_IMPL
+ endif
+ else
+ VBoxDDU_SDKS.win = ReorderCompilerIncs $(VBOX_WINPSDK)
+ endif
+ VBoxDDU_SOURCES = \
+ Storage/VSCSI/VSCSIDevice.cpp \
+ Storage/VSCSI/VSCSILun.cpp \
+ Storage/VSCSI/VSCSILunSbc.cpp \
+ Storage/VSCSI/VSCSILunMmc.cpp \
+ Storage/VSCSI/VSCSISense.cpp \
+ Storage/VSCSI/VSCSIIoReq.cpp \
+ Storage/VSCSI/VSCSIVpdPagePool.cpp \
+ build/VBoxDDUDeps.cpp
+
+ ifdef VBOX_WITH_VSCSI_SSC
+ VBoxDDU_SOURCES += Storage/VSCSI/VSCSILunSsc.cpp
+ VBoxDDU_DEFS += VBOX_WITH_VSCSI_SSC
+ endif
+ VBoxDDU_LIBS = \
+ $(LIB_RUNTIME) \
+ $(PATH_STAGE_LIB)/StorageLib$(VBOX_SUFF_LIB)
+ VBoxDDU_LIBS.freebsd += \
+ geom
+ VBoxDDU_LIBS.solaris += \
+ efi
+ if defined(VBOX_WITH_USB) && "$(intersects $(KBUILD_TARGET_ARCH),$(VBOX_SUPPORTED_HOST_ARCHS))" != ""
+ VBoxDDU_SDKS.win += VBOX_WIN_NEWDEV
+ VBoxDDU_LIBS += \
+ $(PATH_STAGE_LIB)/USBLib$(VBOX_SUFF_LIB)
+ VBoxDDU_LIBS.win += \
+ $(PATH_STAGE_LIB)/VBoxDrvCfgDll$(VBOX_SUFF_LIB)
+ endif
+ VBoxDDU_LDFLAGS.darwin = -install_name $(VBOX_DYLD_EXECUTABLE_PATH)/VBoxDDU.dylib
+ if defined(VBOX_WITH_USB) && "$(intersects $(KBUILD_TARGET_ARCH),$(VBOX_SUPPORTED_HOST_ARCHS))" != ""
+ VBoxDDU_LDFLAGS.darwin += -framework IOKit
+ endif
+
+ VBoxDDU_LDFLAGS.linux = $(VBOX_GCC_NO_UNDEFINED)
+ $(call VBOX_SET_VER_INFO_DLL,VBoxDDU,VirtualBox VMM Devices and Drivers Utilities)
+
+
+endif # VBOX_ONLY_EXTPACKS
+if !defined(VBOX_ONLY_EXTPACKS) && "$(intersects $(KBUILD_TARGET_ARCH),$(VBOX_SUPPORTED_HOST_ARCHS))" != "" # Goes on almost to the end of the file.
+
+
+ #
+ # VBoxDD (shared object)
+ #
+ if "$(KBUILD_TARGET)" != "win" && $(VBOX_GCC_VERSION_CXX) < 40600
+ #
+ # Disable "ISO C++ prohibits anonymous structs [-Werror=pedantic]" caused by Mesa VMSVGA driver headers
+ # For GCC >= 4.6.0 the warning is disabled in DevVGA_SVGA.h
+ #
+ # Template used for gcc older than 4.6. (Strips away compiler options.)
+ #
+ TEMPLATE_VBoxDDOldGCC := VBoxDDOldGCC
+ TEMPLATE_VBoxDDOldGCC_EXTENDS := VBoxR3DllWarnNoPic
+ TEMPLATE_VBoxDDOldGCC_CXXFLAGS = $(filter-out -pedantic,$(TEMPLATE_$(TEMPLATE_VBoxDDOldGCC_EXTENDS)_CXXFLAGS))
+
+ VBoxDD_TEMPLATE = VBoxDDOldGCC
+ else
+ VBoxDD_TEMPLATE = VBoxR3DllWarnNoPic
+ endif
+ VBoxDD_SDKS.win = ReorderCompilerIncs $(VBOX_WINPSDK) $(VBOX_WINDDK) VBOX_NTDLL
+ Storage/DrvHostDVD.cpp_SDKS.win = ReorderCompilerIncs $(VBOX_WINDDK)
+ VBoxDD_INCS = \
+ build \
+ Network/slirp \
+ $(VBOX_GRAPHICS_INCS)
+ VBoxDD_DEFS = \
+ VBOX_HGCM_HOST_CODE \
+ $(if $(VBOX_WITH_HGCM),VBOX_WITH_HGCM,) \
+ $(if $(VBOX_BIOS_DMI_FALLBACK),VBOX_BIOS_DMI_FALLBACK,) \
+ VBOX_WITH_DMI_CHASSIS \
+ VBOX_WITH_DMI_OEMSTRINGS \
+ $(if $(VBOX_WITH_IOMMU_AMD),VBOX_WITH_IOMMU_AMD,) \
+ $(if $(VBOX_WITH_IOMMU_INTEL),VBOX_WITH_IOMMU_INTEL,) \
+ $(if $(VBOX_WITH_INTNET_SERVICE_IN_R3),VBOX_WITH_INTNET_SERVICE_IN_R3,)
+ VBoxDD_DEFS.win = _WIN32_WINNT=0x0510
+ ifeq ($(KBUILD_TARGET_ARCH),x86)
+ VBoxDD_DEFS.darwin = VBOX_WITH_2X_4GB_ADDR_SPACE
+ endif
+ VBoxDD_SOURCES = \
+ build/VBoxDD.cpp \
+ \
+ Input/DevPS2.cpp \
+ Input/DevPS2K.cpp \
+ Input/DevPS2M.cpp \
+ Input/UsbKbd.cpp \
+ Input/UsbMouse.cpp \
+ Bus/DevPCI.cpp \
+ Bus/DevPciIch9.cpp \
+ Bus/MsiCommon.cpp \
+ Bus/MsixCommon.cpp \
+ $(if $(VBOX_WITH_IOMMU_AMD),Bus/DevIommuAmd.cpp,) \
+ $(if $(VBOX_WITH_IOMMU_INTEL),Bus/DevIommuIntel.cpp,) \
+ EFI/DevSmc.cpp \
+ EFI/DevFlash.cpp \
+ EFI/FlashCore.cpp \
+ Graphics/DevVGA.cpp \
+ Storage/DevATA.cpp \
+ PC/DevPit-i8254.cpp \
+ PC/DevPIC.cpp \
+ PC/DevACPI.cpp \
+ PC/ACPI/VBoxAcpi.cpp \
+ PC/DevRTC.cpp \
+ PC/DevPcBios.cpp \
+ PC/DevFwCommon.cpp \
+ PC/DevPcArch.cpp \
+ PC/DevQemuFwCfg.cpp \
+ PC/DevLpc.cpp \
+ GIMDev/GIMDev.cpp \
+ GIMDev/DrvUDP.cpp \
+ VMMDev/VMMDev.cpp \
+ $(if $(VBOX_WITH_HGCM),VMMDev/VMMDevHGCM.cpp,) \
+ VMMDev/VMMDevTesting.cpp \
+ Network/DevPCNet.cpp \
+ Network/DevDP8390.cpp \
+ Network/Dev3C501.cpp \
+ PC/DevDMA.cpp \
+ PC/DevHPET.cpp \
+ PC/DevIoApic.cpp \
+ Storage/DevFdc.cpp \
+ Parallel/DevParallel.cpp \
+ \
+ Input/DrvKeyboardQueue.cpp \
+ Input/DrvMouseQueue.cpp \
+ Network/DrvIntNet.cpp \
+ Network/DrvDedicatedNic.cpp \
+ PC/DrvACPI.cpp \
+ PC/DrvAcpiCpu.cpp \
+ Serial/DevSerial.cpp \
+ Serial/DevOxPcie958.cpp \
+ Serial/UartCore.cpp \
+ Serial/DrvChar.cpp \
+ Serial/DrvHostSerial.cpp \
+ Serial/DrvNamedPipe.cpp \
+ Serial/DrvTCP.cpp \
+ Serial/DrvRawFile.cpp \
+ Storage/Debug.cpp \
+ Storage/DrvVD.cpp \
+ Storage/ATAPIPassthrough.cpp \
+ Storage/IOBufMgmt.cpp \
+ Network/DrvNetSniffer.cpp \
+ Network/Pcap.cpp \
+ Trace/DrvIfsTrace.cpp \
+ Trace/DrvIfsTrace-serial.cpp
+ ifn1of ($(KBUILD_TARGET), os2)
+ VBoxDD_SOURCES += Storage/DrvHostBase.cpp
+ endif
+ ifn1of ($(KBUILD_TARGET), os2)
+ VBoxDD_SOURCES += Storage/DrvHostDVD.cpp
+ endif
+ ifn1of ($(KBUILD_TARGET), darwin freebsd os2 solaris)
+ VBoxDD_SOURCES += Storage/DrvHostFloppy.cpp
+ endif
+
+
+ ifn1of ($(KBUILD_TARGET), darwin)
+ VBoxDD_SOURCES += Storage/HBDMgmt-generic.cpp
+ endif
+
+ VBoxDD_SOURCES.darwin += \
+ Storage/HBDMgmt-darwin.cpp \
+ Storage/DrvHostBase-darwin.cpp
+
+ VBoxDD_SOURCES.freebsd += \
+ Storage/DrvHostBase-freebsd.cpp
+
+ VBoxDD_SOURCES.linux += \
+ Storage/DrvHostBase-linux.cpp
+
+ VBoxDD_SOURCES.solaris += \
+ Storage/DrvHostBase-solaris.cpp
+
+ VBoxDD_SOURCES.win += \
+ Storage/DrvHostBase-win.cpp
+
+ #VBoxDD_SOURCES.win += Storage/HBDMgmt-win.cpp #Disabled until remaining issues are sorted out
+
+ VBoxDD_LIBS = # more later.
+ VBoxDD_LDFLAGS.darwin = -install_name $(VBOX_DYLD_EXECUTABLE_PATH)/VBoxDD.dylib \
+ -framework CoreAudio \
+ -framework AudioUnit \
+ -framework AudioToolbox \
+ -framework IOKit \
+ -framework Carbon \
+ -framework DiskArbitration \
+ -framework SystemConfiguration \
+ -framework AVFoundation \
+ -framework Foundation
+ VBoxDD_LDFLAGS.linux = $(VBOX_GCC_NO_UNDEFINED)
+
+ # --- Tracing bits. ---
+
+ ifdef VBOX_WITH_DTRACE_R3
+ VBoxDD_DEFS += VBOX_WITH_DTRACE
+ VBoxDD_USES += dtrace
+ VBoxDD_SOURCES += build/VBoxDD.d
+ endif
+
+ # --- Graphics bits. ---
+
+ ifdef VBOXWDDM_TEST_UHGSMI
+ VBoxDD_DEFS += VBOXWDDM_TEST_UHGSMI
+ endif
+ ifdef VBOXWDDM_WITH_VBVA
+ VBoxDD_DEFS += VBOXWDDM_WITH_VBVA
+ endif
+ ifdef VBOX_WITH_VIDEOHWACCEL
+ VBoxDD_DEFS += VBOX_WITH_VIDEOHWACCEL
+ endif
+
+ ifdef VBOX_WITH_HGSMI
+ VBoxDD_DEFS += VBOX_WITH_HGSMI
+ VBoxDD_SOURCES += \
+ Graphics/DevVGA_VBVA.cpp \
+ Graphics/HGSMI/HGSMIHost.cpp
+ VBoxDD_LIBS += \
+ $(PATH_STAGE_LIB)/HGSMIHostR3Lib$(VBOX_SUFF_LIB)
+ endif
+
+ ifdef VBOX_WITH_WDDM
+ VBoxDD_DEFS += VBOX_WITH_WDDM
+ VBoxDD_SOURCES += \
+ Graphics/HGSMI/SHGSMIHost.cpp
+ endif
+
+ ifdef VBOX_WITH_VMSVGA
+ VBoxDD_DEFS += VBOX_WITH_VMSVGA
+ VBoxDD_INCS += $(VBOX_PATH_VMSVGA_DEVICE_INC)
+ VBoxDD_SOURCES += \
+ Graphics/DevVGA-SVGA.cpp \
+ Graphics/DevVGA-SVGA-cmd.cpp
+ endif
+ ifdef VBOX_WITH_VMSVGA3D
+ if1of ($(KBUILD_TARGET), linux win)
+# Dynamically load 3D library (opengl32, libGL).
+# This is a temporary solution. In future the 3D backend will be in a separate library.
+VBOX_WITH_VMSVGA3D_DYNAMIC_LOAD = 1
+ endif
+ VBoxDD_DEFS += VBOX_WITH_VMSVGA3D
+ VBoxDD_SOURCES += \
+ Graphics/DevVGA-SVGA3d.cpp \
+ Graphics/DevVGA-SVGA3d-hlp.cpp \
+ Graphics/DevVGA-SVGA3d-info.cpp \
+ Graphics/DevVGA-SVGA3d-shared.cpp \
+ Graphics/DevVGA-SVGA3d-savedstate.cpp
+ ifdef VBOX_WITH_VMSVGA3D_DX
+ VBoxDD_DEFS += VMSVGA3D_DX
+ VBoxDD_SOURCES += \
+ Graphics/DevVGA-SVGA3d-dx.cpp \
+ Graphics/DevVGA-SVGA3d-dx-savedstate.cpp \
+ Graphics/DevVGA-SVGA3d-dx-shader.cpp
+ if "$(KBUILD_TARGET)" == "win" || defined(VBOX_WITH_DXVK)
+ VBoxDD_SDKS.linux += VBOX_DXVK
+ VBoxDD_SDKS.darwin += VBOX_DXVK
+ VBoxDD_DEFS += VMSVGA3D_DX_BACKEND
+ VBoxDD_SOURCES += \
+ Graphics/DevVGA-SVGA3d-dx-dx11.cpp
+ endif
+ endif
+ VBoxDD_SOURCES += \
+ Graphics/svgadump/svga_dump.c
+ if "$(KBUILD_TARGET)" == "win" && !defined(VBOX_WITH_VMSVGA3D_USE_OPENGL)
+ VBoxDD_DEFS += VMSVGA3D_DIRECT3D
+ VBoxDD_SOURCES += \
+ Graphics/DevVGA-SVGA3d-win.cpp \
+ Graphics/DevVGA-SVGA3d-win-d3d9.cpp
+ VBoxDD_LIBS.win += d3d9.lib $(PATH_TOOL_$(VBOX_VCC_TOOL)_LIB)/delayimp.lib
+ VBoxDD_LDFLAGS.win += /DELAYLOAD:d3d9.dll
+ else
+ VBoxDD_DEFS += VMSVGA3D_OPENGL
+ VBoxDD_SOURCES += \
+ Graphics/DevVGA-SVGA3d-ogl.cpp \
+ Graphics/DevVGA-SVGA3d-glHlp.cpp \
+ $(VBoxDD_0_OUTDIR)/VBoxSVGA3DLazyLoad.asm
+ VBoxDD_SOURCES.darwin += \
+ $(VBoxDD_0_OUTDIR)/VBoxSVGA3DObjCLazyLoad.asm
+ VBoxDD_CLEAN += $(VBoxDD_0_OUTDIR)/VBoxSVGA3DLazyLoad.asm
+ $$(VBoxDD_0_OUTDIR)/VBoxSVGA3DLazyLoad.asm: $(PATH_SUB_CURRENT)/Graphics/VBoxSVGA3D.def $(VBOX_DEF_2_LAZY_LOAD) | $$(dir $$@)
+ $(call MSG_TOOL,VBoxDef2LazyLoad,VBoxDD,$(filter %.def, $^),$@)
+ $(QUIET)$(RM) -f -- "$@"
+ $(VBOX_DEF_2_LAZY_LOAD) --explicit-load-function --library VBoxSVGA3D --output "$@" $(filter %.def, $^)
+ $$(VBoxDD_0_OUTDIR)/VBoxSVGA3DObjCLazyLoad.asm: $(PATH_SUB_CURRENT)/Graphics/VBoxSVGA3DObjC.def $(VBOX_DEF_2_LAZY_LOAD) | $$(dir $$@)
+ $(call MSG_TOOL,VBoxDef2LazyLoad,VBoxDD,$(filter %.def, $^),$@)
+ $(QUIET)$(RM) -f -- "$@"
+ $(VBOX_DEF_2_LAZY_LOAD) --explicit-load-function --library VBoxSVGA3DObjC --output "$@" $(filter %.def, $^)
+
+ ifdef VBOX_WITH_VMSVGA3D_DYNAMIC_LOAD
+ VBoxDD_DEFS += VMSVGA3D_DYNAMIC_LOAD
+ VBoxDD_SOURCES += \
+ Graphics/DevVGA-SVGA3d-glLdr.cpp
+ else
+ VBoxDD_LIBS.linux += X11 GL
+ VBoxDD_LIBS.win += $(PATH_SDK_$(VBOX_WINPSDK)_LIB)/Opengl32.lib
+ endif
+ VBoxDD_LDFLAGS.darwin += -framework OpenGL
+ VBoxDD_DEFS.darwin += VBOX_VMSVGA3D_DUAL_OPENGL_PROFILE
+ if 0 # Use the OpenGL 3.2 Core profile (see also VBoxSVGA3D_DEFS.darwin and VBoxSVGA3DObjC_DEFS.darwin).
+ VBoxDD_DEFS.darwin += VBOX_VMSVGA3D_DEFAULT_OGL_PROFILE=3.2 VBOX_VMSVGA3D_OTHER_OGL_PROFILE=2.1
+ else
+ VBoxDD_DEFS.darwin += VBOX_VMSVGA3D_DEFAULT_OGL_PROFILE=2.1 VBOX_VMSVGA3D_OTHER_OGL_PROFILE=3.2
+ endif
+ endif
+ if1of ($(VBOX_DEF_MACOSX_VERSION_MIN), 10.6 10.5 10.4)
+ Graphics/DevVGA-SVGA3d.cpp_CXXFLAGS.darwin = -F$(VBOX_PATH_MACOSX_SDK_10_7)/System/Library/Frameworks/
+ Graphics/DevVGA-SVGA3d-info.cpp_CXXFLAGS.darwin = -F$(VBOX_PATH_MACOSX_SDK_10_7)/System/Library/Frameworks/
+ Graphics/DevVGA-SVGA3d-shared.cpp_CXXFLAGS.darwin = -F$(VBOX_PATH_MACOSX_SDK_10_7)/System/Library/Frameworks/
+ Graphics/DevVGA-SVGA3d-savedstate.cpp_CXXFLAGS.darwin = -F$(VBOX_PATH_MACOSX_SDK_10_7)/System/Library/Frameworks/
+ Graphics/DevVGA-SVGA3d-ogl.cpp_CXXFLAGS.darwin = -F$(VBOX_PATH_MACOSX_SDK_10_7)/System/Library/Frameworks/
+ else if1of ($(VBOX_DEF_MACOSX_VERSION_MIN), 10.14 10.15 10.16 11.0)
+ Graphics/DevVGA-SVGA3d-ogl.cpp_CXXFLAGS.darwin = $(VBOX_GCC_Wno-deprecated-declarations)
+ endif
+ endif
+
+ ifdef VBOX_WITH_VDMA
+ VBoxDD_DEFS += VBOX_WITH_VDMA
+ VBoxDD_SOURCES += \
+ Graphics/DevVGA_VDMA.cpp
+ endif
+
+ ifdef VBOX_WITH_PXE_ROM
+ VBoxDD_DEFS += VBOX_WITH_PXE_ROM
+ endif
+
+ # --- USB bits. ---
+
+ ifdef VBOX_WITH_USB
+ VBoxDD_DEFS += VBOX_WITH_USB
+ VBoxDD_SOURCES += \
+ USB/vrdp/USBProxyDevice-vrdp.cpp \
+ USB/usbip/USBProxyDevice-usbip.cpp
+
+ VBoxDD_DEFS.darwin += VUSB_HAVE_USBPROXY_DEVICE
+ VBoxDD_SOURCES.darwin += \
+ USB/USBProxyDevice.cpp \
+ USB/darwin/USBProxyDevice-darwin.cpp
+# if1of ($(VBOX_DEF_MACOSX_VERSION_MIN), 10.9) # Hack, shouldn't be needed
+# USB/darwin/USBProxyDevice-darwin.cpp_SDKS = MACOSX1010
+# endif
+
+ VBoxDD_DEFS.linux += \
+ VUSB_HAVE_USBPROXY_DEVICE \
+ $(if $(VBOX_WITH_LINUX_COMPILER_H),VBOX_WITH_LINUX_COMPILER_H,) \
+ $(if $(VBOX_USB_WITH_SYSFS),VBOX_USB_WITH_SYSFS,)
+ VBoxDD_SOURCES.linux += \
+ USB/USBProxyDevice.cpp \
+ USB/linux/USBProxyDevice-linux.cpp
+
+ VBoxDD_DEFS.os2 += VUSB_HAVE_USBPROXY_DEVICE
+ VBoxDD_INCS.os2 += $(PATH_ROOT)/src/VBox/HostDrivers/VBoxUSB/os2
+ VBoxDD_SOURCES.os2 += \
+ USB/USBProxyDevice.cpp \
+ USB/os2/USBProxyDevice-os2.cpp
+
+ VBoxDD_DEFS.win += VUSB_HAVE_USBPROXY_DEVICE
+ VBoxDD_SOURCES.win += \
+ USB/USBProxyDevice.cpp \
+ USB/win/USBProxyDevice-win.cpp
+
+ VBoxDD_DEFS.solaris += VUSB_HAVE_USBPROXY_DEVICE
+ VBoxDD_SOURCES.solaris+= \
+ USB/USBProxyDevice.cpp \
+ USB/solaris/USBProxyDevice-solaris.cpp
+
+ VBoxDD_DEFS.freebsd += VUSB_HAVE_USBPROXY_DEVICE
+ VBoxDD_SOURCES.freebsd+= \
+ USB/USBProxyDevice.cpp \
+ USB/freebsd/USBProxyDevice-freebsd.cpp
+
+ ifdef VBOX_WITH_SCSI
+ VBoxDD_SOURCES += \
+ Storage/UsbMsd.cpp
+ endif
+
+ if defined(VBOX_WITH_EHCI_IMPL)
+ VBoxDD_DEFS += VBOX_WITH_EHCI_IMPL
+ VBoxDD_SOURCES += \
+ USB/DevEHCI.cpp
+ endif
+
+ if defined(VBOX_WITH_XHCI_IMPL)
+ VBoxDD_DEFS += VBOX_WITH_XHCI_IMPL
+ VBoxDD_SOURCES += \
+ USB/DevXHCI.cpp
+ endif
+
+ if defined(VBOX_WITH_USB_VIDEO_IMPL) && !defined(VBOX_WITH_EXTPACK_PUEL)
+ if1of ($(KBUILD_TARGET), linux)
+ VBoxDD_DEFS += VBOX_WITH_USB_VIDEO_IMPL
+ VBoxDD_SOURCES += \
+ $(PATH_ROOT)/src/VBox/ExtPacks/Puel/UsbWebcam/UsbWebcam.cpp \
+ $(PATH_ROOT)/src/VBox/ExtPacks/Puel/UsbWebcam/UsbWebcamDesc.cpp \
+ $(PATH_ROOT)/src/VBox/ExtPacks/Puel/UsbWebcam/jpggen.cpp \
+ $(PATH_ROOT)/src/VBox/ExtPacks/Puel/UsbWebcam/DrvHostWebcam/DrvHostWebcam.cpp \
+ $(PATH_ROOT)/src/VBox/ExtPacks/Puel/UsbWebcam/DrvHostWebcam/JPEGEnc.cpp
+ $(PATH_ROOT)/src/VBox/ExtPacks/Puel/UsbWebcam/DrvHostWebcam/JPEGEnc.cpp_INCS = \
+ $(VBOX_JPEG_INCS)
+ VBoxDD_SOURCES.linux += \
+ $(PATH_ROOT)/src/VBox/ExtPacks/Puel/UsbWebcam/DrvHostWebcam/HostWebcam-v4l2.cpp
+ VBoxDD_LIBS += \
+ $(PATH_STAGE_LIB)/VBox-libjpeg$(VBOX_SUFF_LIB)
+ endif
+ endif
+
+ endif # VBOX_WITH_USB
+
+ ifdef VBOX_WITH_VUSB
+ VBoxDD_DEFS += VBOX_WITH_VUSB
+ VBoxDD_SOURCES += \
+ USB/DevOHCI.cpp \
+ USB/DrvVUSBRootHub.cpp \
+ USB/VUSBDevice.cpp \
+ USB/VUSBSniffer.cpp \
+ USB/VUSBSnifferPcapNg.cpp \
+ USB/VUSBSnifferUsbMon.cpp \
+ USB/VUSBSnifferVmx.cpp \
+ USB/VUSBUrb.cpp \
+ USB/VUSBUrbPool.cpp \
+ USB/VUSBUrbTrace.cpp
+ endif
+
+ # --- Networking bits. ---
+
+ ifdef VBOX_WITH_INIP
+ ifndef LWIP_SOURCES
+ include $(PATH_SUB_CURRENT)/Network/lwip-new/Config.kmk
+ endif
+ VBoxDD_DEFS += VBOX_WITH_INIP
+ VBoxDD_SOURCES += \
+ Network/DevINIP.cpp \
+ $(addprefix Network/lwip-new/,$(LWIP_SOURCES))
+ VBoxDD_INCS += \
+ Network \
+ $(addprefix Network/lwip-new/,$(LWIP_INCS))
+ endif # VBOX_WITH_INIP
+
+ ifdef VBOX_WITH_E1000
+ VBoxDD_DEFS += VBOX_WITH_E1000
+ VBoxDD_SOURCES += \
+ Network/DevE1000.cpp \
+ Network/DevE1000Phy.cpp \
+ Network/DevEEPROM.cpp
+ endif
+
+ ifdef VBOX_WITH_VIRTIO
+ VBoxDD_DEFS += VBOX_WITH_VIRTIO
+ VBoxDD_SOURCES += \
+ VirtIO/VirtioCore.cpp \
+ Network/DevVirtioNet_1_0.cpp
+ endif
+
+
+ ifdef VBOX_WITH_UDPTUNNEL
+ VBoxDD_DEFS += VBOX_WITH_UDPTUNNEL
+ VBoxDD_SOURCES += \
+ Network/DrvUDPTunnel.cpp
+ endif
+
+ ifdef VBOX_WITH_VDE
+ VBoxDD_DEFS += VBOX_WITH_VDE
+ VBoxDD_SOURCES += \
+ Network/DrvVDE.cpp \
+ Network/VDEPlug.cpp
+ endif
+
+ ifdef VBOX_WITH_NETSHAPER
+ VBoxDD_DEFS += VBOX_WITH_NETSHAPER
+ VBoxDD_SOURCES += \
+ Network/DrvNetShaper.cpp
+ endif
+
+ ifdef VBOX_WITH_VMNET
+ VBoxDD_DEFS.darwin += VBOX_WITH_VMNET
+ VBoxDD_SOURCES.darwin += \
+ Network/DrvVMNet.m
+ VBoxDD_LDFLAGS.darwin += -framework vmnet
+ endif
+
+ if defined(VBOX_WITH_CLOUD_NET) && defined(VBOX_WITH_LIBSSH)
+ VBoxDD_SDKS += VBOX_SSH VBOX_ZLIB VBOX_OPENSSL2
+ VBoxDD_DEFS += VBOX_WITH_CLOUD_NET
+ VBoxDD_SOURCES += \
+ Network/DrvCloudTunnel.cpp
+
+ VBoxDD_SOURCES += \
+ $(VBoxDD_0_OUTDIR)/VBoxLibSshLazyLoad.asm
+ VBoxDD_CLEAN += $(VBoxDD_0_OUTDIR)/VBoxLibSshLazyLoad.asm
+ $$(VBoxDD_0_OUTDIR)/VBoxLibSshLazyLoad.asm: $(PATH_SUB_CURRENT)/Network/VBoxLibSsh.def $(VBOX_DEF_2_LAZY_LOAD) | $$(dir $$@)
+ $(call MSG_TOOL,VBoxDef2LazyLoad,VBoxDD,$(filter %.def, $^),$@)
+ $(QUIET)$(RM) -f -- "$@"
+ $(VBOX_DEF_2_LAZY_LOAD) --explicit-load-function --library VBoxLibSsh --output "$@" $(filter %.def, $^)
+ endif
+
+ # --- Storage bits. ---
+
+ ifdef VBOX_WITH_AHCI
+ VBoxDD_DEFS += VBOX_WITH_AHCI IN_AHCI_R3
+ VBoxDD_SOURCES += \
+ Storage/DevAHCI.cpp
+ endif
+
+ ifdef VBOX_WITH_BUSLOGIC
+ VBoxDD_DEFS += VBOX_WITH_BUSLOGIC
+ VBoxDD_SOURCES += \
+ Storage/DevBusLogic.cpp
+ endif
+
+ ifdef VBOX_WITH_LSILOGIC
+ VBoxDD_DEFS += VBOX_WITH_LSILOGIC
+ VBoxDD_SOURCES += \
+ Storage/DevLsiLogicSCSI.cpp
+ endif
+
+ if defined(VBOX_WITH_NVME_IMPL) && !defined(VBOX_WITH_EXTPACK_PUEL)
+ VBoxDD_DEFS += VBOX_WITH_NVME_IMPL
+ VBoxDD_SOURCES += \
+ Storage/DevNVMe.cpp
+ endif
+
+ if defined(VBOX_WITH_VIRTIO) && defined(VBOX_WITH_VIRTIO_SCSI)
+ VBoxDD_DEFS += VBOX_WITH_VIRTIO_SCSI
+ VBoxDD_SOURCES += \
+ Storage/DevVirtioSCSI.cpp
+ endif
+
+ if defined(VBOX_WITH_TPM)
+ VBoxDD_DEFS += VBOX_WITH_TPM
+ VBoxDD_SOURCES += \
+ Security/DevTpm.cpp \
+ Security/DrvTpmEmu.cpp
+
+ VBoxDD_SOURCES.linux += \
+ Security/DrvTpmHost.cpp
+
+ VBoxDD_SOURCES.win += \
+ Security/DrvTpmHost.cpp
+
+ if defined(VBOX_WITH_LIBTPMS)
+ VBoxDD_SDKS += VBOX_TPMS
+ VBoxDD_DEFS += VBOX_WITH_LIBTPMS
+ VBoxDD_SOURCES += \
+ Security/DrvTpmEmuTpms.cpp
+ endif
+ endif
+
+ ifdef VBOX_WITH_PDM_ASYNC_COMPLETION
+ VBoxDD_DEFS += VBOX_WITH_PDM_ASYNC_COMPLETION
+ endif
+
+ ifdef VBOX_WITH_SCSI
+ VBoxDD_DEFS += VBOX_WITH_SCSI
+ VBoxDD_SOURCES += \
+ Storage/DrvSCSI.cpp
+ endif
+
+ ifdef VBOX_WITH_ISCSI
+ $(eval $(call def_vbox_lwip_flags, \
+ VBoxDD, Storage/DrvVD.cpp, Network/lwip-new))
+ endif
+
+ ifdef VBOX_WITH_DRV_DISK_INTEGRITY
+ VBoxDD_DEFS += VBOX_WITH_DRV_DISK_INTEGRITY
+ VBoxDD_SOURCES += \
+ Storage/DrvDiskIntegrity.cpp \
+ Storage/DrvRamDisk.cpp
+ endif
+
+ ifdef VBOX_WITH_EFI
+ VBoxDD_DEFS += VBOX_WITH_EFI
+ VBoxDD_SOURCES += EFI/DevEFI.cpp
+ EFI/DevEFI.cpp_INCS += EFI/Firmware/BaseTools/Source/C/Include
+ EFI/DevEFI.cpp_INCS.x86 += EFI/Firmware/BaseTools/Source/C/Include/Ia32
+ EFI/DevEFI.cpp_INCS.amd64 += EFI/Firmware/BaseTools/Source/C/Include/X64
+ EFI/DevEFI.cpp_INCS.arm32 += EFI/Firmware/BaseTools/Source/C/Include/Arm
+ EFI/DevEFI.cpp_INCS.arm64 += EFI/Firmware/BaseTools/Source/C/Include/AArch64
+ endif
+
+ if defined(VBOX_WITH_PCI_PASSTHROUGH_IMPL) && !defined(VBOX_WITH_EXTPACK_PUEL)
+ VBoxDD_DEFS += VBOX_WITH_PCI_PASSTHROUGH_IMPL
+ VBoxDD_SOURCES += \
+ Bus/DevPciRaw.cpp \
+ Bus/DrvPciRaw.cpp
+ endif
+
+ ifdef VBOX_WITH_MSI_DEVICES
+ VBoxDD_DEFS += VBOX_WITH_MSI_DEVICES
+ endif
+
+ ifdef VBOX_WITH_DYNAMIC_DSDT
+ VBoxDD_DEFS += VBOX_WITH_DYNAMIC_DSDT
+ endif
+
+ # --- Audio bits (see also VBOX_AUDIO_DEFS in ./Config.kmk). ---
+
+ VBoxDD_DEFS += $(VBOX_AUDIO_DEFS)
+ VBoxDD_SOURCES += \
+ Audio/DevIchAc97.cpp \
+ Audio/DevSB16.cpp \
+ Audio/DevHda.cpp \
+ Audio/DevHdaCodec.cpp \
+ Audio/DevHdaStream.cpp \
+ Audio/AudioHlp.cpp \
+ Audio/AudioMixBuffer.cpp \
+ Audio/AudioMixer.cpp \
+ Audio/DrvAudio.cpp \
+ Audio/DrvHostAudioNull.cpp
+
+ if defined(VBOX_WITH_AUDIO_DEBUG) || defined(VBOX_WITH_AUDIO_VALIDATIONKIT)
+ VBoxDD_SOURCES += \
+ Audio/AudioTest.cpp \
+ Audio/AudioTestService.cpp \
+ Audio/AudioTestServiceTcp.cpp \
+ Audio/AudioTestServiceProtocol.cpp
+ endif
+
+ ifdef VBOX_WITH_AUDIO_DEBUG
+ VBoxDD_DEFS += VBOX_WITH_AUDIO_DEBUG
+ VBoxDD_SOURCES += \
+ Audio/DrvHostAudioDebug.cpp
+ endif
+
+ ifdef VBOX_WITH_AUDIO_VALIDATIONKIT
+ VBoxDD_DEFS += VBOX_WITH_AUDIO_VALIDATIONKIT
+ VBoxDD_SOURCES += \
+ Audio/DrvHostAudioValidationKit.cpp
+ endif
+
+ ifeq ($(KBUILD_TARGET),darwin)
+ VBoxDD_SOURCES += \
+ Audio/DrvHostAudioCoreAudio.cpp \
+ Audio/DrvHostAudioCoreAudioAuth.mm
+ endif
+
+ ifeq ($(KBUILD_TARGET),win)
+ VBoxDD_SOURCES += \
+ Audio/DrvHostAudioDSound.cpp \
+ Audio/DrvHostAudioWasApi.cpp
+ ifdef VBOX_WITH_AUDIO_MMNOTIFICATION_CLIENT
+ VBoxDD_DEFS += VBOX_WITH_AUDIO_MMNOTIFICATION_CLIENT
+ VBoxDD_SOURCES += \
+ Audio/DrvHostAudioDSoundMMNotifClient.cpp
+ endif
+ endif
+
+ ifdef VBOX_WITH_AUDIO_OSS
+ VBoxDD_DEFS += VBOX_WITH_AUDIO_OSS
+ VBoxDD_SOURCES += \
+ Audio/DrvHostAudioOss.cpp
+ endif
+
+ ifdef VBOX_WITH_AUDIO_ALSA
+ VBoxDD_DEFS += VBOX_WITH_AUDIO_ALSA
+ VBoxDD_SOURCES += \
+ Audio/DrvHostAudioAlsa.cpp \
+ Audio/DrvHostAudioAlsaStubs.cpp
+ endif
+
+ ifdef VBOX_WITH_AUDIO_PULSE
+ VBoxDD_DEFS += VBOX_WITH_AUDIO_PULSE
+ VBoxDD_SOURCES += \
+ Audio/DrvHostAudioPulseAudio.cpp \
+ Audio/DrvHostAudioPulseAudioStubs.cpp
+ endif
+
+ # --- WARNING! SLIRP MESS AHEAD! ;-) ---
+ VBOX_SLIRP_SOURCES = \
+ Network/DrvNAT.cpp \
+ Network/slirp/bootp.c \
+ Network/slirp/debug.c \
+ Network/slirp/ip_icmp.c \
+ Network/slirp/ip_input.c \
+ Network/slirp/ip_output.c \
+ Network/slirp/misc.c \
+ Network/slirp/sbuf.c \
+ Network/slirp/slirp.c \
+ Network/slirp/slirp_dns.c \
+ Network/slirp/socket.c \
+ Network/slirp/tcp_input.c \
+ Network/slirp/tcp_output.c \
+ Network/slirp/tcp_subr.c \
+ Network/slirp/tcp_timer.c \
+ Network/slirp/udp.c \
+ Network/slirp/hostres.c \
+ Network/slirp/dnsproxy/hash.c \
+ Network/slirp/tftp.c \
+ Network/slirp/dnsproxy/dnsproxy.c
+
+ ifeq ($(KBUILD_TARGET), win)
+ VBOX_SLIRP_SOURCES += Network/slirp/ip_icmpwin.c
+ else ifneq ($(KBUILD_TARGET),darwin)
+ # helper for debugging unprivileged
+# Network/slirp/ip_icmp.c_DEFS += VBOX_RAWSOCK_DEBUG_HELPER
+# VBOX_SLIRP_SOURCES += ../NetworkServices/NAT/getrawsock.c
+ endif
+
+ ifneq ($(KBUILD_TARGET), win)
+ VBOX_SLIRP_SOURCES += Network/slirp/resolv_conf_parser.c
+ endif
+
+ VBOX_SLIRP_BSD_ARCH = $(subst x86,i386,$(KBUILD_TARGET_ARCH))
+ VBOX_SLIRP_BSD_SOURCES += \
+ Network/slirp/bsd/kern/kern_mbuf.c \
+ Network/slirp/bsd/kern/uipc_mbuf.c \
+ Network/slirp/bsd/kern/uipc_mbuf2.c \
+ Network/slirp/bsd/$(VBOX_SLIRP_BSD_ARCH)/in_cksum.c
+ VBOX_SLIRP_ALIAS_SOURCES = \
+ Network/slirp/libalias/alias.c \
+ Network/slirp/libalias/alias_db.c \
+ Network/slirp/libalias/alias_mod.c \
+ Network/slirp/libalias/alias_proxy.c \
+ Network/slirp/libalias/alias_ftp.c \
+ Network/slirp/libalias/alias_nbt.c \
+ Network/slirp/libalias/alias_util.c
+
+ # Enable VBOX_WITH_DNSMAPPING_IN_HOSTRESOLVER here for a while, then move to
+ # $(file)_DEFS or clean the code disabled with this definition.
+ VBOX_WITH_DNSMAPPING_IN_HOSTRESOLVER=1
+
+ # dump memory related operations.
+ Network/slirp/misc.c_DEFS += $(if $(VBOX_NAT_MEM_DEBUG),VBOX_NAT_MEM_DEBUG,)
+
+ VBoxDD_SOURCES += $(VBOX_SLIRP_SOURCES)
+ define def_vbox_slirp_cflags
+ $(file)_DEFS += \
+ $(if $(VBOX_WITH_SLIRP_MEMORY_CHECK),RTMEM_WRAP_TO_EF_APIS,) \
+ $(if $(VBOX_WITH_DEBUG_NAT_SOCKETS),VBOX_WITH_DEBUG_NAT_SOCKETS,) \
+ $(if $(VBOX_WITH_DNSMAPPING_IN_HOSTRESOLVER),VBOX_WITH_DNSMAPPING_IN_HOSTRESOLVER,) \
+ $(if $(VBOX_WITH_NAT_SEND2HOME),VBOX_WITH_NAT_SEND2HOME,) \
+ $(if $(VBOX_WITH_HIDDEN_TCPTEMPLATE),VBOX_WITH_HIDDEN_TCPTEMPLATE,) \
+ $(if $(VBOX_WITH_SLIRP_MT),VBOX_WITH_SLIRP_MT,)
+ $(file)_INCS += \
+ $(1)/slirp/bsd/sys \
+ $(1)/slirp/bsd/sys/sys \
+ $(1)/slirp/bsd/$(VBOX_SLIRP_BSD_ARCH)/include \
+ $(1)/slirp/bsd/netinet \
+ $(1)/slirp \
+ $(1)/slirp/libalias
+ ifeq ($(KBUILD_TARGET),win)
+ $(file)_CFLAGS = -wd4018
+ else
+ $(file)_CFLAGS += -Wno-sign-compare -Wno-format -Wno-bad-function-cast
+ endif
+ endef
+
+ $(foreach file,$(VBOX_SLIRP_SOURCES),$(eval $(call def_vbox_slirp_cflags, Network)))
+
+ VBoxDD_SOURCES += $(VBOX_SLIRP_ALIAS_SOURCES)
+ define def_vbox_slirp_alias_cflags
+ $(file)_DEFS += VBOX_SLIRP_ALIAS \
+ $(if $(VBOX_WITH_DEBUG_LIBALIAS),VBOX_WITH_DEBUG_LIBALIAS,)
+ $(file)_INCS += \
+ $(1)/slirp/libalias \
+ $(1)/slirp \
+ $(1)/slirp/dnsproxy
+ ifneq ($(KBUILD_TARGET),win)
+ $(file)_CFLAGS += -Wno-shadow
+ endif
+ endef
+ $(foreach file,$(VBOX_SLIRP_ALIAS_SOURCES),$(eval $(call def_vbox_slirp_cflags, Network)))
+ $(foreach file,$(VBOX_SLIRP_ALIAS_SOURCES),$(eval $(call def_vbox_slirp_alias_cflags, Network)))
+
+ VBOX_SLIRP_BSD_SOURCES += $(VBOX_SLIRP_BSD_SOURCES.${KBUILD_TARGET_ARCH})
+ VBoxDD_SOURCES += $(VBOX_SLIRP_BSD_SOURCES)
+ define def_vbox_slirp_bsd_cflags
+ $(file)_DEFS += VBOX_SLIRP_BSD
+ $(file)_INCS += $(1)/slirp/dnsproxy
+ endef
+ $(foreach file,$(VBOX_SLIRP_BSD_SOURCES),$(eval $(call def_vbox_slirp_cflags, Network)))
+ $(foreach file,$(VBOX_SLIRP_BSD_SOURCES),$(eval $(call def_vbox_slirp_bsd_cflags, Network)))
+
+
+ # --- OS specific driver hacks. ---
+
+ ifeq ($(KBUILD_TARGET),freebsd)
+ VBoxDD_SOURCES.freebsd += Network/DrvTAP.cpp
+ endif # freebsd
+
+ VBoxDD_SOURCES.linux += \
+ Network/DrvTAP.cpp \
+ Parallel/DrvHostParallel.cpp
+
+ ifeq ($(KBUILD_TARGET),solaris)
+ ifdef VBOX_WITH_SUID_WRAPPER
+ VBoxDD_DEFS += VBOX_WITH_SUID_WRAPPER
+ endif
+ endif
+
+ VBoxDD_DEFS.win += VBOX_WITH_WIN_PARPORT_SUP
+ VBoxDD_SOURCES.win += \
+ Parallel/DrvHostParallel.cpp
+
+ ifdef VBOX_WITH_VIRTUALKD
+ VBoxDD_DEFS.win += VBOX_WITH_VIRTUALKD
+ VBoxDD_SOURCES.win += \
+ Misc/DevVirtualKD.cpp
+ endif
+
+ if defined(VBOX_WITH_NETFLT)
+ VBoxDD_DEFS += VBOX_WITH_NETFLT
+ if defined(VBOX_NETFLT_ONDEMAND_BIND)
+ VBoxDD_DEFS.win += VBOX_NETFLT_ONDEMAND_BIND
+ endif
+ endif
+
+ # --- Final bits, mostly libraries for order dependant linkers. ---
+
+ VBoxDD_LIBS += \
+ $(PATH_STAGE_LIB)/VgaDefBiosLogo$(VBOX_SUFF_LIB) \
+ $(LIB_RUNTIME)
+ ifeq ($(KBUILD_TARGET),win)
+ VBoxDD_LIBS += \
+ $(LIB_DDU) \
+ $(PATH_STAGE_LIB)/VBoxDD2.lib
+ else
+ VBoxDD_LIBS += \
+ $(VBoxDDU_1_STAGE_TARGET) \
+ $(VBoxDD2_1_STAGE_TARGET)
+ endif
+
+ ifdef VBOX_WITH_NETFLT
+ VBoxDD_LIBS.win += $(PATH_STAGE_LIB)/WinNetConfigDll$(VBOX_SUFF_LIB)
+ endif
+
+ ifeq ($(KBUILD_TARGET),solaris)
+ VBoxDD_LIBS += adm
+ ifdef VBOX_WITH_SUID_WRAPPER
+ VBoxDD_LIBS += secdb
+ endif
+ ifdef VBOX_WITH_USB
+ VBoxDD_LIBS += aio
+ endif
+ endif
+
+
+ ifdef VBOX_WITH_DYNAMIC_DSDT
+ VBoxDD_CLEAN += $(VBoxDD_0_OUTDIR)/vboxdsl.hex
+ PC/ACPI/VBoxAcpi.cpp_DEPS = $(VBoxDD_0_OUTDIR)/vboxdsl.hex
+
+ $$(VBoxDD_0_OUTDIR)/vboxdsl.hex: $(PATH_SUB_CURRENT)/PC/vbox.dsl | $$(dir $$@)
+ $(call MSG_TOOL,bin2c,VBoxDD,$<,$@)
+ $(QUIET)$(VBOX_BIN2C) -export VboxDslSource $< $@
+
+ vboxdsl.hex:: $$(VBoxDD_0_OUTDIR)/vboxdsl.hex
+
+ else # !VBOX_WITH_DYNAMIC_DSDT
+ # VBoxAcpi.cpp needs vboxaml.hex which we generate from PC/vbox.dsl
+ VBoxDD_CLEAN += \
+ $(VBoxDD_0_OUTDIR)/vboxaml.hex \
+ $(VBoxDD_0_OUTDIR)/vboxaml.aml \
+ $(VBoxDD_0_OUTDIR)/vboxaml.aml.tmp \
+ $(VBoxDD_0_OUTDIR)/vboxssdt_standard.hex \
+ $(VBoxDD_0_OUTDIR)/vboxssdt_standard.aml \
+ $(VBoxDD_0_OUTDIR)/vboxssdt_standard.aml.tmp \
+ $(VBoxDD_0_OUTDIR)/vboxssdt_cpuhotplug.hex \
+ $(VBoxDD_0_OUTDIR)/vboxssdt_cpuhotplug.aml \
+ $(VBoxDD_0_OUTDIR)/vboxssdt_cpuhotplug.aml.tmp \
+ $(VBoxDD_0_OUTDIR)/vboxssdt_cpuhotplug.aml.pre \
+ $(if $(VBOX_WITH_TPM),$(VBoxDD_0_OUTDIR)/vboxssdt_tpm.hex,) \
+ $(if $(VBOX_WITH_TPM),$(VBoxDD_0_OUTDIR)/vboxssdt_tpm.aml,) \
+ $(if $(VBOX_WITH_TPM),$(VBoxDD_0_OUTDIR)/vboxssdt_tpm.aml.tmp,)
+ PC/ACPI/VBoxAcpi.cpp_DEPS = \
+ $(VBoxDD_0_OUTDIR)/vboxaml.hex \
+ $(VBoxDD_0_OUTDIR)/vboxssdt_standard.hex \
+ $(VBoxDD_0_OUTDIR)/vboxssdt_cpuhotplug.hex \
+ $(if $(VBOX_WITH_TPM),$(VBoxDD_0_OUTDIR)/vboxssdt_tpm.hex,)
+
+ $$(VBoxDD_0_OUTDIR)/vboxaml.hex: $(PATH_SUB_CURRENT)/PC/vbox.dsl | $$(dir $$@)
+ $(call MSG_TOOL,iasl,VBoxDD,$<,$@)
+ $(QUIET)$(VBOX_IASLCMD) -tc -vs -p $@ $<
+ $(QUIET)$(MV) -f $@ $@.tmp
+ $(QUIET)$(SED) -e "s/vboxaml_aml_code/AmlCode/g" \
+ --output $@ $@.tmp
+ $(QUIET)$(RM) -f $@.tmp
+
+ vboxaml.hex:: $$(VBoxDD_0_OUTDIR)/vboxaml.hex
+
+ $$(VBoxDD_0_OUTDIR)/vboxssdt_standard.hex: $(PATH_SUB_CURRENT)/PC/vbox-standard.dsl | $$(dir $$@)
+ $(call MSG_TOOL,iasl,VBoxDD,$<,$@)
+ $(QUIET)$(RM) -f $@ $@.tmp
+ $(QUIET)$(VBOX_IASLCMD) -tc -vs -p $@ $<
+ $(QUIET)$(MV) -f $@ $@.tmp
+ $(QUIET)$(SED) -e "s/AmlCode\|vboxssdt_standard_aml_code/AmlCodeSsdtStandard/g" \
+ --output $@ $@.tmp
+ $(QUIET)$(RM) -f $@.tmp
+
+
+ vboxssdt_standard.hex:: $$(VBoxDD_0_OUTDIR)/vboxssdt_standard.hex
+
+ $$(VBoxDD_0_OUTDIR)/vboxssdt_cpuhotplug.hex: $(PATH_SUB_CURRENT)/PC/vbox-cpuhotplug.dsl | $$(dir $$@)
+ $(call MSG_TOOL,iasl,VBoxDD,$<,$@)
+ $(QUIET)$(RM) -f $@ $@.tmp $@.pre
+ $(QUIET)$(TOOL_$(VBOX_GCC_TOOL)_CC) -E -P -x c -o $@.pre $<
+ $(QUIET)$(SED) -e "s/<NL>/\n/g" \
+ --output $@.pre1 $@.pre
+ $(QUIET)$(VBOX_IASLCMD) -tc -vs -p $@ $@.pre1
+ $(QUIET)$(MV) -f $@ $@.tmp
+ $(QUIET)$(SED) -e "s/AmlCode\|vboxssdt_cpuhotplug_aml_code/AmlCodeSsdtCpuHotPlug/g" \
+ --output $@ $@.tmp
+ $(QUIET)$(RM) -f $@.tmp $@.pre $@.pre1
+
+
+ vboxssdt_cpuhotplug.hex:: $$(VBoxDD_0_OUTDIR)/vboxssdt_cpuhotplug.hex
+
+ if defined(VBOX_WITH_TPM)
+ $$(VBoxDD_0_OUTDIR)/vboxssdt_tpm.hex: $(PATH_SUB_CURRENT)/PC/vbox-tpm.dsl | $$(dir $$@)
+ $(call MSG_TOOL,iasl,VBoxDD,$<,$@)
+ $(QUIET)$(RM) -f $@ $@.tmp
+ $(QUIET)$(VBOX_IASLCMD) -tc -vs -p $@ $<
+ $(QUIET)$(MV) -f $@ $@.tmp
+ $(QUIET)$(SED) -e "s/AmlCode\|vboxssdt_tpm_aml_code/AmlCodeSsdtTpm/g" \
+ --output $@ $@.tmp
+ $(QUIET)$(RM) -f $@.tmp
+
+ vboxssdt_tpm.hex:: $$(VBoxDD_0_OUTDIR)/vboxssdt_tpm.hex
+ endif # !VBOX_WITH_TPM
+
+ endif # !VBOX_WITH_DYNAMIC_DSDT
+ PC/ACPI/VBoxAcpi.cpp_INCS = $(VBoxDD_0_OUTDIR)
+
+ # For finding PCIInternal.h from VBox/pci.h.
+ Bus/DevPCI.cpp_INCS = Bus
+ Bus/DevPciIch9.cpp_INCS = Bus
+ Bus/MsiCommon.cpp_INCS = Bus
+ Bus/MsixCommon.cpp_INCS = Bus
+ Bus/DevPciRaw.cpp_INCS = Bus
+
+ # For finding and generating vbetables.h (see Graphics/BIOS/Makefile.kmk).
+ Graphics/DevVGA.cpp_INCS = $(VgaBiosBin_0_OUTDIR) $(VBOX_GRAPHICS_INCS)
+ Graphics/DevVGA.cpp_DEPS = $(VgaBiosBin_0_OUTDIR)/vbetables.h
+
+ $(call VBOX_SET_VER_INFO_DLL,VBoxDD,VirtualBox VMM Devices and Drivers) # (last!)
+
+
+ ifdef VBOX_WITH_RAW_MODE
+ #
+ # VBoxDDRC (sysmod)
+ #
+ VBoxDDRC_TEMPLATE = VBoxRc
+ ifeq ($(KBUILD_TARGET_ARCH),x86)
+ VBoxDDRC_DEFS.darwin = VBOX_WITH_2X_4GB_ADDR_SPACE
+ endif
+ VBoxDDRC_DEFS = \
+ $(if $(VBOX_WITH_HGCM),VBOX_WITH_HGCM,) \
+ $(if $(VBOX_WITH_IOMMU_AMD),VBOX_WITH_IOMMU_AMD,) \
+ $(if $(VBOX_WITH_IOMMU_INTEL),VBOX_WITH_IOMMU_INTEL,)
+ VBoxDDRC_INCS = build $(VBOX_GRAPHICS_INCS)
+ VBoxDDRC_SOURCES = \
+ Bus/DevPCI.cpp \
+ Bus/DevPciIch9.cpp \
+ Bus/MsiCommon.cpp \
+ Bus/MsixCommon.cpp \
+ $(if $(VBOX_WITH_IOMMU_AMD),Bus/DevIommuAmd.cpp,) \
+ $(if $(VBOX_WITH_IOMMU_INTEL),Bus/DevIommuIntel.cpp,) \
+ EFI/DevSmc.cpp \
+ Graphics/DevVGA.cpp \
+ Input/DevPS2.cpp \
+ Input/DevPS2K.cpp \
+ Input/DevPS2M.cpp \
+ PC/DevACPI.cpp \
+ PC/DevIoApic.cpp \
+ PC/DevPit-i8254.cpp \
+ PC/DevPIC.cpp \
+ PC/DevRTC.cpp \
+ PC/DevDMA.cpp \
+ PC/DevHPET.cpp \
+ Storage/DevATA.cpp \
+ Network/DevPCNet.cpp \
+ Network/DevDP8390.cpp \
+ Network/Dev3C501.cpp \
+ Serial/DevSerial.cpp \
+ Serial/DevOxPcie958.cpp \
+ Serial/UartCore.cpp \
+ Parallel/DevParallel.cpp \
+ VMMDev/VMMDev.cpp \
+ VMMDev/VMMDevTesting.cpp
+
+ VBoxDDRC_DEFS += $(VBOX_AUDIO_DEFS)
+ VBoxDDRC_SOURCES += \
+ Audio/DevHda.cpp \
+ Audio/DevIchAc97.cpp
+
+ VBoxDDRC_DEFS += \
+ $(if $(VBOX_WITH_HP_HDA),VBOX_WITH_HP_HDA,) \
+ $(if $(VBOX_WITH_INTEL_HDA),VBOX_WITH_INTEL_HDA,) \
+ $(if $(VBOX_WITH_NVIDIA_HDA),VBOX_WITH_NVIDIA_HDA,)
+
+ ifdef VBOX_WITH_E1000
+ VBoxDDRC_DEFS += VBOX_WITH_E1000
+ VBoxDDRC_SOURCES += \
+ Network/DevE1000.cpp \
+ Network/DevE1000Phy.cpp
+ endif
+
+ ifdef VBOX_WITH_VIRTIO
+ VBoxDDRC_DEFS += VBOX_WITH_VIRTIO
+ VBoxDDRC_SOURCES += \
+ VirtIO/VirtioCore.cpp \
+ Network/DevVirtioNet_1_0.cpp
+ endif
+
+ ifdef VBOX_WITH_HGSMI
+ VBoxDDRC_DEFS += VBOX_WITH_HGSMI
+ endif
+ ifdef VBOX_WITH_WDDM
+ VBoxDDRC_DEFS += VBOX_WITH_WDDM
+ endif
+ ifdef VBOX_WITH_VDMA
+ VBoxDDRC_DEFS += VBOX_WITH_VDMA
+ endif
+ ifdef VBOXWDDM_WITH_VBVA
+ VBoxDDRC_DEFS += VBOXWDDM_WITH_VBVA
+ endif
+ ifdef VBOX_WITH_VMSVGA
+ VBoxDDRC_DEFS += VBOX_WITH_VMSVGA
+ VBoxDDRC_SOURCES += \
+ Graphics/DevVGA-SVGA.cpp
+ endif
+ ifdef VBOX_WITH_VMSVGA3D
+ VBoxDDRC_DEFS += VBOX_WITH_VMSVGA3D
+ endif
+
+ ifdef VBOX_WITH_VUSB
+ VBoxDDRC_DEFS += VBOX_WITH_VUSB
+ VBoxDDRC_SOURCES += \
+ USB/DevOHCI.cpp
+ endif
+
+ ifdef VBOX_WITH_USB
+ VBoxDDRC_DEFS += VBOX_WITH_USB
+ if defined(VBOX_WITH_EHCI_IMPL)
+ VBoxDDRC_DEFS += VBOX_WITH_EHCI_IMPL
+ VBoxDDRC_SOURCES += \
+ USB/DevEHCI.cpp
+ endif
+ if defined(VBOX_WITH_XHCI_IMPL)
+ VBoxDDRC_DEFS += VBOX_WITH_XHCI_IMPL
+ VBoxDDRC_SOURCES += \
+ USB/DevXHCI.cpp
+ endif
+ endif
+
+ ifdef VBOX_WITH_VIDEOHWACCEL
+ VBoxDDRC_DEFS += VBOX_WITH_VIDEOHWACCEL
+ endif
+
+ ifdef VBOX_WITH_AHCI
+ VBoxDDRC_DEFS += VBOX_WITH_AHCI IN_AHCI_GC
+ VBoxDDRC_SOURCES += \
+ Storage/DevAHCI.cpp
+ endif
+
+ ifdef VBOX_WITH_BUSLOGIC
+ VBoxDDRC_DEFS += VBOX_WITH_BUSLOGIC
+ VBoxDDRC_SOURCES += \
+ Storage/DevBusLogic.cpp
+ endif
+
+ ifdef VBOX_WITH_LSILOGIC
+ VBoxDDRC_DEFS += VBOX_WITH_LSILOGIC
+ VBoxDDRC_SOURCES += \
+ Storage/DevLsiLogicSCSI.cpp
+ endif
+
+ if defined(VBOX_WITH_NVME_IMPL) && !defined(VBOX_WITH_EXTPACK_PUEL)
+ VBoxDDGC_DEFS += VBOX_WITH_NVME_IMPL
+ VBoxDDGC_SOURCES += \
+ Storage/DevNVMe.cpp
+ endif
+
+ if1of ($(VBOX_LDR_FMT32), pe lx)
+ VBoxDDRC_LIBS = \
+ $(PATH_STAGE_LIB)/VMMRCBuiltin$(VBOX_SUFF_LIB) \
+ $(PATH_STAGE_LIB)/VMMRCImp$(VBOX_SUFF_LIB)
+ endif
+ $(call VBOX_SET_VER_INFO_RC,VBoxDDRC,VirtualBox VMM Devices and Drivers$(COMMA) raw-mode) # last!
+ endif # VBOX_WITH_RAW_MODE
+
+
+ #
+ # VBoxDD2 (shared object)
+ #
+ VBoxDD2_TEMPLATE = VBoxR3DllWarnNoPic
+ VBoxDD2_DEFS = \
+ IN_VBOXDD2 \
+ $(if $(VBOX_WITH_PXE_ROM),VBOX_WITH_PXE_ROM,)
+ VBoxDD2_INCS := \
+ build \
+ $(PATH_SUB_CURRENT)
+ VBoxDD2_SOURCES = \
+ build/VBoxDD2.cpp
+ VBoxDD2_LIBS = \
+ $(PATH_STAGE_LIB)/PcBiosBin$(VBOX_SUFF_LIB) \
+ $(PATH_STAGE_LIB)/VgaBiosBin$(VBOX_SUFF_LIB) \
+ $(if $(VBOX_WITH_PXE_ROM),\
+ $(if $(VBOX_WITH_INTEL_PXE),\
+ $(PATH_STAGE_LIB)/NetBiosBin$(VBOX_SUFF_LIB),\
+ $(PATH_STAGE_LIB)/iPxeBiosBin$(VBOX_SUFF_LIB)),) \
+ $(LIB_RUNTIME)
+ VBoxDD2_LDFLAGS.darwin = -install_name $(VBOX_DYLD_EXECUTABLE_PATH)/VBoxDD2.dylib
+ VBoxDD2_LDFLAGS.linux = $(VBOX_GCC_NO_UNDEFINED)
+ if defined(VBOX_WITH_EFI) && !defined(VBOX_WITH_EFIFW_PACKING)
+ VBoxDD_DEFS += VBOX_WITH_EFI_IN_DD2
+ VBoxDD2_DEFS += VBOX_WITH_EFI
+ VBoxDD2_SOURCES.x86 += EFI/DevEFI-binaries.asm
+ VBoxDD2_SOURCES.amd64 += EFI/DevEFI-binaries.asm
+ EFI/DevEFI-binaries.asm_ASINCS = $(PATH_STAGE)/$(INST_BIN)
+ EFI/DevEFI-binaries.asm_DEPS = \
+ $(PATH_STAGE)/$(INST_BIN)VBoxEFI32.fd \
+ $(PATH_STAGE)/$(INST_BIN)VBoxEFI64.fd
+
+ VBoxDD2_SOURCES.arm64 += EFI/DevEFI-binaries.S
+ EFI/DevEFI-binaries.S_ASINCS = $(PATH_STAGE)/$(INST_BIN)
+ EFI/DevEFI-binaries.S_DEPS = \
+ $(PATH_STAGE)/$(INST_BIN)VBoxEFI32.fd \
+ $(PATH_STAGE)/$(INST_BIN)VBoxEFI64.fd
+ endif
+
+ $(call VBOX_SET_VER_INFO_DLL,VBoxDD2,VirtualBox VMM Devices and Drivers 2) # (last!)
+
+ #
+ # VBoxDDR0 (sysmod)
+ #
+ if "$(KBUILD_TARGET)" != "win" && $(VBOX_GCC_VERSION_CXX) < 40600
+ #
+ # Disable "ISO C++ prohibits anonymous structs [-Werror=pedantic]" caused by Mesa VMSVGA driver headers
+ # For GCC >= 4.6.0 the warning is disabled in DevVGA_SVGA.h
+ #
+ # Template used for gcc older than 4.6. (Strips away compiler options.)
+ #
+ TEMPLATE_VBoxDDR0OldGCC := VBoxDDR0OldGCC
+ TEMPLATE_VBoxDDR0OldGCC_EXTENDS := VBoxR0
+ TEMPLATE_VBoxDDR0OldGCC_CXXFLAGS = $(filter-out -pedantic,$(TEMPLATE_$(TEMPLATE_VBoxDDR0OldGCC_EXTENDS)_CXXFLAGS))
+
+ VBoxDDR0_TEMPLATE = VBoxDDR0OldGCC
+ else
+ VBoxDDR0_TEMPLATE = VBoxR0
+ endif
+ VBoxDDR0_DEFS = \
+ $(if $(VBOX_WITH_HGCM),VBOX_WITH_HGCM,) \
+ $(if $(VBOX_WITH_IOMMU_AMD),VBOX_WITH_IOMMU_AMD,) \
+ $(if $(VBOX_WITH_IOMMU_INTEL),VBOX_WITH_IOMMU_INTEL,) \
+ IN_RT_R0 # - WTF is IN_RT_R0 doing here?
+ VBoxDDR0_DEFS.win += VBOX_WITH_WIN_PARPORT_SUP
+ VBoxDDR0_INCS = build $(VBOX_GRAPHICS_INCS)
+ VBoxDDR0_INCS += $(VBOX_PATH_VMSVGA_DEVICE_INC)
+ VBoxDDR0_SDKS.win = ReorderCompilerIncs $(VBOX_WINPSDK) $(VBOX_WINDDK)
+ VBoxDDR0_SOURCES = \
+ build/VBoxDDR0.cpp \
+ Bus/DevPCI.cpp \
+ Bus/DevPciIch9.cpp \
+ Bus/MsiCommon.cpp \
+ Bus/MsixCommon.cpp \
+ $(if $(VBOX_WITH_IOMMU_AMD),Bus/DevIommuAmd.cpp,) \
+ $(if $(VBOX_WITH_IOMMU_INTEL),Bus/DevIommuIntel.cpp,) \
+ EFI/DevSmc.cpp \
+ EFI/DevFlash.cpp \
+ EFI/FlashCore.cpp \
+ Graphics/DevVGA.cpp \
+ Input/DevPS2.cpp \
+ Input/DevPS2K.cpp \
+ Input/DevPS2M.cpp \
+ PC/DevACPI.cpp \
+ PC/DevIoApic.cpp \
+ PC/DevPit-i8254.cpp \
+ PC/DevPIC.cpp \
+ PC/DevRTC.cpp \
+ PC/DevDMA.cpp \
+ PC/DevHPET.cpp \
+ Storage/DevATA.cpp \
+ Network/DevPCNet.cpp \
+ Network/DevDP8390.cpp \
+ Network/Dev3C501.cpp \
+ Serial/DevSerial.cpp \
+ Serial/DevOxPcie958.cpp \
+ Serial/UartCore.cpp \
+ Parallel/DevParallel.cpp \
+ GIMDev/GIMDev.cpp \
+ VMMDev/VMMDev.cpp \
+ VMMDev/VMMDevTesting.cpp \
+ Network/DrvDedicatedNic.cpp \
+ $(if-expr 0,Network/DrvIntNet.cpp,) # no ring-0 driver support at the moment
+
+ ifdef VBOX_WITH_DTRACE_R0
+ VBoxDDR0_USES += dtrace
+ VBoxDDR0_SOURCES += build/VBoxDD.d
+ endif
+
+ VBoxDDR0_SOURCES.win += Parallel/DrvHostParallel.cpp
+
+ VBoxDDR0_DEFS += \
+ $(if $(VBOX_WITH_HGSMI),VBOX_WITH_HGSMI,) \
+ $(if $(VBOX_WITH_WDDM),VBOX_WITH_WDDM,) \
+ $(if $(VBOX_WITH_VDMA),VBOX_WITH_VDMA,) \
+ $(if $(VBOXWDDM_WITH_VBVA),VBOXWDDM_WITH_VBVA,) \
+ $(if $(VBOX_WITH_HP_HDA),VBOX_WITH_HP_HDA,) \
+ $(if $(VBOX_WITH_INTEL_HDA),VBOX_WITH_INTEL_HDA,) \
+ $(if $(VBOX_WITH_NVIDIA_HDA),VBOX_WITH_NVIDIA_HDA,)
+
+ VBoxDDR0_DEFS += $(VBOX_AUDIO_DEFS)
+ VBoxDDR0_SOURCES += \
+ Audio/DevHda.cpp \
+ Audio/DevHdaStream.cpp \
+ Audio/DevIchAc97.cpp
+
+ ifdef VBOX_WITH_E1000
+ VBoxDDR0_DEFS += VBOX_WITH_E1000
+ VBoxDDR0_SOURCES += \
+ Network/DevE1000.cpp \
+ Network/DevE1000Phy.cpp
+ endif
+
+ ifdef VBOX_WITH_VIRTIO
+ VBoxDDR0_DEFS += VBOX_WITH_VIRTIO
+ VBoxDDR0_SOURCES += \
+ VirtIO/VirtioCore.cpp \
+ Network/DevVirtioNet_1_0.cpp
+ endif
+
+ if 0 #def VBOX_WITH_NETSHAPER - no ring-0 driver support at the moment.
+ VBoxDDR0_DEFS += VBOX_WITH_NETSHAPER
+ VBoxDDR0_SOURCES += \
+ Network/DrvNetShaper.cpp
+ endif
+
+ ifdef VBOX_WITH_VMSVGA
+ VBoxDDR0_DEFS += VBOX_WITH_VMSVGA
+ VBoxDDR0_SOURCES += \
+ Graphics/DevVGA-SVGA.cpp
+ endif
+ ifdef VBOX_WITH_VMSVGA3D
+ VBoxDDR0_DEFS += VBOX_WITH_VMSVGA3D
+ endif
+
+ ifdef VBOX_WITH_VUSB
+ VBoxDDR0_DEFS += VBOX_WITH_VUSB
+ VBoxDDR0_SOURCES += \
+ USB/DevOHCI.cpp
+ endif
+ ifdef VBOX_WITH_USB
+ VBoxDDR0_DEFS += VBOX_WITH_USB
+ if defined(VBOX_WITH_EHCI_IMPL)
+ VBoxDDR0_DEFS += VBOX_WITH_EHCI_IMPL
+ VBoxDDR0_SOURCES += \
+ USB/DevEHCI.cpp
+ endif
+ if defined(VBOX_WITH_XHCI_IMPL)
+ VBoxDDR0_DEFS += VBOX_WITH_XHCI_IMPL
+ VBoxDDR0_SOURCES += \
+ USB/DevXHCI.cpp
+ endif
+ endif
+
+ ifdef VBOX_WITH_EFI
+ VBoxDDR0_DEFS += VBOX_WITH_EFI
+ VBoxDDR0_SOURCES += EFI/DevEFI.cpp
+ endif
+
+ if defined(VBOX_WITH_PCI_PASSTHROUGH_IMPL) && !defined(VBOX_WITH_EXTPACK_PUEL)
+ VBoxDDR0_SOURCES += \
+ Bus/DevPciRaw.cpp
+ endif
+
+ ifdef VBOX_WITH_AHCI
+ VBoxDDR0_DEFS += VBOX_WITH_AHCI IN_AHCI_R0
+ VBoxDDR0_SOURCES += \
+ Storage/DevAHCI.cpp
+ endif
+
+ ifdef VBOX_WITH_BUSLOGIC
+ VBoxDDR0_DEFS += VBOX_WITH_BUSLOGIC
+ VBoxDDR0_SOURCES += \
+ Storage/DevBusLogic.cpp
+ endif
+
+ ifdef VBOX_WITH_LSILOGIC
+ VBoxDDR0_DEFS += VBOX_WITH_LSILOGIC
+ VBoxDDR0_SOURCES += \
+ Storage/DevLsiLogicSCSI.cpp
+ endif
+
+ if defined(VBOX_WITH_NVME_IMPL) && !defined(VBOX_WITH_EXTPACK_PUEL)
+ VBoxDDR0_DEFS += VBOX_WITH_NVME_IMPL
+ VBoxDDR0_SOURCES += \
+ Storage/DevNVMe.cpp
+ endif
+
+ if defined (VBOX_WITH_VIRTIO) && defined(VBOX_WITH_VIRTIO_SCSI)
+ VBoxDDR0_DEFS += VBOX_WITH_VIRTIO_SCSI
+ VBoxDDR0_SOURCES += \
+ Storage/DevVirtioSCSI.cpp
+ endif
+
+ if defined(VBOX_WITH_TPM)
+ VBoxDDR0_DEFS += VBOX_WITH_TPM
+ VBoxDDR0_SOURCES += \
+ Security/DevTpm.cpp
+ endif
+
+ ifdef VBOX_WITH_HGSMI
+ VBoxDDR0_DEFS += VBOX_WITH_HGSMI
+ endif
+ ifdef VBOX_WITH_VIDEOHWACCEL
+ VBoxDDR0_DEFS += VBOX_WITH_VIDEOHWACCEL
+ endif
+
+ if1of ($(VBOX_LDR_FMT), pe lx)
+ VBoxDDR0_LIBS = \
+ $(PATH_STAGE_LIB)/VMMR0Imp$(VBOX_SUFF_LIB)
+ endif
+ VBoxDDR0_LIBS += \
+ $(VBOX_LIB_SUPR0)
+
+ $(call VBOX_SET_VER_INFO_R0,VBoxDDR0,VirtualBox VMM Devices and Drivers$(COMMA) ring-0) # (last!)
+
+ ifdef VBOX_WITH_KMOD_WRAPPED_R0_MODS
+ # Wrapper kmod for VBoxDDR0.r0
+ INSTALLS.linux += vbox_vboxddr0-src
+ vbox_vboxddr0-src_INST = bin/src/vbox_vboxddr0/
+ vbox_vboxddr0-src_SYMLINKS = \
+ SUPWrapperMod-linux.c=>../common/SUPWrapperMod-linux.c \
+ Makefile-wrapper.gmk=>../common/Makefile-wrapper.gmk
+ vbox_vboxddr0-src_SOURCES = \
+ $(PATH_ROOT)/src/VBox/HostDrivers/Support/linux/Makefile-vbox_vboxddr0.gmk=>Makefile \
+ $(VBoxDDR0_0_OUTDIR)/VBoxDDR0.r0=>VBoxDDR0.r0 \
+ $(VBoxDDR0_0_OUTDIR)/VBoxDDR0.debug=>VBoxDDR0.debug
+ endif
+
+ #
+ # Ring-0 Services (library, linked into VMMR0.r0)
+ #
+ ServicesR0_TEMPLATE = VBoxR0
+ ServicesR0_DEFS = VBOX_IN_VMM IN_INTNET_R0 IN_RT_R0 $(VMM_COMMON_DEFS) \
+ $(if $(VBOX_WITH_PCI_PASSTHROUGH),IN_PCIRAW_R0,) \
+ $(if $(VBOX_WITH_NAT_SERVICE),VBOX_WITH_NAT_SERVICE,)
+ ServicesR0_SOURCES = \
+ Network/SrvIntNetR0.cpp \
+# $(if $(VBOX_WITH_PCI_PASSTHROUGH),Bus/SrvPciRawR0.cpp,)
+ Network/SrvIntNetR0.cpp_CXXFLAGS := $(if-expr $(KBUILD_TARGET) == "win",,$(VBOX_GCC_Wno-array_bounds))
+
+
+ #
+ # Internal Networking - Ring-3 Testcase for the Ring-0 code (a bit hackish).
+ #
+ ifdef VBOX_WITH_TESTCASES
+ PROGRAMS += tstIntNetR0
+ tstIntNetR0_TEMPLATE = VBOXR3TSTEXE
+ tstIntNetR0_DEFS = IN_INTNET_R0
+ tstIntNetR0_SOURCES = \
+ Network/testcase/tstIntNetR0.cpp
+ ifneq ($(KBUILD_TARGET),win)
+ Network/testcase/tstIntNetR0.cpp_CXXFLAGS = $(VBOX_GCC_Wno-array_bounds)
+ endif
+ endif
+
+
+ #
+ # Internal Networking - Ring-3 Testcase for the Ring-0 code (a bit hackish).
+ #
+ ifdef VBOX_WITH_TESTCASES
+ if defined(VBOX_WITH_HARDENING) && "$(KBUILD_TARGET)" == "win"
+ PROGRAMS += tstIntNetHardened-1
+ tstIntNetHardened-1_TEMPLATE = VBoxR3HardenedTstExe
+ tstIntNetHardened-1_NAME = tstIntNet-1
+ ifdef VBOX_WITH_AUTOMATIC_DEFS_QUOTING
+ tstIntNetHardened-1_DEFS = PROGRAM_NAME_STR="tstIntNet-1"
+ else
+ tstIntNetHardened-1_DEFS = PROGRAM_NAME_STR=\"tstIntNet-1\"
+ endif
+ tstIntNetHardened-1_SOURCES = ../HostDrivers/Support/SUPR3HardenedMainTemplateTestcase.cpp
+
+ DLLS += tstIntNet-1
+ tstIntNet-1_TEMPLATE = VBoxR3HardenedTstDll
+ else
+ PROGRAMS += tstIntNet-1
+ tstIntNet-1_TEMPLATE = VBOXR3TSTEXE
+ endif
+ tstIntNet-1_SOURCES = \
+ Network/testcase/tstIntNet-1.cpp \
+ Network/Pcap.cpp
+ endif
+
+
+ #
+ # EEPROM device unit test requires cppunit
+ #
+ ifdef VBOX_WITH_CPPUNIT_TESTCASES
+ ifdef VBOX_WITH_E1000
+ PROGRAMS += tstDevEEPROM
+ tstDevEEPROM_TEMPLATE = VBOXCPPUNITEXE
+ tstDevEEPROM_SOURCES = \
+ Network/testcase/tstDevEEPROM.cpp
+ tstDevEEPROM_LIBS = \
+ $(TARGET_VBoxDD)
+ PROGRAMS += tstDevPhy
+ tstDevPhy_TEMPLATE = VBOXCPPUNITEXE
+ tstDevPhy_SOURCES = \
+ Network/testcase/tstDevPhy.cpp \
+ Network/DevE1000Phy.cpp
+ tstDevPhy_DEFS = PHY_UNIT_TEST
+ endif
+ endif
+
+ #
+ # Apple SMC Utility.
+ #
+ ifdef VBOX_WITH_TESTCASES
+ PROGRAMS.darwin += VBoxSmcUtil-darwin
+ VBoxSmcUtil-darwin_TEMPLATE = VBOXR3TSTEXE
+ VBoxSmcUtil-darwin_SOURCES = EFI/VBoxSmcUtil-darwin.cpp
+ VBoxSmcUtil-darwin_LDFLAGS = -framework IOKit
+ endif
+
+ #
+ # PDM device testcase framework.
+ #
+ ifdef VBOX_WITH_TESTCASES_TSTDEV
+ PROGRAMS += tstDevice
+ tstDevice_TEMPLATE = VBOXR3TSTEXE
+ tstDevice_DEFS += IN_SUP_R3
+ tstDevice_SOURCES = \
+ testcase/tstDevice.cpp \
+ testcase/tstDeviceR0.cpp \
+ testcase/tstDeviceCfg.cpp \
+ testcase/tstDevicePdmDevHlp.cpp \
+ testcase/tstDevicePdmDevHlpR0.cpp \
+ testcase/tstDevicePdmThread.cpp \
+ testcase/tstDeviceSsmFuzz.cpp \
+ testcase/tstDeviceSsmLoadDbg.cpp \
+ testcase/tstDeviceIoFuzz.cpp
+ endif
+
+endif # !VBOX_ONLY_EXTPACKS && "$(intersects $(KBUILD_TARGET_ARCH),$(VBOX_SUPPORTED_HOST_ARCHS))" != ""
+
+
+if defined(VBOX_WITH_EXTPACK) && defined(VBOX_WITH_EXTPACK_PUEL) && defined(VBOX_WITH_EXTPACK_PUEL_BUILD) && "$(intersects $(KBUILD_TARGET_ARCH),$(VBOX_SUPPORTED_HOST_ARCHS))" != ""
+ if defined(VBOX_WITH_PCI_PASSTHROUGH_IMPL)
+ DLLS += VBoxPciRawR3
+ VBoxPciRawR3_TEMPLATE = VBoxR3ExtPackPuel
+ VBoxPciRawR3_SOURCES = Bus/DevPciRaw.cpp
+ $(call VBOX_SET_VER_INFO_DLL,VBoxPciRawR3,PUEL Extension Pack - PCI Passthrough Device)
+
+ DLLS += VBoxPciRawDrv
+ VBoxPciRawDrv_TEMPLATE = VBoxR3ExtPackPuel
+ VBoxPciRawDrv_SOURCES = Bus/DrvPciRaw.cpp
+ $(call VBOX_SET_VER_INFO_DLL,VBoxPciRawDrv,PUEL Extension Pack - PCI Passthrough Driver)
+
+ $(if-expr defined(VBOX_WITH_VBOXR0_AS_DLL),DLLS,SYSMODS) += VBoxPciRawR0
+ VBoxPciRawR0_TEMPLATE = VBoxR0ExtPackPuel
+ VBoxPciRawR0_SOURCES = Bus/DevPciRaw.cpp
+ $(call VBOX_SET_VER_INFO_R0,VBoxPciRawR0,PUEL Extension Pack - PCI Passthrough Driver$(COMMA) ring-0)
+
+ Bus/DevPciRaw.cpp_INCS = Bus
+ endif
+
+ #
+ # The NVMe Extension Pack Modules.
+ #
+ if defined(VBOX_WITH_NVME_IMPL)
+ DLLS += VBoxNvmeR3
+ VBoxNvmeR3_TEMPLATE = VBoxR3ExtPackPuel
+ VBoxNvmeR3_SOURCES = \
+ Storage/DevNVMe.cpp
+ $(call VBOX_SET_VER_INFO_DLL,VBoxNvmeR3,PUEL Extension Pack - NVMe Device)
+
+ ifdef VBOX_WITH_R0_MODULES
+ ifdef VBOX_WITH_VBOXR0_AS_DLL
+ DLLS += VBoxNvmeR0
+ else
+ SYSMODS += VBoxNvmeR0
+ endif
+ VBoxNvmeR0_TEMPLATE = VBoxR0ExtPackPuel
+ VBoxNvmeR0_SOURCES = \
+ Storage/DevNVMe.cpp
+ $(call VBOX_SET_VER_INFO_R0,VBoxNvmeR0,PUEL Extension Pack - NVMe Device$(COMMA) ring-0)
+ ifdef VBOX_WITH_KMOD_WRAPPED_R0_MODS # Wrapper kmod for VBoxEhciR0.r0
+ INSTALLS.linux += vbox_vboxnvmer0-src
+ vbox_vboxnvmer0-src_INST = bin/src/vbox_vboxnvmer0/
+ vbox_vboxnvmer0-src_SYMLINKS = \
+ SUPWrapperMod-linux.c=>../common/SUPWrapperMod-linux.c \
+ Makefile-wrapper.gmk=>../common/Makefile-wrapper.gmk
+ vbox_vboxnvmer0-src_SOURCES = \
+ $(PATH_ROOT)/src/VBox/HostDrivers/Support/linux/Makefile-vbox_vboxnvmer0.gmk=>Makefile \
+ $(VBoxNvmeR0_0_OUTDIR)/VBoxNvmeR0.r0=>VBoxNvmeR0.r0 \
+ $(VBoxNvmeR0_0_OUTDIR)/VBoxNvmeR0.debug=>VBoxNvmeR0.debug
+ endif
+ endif
+
+ ifdef VBOX_WITH_RAW_MODE
+ SYSMODS += VBoxNvmeRC
+ VBoxNvmeRC_TEMPLATE = VBoxRcExtPackPuel
+ VBoxNvmeRC_SOURCES = \
+ Storage/DevNVMe.cpp
+ $(call VBOX_SET_VER_INFO_RC,VBoxNvmeRC,PUEL Extension Pack - NVMe Device$(COMMA) raw-mode)
+ endif
+
+ # Hacky but MSI support *must* be enabled
+ ifdef VBOX_WITH_MSI_DEVICES
+ VBoxNvmeR3_DEFS += VBOX_WITH_MSI_DEVICES
+ VBoxNvmeR0_DEFS += VBOX_WITH_MSI_DEVICES
+ VBoxNvmeRC_DEFS += VBOX_WITH_MSI_DEVICES
+ endif
+
+ endif
+
+
+ #
+ # The Intel PXE ROM.
+ #
+ INSTALLS += VBoxExtPackPuelInsRoms
+ VBoxExtPackPuelInsRoms_TEMPLATE = VBoxInsExtPackPuel
+ ifdef PXE_EXPERIMENTAL_BUILD_SETUP
+ VBoxExtPackPuelInsRoms_SOURCES = $(PATH_OUT)/obj/NetBiosBin/NetBiosBin.rom=>PXE-Intel.rom
+ else
+ VBoxExtPackPuelInsRoms_SOURCES = PC/PXE/PXE-Intel.rom=>PXE-Intel.rom
+ endif
+endif # VBOX_WITH_EXTPACK_PUEL && "$(intersects $(KBUILD_TARGET_ARCH),$(VBOX_SUPPORTED_HOST_ARCHS))" != ""
+
+
+if defined(VBOX_WITH_VMSVGA3D) && !defined(VBOX_ONLY_EXTPACKS) && "$(intersects $(KBUILD_TARGET_ARCH),$(VBOX_SUPPORTED_HOST_ARCHS))" != ""
+ #
+ # Template used for VBoxSVGA3D. (Strips away compiler options.)
+ #
+ TEMPLATE_VBoxSVGA3D := VBoxSVGA3D
+ TEMPLATE_VBoxSVGA3D_EXTENDS := VBOXR3
+ TEMPLATE_VBoxSVGA3D_CFLAGS = $(filter-out -pedantic -Wstrict-prototypes,$(TEMPLATE_$(TEMPLATE_VBoxSVGA3D_EXTENDS)_CFLAGS))
+ if "$(VBOX_VCC_TOOL_STEM)" >= "VCC140"
+ # -wd4777: glsl_shader.c(1542): warning C4777: 'sprintf' : format string '%u' requires an argument of type 'unsigned int', but variadic argument 2 has type 'DWORD'
+ TEMPLATE_VBoxSVGA3D_CFLAGS.win = $(TEMPLATE_$(TEMPLATE_VBoxSVGA3D_EXTENDS)_CFLAGS.win) \
+ -wd4777
+ endif
+ ifeq ($(KBUILD_TARGET),darwin)
+ TEMPLATE_VBoxSVGA3D_CXXFLAGS = $(filter-out -pedantic,$(TEMPLATE_$(TEMPLATE_VBoxSVGA3D_EXTENDS)_CXXFLAGS)) $(VBOX_GCC_Wno-deprecated-declarations)
+ TEMPLATE_VBoxSVGA3D_OBJCFLAGS = $(filter-out -pedantic,$(TEMPLATE_$(TEMPLATE_VBoxSVGA3D_EXTENDS)_OBJCFLAGS)) $(VBOX_GCC_Wno-deprecated-declarations)
+ TEMPLATE_VBoxSVGA3D_OBJCXXFLAGS = $(filter-out -pedantic,$(TEMPLATE_$(TEMPLATE_VBoxSVGA3D_EXTENDS)_OBJCXXFLAGS)) $(VBOX_GCC_Wno-deprecated-declarations)
+ else
+ TEMPLATE_VBoxSVGA3D_CXXFLAGS = $(filter-out -pedantic,$(TEMPLATE_$(TEMPLATE_VBoxSVGA3D_EXTENDS)_CXXFLAGS))
+ TEMPLATE_VBoxSVGA3D_OBJCFLAGS = $(filter-out -pedantic,$(TEMPLATE_$(TEMPLATE_VBoxSVGA3D_EXTENDS)_OBJCFLAGS))
+ TEMPLATE_VBoxSVGA3D_OBJCXXFLAGS = $(filter-out -pedantic,$(TEMPLATE_$(TEMPLATE_VBoxSVGA3D_EXTENDS)_OBJCXXFLAGS))
+ endif
+ TEMPLATE_VBoxSVGA3D_LDFLAGS.darwin = $(TEMPLATE_$(TEMPLATE_VBoxSVGA3D_EXTENDS)_LDFLAGS.darwin) \
+ -framework AppKit -framework OpenGL -framework IOKit
+
+
+ #
+ # The shader library used by the SVGA3D implementation.
+ #
+ DLLS += VBoxSVGA3D
+ VBoxSVGA3D_TEMPLATE = VBoxSVGA3D
+ VBoxSVGA3D_SDKS = ReorderCompilerIncs
+ VBoxSVGA3D_DEFS = \
+ __WINESRC__ \
+ _REENTRANT \
+ WINE_NOWINSOCK \
+ VBOX_WITH_VMSVGA \
+ VBOX_WITH_VMSVGA3D \
+ _USE_MATH_DEFINES \
+ VBOX_USING_WINDDK_W7_OR_LATER \
+ VBOX_WINE_WITH_SINGLE_SWAPCHAIN_CONTEXT \
+ IN_vmsvgashader_STATIC \
+ IN_VMSVGA3D \
+ VBOX_WINE_WITH_IPRT
+ ifdef VBOX_WITH_AUTOMATIC_DEFS_QUOTING
+ VBoxSVGA3D_DEFS += \
+ WINE_UNICODE_API= \
+ DLLDIR="" \
+ BINDIR="" \
+ LIB_TO_BINDIR="" \
+ LIB_TO_DLLDIR="" \
+ BIN_TO_DLLDIR="" \
+ LIB_TO_DATADIR="" \
+ BIN_TO_DATADIR=""
+ else
+ VBoxSVGA3D_DEFS += \
+ WINE_UNICODE_API="" \
+ DLLDIR=\"\" \
+ BINDIR=\"\" \
+ LIB_TO_BINDIR=\"\" \
+ LIB_TO_DLLDIR=\"\" \
+ BIN_TO_DLLDIR=\"\" \
+ LIB_TO_DATADIR=\"\" \
+ BIN_TO_DATADIR=\"\"
+ endif
+ if "$(KBUILD_TYPE)" != "debug" || defined(VBOX_WINE_NO_DEBUG_MSGS)
+ VBoxSVGA3D_DEFS += WINE_NO_DEBUG_MSGS
+ endif
+ VBoxSVGA3D_DEFS.x86 += __i386__
+ VBoxSVGA3D_DEFS.amd64 += __x86_64__
+ VBoxSVGA3D_DEFS.win += \
+ USE_WIN32_OPENGL \
+ VBOX_WINE_WITHOUT_LIBWINE
+ VBoxSVGA3D_DEFS.darwin += VBOX_VMSVGA3D_DUAL_OPENGL_PROFILE
+ if 0 # Use the OpenGL 3.2 Core profile (VBoxSVGA3D_DEFS.darwin).
+ VBoxSVGA3D_DEFS.darwin += VBOX_VMSVGA3D_DEFAULT_OGL_PROFILE=3.2 VBOX_VMSVGA3D_OTHER_OGL_PROFILE=2.1
+ else
+ VBoxSVGA3D_DEFS.darwin += VBOX_VMSVGA3D_DEFAULT_OGL_PROFILE=2.1 VBOX_VMSVGA3D_OTHER_OGL_PROFILE=3.2
+ endif
+
+ # WINE relies on a gcc 4.4 feature but we have 4.2 on Darwin
+ VBoxSVGA3D_DEFS.darwin += \
+ __builtin_ms_va_list=va_list \
+ __stdcall= \
+ ms_abi=
+ VBoxSVGA3D_INCS = $(VBOX_GRAPHICS_INCS)
+ VBoxSVGA3D_INCS.win := \
+ Graphics/shaderlib/libWineStub/include
+ VBoxSVGA3D_INCS.linux := \
+ Graphics/shaderlib/wine/include
+ VBoxSVGA3D_INCS.darwin := \
+ Graphics/ \
+ Graphics/shaderlib/wine/include
+ VBoxSVGA3D_SOURCES := \
+ Graphics/shaderlib/glsl_shader.c \
+ Graphics/shaderlib/shader.c \
+ Graphics/shaderlib/shader_sm1.c \
+ Graphics/shaderlib/shader_sm4.c \
+ Graphics/shaderlib/shaderapi.c \
+ Graphics/shaderlib/utils.c \
+ Graphics/shaderlib/stateblock.c \
+ Graphics/shaderlib/directx.c \
+ Graphics/shaderlib/libWineStub/debug.c
+ VBoxSVGA3D_LIBS = $(LIB_RUNTIME)
+ VBoxSVGA3D_LIBS.win += $(PATH_SDK_$(VBOX_WINPSDK)_LIB)/Opengl32.lib
+ if1of ($(KBUILD_TARGET), solaris linux freebsd)
+ VBoxSVGA3D_LIBS += GL
+ endif
+ VBoxSVGA3D_LDFLAGS.darwin += \
+ -install_name $(VBOX_DYLD_EXECUTABLE_PATH)/VBoxSVGA3D.dylib
+ $(call VBOX_SET_VER_INFO_DLL,VBoxSVGA3D,VirtualBox VMSVGA 3D)
+ # -wd4100: unreferenced format parameter
+ # -wd4204: nonstandard extension used : non-constant initializer
+ # -wd4245: '=' : conversion from 'int' to 'DWORD', signed/unsigned mismatch
+ # -wd4305: 'function' : truncation from 'double' to 'GLclampf'
+ VBoxSVGA3D_CFLAGS.win = -wd4100 -wd4204 -wd4245 -wd4305
+ ifneq ($(KBUILD_TARGET),win)
+ VBoxSVGA3D_CFLAGS += -Wno-unused-parameter -Wno-unused-function
+ endif
+
+ #
+ # The Objective C code needs to be separate since the shaderlib redefines most
+ # GL functions as pointers, making it impossible to mix with code calling OpenGL
+ # functions directly. This module must be compiled for 10.7 or later, thus it
+ # needs to be separate from VBoxDD.dylib, or at least that's our belief...
+ #
+ DLLS.darwin += VBoxSVGA3DObjC
+ VBoxSVGA3DObjC_TEMPLATE = VBoxSVGA3D
+ VBoxSVGA3DObjC_DEFS = $(VBoxSVGA3D_DEFS) IN_VMSVGA3DCOCOA
+ VBoxSVGA3DObjC_DEFS.x86 = __i386__
+ VBoxSVGA3DObjC_DEFS.amd64 = __x86_64__
+ VBoxSVGA3DObjC_DEFS.darwin = $(VBoxSVGA3D_DEFS.darwin)
+ VBoxSVGA3DObjC_INCS = $(VBoxSVGA3D_INCS)
+ VBoxSVGA3DObjC_INCS.darwin = $(VBoxSVGA3D_INCS.darwin)
+ VBoxSVGA3DObjC_LIBS = $(LIB_RUNTIME)
+ VBoxSVGA3DObjC_LDFLAGS.darwin = \
+ -install_name $(VBOX_DYLD_EXECUTABLE_PATH)/VBoxSVGA3DObjC.dylib \
+ -framework OpenGL
+ VBoxSVGA3DObjC_SOURCES.darwin += \
+ Graphics/DevVGA-SVGA3d-cocoa.m
+
+
+endif # defined(VBOX_WITH_VMSVGA3D) && !defined(VBOX_ONLY_EXTPACKS) && "$(intersects $(KBUILD_TARGET_ARCH),$(VBOX_SUPPORTED_HOST_ARCHS))" != ""
+
+include $(FILE_KBUILD_SUB_FOOTER)