diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-05-06 03:01:46 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-05-06 03:01:46 +0000 |
commit | f8fe689a81f906d1b91bb3220acde2a4ecb14c5b (patch) | |
tree | 26484e9d7e2c67806c2d1760196ff01aaa858e8c /src/VBox/Devices/Makefile.kmk | |
parent | Initial commit. (diff) | |
download | virtualbox-f8fe689a81f906d1b91bb3220acde2a4ecb14c5b.tar.xz virtualbox-f8fe689a81f906d1b91bb3220acde2a4ecb14c5b.zip |
Adding upstream version 6.0.4-dfsg.upstream/6.0.4-dfsgupstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/VBox/Devices/Makefile.kmk')
-rw-r--r-- | src/VBox/Devices/Makefile.kmk | 1550 |
1 files changed, 1550 insertions, 0 deletions
diff --git a/src/VBox/Devices/Makefile.kmk b/src/VBox/Devices/Makefile.kmk new file mode 100644 index 00000000..106656dc --- /dev/null +++ b/src/VBox/Devices/Makefile.kmk @@ -0,0 +1,1550 @@ +# $Id: Makefile.kmk $ +## @file +# Top-level sub-makefile for the devices, drivers and services. +# + +# +# Copyright (C) 2006-2019 Oracle Corporation +# +# This file is part of VirtualBox Open Source Edition (OSE), as +# available from http://www.virtualbox.org. This file is free software; +# you can redistribute it and/or modify it under the terms of the GNU +# General Public License (GPL) as published by the Free Software +# Foundation, in version 2 as it comes in the "COPYING" file of the +# VirtualBox OSE distribution. VirtualBox OSE is distributed in the +# hope that it will be useful, but WITHOUT ANY WARRANTY of any kind. +# + +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. +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 +if !defined(VBOX_ONLY_EXTPACKS) # Goes on almost to the end of the file. + include $(PATH_SUB_CURRENT)/BiosCommonCode/Makefile.kmk + include $(PATH_SUB_CURRENT)/PC/BIOS/Makefile.kmk + include $(PATH_SUB_CURRENT)/Graphics/BIOS/Makefile.kmk + + # + # Main targets. + # + LIBRARIES += ServicesR0 + DLLS += VBoxDDU VBoxDD VBoxDD2 + SYSMODS += VBoxDDR0 + ifdef VBOX_WITH_RAW_MODE + SYSMODS += VBoxDDRC + endif + + + # + # VBoxDDU (shared object) + # + VBoxDDU_TEMPLATE = VBoxR3DllWarnNoPic + VBoxDDU_NAME = $(basename $(notdir $(LIB_DDU))) + VBoxDDU_INST.darwin = $(INST_DLL) $(INST_TESTCASE) + VBoxDDU_DEFS = IN_VBOXDDU + ifdef VBOX_WITH_VUSB + VBoxDDU_DEFS += VBOX_WITH_VUSB + endif + ifdef VBOX_WITH_USB + 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 + ifdef VBOX_WITH_USB + VBoxDDU_INCS.os2 += \ + $(PATH_ROOT)/src/VBox/HostDrivers/VBoxUSB/os2 + endif + VBoxDDU_LIBS = \ + $(LIB_RUNTIME) \ + $(PATH_STAGE_LIB)/StorageLib$(VBOX_SUFF_LIB) + ifdef VBOX_WITH_USB + VBoxDDU_LIBS += \ + $(PATH_STAGE_LIB)/USBLib$(VBOX_SUFF_LIB) + VBoxDDU_LIBS.win += \ + $(PATH_STAGE_LIB)/VBoxDrvCfg$(VBOX_SUFF_LIB) \ + $(PATH_SDK_$(VBOX_WINDDK)_LIB)/Newdev.lib + endif + VBoxDDU_LDFLAGS.darwin = -install_name $(VBOX_DYLD_EXECUTABLE_PATH)/VBoxDDU.dylib + ifdef VBOX_WITH_USB + 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) + + # + # VBoxDD (shared object) + # + VBoxDD_TEMPLATE = VBoxR3DllWarnNoPic + 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_ACPI \ + 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_NEW_LPC_DEVICE),VBOX_WITH_NEW_LPC_DEVICE,) + 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/PS2K.cpp \ + Input/PS2M.cpp \ + Input/UsbKbd.cpp \ + Input/UsbMouse.cpp \ + Bus/DevPCI.cpp \ + Bus/DevPciIch9.cpp \ + Bus/MsiCommon.cpp \ + Bus/MsixCommon.cpp \ + EFI/DevSmc.cpp \ + EFI/DevFlash.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 \ + $(if $(VBOX_WITH_NEW_LPC_DEVICE),PC/DevLpc-new.cpp,) \ + GIMDev/GIMDev.cpp \ + GIMDev/DrvUDP.cpp \ + VMMDev/VMMDev.cpp \ + $(if $(VBOX_WITH_HGCM),VMMDev/VMMDevHGCM.cpp,) \ + VMMDev/VMMDevTesting.cpp \ + Network/DevPCNet.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 + 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 + 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 VBOX_WITH_CRHGSMI + VBoxDD_DEFS += VBOX_WITH_CRHGSMI + endif + 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_SOURCES += Graphics/DevVGA-SVGA.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-info.cpp \ + Graphics/DevVGA-SVGA3d-shared.cpp \ + Graphics/DevVGA-SVGA3d-savedstate.cpp + if "$(KBUILD_TARGET)" == "win" && !defined(VBOX_WITH_VMSVGA3D_USE_OPENGL) + VBoxDD_DEFS += VMSVGA3D_DIRECT3D + VBoxDD_SOURCES += Graphics/DevVGA-SVGA3d-win.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 \ + $(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/ + endif + endif + + ifdef VBOX_WITH_VDMA + VBoxDD_DEFS += VBOX_WITH_VDMA + VBoxDD_SOURCES += \ + Graphics/DevVGA_VDMA.cpp + endif + + ifdef VBOX_VDMA_WITH_WATCHDOG + VBoxDD_DEFS += VBOX_VDMA_WITH_WATCHDOG + 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 + + 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) && !defined(VBOX_WITH_EXTPACK_PUEL) + VBoxDD_DEFS += VBOX_WITH_EHCI_IMPL + VBoxDD_SOURCES += \ + USB/DevEHCI.cpp + endif + + if defined(VBOX_WITH_XHCI_IMPL) && !defined(VBOX_WITH_EXTPACK_PUEL) + 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/Virtio.cpp \ + Network/DevVirtioNet.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 + + # --- 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 \ + Storage/VBoxSCSI.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 + + 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 + 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/DevHDACommon.cpp \ + Audio/HDACodec.cpp \ + Audio/HDAStream.cpp \ + Audio/HDAStreamChannel.cpp \ + Audio/HDAStreamMap.cpp \ + Audio/HDAStreamPeriod.cpp \ + Audio/AudioMixBuffer.cpp \ + Audio/AudioMixer.cpp \ + Audio/DrvAudio.cpp \ + Audio/DrvAudioCommon.cpp \ + Audio/DrvHostNullAudio.cpp + + ifdef VBOX_WITH_AUDIO_DEBUG + VBoxDD_DEFS += VBOX_WITH_AUDIO_DEBUG + VBoxDD_SOURCES += \ + Audio/DrvHostDebugAudio.cpp + endif + + ifdef VBOX_WITH_AUDIO_VALIDATIONKIT + VBoxDD_DEFS += VBOX_WITH_AUDIO_VALIDATIONKIT + VBoxDD_SOURCES += \ + Audio/DrvHostValidationKit.cpp + endif + + ifeq ($(KBUILD_TARGET),darwin) + VBoxDD_SOURCES += \ + Audio/DrvHostCoreAudio.cpp + endif + + ifeq ($(KBUILD_TARGET),win) + VBoxDD_SOURCES += \ + Audio/DrvHostDSound.cpp + ifdef VBOX_WITH_AUDIO_MMNOTIFICATION_CLIENT + VBoxDD_SOURCES += \ + Audio/VBoxMMNotificationClient.cpp + VBoxDD_DEFS += VBOX_WITH_AUDIO_MMNOTIFICATION_CLIENT + endif + endif + + ifdef VBOX_WITH_AUDIO_OSS + VBoxDD_DEFS += VBOX_WITH_AUDIO_OSS + VBoxDD_SOURCES += \ + Audio/DrvHostOSSAudio.cpp + endif + + ifdef VBOX_WITH_AUDIO_ALSA + VBoxDD_DEFS += VBOX_WITH_AUDIO_ALSA + VBoxDD_SOURCES += \ + Audio/DrvHostALSAAudio.cpp \ + Audio/alsa_stubs.c + endif + + ifdef VBOX_WITH_AUDIO_PULSE + VBoxDD_DEFS += VBOX_WITH_AUDIO_PULSE + VBoxDD_SOURCES += \ + Audio/DrvHostPulseAudio.cpp \ + Audio/pulse_stubs.c + 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/VirtualKD.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_VMM) \ + $(LIB_RUNTIME) + ifeq ($(KBUILD_TARGET),win) + VBoxDD_LIBS += \ + $(LIB_DDU) \ + $(PATH_STAGE_LIB)/VBoxDD2.lib \ + $(PATH_SDK_$(VBOX_WINDDK)_LIB)/dxguid.lib + else + VBoxDD_LIBS += \ + $(VBoxDDU_1_STAGE_TARGET) \ + $(VBoxDD2_1_STAGE_TARGET) + endif + + ifdef VBOX_WITH_NETFLT + VBoxDD_LIBS.win += $(PATH_STAGE_LIB)/WinNetConfig.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 + + VBoxDD_LIBS.darwin += \ + $(LIB_REM) + + + 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 + PC/ACPI/VBoxAcpi.cpp_DEPS = \ + $(VBoxDD_0_OUTDIR)/vboxaml.hex \ + $(VBoxDD_0_OUTDIR)/vboxssdt_standard.hex \ + $(VBoxDD_0_OUTDIR)/vboxssdt_cpuhotplug.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 + + 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,) + VBoxDDRC_INCS = build $(VBOX_GRAPHICS_INCS) + VBoxDDRC_SOURCES = \ + Bus/DevPCI.cpp \ + Bus/DevPciIch9.cpp \ + Bus/MsiCommon.cpp \ + Bus/MsixCommon.cpp \ + EFI/DevSmc.cpp \ + Graphics/DevVGA.cpp \ + Input/DevPS2.cpp \ + Input/PS2K.cpp \ + Input/PS2M.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 \ + 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/DevHDACommon.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/Virtio.cpp \ + Network/DevVirtioNet.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 VBOX_WITH_CRHGSMI + VBoxDDRC_DEFS += VBOX_WITH_CRHGSMI + 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_VDMA_WITH_WATCHDOG + VBoxDDRC_DEFS += VBOX_VDMA_WITH_WATCHDOG + 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) && !defined(VBOX_WITH_EXTPACK_PUEL) + VBoxDDRC_DEFS += VBOX_WITH_EHCI_IMPL + VBoxDDRC_SOURCES += \ + USB/DevEHCI.cpp + endif + if defined(VBOX_WITH_XHCI_IMPL) && !defined(VBOX_WITH_EXTPACK_PUEL) + 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 + endif # VBOX_WITH_RAW_MODE + + $(call VBOX_SET_VER_INFO_RC,VBoxDDRC,VirtualBox VMM Devices and Drivers$(COMMA) raw-mode) # last! + + + # + # VBoxDD2 (shared object) + # + VBoxDD2_TEMPLATE = VBoxR3DllWarnNoPic + VBoxDD2_DEFS = \ + IN_VBOXDD2 \ + $(if $(VBOX_WITH_PXE_ROM),VBOX_WITH_PXE_ROM,) \ + $(if $(VBOX_WITH_NEW_LPC_DEVICE),VBOX_WITH_NEW_LPC_DEVICE,) + VBoxDD2_INCS := \ + build \ + $(PATH_SUB_CURRENT) + VBoxDD2_SOURCES = \ + build/VBoxDD2.cpp \ + $(if $(VBOX_WITH_NEW_LPC_DEVICE),,PC/DevLPC.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_VMM) \ + $(LIB_RUNTIME) + VBoxDD2_LIBS.darwin += $(LIB_REM) + VBoxDD2_LDFLAGS.darwin = -install_name $(VBOX_DYLD_EXECUTABLE_PATH)/VBoxDD2.dylib + VBoxDD2_LDFLAGS.linux = $(VBOX_GCC_NO_UNDEFINED) + + $(call VBOX_SET_VER_INFO_DLL,VBoxDD2,VirtualBox VMM Devices and Drivers 2) # (last!) + + # + # VBoxDDR0 (sysmod) + # + VBoxDDR0_TEMPLATE = VBoxR0 + VBoxDDR0_DEFS = IN_RT_R0 $(if $(VBOX_WITH_HGCM),VBOX_WITH_HGCM,) # - WTF is IN_RT_R0 doing here? + VBoxDDR0_DEFS.win += VBOX_WITH_WIN_PARPORT_SUP + VBoxDDR0_INCS = build $(VBOX_GRAPHICS_INCS) + 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 \ + EFI/DevSmc.cpp \ + Graphics/DevVGA.cpp \ + Input/DevPS2.cpp \ + Input/PS2K.cpp \ + Input/PS2M.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 \ + Serial/DevSerial.cpp \ + Serial/DevOxPcie958.cpp \ + Serial/UartCore.cpp \ + Parallel/DevParallel.cpp \ + VMMDev/VMMDev.cpp \ + VMMDev/VMMDevTesting.cpp \ + Network/DrvIntNet.cpp \ + Network/DrvDedicatedNic.cpp + + 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 $(VBOX_WITH_CRHGSMI),VBOX_WITH_CRHGSMI,) \ + $(if $(VBOXWDDM_WITH_VBVA),VBOXWDDM_WITH_VBVA,) \ + $(if $(VBOX_VDMA_WITH_WATCHDOG),VBOX_VDMA_WITH_WATCHDOG,) \ + $(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/DevHDACommon.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/Virtio.cpp \ + Network/DevVirtioNet.cpp + endif + + ifdef VBOX_WITH_NETSHAPER + 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) && !defined(VBOX_WITH_EXTPACK_PUEL) + VBoxDDR0_DEFS += VBOX_WITH_EHCI_IMPL + VBoxDDR0_SOURCES += \ + USB/DevEHCI.cpp + endif + if defined(VBOX_WITH_XHCI_IMPL) && !defined(VBOX_WITH_EXTPACK_PUEL) + VBoxDDR0_DEFS += VBOX_WITH_XHCI_IMPL + VBoxDDR0_SOURCES += \ + USB/DevXHCI.cpp + endif + 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 + + 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) \ + $(PATH_STAGE_LIB)/SUPR0$(VBOX_SUFF_LIB) + endif + + $(call VBOX_SET_VER_INFO_R0,VBoxDDR0,VirtualBox VMM Devices and Drivers$(COMMA) ring-0) # (last!) + + + # + # Ring-0 Services (library, linked into VMMR0.r0) + # + ServicesR0_TEMPLATE = VBoxR0 + ServicesR0_DEFS = IN_INTNET_R0 IN_RT_R0 \ + $(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 + tstIntNetHardened-1_DEFS = PROGRAM_NAME_STR=\"tstIntNet-1\" + 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 + DLLS += tstDeviceVBoxVMMStubs + tstDeviceVBoxVMMStubs_TEMPLATE = VBoxR3DllNoPic + tstDeviceVBoxVMMStubs_SONAME.linux = tstDeviceVBoxVMMStubs.so + tstDeviceVBoxVMMStubs_SONAME.darwin = tstDeviceVBoxVMMStubs.dylib + tstDeviceVBoxVMMStubs_DEFS = IN_VMM_R3 IN_DIS IN_GMM_R3 IN_DBG $(VMM_COMMON_DEFS) + tstDeviceVBoxVMMStubs_LIBS = $(LIB_RUNTIME) + + tstDeviceVBoxVMMStubs_SOURCES = \ + testcase/tstDeviceVMMStubs.cpp + + PROGRAMS += tstDevice + tstDevice_TEMPLATE = VBOXR3TSTEXE + tstDevice_DEFS += IN_SUP_R3 + tstDevice_LIBS.linux = $(PATH_STAGE_BIN)/tstDeviceVBoxVMMStubs.so + tstDevice_LIBS.darwin = $(PATH_STAGE_BIN)/tstDeviceVBoxVMMStubs.dylib + # Required on OS X to prevent resolving symbols in the real VBoxVMM.dylib when VBoxDD.dylib is loaded + tstDevice_LDFLAGS.darwin += -force_flat_namespace + tstDevice_SOURCES = \ + testcase/tstDevice.cpp \ + testcase/tstDevicePdmDevHlp.cpp \ + testcase/tstDeviceVMM.cpp \ + testcase/tstDeviceSUP.cpp + endif + +endif # !VBOX_ONLY_EXTPACKS + + +if defined(VBOX_WITH_EXTPACK_PUEL) && defined(VBOX_WITH_EXTPACK_PUEL_BUILD) + # + # The EHCI (USB 2.0) Extension Pack Modules. + # + if defined(VBOX_WITH_USB) + DLLS += VBoxEhciR3 + VBoxEhciR3_TEMPLATE = VBoxR3ExtPackPuel + VBoxEhciR3_SOURCES = \ + USB/DevEHCI.cpp \ + USB/DevXHCI.cpp + $(call VBOX_SET_VER_INFO_DLL,VBoxEhciR3,PUEL Extension Pack - EHCI Device) + + SYSMODS += VBoxEhciR0 + VBoxEhciR0_TEMPLATE = VBoxR0ExtPackPuel + VBoxEhciR0_SOURCES = \ + USB/DevEHCI.cpp \ + USB/DevXHCI.cpp + $(call VBOX_SET_VER_INFO_R0,VBoxEhciR0,PUEL Extension Pack - EHCI Device$(COMMA) ring-0) + + ifdef VBOX_WITH_RAW_MODE + SYSMODS += VBoxEhciRC + VBoxEhciRC_TEMPLATE = VBoxRcExtPackPuel + VBoxEhciRC_SOURCES = \ + USB/DevEHCI.cpp \ + USB/DevXHCI.cpp + $(call VBOX_SET_VER_INFO_RC,VBoxEhciRC,PUEL Extension Pack - EHCI Device$(COMMA) raw-mode) + endif + + # Hacky but MSI support *must* be enabled + ifdef VBOX_WITH_MSI_DEVICES + VBoxEhciR3_DEFS += VBOX_WITH_MSI_DEVICES + VBoxEhciR0_DEFS += VBOX_WITH_MSI_DEVICES + VBoxEhciRC_DEFS += VBOX_WITH_MSI_DEVICES + endif + + endif + + if defined(VBOX_WITH_PCI_PASSTHROUGH) + 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) + + 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) + + SYSMODS += VBoxNvmeR0 + 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_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 + VBoxExtPackPuelInsRoms_SOURCES = PC/PXE/PXE-Intel.rom=>PXE-Intel.rom +endif # VBOX_WITH_EXTPACK_PUEL + + +if defined(VBOX_WITH_VMSVGA3D) && !defined(VBOX_ONLY_EXTPACKS) + # + # Template used for VBoxSVGA3D. (Strips away compiler options.) + # + TEMPLATE_VBoxSVGA3D := VBoxSVGA3D + TEMPLATE_VBoxSVGA3D_EXTENDS := $(if-expr "$(KBUILD_TARGET)" == "darwin" && !defined(VBOX_WITH_NEW_XCODE),VBoxR3DllOsX107,VBOXR3) + TEMPLATE_VBoxSVGA3D_CFLAGS = $(filter-out -pedantic -Wstrict-prototypes,$(TEMPLATE_$(TEMPLATE_VBoxSVGA3D_EXTENDS)_CFLAGS)) + 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)) + 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__ \ + WINE_UNICODE_API="" \ + _REENTRANT \ + WINE_NOWINSOCK \ + VBOX_WITH_VMSVGA \ + VBOX_WITH_VMSVGA3D \ + DLLDIR=\"\" \ + BINDIR=\"\" \ + LIB_TO_BINDIR=\"\" \ + LIB_TO_DLLDIR=\"\" \ + BIN_TO_DLLDIR=\"\" \ + LIB_TO_DATADIR=\"\" \ + BIN_TO_DATADIR=\"\" \ + _USE_MATH_DEFINES \ + VBOX_USING_WINDDK_W7_OR_LATER \ + VBOX_WINE_WITH_SINGLE_SWAPCHAIN_CONTEXT \ + IN_vmsvgashader_STATIC \ + IN_VMSVGA3D \ + VBOX_WINE_WITH_IPRT + 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 + if 1 + VBoxSVGA3DObjC_SOURCES.darwin += \ + Graphics/DevVGA-SVGA3d-cocoa.m + else + VBoxSVGA3DObjC_SOURCES.darwin += \ + ../HostServices/SharedOpenGL/render/renderspu_cocoa_helper.m \ + ../HostServices/SharedOpenGL/OpenGLTest/OpenGLTestDarwin.cpp + endif + + +endif # defined(VBOX_WITH_VMSVGA3D) && !defined(VBOX_ONLY_EXTPACKS) + +include $(FILE_KBUILD_SUB_FOOTER) + |