diff options
Diffstat (limited to '')
-rw-r--r-- | src/VBox/Runtime/Makefile.kmk | 3935 |
1 files changed, 3935 insertions, 0 deletions
diff --git a/src/VBox/Runtime/Makefile.kmk b/src/VBox/Runtime/Makefile.kmk new file mode 100644 index 00000000..b3eb6417 --- /dev/null +++ b/src/VBox/Runtime/Makefile.kmk @@ -0,0 +1,3935 @@ +# $Id: Makefile.kmk $ +## @file +# Sub-Makefile for the IPRT. +# + +# +# 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. +# +# The contents of this file may alternatively be used under the terms +# of the Common Development and Distribution License Version 1.0 +# (CDDL) only, as it comes in the "COPYING.CDDL" file of the +# VirtualBox OSE distribution, in which case the provisions of the +# CDDL are applicable instead of those of the GPL. +# +# You may elect to license modified versions of this file under the +# terms and conditions of either the GPL or the CDDL or both. +# + +SUB_DEPTH = ../../.. +include $(KBUILD_PATH)/subheader.kmk + +ifdef VBOX_ONLY_ADDITIONS + # + # Only build the additions, sort out the legacy names first. + # + LIBRARIES += RuntimeGuestR3 RuntimeGuestR3Shared + LIBRARIES.win.amd64 += RuntimeGuestR3-x86 RuntimeGuestR3Shared-x86 + ifdef VBOX_WITH_ADDITION_DRIVERS + LIBRARIES += RuntimeGuestR0 + #LIBRARIES.os2 += RuntimeGuestR0OS2Warp3 + endif + ifndef VBOX_ONLY_ADDITIONS_WITHOUT_RTISOMAKER + LIBRARIES += RuntimeBldProg + include $(PATH_SUB_CURRENT)/tools/Makefile.kmk + endif + +else ifdef VBOX_ONLY_VALIDATIONKIT + # + # Only build the Validation Kit. + # + LIBRARIES += RuntimeGuestR3 RuntimeGuestR3Shared RuntimeR3 RuntimeR0 RuntimeBldProg + LIBRARIES.solaris += RuntimeR0Stub + LIBRARIES.win += RuntimeR0Stub + LIBRARIES.win.x86 += RuntimeR3VccTricks + include $(PATH_SUB_CURRENT)/tools/Makefile.kmk + +else ifdef VBOX_ONLY_DOCS + # + # Build docs only - need just regular R3 runtime. + # + LIBRARIES += RuntimeR3 RuntimeBldProg + include $(PATH_SUB_CURRENT)/tools/Makefile.kmk + +else ifdef VBOX_ONLY_EXTPACKS_USE_IMPLIBS + # + # Build extension packs using import libraries as much as possible (VBoxDTrace + # needs Ring-0 IPRT, though). + # + LIBRARIES += RuntimeBldProg RuntimeR0 + LIBRARIES.solaris += RuntimeR0Stub + LIBRARIES.win += RuntimeR0Stub RuntimeRCStub + include $(PATH_SUB_CURRENT)/tools/Makefile.kmk + +else # !VBOX_ONLY_ADDITIONS && !VBOX_ONLY_VALIDATIONKIT && !VBOX_ONLY_DOCS + + # + # Normal build. + # + ifndef VBOX_ONLY_EXTPACKS + include $(PATH_SUB_CURRENT)/testcase/Makefile.kmk + endif + include $(PATH_SUB_CURRENT)/tools/Makefile.kmk + + BLDPROGS += uniread + LIBRARIES += RuntimeR3 RuntimeBldProg RuntimeR0 RuntimeEFCPP RuntimeR3NoCRTGCC + LIBRARIES.solaris += RuntimeR0Stub + LIBRARIES.win += RuntimeR0Stub + ifdef VBOX_WITH_RAW_MODE + LIBRARIES += RuntimeRC + LIBRARIES.win += RuntimeRCStub + endif + ifdef VBOX_WITH_VBOXDRV + LIBRARIES += RuntimeR0Drv + endif + ifdef VBOX_WITH_ADDITIONS + LIBRARIES += RuntimeGuestR3 RuntimeGuestR3Shared + LIBRARIES.win.amd64 += RuntimeGuestR3-x86 RuntimeGuestR3Shared-x86 + ifdef VBOX_WITH_ADDITION_DRIVERS + LIBRARIES += RuntimeGuestR0 + endif + #LIBRARIES.os2 += RuntimeGuestR0OS2Warp3 + endif # VBOX_WITH_ADDITIONS + LIBRARIES.win.x86 += RuntimeR3VccTricks + DLLS += VBoxRT + ifdef VBOX_WITH_32_ON_64_MAIN_API + DLLS += VBoxRT-x86 + endif +endif + + +# Always build the ntdll import libraries on windows. +LIBRARIES.win += RuntimeR3NtDll-x86 +if1of (amd64, $(KBUILD_TARGET_ARCH) $(KBUILD_HOST_ARCH)) + LIBRARIES.win += RuntimeR3NtDll-amd64 +endif + + +# Always build the import library. +IMPORT_LIBS += VBoxRTImp + + +# Where the generated stuff goes. +IPRT_OUT_DIR := $(PATH_TARGET)/Runtime +BLDDIRS += $(IPRT_OUT_DIR) +OTHER_CLEAN += \ + $(IPRT_OUT_DIR)/errmsgdata.h \ + $(IPRT_OUT_DIR)/errmsgcomdata.h \ + $(IPRT_OUT_DIR)/errmsgvboxcomdata.h \ + $(IPRT_OUT_DIR)/errmsgvboxcomdata.h.ts \ + $(IPRT_OUT_DIR)/odi2name.h \ + $(IPRT_OUT_DIR)/odi2name.h.ts \ + $(IPRT_DOXYFILE_OUTPUT)/Doxyfile.iprt \ + $(IPRT_DOXYFILE_OUTPUT)/Doxyfile.iprt.dep \ + $(IPRT_DOXYFILE_OUTPUT)/docs.iprt + + +# +# Globals +# +VBOX_PATH_RUNTIME_SRC := $(PATH_SUB_CURRENT) + + +# +# Set the defines that buildconfig.cpp needs. Its used by several targets. +# +common/misc/buildconfig.cpp_DEFS = \ + IPRT_BLDCFG_SCM_REV=$(VBOX_SVN_REV) \ + IPRT_BLDCFG_VERSION_STRING=\"$(VBOX_VERSION_STRING)\" \ + IPRT_BLDCFG_VERSION_MAJOR=$(VBOX_VERSION_MAJOR) \ + IPRT_BLDCFG_VERSION_MINOR=$(VBOX_VERSION_MINOR) \ + IPRT_BLDCFG_VERSION_BUILD=$(VBOX_VERSION_BUILD) \ + IPRT_BLDCFG_TARGET=\"$(KBUILD_TARGET)\" \ + IPRT_BLDCFG_TARGET_ARCH=\"$(KBUILD_TARGET_ARCH)\" \ + IPRT_BLDCFG_TYPE=\"$(KBUILD_TYPE)\" + +# +# OID to C table conversion program. +# +BLDPROGS += oiddb2c +oiddb2c_TEMPLATE = VBoxBldProg +oiddb2c_SOURCES = common/asn1/oiddb2c.cpp +common/asn1/asn1-dump.cpp_DEPS = $(IPRT_OUT_DIR)/oiddb.h +common/asn1/asn1-dump.cpp_INCS = $(IPRT_OUT_DIR) + +$(IPRT_OUT_DIR)/oiddb.h.ts +| $(IPRT_OUT_DIR)/oiddb.h: \ + $(VBOX_PATH_RUNTIME_SRC)/common/asn1/oiddb.cfg \ + $(VBOX_EXTRA_OID_CFG_FILES) \ + $$(oiddb2c_1_TARGET) \ + | $$(dir $$@) + $(call MSG_GENERATE,,$@,$(filter %.xidl,$^)) + $(QUIET)$(oiddb2c_1_TARGET) "$@" $(filter %.cfg,$^) + $(QUIET)$(CP) --changed -fv "$@" "$(IPRT_OUT_DIR)/oiddb.h" + + +# +# Unicode Specification reader used to regenerate unidata-*.cpp. +# +uniread_TEMPLATE = VBoxBldProg +uniread_SOURCES = common/string/uniread.cpp +uniread_INCS = include + +# +# Win64 assembly sources. +# +RuntimeWin64ASM_SOURCES = \ + win/amd64/ASMAtomicBitClear.asm \ + win/amd64/ASMAtomicBitTestAndToggle.asm \ + win/amd64/ASMAtomicBitToggle.asm \ + win/amd64/ASMAtomicReadU64.asm \ + win/amd64/ASMAtomicXchgU8.asm \ + win/amd64/ASMGetCS.asm \ + win/amd64/ASMGetDS.asm \ + win/amd64/ASMGetES.asm \ + win/amd64/ASMGetFlags.asm \ + win/amd64/ASMGetFS.asm \ + win/amd64/ASMGetGS.asm \ + win/amd64/ASMGetSS.asm \ + win/amd64/ASMProbeReadByte.asm \ + win/amd64/ASMSetFlags.asm \ + win/amd64/ASMGetDR0.asm \ + win/amd64/ASMGetDR1.asm \ + win/amd64/ASMGetDR2.asm \ + win/amd64/ASMGetDR3.asm \ + win/amd64/ASMGetDR6.asm \ + win/amd64/ASMGetDR7.asm \ + common/asm/ASMAtomicCmpXchgU8.asm \ + common/asm/ASMAtomicCmpXchgU16.asm \ + common/asm/ASMAtomicXchgU16.asm \ + common/asm/ASMBitFirstClear.asm \ + common/asm/ASMBitFirstSet.asm \ + common/asm/ASMBitNextClear.asm \ + common/asm/ASMBitNextSet.asm \ + common/asm/ASMMultU32ByU32DivByU32.asm \ + common/asm/ASMMultU64ByU32DivByU32.asm \ + common/asm/ASMCpuId_Idx_ECX.asm \ + common/asm/ASMNopPause.asm \ + common/asm/ASMGetIDTR.asm \ + common/asm/ASMGetIdtrLimit.asm \ + common/asm/ASMSetIDTR.asm \ + common/asm/ASMGetGDTR.asm \ + common/asm/ASMSetGDTR.asm \ + common/asm/ASMGetLDTR.asm \ + common/asm/ASMGetSegAttr.asm \ + common/asm/ASMGetTR.asm + +# +# Win32 assembly sources. +# +RuntimeWin32ASM_SOURCES = \ + common/asm/ASMAtomicCmpXchgU8.asm \ + common/asm/ASMAtomicCmpXchgU16.asm \ + common/asm/ASMAtomicXchgU16.asm \ + common/asm/ASMMultU32ByU32DivByU32.asm \ + common/asm/ASMMultU64ByU32DivByU32.asm \ + common/asm/ASMCpuId_Idx_ECX.asm \ + common/asm/ASMGetSegAttr.asm + +# +# NoCRT sources (minus math stuff). +# +if1of ($(KBUILD_TARGET_ARCH), amd64 x86) +RuntimeNoCrt_SOURCES = \ + common/misc/setjmp.asm \ + common/string/bzero.asm \ + common/string/memchr.asm \ + common/string/memcmp.asm \ + common/string/memcpy.asm \ + common/string/mempcpy.asm \ + common/string/memmove.asm \ + common/string/memset.asm \ + common/string/strchr.asm \ + common/string/strcpy.asm \ + common/string/strncpy.asm \ + common/string/strcmp.asm \ + common/string/strlen.asm +endif + + +# +# RuntimeR3 - Static Runtime for Ring-3 executables. +# +RuntimeR3_TEMPLATE = VBoxR3Static +RuntimeR3_SDKS = VBOX_LIBXML2 +RuntimeR3_SDKS.win = $(VBOX_WINPSDK) $(VBOX_WINDDK) +RuntimeR3_DEFS = \ + IN_RT_R3 \ + LDR_WITH_NATIVE \ + LDR_WITH_ELF32 \ + LDR_WITH_LX \ + LDR_WITH_MACHO \ + LDR_WITH_PE \ + RT_WITH_VBOX \ + RT_NO_GIP \ + RT_WITHOUT_NOCRT_WRAPPERS \ + NOFILEID +if1of ($(KBUILD_TARGET_ARCH), amd64 x86) + RuntimeR3_DEFS += \ + IN_SUP_R3 +endif +#RuntimeR3_DEFS += RTMEM_WRAP_TO_EF_APIS +ifdef IPRT_WITH_LZJB + RuntimeR3_DEFS += RTZIP_USE_LZJB +endif +ifdef IPRT_WITH_LZO + RuntimeR3_DEFS += RTZIP_USE_LZO +endif +ifn1of ($(KBUILD_TARGET), win) + RuntimeR3_DEFS += RT_WITH_ICONV_CACHE +endif +ifdef IPRT_WITH_FUTEX_BASED_SEMS + RuntimeR3_DEFS.linux += IPRT_WITH_FUTEX_BASED_SEMS +endif +RuntimeR3_INCS = \ + include \ + $(SDK_VBOX_ZLIB_INCS) +RuntimeR3_INCS += \ + $(PATH_ROOT)/src/libs/liblzf-3.4 + +# RuntimeR3_INCS.solaris = \ +# /usr/include + +RuntimeR3_SOURCES = \ + common/alloc/alloc.cpp \ + common/alloc/heapsimple.cpp \ + common/alloc/heapoffset.cpp \ + common/alloc/memcache.cpp \ + common/alloc/memtracker.cpp \ + common/asn1/asn1-basics.cpp \ + common/asn1/asn1-cursor.cpp \ + common/asn1/asn1-default-allocator.cpp \ + common/asn1/asn1-efence-allocator.cpp \ + common/asn1/asn1-safer-allocator.cpp \ + common/asn1/asn1-dump.cpp \ + common/asn1/asn1-encode.cpp \ + common/asn1/asn1-ut-bitstring.cpp \ + common/asn1/asn1-ut-bitstring-decode.cpp \ + common/asn1/asn1-ut-boolean.cpp \ + common/asn1/asn1-ut-boolean-decode.cpp \ + common/asn1/asn1-ut-core.cpp \ + common/asn1/asn1-ut-core-decode.cpp \ + common/asn1/asn1-ut-dyntype.cpp \ + common/asn1/asn1-ut-dyntype-decode.cpp \ + common/asn1/asn1-ut-integer.cpp \ + common/asn1/asn1-ut-integer-decode.cpp \ + common/asn1/asn1-ut-null.cpp \ + common/asn1/asn1-ut-null-decode.cpp \ + common/asn1/asn1-ut-objid.cpp \ + common/asn1/asn1-ut-objid-decode.cpp \ + common/asn1/asn1-ut-octetstring.cpp \ + common/asn1/asn1-ut-octetstring-decode.cpp \ + common/asn1/asn1-ut-string.cpp \ + common/asn1/asn1-ut-string-decode.cpp \ + common/asn1/asn1-ut-time.cpp \ + common/asn1/asn1-ut-time-decode.cpp \ + common/checksum/adler32.cpp \ + common/checksum/crc32.cpp \ + common/checksum/crc32c.cpp \ + common/checksum/crc64.cpp \ + common/checksum/crc16ccitt.cpp \ + common/checksum/alt-md2.cpp \ + common/checksum/alt-md4.cpp \ + common/checksum/alt-md5.cpp \ + common/checksum/alt-sha1.cpp \ + common/checksum/alt-sha256.cpp \ + common/checksum/alt-sha512.cpp \ + common/checksum/md2str.cpp \ + common/checksum/md4str.cpp \ + common/checksum/md5str.cpp \ + common/checksum/ipv4.cpp \ + common/checksum/ipv6.cpp \ + common/checksum/manifest.cpp \ + common/checksum/manifest2.cpp \ + common/checksum/manifest3.cpp \ + common/checksum/manifest-file.cpp \ + common/checksum/RTSha1Digest.cpp \ + common/checksum/RTSha256Digest.cpp \ + common/checksum/sha1str.cpp \ + common/checksum/sha224str.cpp \ + common/checksum/sha256str.cpp \ + common/checksum/sha384str.cpp \ + common/checksum/sha512str.cpp \ + common/checksum/sha512t224str.cpp \ + common/checksum/sha512t256str.cpp \ + common/crypto/cipher-openssl.cpp \ + common/crypto/digest-core.cpp \ + common/crypto/digest-builtin.cpp \ + common/crypto/digest-vfs.cpp \ + common/crypto/iprt-openssl.cpp \ + common/crypto/key.cpp \ + common/crypto/key-file.cpp \ + common/crypto/key-openssl.cpp \ + common/crypto/key-create-rsa-openssl.cpp \ + common/crypto/rc4-openssl.cpp \ + common/crypto/rsa-asn1-decoder.cpp \ + common/crypto/rsa-core.cpp \ + common/crypto/rsa-init.cpp \ + common/crypto/rsa-sanity.cpp \ + common/crypto/pemfile.cpp \ + common/crypto/pkcs7-asn1-decoder.cpp \ + common/crypto/pkcs7-core.cpp \ + common/crypto/pkcs7-init.cpp \ + common/crypto/pkcs7-sanity.cpp \ + common/crypto/pkcs7-verify.cpp \ + common/crypto/pkix-sign.cpp \ + common/crypto/pkix-signature-builtin.cpp \ + common/crypto/pkix-signature-core.cpp \ + common/crypto/pkix-signature-rsa.cpp \ + common/crypto/pkix-util.cpp \ + common/crypto/pkix-verify.cpp \ + common/crypto/spc-asn1-decoder.cpp \ + common/crypto/spc-core.cpp \ + common/crypto/spc-init.cpp \ + common/crypto/spc-sanity.cpp \ + common/crypto/ssl-openssl.cpp \ + common/crypto/x509-asn1-decoder.cpp \ + common/crypto/x509-certpaths.cpp \ + common/crypto/x509-core.cpp \ + common/crypto/x509-file.cpp \ + common/crypto/x509-init.cpp \ + common/crypto/x509-sanity.cpp \ + common/crypto/x509-verify.cpp \ + common/crypto/taf-asn1-decoder.cpp \ + common/crypto/taf-core.cpp \ + common/crypto/taf-init.cpp \ + common/crypto/taf-sanity.cpp \ + common/crypto/tsp-asn1-decoder.cpp \ + common/crypto/tsp-core.cpp \ + common/crypto/tsp-init.cpp \ + common/crypto/tsp-sanity.cpp \ + common/crypto/store.cpp \ + common/crypto/store-inmem.cpp \ + common/crypto/store-cert-add-basic.cpp \ + common/crypto/RTCrPkcs5Pbkdf2Hmac-openssl.cpp \ + common/crypto/RTCrRandBytes-openssl.cpp \ + common/crypto/RTCrStoreCertAddFromJavaKeyStore.cpp \ + common/crypto/RTCrStoreCertAddWantedFromFishingExpedition.cpp \ + common/crypto/RTCrStoreCertExportAsPem.cpp \ + common/crypto/RTCrStoreCreateSnapshotOfUserAndSystemTrustedCAsAndCerts.cpp \ + common/dbg/dbg.cpp \ + common/dbg/dbgas.cpp \ + common/dbg/dbgcfg.cpp \ + common/dbg/dbgmod.cpp \ + common/dbg/dbgmodldr.cpp \ + common/dbg/dbgmodcontainer.cpp \ + common/dbg/dbgmoddeferred.cpp \ + common/dbg/dbgmodexports.cpp \ + common/dbg/dbgmodcodeview.cpp \ + common/dbg/dbgmoddwarf.cpp \ + common/dbg/dbgmodmapsym.cpp \ + common/dbg/dbgmodnm.cpp \ + common/dvm/dvm.cpp \ + common/dvm/dvmbsdlabel.cpp \ + common/dvm/dvmgpt.cpp \ + common/dvm/dvmmbr.cpp \ + common/dvm/dvmvfs.cpp \ + common/err/errinfo.cpp \ + common/err/errinfolog.cpp \ + common/err/errinfo-alloc.cpp \ + common/err/errmsg.cpp \ + common/err/RTErrConvertFromErrno.cpp \ + common/err/RTErrConvertToErrno.cpp \ + common/fs/extvfs.cpp \ + common/fs/fatvfs.cpp \ + common/fs/isovfs.cpp \ + common/fs/isomaker.cpp \ + common/fs/isomakercmd.cpp \ + common/fs/isomakerimport.cpp \ + common/fs/ntfsvfs.cpp \ + common/fs/RTFsCmdLs.cpp \ + common/ldr/ldr.cpp \ + common/ldr/ldrELF.cpp \ + common/ldr/ldrEx.cpp \ + common/ldr/ldrFile.cpp \ + common/ldr/ldrVfsFile.cpp \ + common/ldr/ldrLX.cpp \ + common/ldr/ldrMachO.cpp \ + common/ldr/ldrMemory.cpp \ + common/ldr/ldrNative.cpp \ + common/ldr/ldrPE.cpp \ + common/log/log.cpp \ + common/log/logellipsis.cpp \ + common/log/logrel.cpp \ + common/log/logrelellipsis.cpp \ + common/log/logcom.cpp \ + common/log/logformat.cpp \ + common/log/tracebuf.cpp \ + common/log/tracedefault.cpp \ + common/log/tracelogreader.cpp \ + common/log/tracelogwriter.cpp \ + common/math/bignum.cpp \ + common/misc/RTAssertMsg1Weak.cpp \ + common/misc/RTAssertMsg2.cpp \ + common/misc/RTAssertMsg2Add.cpp \ + common/misc/RTAssertMsg2AddWeak.cpp \ + common/misc/RTAssertMsg2AddWeakV.cpp \ + common/misc/RTAssertMsg2Weak.cpp \ + common/misc/RTAssertMsg2WeakV.cpp \ + common/misc/RTFileModeToFlags.cpp \ + common/misc/RTFileOpenF.cpp \ + common/misc/RTFileOpenV.cpp \ + common/misc/RTMemWipeThoroughly.cpp \ + common/misc/assert.cpp \ + common/misc/buildconfig.cpp \ + common/misc/cidr.cpp \ + common/misc/getopt.cpp \ + common/misc/getoptargv.cpp \ + common/misc/handle.cpp \ + common/misc/handletable.cpp \ + common/misc/handletablectx.cpp \ + common/misc/handletablesimple.cpp \ + common/misc/inifile.cpp \ + common/misc/json.cpp \ + common/misc/lockvalidator.cpp \ + common/misc/message.cpp \ + common/misc/messagerefentry.cpp \ + common/misc/once.cpp \ + common/misc/req.cpp \ + common/misc/reqpool.cpp \ + common/misc/reqqueue.cpp \ + common/misc/sanity-c.c \ + common/misc/sanity-cpp.cpp \ + common/misc/semspingpong.cpp \ + common/misc/sg.cpp \ + common/misc/circbuf.cpp \ + common/misc/thread.cpp \ + common/misc/term.cpp \ + common/misc/uri.cpp \ + common/misc/zero.asm \ + common/net/netaddrstr2.cpp \ + common/net/macstr.cpp \ + common/path/rtPathRootSpecLen.cpp \ + common/path/rtPathVolumeSpecLen.cpp \ + common/path/RTPathAbsDup.cpp \ + common/path/RTPathAbsEx.cpp \ + common/path/RTPathAbsExDup.cpp \ + common/path/RTPathAppend.cpp \ + common/path/RTPathAppendEx.cpp \ + common/path/RTPathCalcRelative.cpp \ + common/path/RTPathChangeToDosSlashes.cpp \ + common/path/RTPathChangeToUnixSlashes.cpp \ + common/path/RTPathCopyComponents.cpp \ + common/path/RTPathCountComponents.cpp \ + common/path/RTPathEnsureTrailingSeparator.cpp \ + common/path/RTPathExt.cpp \ + common/path/RTPathFilename.cpp \ + common/path/RTPathFilenameUtf16.cpp \ + common/path/RTPathGlob.cpp \ + common/path/RTPathHasExt.cpp \ + common/path/RTPathHasPath.cpp \ + common/path/RTPathJoin.cpp \ + common/path/RTPathJoinA.cpp \ + common/path/RTPathJoinEx.cpp \ + common/path/RTPathParse.cpp \ + common/path/RTPathParsedReassemble.cpp \ + common/path/RTPathParseSimple.cpp \ + common/path/RTPathRealDup.cpp \ + common/path/RTPathRmCmd.cpp \ + common/path/RTPathSkipRootSpec.cpp \ + common/path/RTPathSplit.cpp \ + common/path/RTPathSplitA.cpp \ + common/path/RTPathSplitReassemble.cpp \ + common/path/RTPathStartsWithRoot.cpp \ + common/path/RTPathStripExt.cpp \ + common/path/RTPathStripFilename.cpp \ + common/path/RTPathStripTrailingSlash.cpp \ + common/path/RTPathTraverseList.cpp \ + common/path/comparepaths.cpp \ + common/rand/rand.cpp \ + common/rand/randadv.cpp \ + common/rand/randparkmiller.cpp \ + common/sort/RTSortIsSorted.cpp \ + common/sort/RTSortApvIsSorted.cpp \ + common/sort/shellsort.cpp \ + common/string/RTStrCat.cpp \ + common/string/RTStrCatEx.cpp \ + common/string/RTStrCatP.cpp \ + common/string/RTStrCatPEx.cpp \ + common/string/RTStrCmp.cpp \ + common/string/RTStrCopy.cpp \ + common/string/RTStrCopyEx.cpp \ + common/string/RTStrCopyP.cpp \ + common/string/RTStrCopyPEx.cpp \ + common/string/RTStrNCmp.cpp \ + common/string/RTStrNLen.cpp \ + common/string/RTStrNLenEx.cpp \ + common/string/RTStrPrintHexBytes.cpp \ + common/string/RTStrStartsWith.cpp \ + common/string/RTStrIStartsWith.cpp \ + common/string/RTStrICmpAscii.cpp \ + common/string/RTStrNICmpAscii.cpp \ + common/string/RTStrStr.cpp \ + common/string/RTUtf16Copy.cpp \ + common/string/RTUtf16CopyAscii.cpp \ + common/string/RTUtf16Cat.cpp \ + common/string/RTUtf16CatAscii.cpp \ + common/string/RTUtf16Chr.cpp \ + common/string/RTUtf16CmpAscii.cpp \ + common/string/RTUtf16ICmpAscii.cpp \ + common/string/RTUtf16End.cpp \ + common/string/RTUtf16NCmpAscii.cpp \ + common/string/RTUtf16NICmpAscii.cpp \ + common/string/RTUtf16NLen.cpp \ + common/string/RTUtf16NLenEx.cpp \ + common/string/RTUtf16PrintHexBytes.cpp \ + common/string/base64.cpp \ + common/string/simplepattern.cpp \ + common/string/straprintf.cpp \ + common/string/strformat.cpp \ + common/string/strformatnum.cpp \ + common/string/strformatrt.cpp \ + common/string/strformattype.cpp \ + common/string/strhash1.cpp \ + common/string/stringalloc.cpp \ + common/string/strprintf.cpp \ + common/string/strprintf2.cpp \ + common/string/strcache.cpp \ + common/string/strspace.cpp \ + common/string/strstrip.cpp \ + common/string/strtonum.cpp \ + common/string/strversion.cpp \ + common/string/uni.cpp \ + common/string/unidata-flags.cpp \ + common/string/unidata-lower.cpp \ + common/string/unidata-upper.cpp \ + common/string/utf-16.cpp \ + common/string/utf-16-case.cpp \ + common/string/utf-16-latin-1.cpp \ + common/string/utf-8.cpp \ + common/string/utf-8-case.cpp \ + common/string/utf-8-case2.cpp \ + common/string/ministring.cpp \ + common/table/avlgcptr.cpp \ + common/table/avlhcphys.cpp \ + common/table/avlgcphys.cpp \ + common/table/avllu32.cpp \ + common/table/avlou32.cpp \ + common/table/avlogcphys.cpp \ + common/table/avlogcptr.cpp \ + common/table/avlohcphys.cpp \ + common/table/avloioport.cpp \ + common/table/avlpv.cpp \ + common/table/avlrgcptr.cpp \ + common/table/avlrogcphys.cpp \ + common/table/avlrogcptr.cpp \ + common/table/avlroioport.cpp \ + common/table/avlroogcptr.cpp \ + common/table/avlrpv.cpp \ + common/table/avlruintptr.cpp \ + common/table/avlrfoff.cpp \ + common/table/avlru64.cpp \ + common/table/avlu32.cpp \ + common/table/avlu64.cpp \ + common/table/avluintptr.cpp \ + common/table/avlul.cpp \ + common/table/table.cpp \ + common/time/time.cpp \ + common/time/timeprog.cpp \ + common/time/timesup.cpp \ + common/time/timezoneinfo.cpp \ + common/vfs/vfsbase.cpp \ + common/vfs/vfschain.cpp \ + common/vfs/vfsfss2dir.cpp \ + common/vfs/vfsiosmisc.cpp \ + common/vfs/vfsmemory.cpp \ + common/vfs/vfsmisc.cpp \ + common/vfs/vfsmount.cpp \ + common/vfs/vfsmsg.cpp \ + common/vfs/vfsprogress.cpp \ + common/vfs/vfsreadahead.cpp \ + common/vfs/vfsstddir.cpp \ + common/vfs/vfsstdfile.cpp \ + common/vfs/vfsstdpipe.cpp \ + common/zip/tar.cpp \ + common/zip/tarcmd.cpp \ + common/zip/tarvfs.cpp \ + common/zip/tarvfswriter.cpp \ + common/zip/gzipvfs.cpp \ + common/zip/gzipcmd.cpp \ + common/zip/pkzip.cpp \ + common/zip/pkzipvfs.cpp \ + common/zip/unzipcmd.cpp \ + common/zip/zip.cpp \ + generic/createtemp-generic.cpp \ + generic/critsect-generic.cpp \ + generic/critsectrw-generic.cpp \ + generic/env-generic.cpp \ + generic/RTDirCreateUniqueNumbered-generic.cpp \ + generic/RTEnvDupEx-generic.cpp \ + generic/RTFileCopy-generic.cpp \ + generic/RTFileQuerySize-generic.cpp \ + generic/RTFileReadAll-generic.cpp \ + generic/RTFileReadAllEx-generic.cpp \ + generic/RTFileReadAllByHandle-generic.cpp \ + generic/RTFileReadAllByHandleEx-generic.cpp \ + generic/RTFileReadAllFree-generic.cpp \ + generic/RTLogWriteStdErr-generic.cpp \ + generic/RTLogWriteStdOut-generic.cpp \ + generic/RTLogWriteUser-generic.cpp \ + generic/RTPathGetCurrentDrive-generic.cpp \ + generic/RTPathIsSame-generic.cpp \ + generic/RTTimerLRCreate-generic.cpp \ + generic/rtStrFormatKernelAddress-generic.cpp \ + generic/mempool-generic.cpp \ + generic/semfastmutex-generic.cpp \ + generic/semxroads-generic.cpp \ + generic/spinlock-generic.cpp \ + generic/timerlr-generic.cpp \ + r3/alloc-ef.cpp \ + r3/alloc.cpp \ + r3/allocex.cpp \ + r3/dir.cpp \ + r3/dir2.cpp \ + r3/fileio.cpp \ + r3/fs.cpp \ + r3/init.cpp \ + r3/memsafer-r3.cpp \ + r3/path.cpp \ + r3/poll.cpp \ + r3/process.cpp \ + r3/socket.cpp \ + r3/stream.cpp \ + r3/test.cpp \ + r3/testi.cpp \ + r3/tcp.cpp \ + r3/udp.cpp \ + r3/generic/semspinmutex-r3-generic.cpp \ + r3/xml.cpp \ + common/zip/xarvfs.cpp + + +#if1of ($(KBUILD_TARGET_ARCH),amd64 x86) +# RuntimeR3_SOURCES += common/time/timesupA.asm +#else + RuntimeR3_SOURCES += common/time/timesupref.cpp +#endif + +RuntimeR3_SOURCES.x86 += \ + generic/RTMpGetDescription-generic.cpp \ + common/misc/RTSystemIsInsideVM-amd64-x86.cpp +RuntimeR3_SOURCES.amd64 += \ + generic/RTMpGetDescription-generic.cpp \ + common/misc/RTSystemIsInsideVM-amd64-x86.cpp +RuntimeR3_SOURCES.sparc32 += \ + generic/RTMpGetDescription-generic-stub.cpp \ + generic/RTSystemIsInsideVM-generic.cpp \ + common/asm/asm-fake.cpp +RuntimeR3_SOURCES.sparc64 += \ + generic/RTMpGetDescription-generic-stub.cpp \ + generic/RTSystemIsInsideVM-generic.cpp \ + common/asm/asm-fake.cpp + +ifdef IPRT_WITH_LZJB + RuntimeR3_SOURCES += common/misc/lzjb.c +endif + +# AMD64 / x86 assembly code. +RuntimeR3_SOURCES.x86 += \ + common/asm/ASMCpuIdExSlow.asm \ + common/asm/ASMAtomicUoAndU64.asm \ + common/asm/ASMAtomicUoAndU32.asm \ + common/asm/ASMAtomicUoDecU32.asm \ + common/asm/ASMAtomicUoIncU32.asm \ + common/asm/ASMAtomicUoOrU64.asm \ + common/asm/ASMAtomicUoOrU32.asm \ + common/asm/ASMMemFirstMismatchingU8.asm \ + common/asm/ASMRdMsrEx.asm \ + common/asm/ASMWrMsrEx.asm \ + common/asm/ASMGetXcr0.asm \ + common/asm/ASMSetXcr0.asm \ + common/asm/ASMXSave.asm \ + common/asm/ASMXRstor.asm \ + common/asm/ASMFxSave.asm \ + common/asm/ASMFxRstor.asm \ + common/asm/ASMSerializeInstruction-cpuid.asm \ + common/asm/ASMSerializeInstruction-iret.asm \ + common/asm/ASMSerializeInstruction-rdtscp.asm \ + common/dbg/dbgstackdumpself.cpp \ + common/dbg/dbgstackdumpself-amd64-x86.asm \ + common/math/bignum-amd64-x86.asm +RuntimeR3_SOURCES.amd64 += \ + common/asm/ASMCpuIdExSlow.asm \ + common/asm/ASMAtomicUoAndU64.asm \ + common/asm/ASMAtomicUoAndU32.asm \ + common/asm/ASMAtomicUoDecU32.asm \ + common/asm/ASMAtomicUoIncU32.asm \ + common/asm/ASMAtomicUoOrU64.asm \ + common/asm/ASMAtomicUoOrU32.asm \ + common/asm/ASMMemFirstMismatchingU8.asm \ + common/asm/ASMRdMsrEx.asm \ + common/asm/ASMWrMsrEx.asm \ + common/asm/ASMGetXcr0.asm \ + common/asm/ASMSetXcr0.asm \ + common/asm/ASMXSave.asm \ + common/asm/ASMXRstor.asm \ + common/asm/ASMFxSave.asm \ + common/asm/ASMFxRstor.asm \ + common/asm/ASMSerializeInstruction-cpuid.asm \ + common/asm/ASMSerializeInstruction-iret.asm \ + common/asm/ASMSerializeInstruction-rdtscp.asm \ + common/dbg/dbgstackdumpself.cpp \ + common/dbg/dbgstackdumpself-amd64-x86.asm \ + common/math/bignum-amd64-x86.asm \ + common/math/RTUInt128MulByU64.asm + +# Some versions of GCC might require this. +RuntimeR3_SOURCES.x86 += \ + common/asm/ASMAtomicXchgU64.asm \ + common/asm/ASMAtomicCmpXchgU64.asm \ + common/asm/ASMAtomicCmpXchgExU64.asm \ + common/asm/ASMAtomicReadU64.asm \ + common/asm/ASMAtomicUoReadU64.asm + + +# VBox specific stuff. +RuntimeR3_SOURCES += \ + VBox/RTAssertShouldPanic-vbox.cpp \ + VBox/log-vbox.cpp +ifneq ($(KBUILD_TARGET),win) +RuntimeR3_SOURCES += \ + common/err/errmsgxpcom.cpp +endif +if1of ($(KBUILD_TARGET),freebsd linux netbsd openbsd solaris) +RuntimeR3_SOURCES += \ + $(if $(VBOX_WITH_DBUS),VBox/dbus.cpp,) +endif + +if1of ($(KBUILD_TARGET_ARCH), sparc32 sparc64) +RuntimeR3_SOURCES := \ + $(filter-out common/misc/zero.asm, $(RuntimeR3_SOURCES)) \ + common/misc/zero.cpp +endif + +VBOX_WITH_NT_DIRENUM = 1 +RuntimeR3_SOURCES.win = \ + common/dbg/dbgmoddbghelp.cpp \ + generic/cdrom-generic.cpp \ + generic/RTDirExists-generic.cpp \ + generic/RTDirSetTimes-generic.cpp \ + generic/RTFileExists-generic.cpp \ + generic/RTFileSetAllocationSize-generic.cpp \ + generic/RTMpGetCurFrequency-generic.cpp \ + generic/RTMpGetMaxFrequency-generic.cpp \ + generic/RTPathAbs-generic.cpp \ + generic/RTRandAdvCreateSystemFaster-generic.cpp \ + generic/RTRandAdvCreateSystemTruer-generic.cpp \ + generic/RTSemEventWait-generic.cpp \ + generic/RTSemEventMultiWait-2-ex-generic.cpp \ + generic/RTSemEventMultiWaitNoResume-2-ex-generic.cpp \ + generic/RTSemMutexRequest-generic.cpp \ + generic/RTSemMutexRequestDebug-generic.cpp \ + generic/RTThreadSetAffinityToCpu-generic.cpp \ + generic/mppresent-generic-online.cpp \ + generic/semrw-$(if-expr defined(VBOX_WITH_LOCKLESS_SEMRW),lockless-,)generic.cpp \ + generic/uuid-generic.cpp \ + generic/RTProcDaemonize-generic.cpp \ + generic/RTProcIsRunningByName-generic.cpp \ + generic/RTThreadGetNativeState-generic.cpp \ + nt/RTErrConvertFromNtStatus.cpp \ + nt/RTNtPathExpand8dot3Path.cpp \ + nt/RTNtPathFindPossible8dot3Name.cpp \ + nt/fileioutils-nt.cpp \ + r3/generic/RTLocaleQueryLocaleName-r3-generic.cpp \ + r3/nt/dirrel-r3-nt.cpp \ + r3/nt/fs-nt.cpp \ + r3/nt/pathint-nt.cpp \ + r3/nt/RTFileQueryFsSizes-nt.cpp \ + r3/nt/RTFileSetMode-r3-nt.cpp \ + r3/nt/RTPathQueryInfo-nt.cpp \ + r3/nt/RTPathSetMode-r3-nt.cpp \ + r3/nt/RTProcQueryParent-r3-nt.cpp \ + r3/win/env-win.cpp \ + r3/win/RTCrStoreCreateSnapshotById-win.cpp \ + r3/win/RTHandleGetStandard-win.cpp \ + r3/win/RTLocaleQueryNormalizedBaseLocaleName-win.cpp \ + r3/win/RTLocaleQueryUserCountryCode-win.cpp \ + r3/win/RTSystemQueryOSInfo-win.cpp \ + r3/win/RTSystemShutdown-win.cpp \ + r3/win/RTSystemQueryDmiString-win.cpp \ + r3/win/RTSystemQueryTotalRam-win.cpp \ + r3/win/RTTimeZoneGetCurrent-win.cpp \ + r3/win/alloc-win.cpp \ + r3/win/allocex-win.cpp \ + r3/win/dir-win.cpp \ + $(if-expr defined(VBOX_WITH_NT_DIRENUM),r3/nt/direnum-r3-nt.cpp,r3/win/direnum-win.cpp generic/RTDirQueryInfo-generic.cpp) \ + r3/win/errvars-win.cpp \ + r3/win/fileio-win.cpp \ + r3/win/init-win.cpp \ + r3/win/krnlmod-win.cpp \ + r3/win/ldrNative-win.cpp \ + r3/win/localipc-win.cpp \ + r3/win/mp-win.cpp \ + r3/win/path-win.cpp \ + r3/win/pathint-win.cpp \ + r3/win/pipe-win.cpp \ + r3/win/process-win.cpp \ + r3/win/RTLogWriteDebugger-win.cpp \ + r3/win/rtProcInitExePath-win.cpp \ + r3/win/sched-win.cpp \ + r3/win/semevent-win.cpp \ + r3/win/semeventmulti-win.cpp \ + r3/win/semmutex-win.cpp \ + r3/win/serialport-win.cpp \ + r3/win/shmem-win.cpp \ + r3/win/symlink-win.cpp \ + r3/win/thread-win.cpp \ + r3/win/thread2-win.cpp \ + $(if-expr 1,r3/win/time-win.cpp,r3/nt/time-nt.cpp) \ + r3/win/time2-win.cpp \ + r3/win/timer-win.cpp \ + r3/win/tls-win.cpp \ + r3/win/utf16locale-win.cpp \ + r3/win/utf8-win.cpp \ + r3/win/RTUuidCreate-win.cpp \ + win/errmsgwin.cpp \ + win/RTErrConvertFromWin32.cpp \ + common/string/mempcpy.asm + +RuntimeR3_SOURCES.win.amd64 := \ + $(RuntimeWin64ASM_SOURCES) \ + common/string/memrchr.asm +RuntimeR3_SOURCES.win.x86 := \ + $(RuntimeWin32ASM_SOURCES) \ + common/string/memrchr.asm + +RuntimeR3_SOURCES.linux = \ + generic/cdrom-generic.cpp \ + generic/RTCrStoreCreateSnapshotById-generic.cpp \ + generic/RTDirQueryInfo-generic.cpp \ + generic/RTDirSetTimes-generic.cpp \ + generic/RTFileMove-generic.cpp \ + generic/RTLogWriteDebugger-generic.cpp \ + generic/RTPathAbs-generic.cpp \ + generic/RTPathGetCurrentOnDrive-generic.cpp \ + generic/RTProcDaemonize-generic.cpp \ + generic/RTSemEventMultiWait-2-ex-generic.cpp \ + generic/RTSemEventMultiWaitNoResume-2-ex-generic.cpp \ + generic/RTTimeLocalNow-generic.cpp \ + generic/RTTimerCreate-generic.cpp \ + generic/RTThreadSetAffinityToCpu-generic.cpp \ + generic/RTUuidCreate-generic.cpp \ + generic/mppresent-generic.cpp \ + generic/utf16locale-generic.cpp \ + generic/uuid-generic.cpp \ + r3/generic/RTLocaleQueryLocaleName-r3-generic.cpp \ + r3/generic/RTLocaleQueryNormalizedBaseLocaleName-r3-generic.cpp \ + r3/generic/RTLocaleQueryUserCountryCode-r3-generic.cpp \ + r3/generic/RTTimeZoneGetCurrent-generic.cpp \ + r3/generic/dirrel-r3-generic.cpp \ + r3/posix/allocex-r3-posix.cpp \ + r3/linux/RTThreadGetNativeState-linux.cpp \ + r3/linux/krnlmod-linux.cpp \ + r3/linux/mp-linux.cpp \ + r3/linux/rtProcInitExePath-linux.cpp \ + r3/linux/sched-linux.cpp \ + r3/linux/sysfs.cpp \ + r3/linux/time-linux.cpp \ + r3/linux/thread-affinity-linux.cpp \ + r3/linux/RTFileSetAllocationSize-linux.cpp \ + r3/linux/RTProcIsRunningByName-linux.cpp \ + r3/linux/RTSystemQueryDmiString-linux.cpp \ + r3/linux/RTSystemShutdown-linux.cpp \ + r3/posix/RTFileQueryFsSizes-posix.cpp \ + r3/posix/RTHandleGetStandard-posix.cpp \ + r3/posix/RTMemProtect-posix.cpp \ + r3/posix/RTPathUserHome-posix.cpp \ + r3/posix/RTSystemQueryOSInfo-posix.cpp \ + r3/linux/systemmem-linux.cpp \ + r3/posix/RTTimeNow-posix.cpp \ + r3/posix/RTTimeSet-posix.cpp \ + r3/posix/rtmempage-exec-mmap-heap-posix.cpp \ + r3/posix/dir-posix.cpp \ + r3/posix/env-posix.cpp \ + r3/posix/errvars-posix.cpp \ + r3/posix/fileio-posix.cpp \ + r3/posix/fileio2-posix.cpp \ + r3/posix/filelock-posix.cpp \ + r3/posix/fs-posix.cpp \ + r3/posix/fs2-posix.cpp \ + r3/posix/fs3-posix.cpp \ + r3/posix/ldrNative-posix.cpp \ + r3/posix/localipc-posix.cpp \ + r3/posix/path-posix.cpp \ + r3/posix/path2-posix.cpp \ + r3/posix/pathhost-posix.cpp \ + r3/posix/RTPathUserDocuments-posix.cpp \ + r3/posix/pipe-posix.cpp \ + r3/posix/process-posix.cpp \ + r3/posix/process-creation-posix.cpp \ + r3/posix/rand-posix.cpp \ + r3/posix/semrw-posix.cpp \ + r3/posix/serialport-posix.cpp \ + r3/posix/shmem-posix.cpp \ + r3/posix/symlink-posix.cpp \ + r3/posix/thread-posix.cpp \ + r3/posix/thread2-posix.cpp \ + r3/posix/timelocal-posix.cpp \ + r3/posix/timer-posix.cpp \ + r3/posix/tls-posix.cpp \ + r3/posix/utf8-posix.cpp +ifdef IPRT_WITH_FUTEX_BASED_SEMS + RuntimeR3_SOURCES.linux += \ + r3/linux/semevent-linux.cpp \ + r3/linux/semeventmulti-linux.cpp \ + r3/linux/semmutex-linux.cpp +else + RuntimeR3_SOURCES.linux.x86 += \ + r3/posix/semevent-posix.cpp \ + r3/posix/semeventmulti-posix.cpp \ + r3/posix/semmutex-posix.cpp + RuntimeR3_SOURCES.linux.amd64 += \ + r3/linux/semevent-linux.cpp \ + r3/linux/semeventmulti-linux.cpp + ifdef RT_NEW_LINUX_MUTEX_CODE + RuntimeR3_SOURCES.linux.amd64 += \ + r3/linux/semmutex-linux.cpp + else + RuntimeR3_SOURCES.linux.amd64 += \ + r3/posix/semmutex-posix.cpp + endif +endif + +RuntimeR3_SOURCES.os2 = \ + common/string/memrchr.asm \ + generic/cdrom-generic.cpp \ + generic/RTCrStoreCreateSnapshotById-generic.cpp \ + generic/RTDirQueryInfo-generic.cpp \ + generic/RTDirSetTimes-generic.cpp \ + generic/RTFileMove-generic.cpp \ + generic/RTFileSetAllocationSize-generic.cpp \ + generic/RTLogWriteDebugger-generic.cpp \ + generic/RTPathAbs-generic.cpp \ + generic/RTPathGetCurrentOnDrive-generic.cpp \ + generic/RTProcDaemonize-generic.cpp \ + generic/RTRandAdvCreateSystemFaster-generic.cpp \ + generic/RTRandAdvCreateSystemTruer-generic.cpp \ + generic/RTSystemQueryDmiString-generic.cpp \ + generic/RTSystemShutdown-generic.cpp \ + generic/RTTimeLocalNow-generic.cpp \ + generic/RTTimerCreate-generic.cpp \ + generic/RTThreadSetAffinityToCpu-generic.cpp \ + generic/RTUuidCreate-generic.cpp \ + generic/mppresent-generic.cpp \ + generic/RTSemEventWait-generic.cpp \ + generic/RTSemEventMultiWait-generic.cpp \ + generic/RTSemMutexRequest-generic.cpp \ + generic/RTSemMutexRequestDebug-generic.cpp \ + generic/semrw-$(if-expr defined(VBOX_WITH_LOCKLESS_SEMRW),lockless-,)generic.cpp \ + generic/timer-generic.cpp \ + generic/utf16locale-generic.cpp \ + generic/uuid-generic.cpp \ + generic/RTMpGetCoreCount-generic.cpp \ + generic/RTMpGetOnlineCoreCount-generic.cpp \ + generic/RTMpGetCurFrequency-generic.cpp \ + generic/RTMpGetMaxFrequency-generic.cpp \ + generic/RTProcIsRunningByName-generic.cpp \ + generic/RTThreadGetNativeState-generic.cpp \ + os2/RTErrConvertFromOS2.cpp \ + r3/generic/allocex-r3-generic.cpp \ + r3/generic/RTLocaleQueryLocaleName-r3-generic.cpp \ + r3/generic/RTLocaleQueryNormalizedBaseLocaleName-r3-generic.cpp \ + r3/generic/RTLocaleQueryUserCountryCode-r3-generic.cpp \ + r3/generic/RTTimeZoneGetCurrent-generic.cpp \ + r3/generic/dirrel-r3-generic.cpp \ + r3/os2/RTTimeSet-os2.cpp \ + r3/os2/filelock-os2.cpp \ + r3/os2/mp-os2.cpp \ + r3/os2/pipe-os2.cpp \ + r3/os2/rtProcInitExePath-os2.cpp \ + r3/os2/sched-os2.cpp \ + r3/os2/sems-os2.cpp \ + r3/os2/systemmem-os2.cpp \ + r3/os2/thread-os2.cpp \ + r3/os2/time-os2.cpp \ + r3/posix/RTFileQueryFsSizes-posix.cpp \ + r3/posix/RTHandleGetStandard-posix.cpp \ + r3/posix/RTMemProtect-posix.cpp \ + r3/posix/RTPathUserHome-posix.cpp \ + r3/posix/RTSystemQueryOSInfo-posix.cpp \ + r3/posix/RTTimeNow-posix.cpp \ + r3/posix/dir-posix.cpp \ + r3/posix/env-posix.cpp \ + r3/posix/errvars-posix.cpp \ + r3/posix/fileio-posix.cpp \ + r3/posix/fileio2-posix.cpp \ + r3/posix/fs-posix.cpp \ + r3/posix/fs2-posix.cpp \ + r3/posix/fs3-posix.cpp \ + r3/posix/ldrNative-posix.cpp \ + r3/posix/localipc-posix.cpp \ + r3/posix/path-posix.cpp \ + r3/posix/path2-posix.cpp \ + r3/posix/pathhost-posix.cpp \ + r3/posix/rtmempage-exec-mmap-heap-posix.cpp \ + r3/posix/RTPathUserDocuments-posix.cpp \ + r3/posix/process-posix.cpp \ + r3/posix/process-creation-posix.cpp \ + r3/posix/symlink-posix.cpp \ + r3/posix/timelocal-posix.cpp \ + r3/posix/utf8-posix.cpp + +RuntimeR3_SOURCES.darwin = \ + darwin/RTErrConvertFromDarwin.cpp \ + darwin/RTErrConvertFromDarwinCOM.cpp \ + darwin/RTErrConvertFromDarwinIO.cpp \ + darwin/RTErrConvertFromDarwinKern.cpp \ + generic/cdrom-generic.cpp \ + generic/RTDirQueryInfo-generic.cpp \ + generic/RTDirSetTimes-generic.cpp \ + generic/RTFileMove-generic.cpp \ + generic/RTFileSetAllocationSize-generic.cpp \ + generic/RTLogWriteDebugger-generic.cpp \ + generic/RTPathAbs-generic.cpp \ + generic/RTPathGetCurrentOnDrive-generic.cpp \ + generic/RTProcDaemonize-generic.cpp \ + generic/RTThreadGetAffinity-stub-generic.cpp \ + generic/RTThreadSetAffinity-stub-generic.cpp \ + generic/RTThreadSetAffinityToCpu-generic.cpp \ + generic/RTTimeLocalNow-generic.cpp \ + generic/RTTimerCreate-generic.cpp \ + generic/RTUuidCreate-generic.cpp \ + generic/mppresent-generic.cpp \ + generic/RTSemEventMultiWait-2-ex-generic.cpp \ + generic/RTSemEventMultiWaitNoResume-2-ex-generic.cpp \ + generic/semrw-$(if-expr defined(VBOX_WITH_LOCKLESS_SEMRW),lockless-,)generic.cpp \ + generic/RTSystemShutdown-generic.cpp \ + generic/timer-generic.cpp \ + generic/utf16locale-generic.cpp \ + generic/uuid-generic.cpp\ + generic/RTProcIsRunningByName-generic.cpp \ + generic/RTThreadGetNativeState-generic.cpp \ + r3/darwin/RTCrStoreCreateSnapshotById-darwin.cpp \ + r3/darwin/filelock-darwin.cpp \ + r3/darwin/krnlmod-darwin.cpp \ + r3/darwin/mp-darwin.cpp \ + r3/darwin/pathhost-darwin.cpp \ + r3/darwin/rtProcInitExePath-darwin.cpp \ + r3/darwin/RTSystemQueryDmiString-darwin.cpp \ + r3/darwin/sched-darwin.cpp \ + r3/darwin/systemmem-darwin.cpp \ + r3/darwin/time-darwin.cpp \ + r3/darwin/RTPathUserDocuments-darwin.cpp \ + r3/generic/allocex-r3-generic.cpp \ + r3/generic/RTLocaleQueryLocaleName-r3-generic.cpp \ + r3/generic/RTLocaleQueryNormalizedBaseLocaleName-r3-generic.cpp \ + r3/generic/RTLocaleQueryUserCountryCode-r3-generic.cpp \ + r3/generic/RTTimeZoneGetCurrent-generic.cpp \ + r3/generic/dirrel-r3-generic.cpp \ + r3/posix/RTFileQueryFsSizes-posix.cpp \ + r3/posix/RTHandleGetStandard-posix.cpp \ + r3/posix/RTMemProtect-posix.cpp \ + r3/posix/RTPathUserHome-posix.cpp \ + r3/posix/RTSystemQueryOSInfo-posix.cpp \ + r3/posix/RTTimeSet-posix.cpp \ + r3/posix/dir-posix.cpp \ + r3/posix/env-posix.cpp \ + r3/posix/errvars-posix.cpp \ + r3/posix/fileio-posix.cpp \ + r3/posix/fileio2-posix.cpp \ + r3/posix/fs-posix.cpp \ + r3/posix/fs2-posix.cpp \ + r3/posix/fs3-posix.cpp \ + r3/posix/ldrNative-posix.cpp \ + r3/posix/localipc-posix.cpp \ + r3/posix/rtmempage-exec-mmap-heap-posix.cpp \ + r3/posix/path-posix.cpp \ + r3/posix/path2-posix.cpp \ + r3/posix/pipe-posix.cpp \ + r3/posix/process-posix.cpp \ + r3/posix/process-creation-posix.cpp \ + r3/posix/rand-posix.cpp \ + r3/posix/semevent-posix.cpp \ + r3/posix/semeventmulti-posix.cpp \ + r3/posix/semmutex-posix.cpp \ + r3/posix/serialport-posix.cpp \ + r3/posix/symlink-posix.cpp \ + r3/posix/shmem-posix.cpp \ + r3/posix/thread-posix.cpp \ + r3/posix/thread2-posix.cpp \ + r3/posix/timelocal-posix.cpp \ + r3/posix/tls-posix.cpp \ + r3/posix/utf8-posix.cpp +RuntimeR3_SOURCES.darwin.x86 += common/string/memrchr.asm +RuntimeR3_SOURCES.darwin.amd64 += common/string/memrchr.asm + +## @todo Make BSD sched, implement RTMP*. +RuntimeR3_SOURCES.freebsd = \ + generic/cdrom-generic.cpp \ + generic/RTCrStoreCreateSnapshotById-generic.cpp \ + generic/RTDirQueryInfo-generic.cpp \ + generic/RTDirSetTimes-generic.cpp \ + generic/RTFileMove-generic.cpp \ + generic/RTFileSetAllocationSize-generic.cpp \ + generic/RTLogWriteDebugger-generic.cpp \ + generic/RTPathAbs-generic.cpp \ + generic/RTPathGetCurrentOnDrive-generic.cpp \ + generic/RTSemEventMultiWait-2-ex-generic.cpp \ + generic/RTSemEventMultiWaitNoResume-2-ex-generic.cpp \ + generic/RTSystemQueryDmiString-generic.cpp \ + generic/RTSystemShutdown-generic.cpp \ + generic/RTThreadGetAffinity-stub-generic.cpp \ + generic/RTThreadSetAffinity-stub-generic.cpp \ + generic/RTThreadSetAffinityToCpu-generic.cpp \ + generic/RTTimeLocalNow-generic.cpp \ + generic/RTTimerCreate-generic.cpp \ + generic/RTUuidCreate-generic.cpp \ + generic/mppresent-generic.cpp \ + generic/sched-generic.cpp \ + generic/utf16locale-generic.cpp \ + generic/uuid-generic.cpp \ + generic/RTMpCpuId-generic.cpp \ + generic/RTMpGetCoreCount-generic.cpp \ + generic/RTMpGetOnlineCoreCount-generic.cpp \ + generic/RTProcDaemonize-generic.cpp \ + generic/RTProcIsRunningByName-generic.cpp \ + generic/RTThreadGetNativeState-generic.cpp \ + r3/freebsd/mp-freebsd.cpp \ + r3/freebsd/systemmem-freebsd.cpp \ + r3/freebsd/rtProcInitExePath-freebsd.cpp \ + r3/generic/allocex-r3-generic.cpp \ + r3/generic/RTLocaleQueryLocaleName-r3-generic.cpp \ + r3/generic/RTLocaleQueryNormalizedBaseLocaleName-r3-generic.cpp \ + r3/generic/RTLocaleQueryUserCountryCode-r3-generic.cpp \ + r3/generic/RTTimeZoneGetCurrent-generic.cpp \ + r3/generic/dirrel-r3-generic.cpp \ + r3/posix/RTFileQueryFsSizes-posix.cpp \ + r3/posix/RTHandleGetStandard-posix.cpp \ + r3/posix/RTMemProtect-posix.cpp \ + r3/posix/RTPathUserHome-posix.cpp \ + r3/posix/RTSystemQueryOSInfo-posix.cpp \ + r3/posix/RTTimeNow-posix.cpp \ + r3/posix/RTTimeSet-posix.cpp \ + r3/posix/dir-posix.cpp \ + r3/posix/env-posix.cpp \ + r3/posix/errvars-posix.cpp \ + r3/posix/fileio-posix.cpp \ + r3/posix/fileio2-posix.cpp \ + r3/posix/filelock-posix.cpp \ + r3/posix/fs-posix.cpp \ + r3/posix/fs2-posix.cpp \ + r3/posix/fs3-posix.cpp \ + r3/posix/ldrNative-posix.cpp \ + r3/posix/localipc-posix.cpp \ + r3/posix/rtmempage-exec-mmap-heap-posix.cpp \ + r3/posix/path-posix.cpp \ + r3/posix/path2-posix.cpp \ + r3/posix/pathhost-posix.cpp \ + r3/posix/RTPathUserDocuments-posix.cpp \ + r3/posix/pipe-posix.cpp \ + r3/posix/process-posix.cpp \ + r3/posix/process-creation-posix.cpp \ + r3/posix/rand-posix.cpp \ + r3/posix/semevent-posix.cpp \ + r3/posix/semeventmulti-posix.cpp \ + r3/posix/semmutex-posix.cpp \ + r3/posix/semrw-posix.cpp \ + r3/posix/serialport-posix.cpp \ + r3/posix/symlink-posix.cpp \ + r3/posix/shmem-posix.cpp \ + r3/posix/thread-posix.cpp \ + r3/posix/thread2-posix.cpp \ + r3/posix/time-posix.cpp \ + r3/posix/timelocal-posix.cpp \ + r3/posix/timer-posix.cpp \ + r3/posix/tls-posix.cpp \ + r3/posix/utf8-posix.cpp + +RuntimeR3_SOURCES.netbsd = \ + generic/cdrom-generic.cpp \ + generic/RTDirQueryInfo-generic.cpp \ + generic/RTDirSetTimes-generic.cpp \ + generic/RTFileMove-generic.cpp \ + generic/RTLogWriteDebugger-generic.cpp \ + generic/RTPathAbs-generic.cpp \ + generic/RTSemEventMultiWait-2-ex-generic.cpp \ + generic/RTSemEventMultiWaitNoResume-2-ex-generic.cpp \ + generic/RTSystemQueryDmiString-generic.cpp \ + generic/RTSystemShutdown-generic.cpp \ + generic/RTThreadGetAffinity-stub-generic.cpp \ + generic/RTThreadSetAffinity-stub-generic.cpp \ + generic/RTThreadSetAffinityToCpu-generic.cpp \ + generic/RTTimeLocalNow-generic.cpp \ + generic/RTTimerCreate-generic.cpp \ + generic/RTUuidCreate-generic.cpp \ + generic/mppresent-generic.cpp \ + generic/sched-generic.cpp \ + generic/utf16locale-generic.cpp \ + generic/uuid-generic.cpp \ + generic/RTMpCpuId-generic.cpp \ + generic/RTMpGetCoreCount-generic.cpp \ + generic/RTMpGetOnlineCoreCount-generic.cpp \ + generic/RTProcDaemonize-generic.cpp \ + generic/RTProcIsRunningByName-generic.cpp \ + generic/RTThreadGetNativeState-generic.cpp \ + r3/netbsd/rtProcInitExePath-netbsd.cpp \ + r3/generic/allocex-r3-generic.cpp \ + r3/generic/RTLocaleQueryLocaleName-r3-generic.cpp \ + r3/generic/RTLocaleQueryNormalizedBaseLocaleName-r3-generic.cpp \ + r3/generic/RTLocaleQueryUserCountryCode-r3-generic.cpp \ + r3/generic/RTTimeZoneGetCurrent-generic.cpp \ + r3/generic/dirrel-r3-generic.cpp \ + r3/posix/RTFileQueryFsSizes-posix.cpp \ + r3/posix/RTFileSetAllocationSize-posix.cpp \ + r3/posix/RTHandleGetStandard-posix.cpp \ + r3/posix/RTMemProtect-posix.cpp \ + r3/posix/RTPathUserHome-posix.cpp \ + r3/posix/RTSystemQueryOSInfo-posix.cpp \ + r3/posix/RTSystemQueryTotalRam-posix.cpp \ + r3/posix/RTTimeNow-posix.cpp \ + r3/posix/RTTimeSet-posix.cpp \ + r3/posix/dir-posix.cpp \ + r3/posix/env-posix.cpp \ + r3/posix/errvars-posix.cpp \ + r3/posix/fileio-posix.cpp \ + r3/posix/fileio2-posix.cpp \ + r3/posix/filelock-posix.cpp \ + r3/posix/fs-posix.cpp \ + r3/posix/fs2-posix.cpp \ + r3/posix/fs3-posix.cpp \ + r3/posix/ldrNative-posix.cpp \ + r3/posix/rtmempage-exec-mmap-heap-posix.cpp \ + r3/posix/path-posix.cpp \ + r3/posix/path2-posix.cpp \ + r3/posix/pathhost-posix.cpp \ + r3/posix/RTPathUserDocuments-posix.cpp \ + r3/posix/pipe-posix.cpp \ + r3/posix/process-posix.cpp \ + r3/posix/process-creation-posix.cpp \ + r3/posix/rand-posix.cpp \ + r3/posix/semevent-posix.cpp \ + r3/posix/semeventmulti-posix.cpp \ + r3/posix/semmutex-posix.cpp \ + r3/posix/semrw-posix.cpp \ + r3/posix/serialport-posix.cpp \ + r3/posix/symlink-posix.cpp \ + r3/posix/shmem-posix.cpp \ + r3/posix/thread-posix.cpp \ + r3/posix/thread2-posix.cpp \ + r3/posix/time-posix.cpp \ + r3/posix/timelocal-posix.cpp \ + r3/posix/timer-posix.cpp \ + r3/posix/tls-posix.cpp \ + r3/posix/utf8-posix.cpp + +RuntimeR3_SOURCES.solaris = \ + generic/cdrom-generic.cpp \ + generic/RTCrStoreCreateSnapshotById-generic.cpp \ + generic/RTDirQueryInfo-generic.cpp \ + generic/RTDirSetTimes-generic.cpp \ + generic/RTFileMove-generic.cpp \ + generic/RTLogWriteDebugger-generic.cpp \ + generic/RTPathAbs-generic.cpp \ + generic/RTPathGetCurrentOnDrive-generic.cpp \ + generic/RTProcDaemonize-generic.cpp \ + generic/RTProcIsRunningByName-generic.cpp \ + generic/RTSemEventMultiWait-2-ex-generic.cpp \ + generic/RTSemEventMultiWaitNoResume-2-ex-generic.cpp \ + generic/RTThreadSetAffinityToCpu-generic.cpp \ + generic/RTTimeLocalNow-generic.cpp \ + generic/RTTimerCreate-generic.cpp \ + generic/RTUuidCreate-generic.cpp \ + generic/sched-generic.cpp \ + generic/utf16locale-generic.cpp \ + generic/uuid-generic.cpp \ + generic/RTThreadGetNativeState-generic.cpp \ + r3/generic/allocex-r3-generic.cpp \ + r3/generic/RTLocaleQueryLocaleName-r3-generic.cpp \ + r3/generic/RTLocaleQueryNormalizedBaseLocaleName-r3-generic.cpp \ + r3/generic/RTLocaleQueryUserCountryCode-r3-generic.cpp \ + r3/generic/RTTimeZoneGetCurrent-generic.cpp \ + r3/generic/dirrel-r3-generic.cpp \ + r3/posix/RTFileQueryFsSizes-posix.cpp \ + r3/posix/RTFileSetAllocationSize-posix.cpp \ + r3/posix/RTHandleGetStandard-posix.cpp \ + r3/posix/RTMemProtect-posix.cpp \ + r3/posix/RTPathUserHome-posix.cpp \ + r3/posix/RTSystemQueryOSInfo-posix.cpp \ + r3/posix/RTTimeNow-posix.cpp \ + r3/posix/RTTimeSet-posix.cpp \ + r3/posix/dir-posix.cpp \ + r3/posix/env-posix.cpp \ + r3/posix/errvars-posix.cpp \ + r3/posix/fileio-posix.cpp \ + r3/posix/fileio2-posix.cpp \ + r3/posix/filelock-posix.cpp \ + r3/posix/fs-posix.cpp \ + r3/posix/fs2-posix.cpp \ + r3/posix/fs3-posix.cpp \ + r3/posix/ldrNative-posix.cpp \ + r3/posix/localipc-posix.cpp \ + r3/posix/rtmempage-exec-mmap-heap-posix.cpp \ + r3/posix/path-posix.cpp \ + r3/posix/path2-posix.cpp \ + r3/posix/pathhost-posix.cpp \ + r3/posix/RTPathUserDocuments-posix.cpp \ + r3/posix/pipe-posix.cpp \ + r3/posix/process-posix.cpp \ + r3/posix/process-creation-posix.cpp \ + r3/posix/rand-posix.cpp \ + r3/posix/semevent-posix.cpp \ + r3/posix/semeventmulti-posix.cpp \ + r3/posix/semmutex-posix.cpp \ + r3/posix/semrw-posix.cpp \ + r3/posix/serialport-posix.cpp \ + r3/posix/symlink-posix.cpp \ + r3/posix/shmem-posix.cpp \ + r3/posix/thread-posix.cpp \ + r3/posix/thread2-posix.cpp \ + r3/posix/time-posix.cpp \ + r3/posix/timelocal-posix.cpp \ + r3/posix/timer-posix.cpp \ + r3/posix/tls-posix.cpp \ + r3/posix/utf8-posix.cpp \ + r3/solaris/krnlmod-solaris.cpp \ + r3/solaris/systemmem-solaris.cpp \ + r3/solaris/mp-solaris.cpp \ + r3/solaris/rtProcInitExePath-solaris.cpp \ + r3/solaris/RTSystemShutdown-solaris.cpp \ + r3/solaris/thread-affinity-solaris.cpp +RuntimeR3_SOURCES.solaris.amd64 = \ + common/string/memrchr.asm \ + r3/solaris/coredumper-solaris.cpp \ + r3/solaris/RTSystemQueryDmiString-solaris.cpp +RuntimeR3_SOURCES.solaris.x86 = \ + common/string/memrchr.asm \ + r3/solaris/coredumper-solaris.cpp \ + r3/solaris/RTSystemQueryDmiString-solaris.cpp +RuntimeR3_SOURCES.solaris.sparc32 = \ + common/string/memrchr.cpp \ + generic/RTSystemQueryDmiString-generic.cpp +RuntimeR3_SOURCES.solaris.sparc64 = \ + common/string/memrchr.cpp \ + generic/RTSystemQueryDmiString-generic.cpp + +RuntimeR3_SOURCES.haiku = \ + generic/RTCrStoreCreateSnapshotById-generic.cpp \ + generic/RTDirQueryInfo-generic.cpp \ + generic/RTDirSetTimes-generic.cpp \ + generic/RTFileMove-generic.cpp \ + generic/RTFileSetAllocationSize-generic.cpp \ + generic/RTLogWriteDebugger-generic.cpp \ + generic/RTPathAbs-generic.cpp \ + generic/RTPathGetCurrentOnDrive-generic.cpp \ + generic/RTProcDaemonize-generic.cpp \ + generic/RTTimeLocalNow-generic.cpp \ + generic/RTTimerCreate-generic.cpp \ + generic/RTUuidCreate-generic.cpp \ + generic/mppresent-generic.cpp \ + generic/RTSemEventMultiWait-2-ex-generic.cpp \ + generic/RTSemEventMultiWaitNoResume-2-ex-generic.cpp \ + generic/sched-generic.cpp \ + generic/semrw-$(if-expr defined(VBOX_WITH_LOCKLESS_SEMRW),lockless-,)generic.cpp \ + generic/timer-generic.cpp \ + generic/utf16locale-generic.cpp \ + generic/uuid-generic.cpp\ + generic/RTProcIsRunningByName-generic.cpp \ + generic/RTThreadGetNativeState-generic.cpp \ + generic/RTMpGetCoreCount-generic.cpp \ + generic/RTMpGetOnlineCoreCount-generic.cpp \ + r3/haiku/rtProcInitExePath-haiku.cpp \ + r3/haiku/time-haiku.cpp \ + r3/generic/allocex-r3-generic.cpp \ + r3/generic/RTLocaleQueryLocaleName-r3-generic.cpp \ + r3/generic/RTLocaleQueryNormalizedBaseLocaleName-r3-generic.cpp \ + r3/generic/RTLocaleQueryUserCountryCode-r3-generic.cpp \ + r3/generic/RTTimeZoneGetCurrent-generic.cpp \ + r3/generic/dirrel-r3-generic.cpp \ + r3/posix/RTFileQueryFsSizes-posix.cpp \ + r3/posix/RTHandleGetStandard-posix.cpp \ + r3/posix/RTMemProtect-posix.cpp \ + r3/posix/RTPathUserHome-posix.cpp \ + r3/posix/RTSystemQueryOSInfo-posix.cpp \ + r3/posix/RTSystemQueryTotalRam-posix.cpp \ + r3/posix/RTTimeNow-posix.cpp \ + r3/posix/dir-posix.cpp \ + r3/posix/env-posix.cpp \ + r3/posix/errvars-posix.cpp \ + r3/posix/fileio-posix.cpp \ + r3/posix/fileio2-posix.cpp \ + r3/posix/filelock-posix.cpp \ + r3/posix/fs-posix.cpp \ + r3/posix/fs2-posix.cpp \ + r3/posix/fs3-posix.cpp \ + r3/posix/ldrNative-posix.cpp \ + r3/posix/localipc-posix.cpp \ + r3/posix/rtmempage-exec-mmap-heap-posix.cpp \ + r3/posix/path-posix.cpp \ + r3/posix/path2-posix.cpp \ + r3/posix/pathhost-posix.cpp \ + r3/posix/pipe-posix.cpp \ + r3/posix/process-posix.cpp \ + r3/posix/process-creation-posix.cpp \ + r3/posix/rand-posix.cpp \ + r3/posix/semevent-posix.cpp \ + r3/posix/semeventmulti-posix.cpp \ + r3/posix/semmutex-posix.cpp \ + r3/posix/serialport-posix.cpp \ + r3/posix/symlink-posix.cpp \ + r3/posix/thread-posix.cpp \ + r3/posix/thread2-posix.cpp \ + r3/posix/timelocal-posix.cpp \ + r3/posix/tls-posix.cpp \ + r3/posix/utf8-posix.cpp +RuntimeR3_SOURCES.haiku.x86 += common/string/memrchr.asm +RuntimeR3_SOURCES.haiku.amd64 += common/string/memrchr.asm + +## PORTME: Porters add their selection of platform specific files for Ring-3 here. + + +# +# Generate RTIsoMaker / VISO help text from the manpage xml. +# +ifn1of ($(KBUILD_TARGET), os2) # breaks validationkit, figure out later. + + IPRT_XML_REFENTRY_FILES = \ + common/fs/isomakercmd-man.xml + + #$(call KB_FN_DO_PASS0_ON_TARGET,RuntimeR3) + + BLDDIRS += $(IPRT_OUT_DIR)/man/ + OTHER_CLEAN += \ + $(addprefix $(IPRT_OUT_DIR)/man/,$(IPRT_XML_REFENTRY_FILES)) \ + $(addprefix $(IPRT_OUT_DIR)/man/,$(patsubst %.xml,%.h,$(IPRT_XML_REFENTRY_FILES))) \ + $(addprefix $(IPRT_OUT_DIR)/man/,$(patsubst %.xml,%.h.ts,$(IPRT_XML_REFENTRY_FILES))) + + + include $(PATH_ROOT)/doc/manual/Config.kmk + + # Preprocess the xml files, applying remarks. + $(foreach file,$(IPRT_XML_REFENTRY_FILES) \ + , $(evalcall2 def_vbox_refentry_preprocess_for_manpage,$(IPRT_OUT_DIR)/man,$(notdir $(file)),$(VBOX_PATH_RUNTIME_SRC)/$(file))) + + # generate the header and add it as a dependency to the source using it. + $(evalcall2 def_vbox_single_refentry_to_h,$(IPRT_OUT_DIR)/man/isomakercmd-man.h, $(IPRT_OUT_DIR)/man/isomakercmd-man.xml) + common/fs/isomakercmd.cpp_DEPS = $(IPRT_OUT_DIR)/man/isomakercmd-man.h + common/fs/isomakercmd.cpp_INCS = $(IPRT_OUT_DIR)/man/ + +endif + + + +# +# RuntimeBldProg - Static Runtime for build programs. +# +# Note! This is a bit of hacky since kBuild doesn't support building libraries +# for build programs. +# +RuntimeBldProg_TEMPLATE := VBoxAdvBldProg +RuntimeBldProg_EXTENDS := RuntimeR3 +RuntimeBldProg_BLD_TRG := $(KBUILD_HOST) +RuntimeBldProg_BLD_TRG_ARCH := $(KBUILD_HOST_ARCH) +RuntimeBldProg_BLD_TRG_CPU := $(KBUILD_HOST_CPU) +RuntimeBldProg_DEFS := $(filter-out IN_SUP_R3 IN_SUP, $(RuntimeR3_DEFS)) IPRT_WITHOUT_LDR_VERIFY RT_NO_GIP +RuntimeBldProg_SOURCES = \ + common/alloc/alloc.cpp \ + common/alloc/memcache.cpp \ + common/asn1/asn1-basics.cpp \ + common/asn1/asn1-cursor.cpp \ + common/asn1/asn1-default-allocator.cpp \ + common/asn1/asn1-dump.cpp \ + common/asn1/asn1-efence-allocator.cpp \ + common/asn1/asn1-encode.cpp \ + common/asn1/asn1-safer-allocator.cpp \ + common/asn1/asn1-ut-bitstring-decode.cpp \ + common/asn1/asn1-ut-bitstring.cpp \ + common/asn1/asn1-ut-boolean-decode.cpp \ + common/asn1/asn1-ut-boolean.cpp \ + common/asn1/asn1-ut-core-decode.cpp \ + common/asn1/asn1-ut-core.cpp \ + common/asn1/asn1-ut-dyntype-decode.cpp \ + common/asn1/asn1-ut-dyntype.cpp \ + common/asn1/asn1-ut-integer-decode.cpp \ + common/asn1/asn1-ut-integer.cpp \ + common/asn1/asn1-ut-null-decode.cpp \ + common/asn1/asn1-ut-null.cpp \ + common/asn1/asn1-ut-objid-decode.cpp \ + common/asn1/asn1-ut-objid.cpp \ + common/asn1/asn1-ut-octetstring-decode.cpp \ + common/asn1/asn1-ut-octetstring.cpp \ + common/asn1/asn1-ut-string-decode.cpp \ + common/asn1/asn1-ut-string.cpp \ + common/asn1/asn1-ut-time-decode.cpp \ + common/asn1/asn1-ut-time.cpp \ + common/checksum/adler32.cpp \ + common/checksum/alt-md2.cpp \ + common/checksum/alt-md4.cpp \ + common/checksum/alt-md5.cpp \ + common/checksum/alt-sha1.cpp \ + common/checksum/alt-sha256.cpp \ + common/checksum/alt-sha512.cpp \ + common/checksum/crc16ccitt.cpp \ + common/checksum/crc32.cpp \ + common/checksum/crc32c.cpp \ + common/checksum/crc64.cpp \ + common/checksum/manifest2.cpp \ + common/checksum/manifest3.cpp \ + common/checksum/md5str.cpp \ + common/checksum/sha1str.cpp \ + common/checksum/sha256str.cpp \ + common/checksum/sha512str.cpp \ + common/crypto/digest-core.cpp \ + common/crypto/pemfile.cpp \ + common/crypto/pkcs7-asn1-decoder.cpp \ + common/crypto/pkcs7-core.cpp \ + common/crypto/pkcs7-init.cpp \ + common/crypto/pkcs7-sanity.cpp \ + common/crypto/pkcs7-verify.cpp \ + common/crypto/spc-asn1-decoder.cpp \ + common/crypto/spc-core.cpp \ + common/crypto/spc-init.cpp \ + common/crypto/spc-sanity.cpp \ + common/crypto/taf-asn1-decoder.cpp \ + common/crypto/taf-core.cpp \ + common/crypto/taf-init.cpp \ + common/crypto/taf-sanity.cpp \ + common/crypto/tsp-asn1-decoder.cpp \ + common/crypto/tsp-core.cpp \ + common/crypto/tsp-init.cpp \ + common/crypto/tsp-sanity.cpp \ + common/crypto/x509-asn1-decoder.cpp \ + common/crypto/x509-core.cpp \ + common/crypto/x509-file.cpp \ + common/crypto/x509-init.cpp \ + common/crypto/x509-sanity.cpp \ + common/dbg/dbg.cpp \ + common/dbg/dbgcfg.cpp \ + common/dbg/dbgmod.cpp \ + common/dbg/dbgmodcodeview.cpp \ + common/dbg/dbgmodcontainer.cpp \ + common/dbg/dbgmoddeferred.cpp \ + common/dbg/dbgmoddwarf.cpp \ + common/dbg/dbgmodexports.cpp \ + common/dbg/dbgmodldr.cpp \ + common/dbg/dbgmodmapsym.cpp \ + common/dbg/dbgmodnm.cpp \ + common/err/errinfo-alloc.cpp \ + common/err/errinfo.cpp \ + common/err/errinfolog.cpp \ + common/err/errmsg.cpp \ + common/err/RTErrConvertFromErrno.cpp \ + common/err/RTErrConvertToErrno.cpp \ + common/fs/isomaker.cpp \ + common/fs/isomakercmd.cpp \ + common/fs/isomakerimport.cpp \ + common/fs/isovfs.cpp \ + common/ldr/ldr.cpp \ + common/ldr/ldrELF.cpp \ + common/ldr/ldrEx.cpp \ + common/ldr/ldrFile.cpp \ + common/ldr/ldrLX.cpp \ + common/ldr/ldrMachO.cpp \ + common/ldr/ldrNative.cpp \ + common/ldr/ldrPE.cpp \ + common/ldr/ldrVfsFile.cpp \ + common/log/log.cpp \ + common/log/logellipsis.cpp \ + common/log/logformat.cpp \ + common/log/logrel.cpp \ + common/log/logrelellipsis.cpp \ + common/math/bignum.cpp \ + common/misc/assert.cpp \ + common/misc/cidr.cpp \ + common/misc/getopt.cpp \ + common/misc/getoptargv.cpp \ + common/misc/lockvalidator.cpp \ + common/misc/message.cpp \ + common/misc/messagerefentry.cpp \ + common/misc/once.cpp \ + common/misc/RTAssertMsg1Weak.cpp \ + common/misc/RTAssertMsg2.cpp \ + common/misc/RTAssertMsg2Add.cpp \ + common/misc/RTAssertMsg2AddWeak.cpp \ + common/misc/RTAssertMsg2AddWeakV.cpp \ + common/misc/RTAssertMsg2Weak.cpp \ + common/misc/RTAssertMsg2WeakV.cpp \ + common/misc/RTFileModeToFlags.cpp \ + common/misc/RTFileOpenF.cpp \ + common/misc/RTFileOpenV.cpp \ + common/misc/RTMemWipeThoroughly.cpp \ + common/misc/sanity-c.c \ + common/misc/sanity-cpp.cpp \ + common/misc/sg.cpp \ + common/misc/term.cpp \ + common/misc/thread.cpp \ + common/misc/zero.asm \ + common/net/macstr.cpp \ + common/net/netaddrstr2.cpp \ + common/path/comparepaths.cpp \ + common/path/RTPathAbsDup.cpp \ + common/path/RTPathAbsEx.cpp \ + common/path/RTPathAbsExDup.cpp \ + common/path/RTPathAppend.cpp \ + common/path/RTPathAppendEx.cpp \ + common/path/RTPathChangeToDosSlashes.cpp \ + common/path/RTPathChangeToUnixSlashes.cpp \ + common/path/RTPathCopyComponents.cpp \ + common/path/RTPathCountComponents.cpp \ + common/path/RTPathEnsureTrailingSeparator.cpp \ + common/path/RTPathExt.cpp \ + common/path/RTPathFilename.cpp \ + common/path/RTPathHasExt.cpp \ + common/path/RTPathHasPath.cpp \ + common/path/RTPathJoin.cpp \ + common/path/RTPathJoinA.cpp \ + common/path/RTPathJoinEx.cpp \ + common/path/RTPathParse.cpp \ + common/path/RTPathParsedReassemble.cpp \ + common/path/RTPathParseSimple.cpp \ + common/path/RTPathRealDup.cpp \ + common/path/rtPathRootSpecLen.cpp \ + common/path/RTPathSkipRootSpec.cpp \ + common/path/RTPathSplit.cpp \ + common/path/RTPathSplitA.cpp \ + common/path/RTPathSplitReassemble.cpp \ + common/path/RTPathStartsWithRoot.cpp \ + common/path/RTPathStripExt.cpp \ + common/path/RTPathStripFilename.cpp \ + common/path/RTPathStripTrailingSlash.cpp \ + common/path/RTPathTraverseList.cpp \ + common/path/rtPathVolumeSpecLen.cpp \ + common/rand/rand.cpp \ + common/rand/randadv.cpp \ + common/rand/randparkmiller.cpp \ + common/sort/shellsort.cpp \ + common/string/base64.cpp \ + common/string/RTStrCat.cpp \ + common/string/RTStrCmp.cpp \ + common/string/RTStrCopy.cpp \ + common/string/RTStrCopyEx.cpp \ + common/string/RTStrCopyP.cpp \ + common/string/RTStrIStartsWith.cpp \ + common/string/RTStrNCmp.cpp \ + common/string/RTStrNLen.cpp \ + common/string/RTStrPrintHexBytes.cpp \ + common/string/RTStrStr.cpp \ + common/string/simplepattern.cpp \ + common/string/straprintf.cpp \ + common/string/strcache.cpp \ + common/string/strformat.cpp \ + common/string/strformatnum.cpp \ + common/string/strformatrt.cpp \ + common/string/strformattype.cpp \ + common/string/strhash1.cpp \ + common/string/stringalloc.cpp \ + common/string/strprintf.cpp \ + common/string/strprintf2.cpp \ + common/string/strspace.cpp \ + common/string/strstrip.cpp \ + common/string/strtonum.cpp \ + common/string/unidata-flags.cpp \ + common/string/unidata-lower.cpp \ + common/string/unidata-upper.cpp \ + common/string/utf-16-case.cpp \ + common/string/utf-16.cpp \ + common/string/utf-8-case.cpp \ + common/string/utf-8-case2.cpp \ + common/string/utf-8.cpp \ + common/table/avllu32.cpp \ + common/table/avlpv.cpp \ + common/table/avlrpv.cpp \ + common/table/avlruintptr.cpp \ + common/table/avlu32.cpp \ + common/table/avluintptr.cpp \ + common/time/time.cpp \ + common/time/timeprog.cpp \ + common/time/timesupref.cpp \ + common/time/timesysalias.cpp \ + common/vfs/vfsbase.cpp \ + common/vfs/vfschain.cpp \ + common/vfs/vfsmemory.cpp \ + common/vfs/vfsmisc.cpp \ + common/vfs/vfsmsg.cpp \ + common/vfs/vfsstddir.cpp \ + common/vfs/vfsstdfile.cpp \ + common/vfs/vfsstdpipe.cpp \ + common/zip/gzipvfs.cpp \ + common/zip/tar.cpp \ + common/zip/tarcmd.cpp \ + common/zip/tarvfs.cpp \ + common/zip/tarvfswriter.cpp \ + generic/critsect-generic.cpp \ + generic/critsectrw-generic.cpp \ + generic/env-generic.cpp \ + generic/mempool-generic.cpp \ + generic/RTEnvDupEx-generic.cpp \ + generic/RTFileCopy-generic.cpp \ + generic/RTFileQuerySize-generic.cpp \ + generic/RTFileReadAll-generic.cpp \ + generic/RTFileReadAllByHandle-generic.cpp \ + generic/RTFileReadAllByHandleEx-generic.cpp \ + generic/RTFileReadAllEx-generic.cpp \ + generic/RTFileReadAllFree-generic.cpp \ + generic/RTLogWriteStdErr-generic.cpp \ + generic/RTLogWriteStdOut-generic.cpp \ + generic/RTLogWriteUser-generic.cpp \ + generic/RTPathIsSame-generic.cpp \ + generic/rtStrFormatKernelAddress-generic.cpp \ + generic/RTTimerLRCreate-generic.cpp \ + generic/semfastmutex-generic.cpp \ + generic/semxroads-generic.cpp \ + generic/spinlock-generic.cpp \ + r3/alloc-ef.cpp \ + r3/alloc.cpp \ + r3/allocex.cpp \ + r3/dir.cpp \ + r3/dir2.cpp \ + r3/fileio.cpp \ + r3/fs.cpp \ + r3/generic/semspinmutex-r3-generic.cpp \ + r3/init.cpp \ + r3/memsafer-r3.cpp \ + r3/path.cpp \ + r3/process.cpp \ + r3/socket.cpp \ + r3/stream.cpp \ + r3/tcp.cpp \ + VBox/log-vbox.cpp \ + VBox/RTAssertShouldPanic-vbox.cpp \ + \ + common/string/ministring.cpp # for main +ifneq ($(KBUILD_HOST),win) + RuntimeBldProg_SOURCES += \ + common/err/errmsgxpcom.cpp +endif +RuntimeBldProg_SOURCES.darwin = $(filter-out \ + generic/cdrom-generic.cpp \ + generic/RTFileMove-generic.cpp \ + generic/RTPathGetCurrentOnDrive-generic.cpp \ + generic/RTProcDaemonize-generic.cpp \ + generic/RTThreadGetAffinity-stub-generic.cpp \ + generic/RTThreadSetAffinity-stub-generic.cpp \ + generic/RTThreadSetAffinityToCpu-generic.cpp \ + generic/RTTimerCreate-generic.cpp \ + generic/mppresent-generic.cpp \ + generic/RTSystemShutdown-generic.cpp \ + generic/timer-generic.cpp \ + generic/utf16locale-generic.cpp \ + generic/RTProcIsRunningByName-generic.cpp \ + generic/RTThreadGetNativeState-generic.cpp \ + r3/darwin/RTCrStoreCreateSnapshotById-darwin.cpp \ + r3/darwin/filelock-darwin.cpp \ + r3/darwin/systemmem-darwin.cpp \ + r3/darwin/krnlmod-darwin.cpp \ + r3/darwin/filelock-darwin.cpp \ + r3/darwin/RTSystemQueryDmiString-darwin.cpp \ + r3/darwin/RTPathUserDocuments-darwin.cpp \ + r3/posix/RTTimeSet-posix.cpp \ + r3/posix/serialport-posix.cpp \ + r3/posix/localipc-posix.cpp \ + r3/posix/ldrNative-posix.cpp \ + r3/generic/allocex-r3-generic.cpp \ + r3/generic/RTLocaleQueryLocaleName-r3-generic.cpp \ + r3/generic/RTLocaleQueryNormalizedBaseLocaleName-r3-generic.cpp \ + r3/generic/RTLocaleQueryUserCountryCode-r3-generic.cpp \ + , $(RuntimeR3_SOURCES.darwin)) + +RuntimeBldProg_SOURCES.win = \ + common/dbg/dbgmoddbghelp.cpp \ + common/string/mempcpy.asm \ + common/string/RTUtf16CopyAscii.cpp \ + common/string/RTUtf16End.cpp \ + common/string/RTUtf16NLenEx.cpp \ + generic/mppresent-generic-online.cpp \ + generic/RTDirExists-generic.cpp \ + generic/RTDirSetTimes-generic.cpp \ + generic/RTFileExists-generic.cpp \ + generic/RTFileSetAllocationSize-generic.cpp \ + generic/RTPathAbs-generic.cpp \ + generic/RTPathGetCurrentDrive-generic.cpp \ + generic/RTRandAdvCreateSystemFaster-generic.cpp \ + generic/RTRandAdvCreateSystemTruer-generic.cpp \ + generic/RTSemEventMultiWait-2-ex-generic.cpp \ + generic/RTSemEventMultiWaitNoResume-2-ex-generic.cpp \ + generic/RTSemEventWait-generic.cpp \ + generic/RTSemMutexRequest-generic.cpp \ + generic/RTSemMutexRequestDebug-generic.cpp \ + generic/semrw-$(if-expr defined(VBOX_WITH_LOCKLESS_SEMRW),lockless-,)generic.cpp \ + generic/uuid-generic.cpp \ + nt/fileioutils-nt.cpp \ + nt/RTErrConvertFromNtStatus.cpp \ + r3/nt/direnum-r3-nt.cpp \ + r3/nt/dirrel-r3-nt.cpp \ + r3/nt/fs-nt.cpp \ + r3/nt/pathint-nt.cpp \ + r3/nt/RTFileQueryFsSizes-nt.cpp \ + r3/nt/RTFileSetMode-r3-nt.cpp \ + r3/nt/RTPathQueryInfo-nt.cpp \ + r3/nt/RTPathSetMode-r3-nt.cpp \ + r3/win/alloc-win.cpp \ + r3/win/allocex-win.cpp \ + r3/win/dir-win.cpp \ + r3/win/env-win.cpp \ + r3/win/errvars-win.cpp \ + r3/win/fileio-win.cpp \ + r3/win/init-win.cpp \ + r3/win/ldrNative-win.cpp \ + r3/win/path-win.cpp \ + r3/win/pathint-win.cpp \ + r3/win/pipe-win.cpp \ + r3/win/process-win.cpp \ + r3/win/RTHandleGetStandard-win.cpp \ + r3/win/RTLogWriteDebugger-win.cpp \ + r3/win/rtProcInitExePath-win.cpp \ + r3/win/RTUuidCreate-win.cpp \ + r3/win/sched-win.cpp \ + r3/win/semevent-win.cpp \ + r3/win/semeventmulti-win.cpp \ + r3/win/semmutex-win.cpp \ + r3/win/symlink-win.cpp \ + r3/win/thread-win.cpp \ + r3/win/thread2-win.cpp \ + $(if-expr 1,r3/win/time-win.cpp,r3/nt/time-nt.cpp) \ + r3/win/time2-win.cpp \ + r3/win/utf16locale-win.cpp \ + r3/win/utf8-win.cpp \ + win/errmsgwin.cpp \ + win/RTErrConvertFromWin32.cpp + +RuntimeBldProg_SOURCES.win.amd64 := \ + $(RuntimeWin64ASM_SOURCES) \ + common/string/memrchr.asm +RuntimeBldProg_SOURCES.win.x86 := \ + $(RuntimeWin32ASM_SOURCES) \ + common/string/memrchr.asm + +## @todo reduce this +RuntimeBldProg_SOURCES.os2 += \ + common/string/memrchr.asm \ + generic/mppresent-generic.cpp \ + generic/RTCrStoreCreateSnapshotById-generic.cpp \ + generic/RTDirQueryInfo-generic.cpp \ + generic/RTDirSetTimes-generic.cpp \ + generic/RTFileMove-generic.cpp \ + generic/RTFileSetAllocationSize-generic.cpp \ + generic/RTLogWriteDebugger-generic.cpp \ + generic/RTPathAbs-generic.cpp \ + generic/RTPathGetCurrentDrive-generic.cpp \ + generic/RTPathGetCurrentOnDrive-generic.cpp \ + generic/RTRandAdvCreateSystemFaster-generic.cpp \ + generic/RTRandAdvCreateSystemTruer-generic.cpp \ + generic/RTSemEventMultiWait-generic.cpp \ + generic/RTSemEventWait-generic.cpp \ + generic/RTSemMutexRequest-generic.cpp \ + generic/RTSemMutexRequestDebug-generic.cpp \ + generic/RTThreadGetNativeState-generic.cpp \ + generic/RTUuidCreate-generic.cpp \ + generic/semrw-$(if-expr defined(VBOX_WITH_LOCKLESS_SEMRW),lockless-,)generic.cpp \ + generic/timer-generic.cpp \ + generic/utf16locale-generic.cpp \ + generic/uuid-generic.cpp \ + os2/RTErrConvertFromOS2.cpp \ + r3/generic/allocex-r3-generic.cpp \ + r3/generic/dirrel-r3-generic.cpp \ + r3/os2/filelock-os2.cpp \ + r3/os2/mp-os2.cpp \ + r3/os2/pipe-os2.cpp \ + r3/os2/rtProcInitExePath-os2.cpp \ + r3/os2/sched-os2.cpp \ + r3/os2/sems-os2.cpp \ + r3/os2/systemmem-os2.cpp \ + r3/os2/thread-os2.cpp \ + r3/os2/time-os2.cpp \ + r3/posix/dir-posix.cpp \ + r3/posix/env-posix.cpp \ + r3/posix/errvars-posix.cpp \ + r3/posix/fileio-posix.cpp \ + r3/posix/fileio2-posix.cpp \ + r3/posix/fs-posix.cpp \ + r3/posix/fs2-posix.cpp \ + r3/posix/fs3-posix.cpp \ + r3/posix/ldrNative-posix.cpp \ + r3/posix/path-posix.cpp \ + r3/posix/path2-posix.cpp \ + r3/posix/pathhost-posix.cpp \ + r3/posix/process-creation-posix.cpp \ + r3/posix/process-posix.cpp \ + r3/posix/RTFileQueryFsSizes-posix.cpp \ + r3/posix/RTHandleGetStandard-posix.cpp \ + r3/posix/rtmempage-exec-mmap-heap-posix.cpp \ + r3/posix/RTMemProtect-posix.cpp \ + r3/posix/RTPathUserDocuments-posix.cpp \ + r3/posix/RTPathUserHome-posix.cpp \ + r3/posix/RTTimeNow-posix.cpp \ + r3/posix/RTTimeSet-posix.cpp \ + r3/posix/symlink-posix.cpp \ + r3/posix/timelocal-posix.cpp \ + r3/posix/utf8-posix.cpp + +## @todo reduce linux, solaris and freebsd sources too. + + + +# +# RuntimeGuestR3 - Guest Additions Runtime (static/exe). +# (The KBUILD_HOST inheritance here is for cross building the linux +# additions, while .x86 is for cross building x86 while targeting amd64.) +# +RuntimeGuestR3_TEMPLATE := VBoxGuestR3Lib +## @todo change this to EXTEND the RuntimeR3 target. +RuntimeGuestR3_SDKS.win := $(RuntimeR3_SDKS.win) +RuntimeGuestR3_DEFS := $(filter-out RTCRITSECT_STRICT RT_NO_GIP, $(RuntimeR3_DEFS)) +RuntimeGuestR3_DEFS := $(filter-out IN_SUP_R3, $(RuntimeGuestR3_DEFS)) +RuntimeGuestR3_DEFS.$(KBUILD_TARGET) := $(RuntimeR3_DEFS.$(KBUILD_TARGET)) +RuntimeGuestR3_DEFS.$(KBUILD_HOST) := $(RuntimeR3_DEFS.$(KBUILD_HOST)) +RuntimeGuestR3_INCS := $(RuntimeR3_INCS) +RuntimeGuestR3_INCS.$(KBUILD_TARGET) := $(RuntimeR3_INCS.$(KBUILD_TARGET)) +RuntimeGuestR3_INCS.$(KBUILD_HOST) := $(RuntimeR3_INCS.$(KBUILD_HOST)) +RuntimeGuestR3_SOURCES := $(filter-out \ + common/time/timesupref.cpp \ + common/time/timesupA.asm \ + common/time/timesup.cpp \ + common/zip/xarvfs.cpp \ + generic/RTLogWriteUser-generic.cpp \ + r3/xml.cpp \ + , $(RuntimeR3_SOURCES)) +RuntimeGuestR3_SOURCES += \ + common/time/timesysalias.cpp \ + VBox/logbackdoor.cpp +RuntimeGuestR3_SOURCES.$(KBUILD_TARGET) := $(RuntimeR3_SOURCES.$(KBUILD_TARGET)) +RuntimeGuestR3_SOURCES.$(KBUILD_HOST) := $(RuntimeR3_SOURCES.$(KBUILD_HOST)) +RuntimeGuestR3_SOURCES.$(KBUILD_TARGET_ARCH) := $(RuntimeR3_SOURCES.$(KBUILD_TARGET_ARCH)) +RuntimeGuestR3_SOURCES.x86 := $(RuntimeR3_SOURCES.x86) +RuntimeGuestR3_SOURCES.amd64 := $(RuntimeR3_SOURCES.amd64) +RuntimeGuestR3_SOURCES.$(KBUILD_TARGET).$(KBUILD_TARGET_ARCH) := $(RuntimeR3_SOURCES.$(KBUILD_TARGET).$(KBUILD_TARGET_ARCH)) +RuntimeGuestR3_SOURCES.$(KBUILD_TARGET).x86 := $(RuntimeR3_SOURCES.$(KBUILD_TARGET).x86) +RuntimeGuestR3_SOURCES.$(KBUILD_TARGET).amd64:= $(RuntimeR3_SOURCES.$(KBUILD_TARGET).amd64) +RuntimeGuestR3_SOURCES.$(KBUILD_HOST).$(KBUILD_TARGET_ARCH) := $(RuntimeR3_SOURCES.$(KBUILD_HOST).$(KBUILD_TARGET_ARCH)) +RuntimeGuestR3_SOURCES.win.x86 += \ + r3/win/vcc100-kernel32-fakes.cpp \ + r3/win/vcc100-kernel32-fakesA.asm \ + r3/win/vcc100-ntdll-fakes.cpp \ + r3/win/vcc100-ntdll-fakesA.asm \ + r3/win/vcc100-ws2_32-fakes.cpp \ + r3/win/vcc100-ws2_32-fakesA.asm \ + r3/win/vcc100-shell32-fakes.cpp \ + r3/win/vcc100-shell32-fakesA.asm \ + + +# +# RuntimeGuestR3-x86 - Same as RuntimeGuestR3, except that it's targeting x86. +# +RuntimeGuestR3-x86_EXTENDS := RuntimeGuestR3 +RuntimeGuestR3-x86_BLD_TRG_ARCH := x86 + + +# +# RuntimeGuestR3Shared - Guest Additions Runtime (static/dll). +# +RuntimeGuestR3Shared_TEMPLATE := VBoxGuestR3Dll +RuntimeGuestR3Shared_EXTENDS := RuntimeGuestR3 +RuntimeGuestR3Shared_INST = $(INST_ADDITIONS_LIB) + + +# +# RuntimeGuestR3Shared-x86 - Same as RuntimeGuestR3Shared, except that it's targeting x86. +# +RuntimeGuestR3Shared-x86_EXTENDS := RuntimeGuestR3Shared +RuntimeGuestR3Shared-x86_BLD_TRG_ARCH := x86 + + +# +# VBoxRT - Shared Object / DLL version. +# +VBoxRT_TEMPLATE = VBoxR3DllNoPic +VBoxRT_SDKS = VBOX_LIBXML2 +ifdef VBOX_WITH_LIBCURL + VBoxRT_SDKS += VBOX_LIBCURL +endif +VBoxRT_SDKS += VBOX_OPENSSL +VBoxRT_SDKS.win = $(VBOX_WINPSDK) $(VBOX_WINDDK) VBOX_NTDLL +if1of ($(KBUILD_TARGET), win) +VBoxRT_INST = $(INST_DLL) $(INST_TESTCASE) $(VBOX_INST_TOOLS) +else if1of ($(KBUILD_TARGET)$(VBOX_WITH_HARDENING), darwin win$(VBOX_WITH_HARDENING)) +VBoxRT_INST = $(INST_DLL) $(INST_TESTCASE) +endif +VBoxRT_DEFS := $(filter-out RT_NO_GIP, $(RuntimeR3_DEFS)) \ + IPRT_WITH_OPENSSL \ + IPRT_WITH_XAR \ + $(if-expr !defined(VBOX_WITH_ALT_HASH_CODE),IPRT_WITHOUT_SHA512T224 IPRT_WITHOUT_SHA512T256,) +ifn1of ($(KBUILD_TARGET_ARCH), amd64 x86) + VBoxRT_DEFS += RT_NO_GIP +endif +ifdef VBOX_WITH_LIBCURL + VBoxRT_DEFS += IPRT_WITH_HTTP +endif +ifdef RTALLOC_REPLACE_MALLOC + VBoxRT_DEFS += RTALLOC_REPLACE_MALLOC +endif +ifdef VBOX_WITH_DTRACE_R3 + VBoxRT_DEFS += IPRT_WITH_DTRACE IPRT_DTRACE_INCLUDE=\"dtrace/iprt.h\" +endif +VBoxRT_DEFS.$(KBUILD_TYPE) := $(RuntimeR3_DEFS.$(KBUILD_TYPE)) +VBoxRT_SOURCES := \ + VBox/VBoxRTDeps.cpp \ + $(filter-out common/checksum/crc32.cpp, \ + $(if-expr defined(VBOX_WITH_ALT_HASH_CODE), $(RuntimeR3_SOURCES), \ + $(patsubst common/checksum/alt-%,common/checksum/openssl-%,$(RuntimeR3_SOURCES)) ) ) \ + common/checksum/crc32-zlib.cpp \ + common/fuzz/fuzz.cpp \ + common/fuzz/fuzz-observer.cpp \ + common/fuzz/fuzzmastercmd.cpp \ + common/fuzz/fuzzclientcmd.cpp \ + common/misc/aiomgr.cpp +ifneq ($(KBUILD_TARGET),win) +VBox/VBoxRTDeps.cpp_CXXFLAGS = -Wno-deprecated-declarations +endif +ifdef VBOX_WITH_LIBCURL + VBoxRT_SOURCES += \ + common/misc/s3.cpp \ + generic/http-curl.cpp \ + common/rest/rest-primary-object-types.cpp \ + common/rest/rest-binary.cpp \ + common/rest/RTCRestAnyObject.cpp \ + common/rest/RTCRestArrayBase.cpp \ + common/rest/RTCRestClientApiBase.cpp \ + common/rest/RTCRestClientApiBaseOci.cpp \ + common/rest/RTCRestClientRequestBase.cpp \ + common/rest/RTCRestClientResponseBase.cpp \ + common/rest/RTCRestJsonPrimaryCursor.cpp \ + common/rest/RTCRestStringMapBase.cpp \ + common/rest/RTCRestOutputBase.cpp \ + common/rest/RTCRestOutputPrettyBase.cpp \ + common/rest/RTCRestOutputPrettyToString.cpp \ + common/rest/RTCRestOutputToString.cpp +endif +ifdef VBOX_WITH_DTRACE_R3 + VBoxRT_SOURCES += \ + iprt.d +endif +VBoxRT_SOURCES.$(KBUILD_TARGET) = $(RuntimeR3_SOURCES.$(KBUILD_TARGET)) +VBoxRT_SOURCES.$(KBUILD_TARGET).$(KBUILD_TARGET_ARCH) := $(RuntimeR3_SOURCES.$(KBUILD_TARGET).$(KBUILD_TARGET_ARCH)) +VBoxRT_SOURCES.$(KBUILD_TARGET).x86 := $(RuntimeR3_SOURCES.$(KBUILD_TARGET).x86) +VBoxRT_SOURCES.$(KBUILD_TARGET).amd64 := $(RuntimeR3_SOURCES.$(KBUILD_TARGET).amd64) +VBoxRT_SOURCES.$(KBUILD_TARGET_ARCH) := $(RuntimeR3_SOURCES.$(KBUILD_TARGET_ARCH)) +VBoxRT_SOURCES.x86 := $(RuntimeR3_SOURCES.x86) +VBoxRT_SOURCES.amd64 := $(RuntimeR3_SOURCES.amd64) +VBoxRT_SOURCES.win += \ + r3/win/dllmain-win.cpp \ + r3/win/fileaio-win.cpp \ + $(VBoxRT_0_OUTDIR)/VBoxRT.def +VBoxRT_SOURCES.linux += \ + r3/linux/fileaio-linux.cpp +VBoxRT_SOURCES.solaris += \ + r3/solaris/fileaio-solaris.cpp +VBoxRT_SOURCES.darwin += \ + r3/posix/fileaio-posix.cpp +VBoxRT_SOURCES.freebsd += \ + r3/freebsd/fileaio-freebsd.cpp +VBoxRT_INCS := $(RuntimeR3_INCS) +VBoxRT_INCS.$(KBUILD_TARGET) := $(RuntimeR3_INCS.$(KBUILD_TARGET)) +VBoxRT_INCS.$(KBUILD_TARGET).$(KBUILD_TARGET_ARCH) := $(RuntimeR3_INCS.$(KBUILD_TARGET).$(KBUILD_TARGET_ARCH)) +VBoxRT_LIBS = \ + $(PATH_STAGE_LIB)/VBox-liblzf$(VBOX_SUFF_LIB) +if1of ($(KBUILD_TARGET_ARCH), amd64 x86) +VBoxRT_LIBS += \ + $(PATH_STAGE_LIB)/SUPR3$(VBOX_SUFF_LIB) +endif +ifndef SDK_VBOX_LIBXML2_LIBS + VBoxRT_LIBS += \ + $(PATH_STAGE_LIB)/VBox-libxml2$(VBOX_SUFF_LIB) +endif +VBoxRT_LIBS += \ + $(SDK_VBOX_ZLIB_LIBS) +ifndef SDK_VBOX_OPENSSL_LIBS + VBoxRT_LIBS += \ + $(PATH_STAGE_LIB)/VBox-libcrypto$(VBOX_SUFF_LIB) \ + $(PATH_STAGE_LIB)/VBox-libssl$(VBOX_SUFF_LIB) +endif +ifdef IPRT_WITH_LZO + VBoxRT_LIBS += lzo2 +endif +ifdef RTALLOC_REPLACE_MALLOC +VBoxRT_LIBS += \ + $(PATH_STAGE_LIB)/DisasmR3$(VBOX_SUFF_LIB) +endif +VBoxRT_LIBS.linux = \ + crypt +VBoxRT_LIBS.darwin = \ + iconv +VBoxRT_LIBS.freebsd = \ + iconv \ + rt +VBoxRT_LIBS.haiku = \ + iconv +VBoxRT_LIBS.solaris = \ + kstat \ + contract +ifn1of ($(KBUILD_TARGET_ARCH), sparc32 sparc64) + # SMBIOS not available on Solaris SPARC. + VBoxRT_LIBS.solaris += smbios +endif +VBoxRT_LIBS.win = \ + $(PATH_SDK_$(VBOX_WINDDK)_LIB)/vccomsup.lib \ + $(PATH_SDK_$(VBOX_WINDDK)_LIB)/wbemuuid.lib \ + $(PATH_TOOL_$(VBOX_VCC_TOOL)_LIB)/delayimp.lib +VBoxRT_LDFLAGS.darwin = \ + -framework IOKit \ + -framework CoreFoundation \ + -framework CoreServices \ + -framework Security \ + -framework SystemConfiguration \ + -install_name $(VBOX_DYLD_EXECUTABLE_PATH)/VBoxRT.dylib +VBoxRT_LDFLAGS.win = /MANIFEST \ + /delayload:user32.dll \ + /delayload:shell32.dll \ + /delayload:ole32.dll \ + /delayload:oleaut32.dll \ + /delayload:advapi32.dll + +if1of ($(DLLS), VBoxRT) +VBoxRT_CLEAN += $(VBoxRT_0_OUTDIR)/VBoxRT.def +$$(VBoxRT_0_OUTDIR)/VBoxRT.def: \ + $(PATH_SUB_CURRENT)/r3/win/VBoxRT-$$(if-expr $$(KBUILD_TARGET_ARCH) == amd64,win64,win32).def \ + $(if-expr defined(VBOX_WITH_OPENSSL_PRE_1_1)\ + ,$(PATH_SUB_CURRENT)/r3/win/VBoxRT-openssl-pre-1.1.def \ + ,$(PATH_SUB_CURRENT)/r3/win/VBoxRT-openssl-1.1plus.def )\ + $(if-expr "$(KBUILD_TARGET).$(KBUILD_TARGET_ARCH)" == "win.x86" && defined(VBOX_WITH_MORE_NT4_COMPAT_BINARIES)\ + ,$(PATH_SUB_CURRENT)/r3/win/VBoxRT-msvcr100-win32.def ,) #$(PATH_SUB_CURRENT)/r3/win/VBoxRT-msvcp100-win32.def + $(RM) -f -- $@ + $(REDIRECT) -wto $@ -- $(CAT_EXT) $^ +endif + +if1of (VBoxRT,$(DLLS)) + $(call VBOX_SET_VER_INFO_DLL,VBoxRT,VirtualBox Runtime) +endif + + +if defined(VBOX_WITH_MORE_NT4_COMPAT_BINARIES) && "$(KBUILD_TARGET).$(KBUILD_TARGET_ARCH)" == "win.x86" + # + # Hacks for running tests on NT 4. Really ugly! + # + # We put most of the CRT in VBoxRT because we cannot even load msvcr100.dll + # or msvcp100.dll on NT4 because of kernel32.dll dependencies. More hacks + # in RuntimeR3VccTricks. + # + TEMPLATE_VBoxR3RuntimeDllItself = xx + TEMPLATE_VBoxR3RuntimeDllItself_EXTENDS = VBoxR3RuntimeDll + TEMPLATE_VBoxR3RuntimeDllItself_LIBS.win.x86 = \ + $(filter-out $(PATH_STAGE_LIB)/RuntimeR3VccTricks%, $(TEMPLATE_VBoxR3RuntimeDll_LIBS.win.x86)) + TEMPLATE_VBoxR3RuntimeDllItself_SOURCES = \ + r3/win/vcc100-kernel32-fakes.cpp \ + r3/win/vcc100-kernel32-fakesA.asm \ + r3/win/vcc100-ws2_32-fakes.cpp \ + r3/win/vcc100-ws2_32-fakesA.asm \ + r3/win/vcc100-ntdll-fakes.cpp \ + r3/win/vcc100-ntdll-fakesA.asm \ + r3/win/vcc100-msvcrt-fakes.cpp + VBoxRT_TEMPLATE = VBoxR3RuntimeDllItself + VBoxRT_TEMPLATE.win.x86 = VBoxR3RuntimeDllItself + VBoxRT_DEFS.win.x86 = $(TEMPLATE_VBoxR3RuntimeDll_DEFS.win.x86) _CRTIMP_PURE="__declspec(dllexport)" + VBoxRT_LDFLAGS.win.x86 = /IGNORE:4049 /IGNORE:4217 + VBoxRT_LIBS.win.x86 = \ + $(PATH_TOOL_$(VBOX_VCC_TOOL_STEM)X86_LIB)/oldnames.lib \ + $(PATH_TOOL_$(VBOX_VCC_TOOL_STEM)X86_LIB)/libcmt.lib \ + $(PATH_TOOL_$(VBOX_VCC_TOOL_STEM)X86_LIB)/libcpmt.lib +endif + + +# +# HACK ALERT! Make testcase run during build on SELinux boxes. +# Create a dummy DLL that ensure that VBoxRT is installed +# during the DLL pass and cleaned up later. +# +ifeq ($(KBUILD_TARGET),linux) + if1of (VBoxRT, $(DLLS)) + ifneq ($(wildcard /usr/bin/chcon),) +VBoxRT_INSTTYPE = none +VBoxRT_DEBUG_INSTTYPE = both + +VBoxRT-x86_INSTTYPE = $(NO_SUCH_VARIABLE) + +DLLS += VBoxRTDummy +VBoxRTDummy_TEMPLATE = VBoxR3Dll +VBoxRTDummy_INSTTYPE = none +VBoxRTDummy_LIBS = $(PATH_STAGE_BIN)/VBoxRT.so +VBoxRTDummy_CLEAN = $(PATH_STAGE_BIN)/VBoxRT.so +BLDDIRS += $(PATH_STAGE_BIN) + +$(PATH_STAGE_BIN)/VBoxRT.so: $$(VBoxRT_1_TARGET) | $$(dir $$@) + $(INSTALL) $< $@ + chcon -t texrel_shlib_t $@ || true + +VBoxRT:: VBoxRTDummy + endif # chcon present. + endif # building VBoxRT +endif # linux + + +# +# VBoxRT-x86 - 32-bit version of VBoxRT +# +VBoxRT-x86_EXTENDS = VBoxRT +VBoxRT-x86_TEMPLATE = VBoxR3Dll-x86 +VBoxRT-x86_INST.win = $(INST_DLL)x86/ +VBoxRT-x86_SDKS = VBOX_LIBXML2 +ifdef VBOX_WITH_LIBCURL + VBoxRT-x86_SDKS += VBOX_LIBCURL-x86 +endif +VBoxRT-x86_SDKS += VBOX_OPENSSL-x86 + +VBoxRT-x86_LIBS = \ + $(PATH_STAGE_LIB)/VBox-liblzf-x86$(VBOX_SUFF_LIB) +if1of ($(KBUILD_TARGET_ARCH), amd64 x86) +VBoxRT-x86_LIBS += \ + $(PATH_STAGE_LIB)/SUPR3-x86$(VBOX_SUFF_LIB) +endif +ifndef SDK_VBOX_LIBXML2_LIBS + VBoxRT-x86_LIBS += \ + $(PATH_STAGE_LIB)/VBox-libxml2-x86$(VBOX_SUFF_LIB) +endif +VBoxRT-x86_LIBS += \ + $(SDK_VBOX_ZLIB_LIBS-x86) +ifndef SDK_VBOX_OPENSSL_LIBS + VBoxRT-x86_LIBS += \ + $(PATH_STAGE_LIB)/VBox-libcrypto-x86$(VBOX_SUFF_LIB) \ + $(PATH_STAGE_LIB)/VBox-libssl-x86$(VBOX_SUFF_LIB) +endif +ifdef IPRT_WITH_LZO + VBoxRT-x86_LIBS += lzo2 +endif +VBoxRT-x86_LIBS.linux = \ + crypt +VBoxRT-x86_LIBS.darwin = \ + iconv +VBoxRT-x86_LIBS.freebsd = \ + iconv \ + rt +VBoxRT-x86_LIBS.haiku = \ + iconv +VBoxRT-x86_LIBS.solaris = \ + kstat \ + contract +ifn1of ($(KBUILD_TARGET_ARCH), sparc32 sparc64) + # SMBIOS not available on Solaris SPARC. + VBoxRT-x86_LIBS.solaris += smbios +endif +VBoxRT-x86_LIBS.win = \ + $(PATH_SDK_$(VBOX_WINDDK)_LIB.x86)/vccomsup.lib \ + $(PATH_SDK_$(VBOX_WINDDK)_LIB.x86)/wbemuuid.lib \ + $(PATH_TOOL_$(VBOX_VCC_TOOL_STEM)X86_LIB)/delayimp.lib + +VBoxRT-x86_SOURCES.win = $(filter-out %.def %.rc,$(VBoxRT_SOURCES.win)) \ + $(VBoxRT-x86_0_OUTDIR)/VBoxRT-x86.def +VBoxRT-x86_CLEAN += $(VBoxRT-x86_0_OUTDIR)/VBoxRT-x86.def +if1of ($(DLLS), VBoxRT-x86) +$$(VBoxRT-x86_0_OUTDIR)/VBoxRT-x86.def: \ + $(PATH_SUB_CURRENT)/r3/win/VBoxRT-win32.def # Hopefully no need to export openssl here. + $(RM) -f -- $@ + $(REDIRECT) -wto $@ -- $(CAT_EXT) $^ +endif + +if1of (VBoxRT-x86,$(DLLS)) + $(call VBOX_SET_VER_INFO_DLL,VBoxRT-x86,VirtualBox 32-bit Runtime) +endif + +# +# VBoxRTImp - Import library/hack. +# +ifeq ($(KBUILD_TARGET).$(KBUILD_TARGET_ARCH),win.amd64) +$(call VBOX_GENERATE_IMPORT_TARGET_FN,VBoxRTImp,VBoxRT,VBox/VBoxRTImp.def VBox/VBoxRTImp-vcc64.def r3/win/VBoxRT-win64.def) +else ifeq ($(KBUILD_TARGET).$(KBUILD_TARGET_ARCH),win.x86) +$(call VBOX_GENERATE_IMPORT_TARGET_FN,VBoxRTImp,VBoxRT,VBox/VBoxRTImp.def VBox/VBoxRTImp-vcc32.def r3/win/VBoxRT-win32.def) +else +$(call VBOX_GENERATE_IMPORT_TARGET_FN,VBoxRTImp,VBoxRT,VBox/VBoxRTImp.def VBox/VBoxRTImp-gcc.def) +endif + + +if1of ($(KBUILD_TARGET),win linux darwin) # remove later +if1of (VBoxRT,$(DLLS)) + # + # VBoxRTImpCheck - Import library check. + # + PROGRAMS += VBoxRTStableCheck + VBoxRTStableCheck_TEMPLATE = VBOXR3TSTEXE + VBoxRTStableCheck_SOURCES = \ + VBox/VBoxRTStableCheck.cpp \ + $(VBoxRTStableCheck_0_OUTDIR)/VBoxRTStableCheckA.asm + VBoxRTStableCheck_LIBS = \ + $(LIB_RUNTIME) + ifeq ($(KBUILD_TARGET).$(KBUILD_TARGET_ARCH),win.amd64) +$$(VBoxRTStableCheck_0_OUTDIR)/VBoxRTStableCheckA.asm: \ + $(PATH_SUB_CURRENT)/VBox/DefToAsmExterns.sed \ + $(PATH_SUB_CURRENT)/VBox/VBoxRTImp.def \ + $(PATH_SUB_CURRENT)/VBox/VBoxRTImp-vcc64.def \ + $(PATH_SUB_CURRENT)/r3/win/VBoxRT-win64.def \ + | $$(dir $$@) + else ifeq ($(KBUILD_TARGET).$(KBUILD_TARGET_ARCH),win.x86) +$$(VBoxRTStableCheck_0_OUTDIR)/VBoxRTStableCheckA.asm: \ + $(PATH_SUB_CURRENT)/VBox/DefToAsmExternsVcc32.sed \ + $(PATH_SUB_CURRENT)/VBox/VBoxRTImp.def \ + $(PATH_SUB_CURRENT)/VBox/VBoxRTImp-vcc32.def \ + $(PATH_SUB_CURRENT)/r3/win/VBoxRT-win32.def | $$(dir $$@) + else +$$(VBoxRTStableCheck_0_OUTDIR)/VBoxRTStableCheckA.asm: \ + $(PATH_SUB_CURRENT)/VBox/DefToAsmExterns.sed \ + $(PATH_SUB_CURRENT)/VBox/VBoxRTImp.def \ + $(PATH_SUB_CURRENT)/VBox/VBoxRTImp-gcc.def | $$(dir $$@) + endif + $(APPEND) -tn "$@" '%include "iprt/asmdefs.mac"' '' + $(SED) --append "$@" \ + -e "/not-$(KBUILD_TARGET)/d" \ + $(if-expr "$(KBUILD_TARGET)" == "linux" ,, -e "/only-linux/d") \ + $(if-expr "$(KBUILD_TARGET)" == "win" ,, -e "/only-win/d") \ + $(if-expr "$(KBUILD_TARGET)" == "darwin",, -e "/only-darwin/d") \ + -f "$<" $(filter %.def, $^) +endif +endif # remove later + + +# +# RuntimeR3NoCRTGCC - CRT replacement lib for VBoxREM. +# This is used together with VBoxRT. +# +## @todo the *_alias.c stuff is busted, remove and use RT_WITH_NOCRT_ALIASES instead. +RuntimeR3NoCRTGCC_TEMPLATE = VBoxNoCrtGccLib +RuntimeR3NoCRTGCC_LIBSUFF = $(VBOX_SUFF_LIB) +ifn1of ($(KBUILD_TARGET_ARCH), amd64 x86) + RuntimeR3NoCRTGCC_DEFS += RT_NO_GIP +endif +RuntimeR3NoCRTGCC_INCS = include +RuntimeR3NoCRTGCC_SOURCES := \ + common/misc/sanity-cpp.cpp \ + common/misc/sanity-c.c \ + \ + $(RuntimeNoCrt_SOURCES) + +if1of ($(KBUILD_TARGET_ARCH), amd64 x86) +RuntimeR3NoCRTGCC_SOURCES += \ + common/math/ceill.asm \ + common/math/cosl.asm \ + common/math/fabs.asm \ + common/math/fabsf.asm \ + common/math/fabsl.asm \ + common/math/floor.asm \ + common/math/floorf.asm \ + common/math/floorl.asm \ + common/math/ldexpl.asm \ + common/math/llrint.asm \ + common/math/llrintf.asm \ + common/math/llrintl.asm \ + common/math/logl.asm \ + common/math/lrint.asm \ + common/math/lrintf.asm \ + common/math/lrintl.asm \ + common/math/remainder.asm \ + common/math/remainderf.asm \ + common/math/remainderl.asm \ + common/math/sinl.asm \ + common/math/tanl.asm \ + common/math/trunc.asm \ + common/math/truncf.asm \ + common/math/truncl.asm \ + \ + common/string/memchr_alias.c \ + common/string/memcmp_alias.c \ + common/string/memcpy_alias.c \ + common/string/memmove_alias.c \ + common/string/memset_alias.c \ + common/string/strchr_alias.c \ + common/string/strcmp_alias.c \ + common/string/strlen_alias.c +endif + +RuntimeR3NoCRTGCC_SOURCES.x86 = \ + common/math/x86/fenv-x86.c \ + common/math/gcc/adddi3.c \ + common/math/gcc/anddi3.c \ + common/math/gcc/ashldi3.c \ + common/math/gcc/ashrdi3.c \ + common/math/gcc/cmpdi2.c \ + common/math/gcc/divdi3.c \ + common/math/gcc/iordi3.c \ + common/math/gcc/lshldi3.c \ + common/math/gcc/lshrdi3.c \ + common/math/gcc/moddi3.c \ + common/math/gcc/muldi3.c \ + common/math/gcc/negdi2.c \ + common/math/gcc/notdi2.c \ + common/math/gcc/qdivrem.c \ + common/math/gcc/subdi3.c \ + common/math/gcc/ucmpdi2.c \ + common/math/gcc/udivdi3.c \ + common/math/gcc/udivmoddi4.c \ + common/math/gcc/umoddi3.c \ + common/math/gcc/xordi3.c + + +# +# RuntimeR0 - Ring-0 library for VMMR0. +# +RuntimeR0_TEMPLATE = VBoxR0 +RuntimeR0_DEFS = IN_RT_R0 RT_WITH_VBOX NOFILEID +ifn1of ($(KBUILD_TARGET_ARCH), amd64 x86) + RuntimeR0_DEFS += RT_NO_GIP +endif +if defined(VBOX_WITH_DTRACE_R0) && !defined(VBOX_ONLY_VALIDATIONKIT) + RuntimeR0_DEFS += IPRT_WITH_DTRACE IPRT_DTRACE_PREFIX=VBOXVMM_ IPRT_DTRACE_INCLUDE=\"dtrace/VBoxVMM.h\" +endif +RuntimeR0_INCS = include +RuntimeR0_SOURCES := \ + $(if $(VBOX_ONLY_VALIDATIONKIT),,../VMM/VBoxVMM.d) \ + common/log/logellipsis.cpp \ + common/log/logrelellipsis.cpp \ + common/log/logcom.cpp \ + common/log/logformat.cpp \ + common/log/tracebuf.cpp \ + common/log/tracedefault.cpp \ + common/misc/RTAssertMsg1Weak.cpp \ + common/misc/RTAssertMsg2.cpp \ + common/misc/RTAssertMsg2Add.cpp \ + common/misc/RTAssertMsg2AddWeak.cpp \ + common/misc/RTAssertMsg2AddWeakV.cpp \ + common/misc/RTAssertMsg2Weak.cpp \ + common/misc/RTAssertMsg2WeakV.cpp \ + common/misc/buildconfig.cpp \ + common/misc/once.cpp \ + common/misc/sanity-c.c \ + common/misc/sanity-cpp.cpp \ + common/misc/term.cpp \ + common/path/RTPathFilename.cpp \ + common/string/strhash1.cpp \ + common/string/strncmp.cpp \ + common/string/strpbrk.cpp \ + common/string/RTStrCat.cpp \ + common/string/RTStrCatEx.cpp \ + common/string/RTStrCatP.cpp \ + common/string/RTStrCatPEx.cpp \ + common/string/RTStrCopy.cpp \ + common/string/RTStrCopyEx.cpp \ + common/string/RTStrCopyP.cpp \ + common/string/RTStrCopyPEx.cpp \ + common/string/RTStrCmp.cpp \ + common/string/RTStrICmpAscii.cpp \ + common/string/RTStrNICmpAscii.cpp \ + common/string/RTStrNLen.cpp \ + common/string/RTStrNLenEx.cpp \ + common/table/avlgcptr.cpp \ + common/table/avlhcphys.cpp \ + common/table/avllu32.cpp \ + common/table/avlogcphys.cpp \ + common/table/avlogcptr.cpp \ + common/table/avlohcphys.cpp \ + common/table/avloioport.cpp \ + common/table/avlpv.cpp \ + common/table/avlrogcphys.cpp \ + common/table/avlrogcptr.cpp \ + common/table/avlroioport.cpp \ + common/table/avlroogcptr.cpp \ + common/table/avlu32.cpp \ + common/table/avlou32.cpp \ + common/time/timesup.cpp \ + generic/RTAssertShouldPanic-generic.cpp \ + generic/critsect-generic.cpp \ + generic/critsectrw-generic.cpp \ + \ + $(RuntimeNoCrt_SOURCES) + +if1of ($(KBUILD_TARGET), darwin solaris freebsd os2) +RuntimeR0_SOURCES += \ + common/math/gcc/adddi3.c \ + common/math/gcc/anddi3.c \ + common/math/gcc/ashldi3.c \ + common/math/gcc/ashrdi3.c \ + common/math/gcc/cmpdi2.c \ + common/math/gcc/divdi3.c \ + common/math/gcc/iordi3.c \ + common/math/gcc/lshldi3.c \ + common/math/gcc/lshrdi3.c \ + common/math/gcc/moddi3.c \ + common/math/gcc/muldi3.c \ + common/math/gcc/negdi2.c \ + common/math/gcc/notdi2.c \ + common/math/gcc/qdivrem.c \ + common/math/gcc/subdi3.c \ + common/math/gcc/ucmpdi2.c \ + common/math/gcc/udivdi3.c \ + common/math/gcc/udivmoddi4.c \ + common/math/gcc/umoddi3.c \ + common/math/gcc/xordi3.c +endif + +RuntimeR0_SOURCES.x86 += \ + common/asm/ASMCpuIdExSlow.asm \ + common/asm/ASMAtomicUoAndU64.asm \ + common/asm/ASMAtomicUoAndU32.asm \ + common/asm/ASMAtomicUoDecU32.asm \ + common/asm/ASMAtomicUoIncU32.asm \ + common/asm/ASMAtomicUoOrU64.asm \ + common/asm/ASMAtomicUoOrU32.asm \ + common/asm/ASMMemFirstMismatchingU8.asm \ + common/asm/ASMGetXcr0.asm \ + common/asm/ASMSetXcr0.asm \ + common/asm/ASMXSave.asm \ + common/asm/ASMXRstor.asm \ + common/asm/ASMFxSave.asm \ + common/asm/ASMFxRstor.asm \ + common/asm/ASMRdMsrEx.asm \ + common/asm/ASMWrMsrEx.asm +RuntimeR0_SOURCES.amd64 += \ + common/asm/ASMCpuIdExSlow.asm \ + common/asm/ASMAtomicUoAndU64.asm \ + common/asm/ASMAtomicUoAndU32.asm \ + common/asm/ASMAtomicUoDecU32.asm \ + common/asm/ASMAtomicUoIncU32.asm \ + common/asm/ASMAtomicUoOrU64.asm \ + common/asm/ASMAtomicUoOrU32.asm \ + common/asm/ASMMemFirstMismatchingU8.asm \ + common/asm/ASMGetXcr0.asm \ + common/asm/ASMSetXcr0.asm \ + common/asm/ASMXSave.asm \ + common/asm/ASMXRstor.asm \ + common/asm/ASMFxSave.asm \ + common/asm/ASMFxRstor.asm \ + common/asm/ASMRdMsrEx.asm \ + common/asm/ASMWrMsrEx.asm + +#if1of ($(KBUILD_TARGET_ARCH),amd64 x86) +# RuntimeR0_SOURCES += common/time/timesupA.asm +#else + RuntimeR0_SOURCES += common/time/timesupref.cpp +#endif + +RuntimeR0_SOURCES.win.amd64 := $(RuntimeWin64ASM_SOURCES) +RuntimeR0_SOURCES.win.x86 := $(RuntimeWin32ASM_SOURCES) +RuntimeR0_SOURCES.win = \ + nt/NtProcessStartup-stub.cpp + +RuntimeR0_SOURCES.os2 = \ + os2/sys0.asm + + +# +# RuntimeR0Stub - Ring-0 context startup stub for Windows and Solaris. +# +RuntimeR0Stub_TEMPLATE = $(if-expr "$(KBUILD_TARGET)" == "solaris",VBoxR0DrvLib,VBoxR0) +RuntimeR0Stub_SOURCES.win = \ + nt/NtProcessStartup-stub.cpp +RuntimeR0Stub_SOURCES.solaris = \ + r0drv/solaris/modulestub-r0drv-solaris.c + + +# +# RuntimeR0Drv - Ring-0 library for host drivers. +# +RuntimeR0Drv_TEMPLATE = VBoxR0DrvLib +RuntimeR0Drv_SDKS.win = ReorderCompilerIncs $(VBOX_WINDDK) $(VBOX_WINPSDK)INCS VBOX_OPENSSL +RuntimeR0Drv_DEFS = IN_RT_R0 RT_WITH_VBOX RT_WITHOUT_NOCRT_WRAPPERS RT_NO_EXPORT_SYMBOL NOFILEID +RuntimeR0Drv_DEFS.win = IN_SUP_R0 LDR_ONLY_PE IPRT_WITHOUT_DIGEST_MD4 +RuntimeR0Drv_DEFS.darwin= IN_SUP_R0 LDR_ONLY_MACHO IPRT_WITHOUT_DIGEST_MD4 + +RuntimeR0Drv_INCS := $(PATH_SUB_CURRENT) include +RuntimeR0Drv_INCS.freebsd = \ + $(PATH_STAGE)/gen-sys-hdrs +RuntimeR0Drv_INCS.solaris = \ + r0drv/solaris/vbi/i86pc \ + r0drv/solaris/vbi/i86pc/sys + +RuntimeR0Drv_SOURCES = \ + common/alloc/alloc.cpp \ + common/alloc/heapsimple.cpp \ + common/alloc/heapoffset.cpp \ + common/checksum/alt-md5.cpp \ + common/checksum/crc32.cpp \ + common/checksum/crc64.cpp \ + common/checksum/ipv4.cpp \ + common/checksum/ipv6.cpp \ + common/err/RTErrConvertToErrno.cpp \ + common/err/RTErrConvertFromErrno.cpp \ + common/err/errinfo.cpp \ + common/log/log.cpp \ + common/log/logellipsis.cpp \ + common/log/logrel.cpp \ + common/log/logrelellipsis.cpp \ + common/log/logcom.cpp \ + common/log/logformat.cpp \ + common/log/tracebuf.cpp \ + common/log/tracedefault.cpp \ + common/misc/RTAssertMsg1Weak.cpp \ + common/misc/RTAssertMsg2.cpp \ + common/misc/RTAssertMsg2Add.cpp \ + common/misc/RTAssertMsg2AddWeak.cpp \ + common/misc/RTAssertMsg2AddWeakV.cpp \ + common/misc/RTAssertMsg2Weak.cpp \ + common/misc/RTAssertMsg2WeakV.cpp \ + common/misc/assert.cpp \ + common/misc/buildconfig.cpp \ + common/misc/handletable.cpp \ + common/misc/handletablectx.cpp \ + common/misc/handletablesimple.cpp \ + common/misc/once.cpp \ + common/misc/sanity-c.c \ + common/misc/sanity-cpp.cpp \ + common/misc/term.cpp \ + common/misc/RTMemWipeThoroughly.cpp \ + common/path/rtPathVolumeSpecLen.cpp \ + common/path/RTPathAbsDup.cpp \ + common/path/RTPathAbsEx.cpp \ + common/path/RTPathAbsExDup.cpp \ + common/path/RTPathAppend.cpp \ + common/path/RTPathAppendEx.cpp \ + common/path/RTPathExt.cpp \ + common/path/RTPathFilename.cpp \ + common/path/RTPathHasExt.cpp \ + common/path/RTPathHasPath.cpp \ + common/path/RTPathParseSimple.cpp \ + common/path/RTPathRealDup.cpp \ + common/path/RTPathStripExt.cpp \ + common/path/RTPathStripFilename.cpp \ + common/path/RTPathStripTrailingSlash.cpp \ + common/rand/rand.cpp \ + common/rand/randadv.cpp \ + common/rand/randparkmiller.cpp \ + common/string/RTStrCat.cpp \ + common/string/RTStrCatEx.cpp \ + common/string/RTStrCatP.cpp \ + common/string/RTStrCatPEx.cpp \ + common/string/RTStrCmp.cpp \ + common/string/RTStrCopy.cpp \ + common/string/RTStrCopyEx.cpp \ + common/string/RTStrCopyP.cpp \ + common/string/RTStrCopyPEx.cpp \ + common/string/RTStrICmpAscii.cpp \ + common/string/RTStrNICmpAscii.cpp \ + common/string/RTStrNCmp.cpp \ + common/string/RTStrNLen.cpp \ + common/string/RTStrNLenEx.cpp \ + common/string/RTUtf16ICmpAscii.cpp \ + common/string/RTUtf16NICmpAscii.cpp \ + common/string/straprintf.cpp \ + common/string/strformat.cpp \ + common/string/strformatnum.cpp \ + common/string/strformatrt.cpp \ + common/string/strformattype.cpp \ + common/string/strhash1.cpp \ + common/string/strprintf.cpp \ + common/string/strprintf2.cpp \ + common/string/strtonum.cpp \ + common/string/stringalloc.cpp \ + common/string/unidata-flags.cpp \ + common/string/unidata-lower.cpp \ + common/string/unidata-upper.cpp \ + common/string/utf-8.cpp \ + common/string/utf-8-case.cpp \ + common/string/utf-8-case2.cpp \ + common/string/utf-16.cpp \ + common/string/utf-16-case.cpp \ + common/string/utf-16-latin-1.cpp \ + common/table/avlpv.cpp \ + common/table/avlu32.cpp \ + common/time/time.cpp \ + generic/RTLogWriteStdErr-stub-generic.cpp \ + generic/RTLogWriteUser-generic.cpp \ + generic/RTMpGetArraySize-generic.cpp \ + generic/RTRandAdvCreateSystemFaster-generic.cpp \ + generic/RTSemEventWait-2-ex-generic.cpp \ + generic/RTSemEventWaitNoResume-2-ex-generic.cpp \ + generic/RTSemEventMultiWait-2-ex-generic.cpp \ + generic/RTSemEventMultiWaitNoResume-2-ex-generic.cpp \ + generic/critsect-generic.cpp \ + generic/critsectrw-generic.cpp \ + generic/errvars-generic.cpp \ + generic/uuid-generic.cpp \ + r0drv/alloc-r0drv.cpp \ + r0drv/initterm-r0drv.cpp \ + r0drv/generic/semspinmutex-r0drv-generic.c \ + r0drv/RTR0DbgKrnlInfoGetSymbol.cpp \ + VBox/log-vbox.cpp \ + +RuntimeR0Drv_SOURCES.amd64 = \ + common/asm/ASMMemFirstMismatchingU8.asm \ + common/asm/ASMRdMsrEx.asm \ + common/asm/ASMWrMsrEx.asm \ + common/math/bignum-amd64-x86.asm \ + common/math/RTUInt128MulByU64.asm +RuntimeR0Drv_SOURCES.x86 = \ + common/asm/ASMMemFirstMismatchingU8.asm \ + common/asm/ASMRdMsrEx.asm \ + common/asm/ASMWrMsrEx.asm \ + common/math/bignum-amd64-x86.asm + + +RuntimeR0Drv_SOURCES.linux = \ + common/misc/thread.cpp \ + common/string/strpbrk.cpp \ + generic/RTAssertShouldPanic-generic.cpp \ + generic/RTLogWriteStdOut-stub-generic.cpp \ + generic/RTMpGetCoreCount-generic.cpp \ + generic/mppresent-generic.cpp \ + generic/rtStrFormatKernelAddress-generic.cpp \ + r0drv/linux/alloc-r0drv-linux.c \ + r0drv/linux/assert-r0drv-linux.c \ + r0drv/linux/initterm-r0drv-linux.c \ + r0drv/linux/memobj-r0drv-linux.c \ + r0drv/linux/memuserkernel-r0drv-linux.c \ + r0drv/linux/mp-r0drv-linux.c \ + r0drv/linux/mpnotification-r0drv-linux.c \ + r0drv/linux/process-r0drv-linux.c \ + r0drv/linux/RTLogWriteDebugger-r0drv-linux.c \ + r0drv/linux/semevent-r0drv-linux.c \ + r0drv/linux/semeventmulti-r0drv-linux.c \ + r0drv/linux/semfastmutex-r0drv-linux.c \ + r0drv/linux/semmutex-r0drv-linux.c \ + r0drv/linux/spinlock-r0drv-linux.c \ + r0drv/linux/thread-r0drv-linux.c \ + r0drv/linux/thread2-r0drv-linux.c \ + r0drv/linux/threadctxhooks-r0drv-linux.c \ + r0drv/linux/time-r0drv-linux.c \ + r0drv/linux/timer-r0drv-linux.c \ + r0drv/memobj-r0drv.cpp \ + r0drv/mpnotification-r0drv.c \ + r0drv/powernotification-r0drv.c + +RuntimeR0Drv_SOURCES.win = \ + common/asm/ASMCpuIdExSlow.asm \ + common/ldr/ldr.cpp \ + common/ldr/ldrEx.cpp \ + common/ldr/ldrPE.cpp \ + common/asn1/asn1-basics.cpp \ + common/asn1/asn1-dump.cpp \ + common/asn1/asn1-cursor.cpp \ + common/asn1/asn1-default-allocator.cpp \ + common/asn1/asn1-safer-allocator.cpp \ + common/asn1/asn1-encode.cpp \ + common/asn1/asn1-ut-bitstring.cpp \ + common/asn1/asn1-ut-bitstring-decode.cpp \ + common/asn1/asn1-ut-boolean.cpp \ + common/asn1/asn1-ut-boolean-decode.cpp \ + common/asn1/asn1-ut-core.cpp \ + common/asn1/asn1-ut-core-decode.cpp \ + common/asn1/asn1-ut-dyntype.cpp \ + common/asn1/asn1-ut-dyntype-decode.cpp \ + common/asn1/asn1-ut-integer.cpp \ + common/asn1/asn1-ut-integer-decode.cpp \ + common/asn1/asn1-ut-null.cpp \ + common/asn1/asn1-ut-null-decode.cpp \ + common/asn1/asn1-ut-objid.cpp \ + common/asn1/asn1-ut-objid-decode.cpp \ + common/asn1/asn1-ut-octetstring.cpp \ + common/asn1/asn1-ut-octetstring-decode.cpp \ + common/asn1/asn1-ut-string.cpp \ + common/asn1/asn1-ut-string-decode.cpp \ + common/asn1/asn1-ut-time.cpp \ + common/asn1/asn1-ut-time-decode.cpp \ + common/crypto/digest-core.cpp \ + common/crypto/digest-builtin.cpp \ + common/crypto/key.cpp \ + common/crypto/rsa-asn1-decoder.cpp \ + common/crypto/rsa-core.cpp \ + common/crypto/rsa-init.cpp \ + common/crypto/rsa-sanity.cpp \ + common/crypto/pkcs7-asn1-decoder.cpp \ + common/crypto/pkcs7-core.cpp \ + common/crypto/pkcs7-init.cpp \ + common/crypto/pkcs7-sanity.cpp \ + common/crypto/pkcs7-verify.cpp \ + common/crypto/pkix-signature-builtin.cpp \ + common/crypto/pkix-signature-core.cpp \ + common/crypto/pkix-signature-rsa.cpp \ + common/crypto/pkix-util.cpp \ + common/crypto/pkix-verify.cpp \ + common/crypto/spc-asn1-decoder.cpp \ + common/crypto/spc-core.cpp \ + common/crypto/spc-init.cpp \ + common/crypto/spc-sanity.cpp \ + common/crypto/x509-asn1-decoder.cpp \ + common/crypto/x509-certpaths.cpp \ + common/crypto/x509-core.cpp \ + common/crypto/x509-init.cpp \ + common/crypto/x509-sanity.cpp \ + common/crypto/x509-verify.cpp \ + common/crypto/store.cpp \ + common/crypto/store-inmem.cpp \ + common/crypto/taf-asn1-decoder.cpp \ + common/crypto/taf-core.cpp \ + common/crypto/taf-init.cpp \ + common/crypto/taf-sanity.cpp \ + common/crypto/tsp-asn1-decoder.cpp \ + common/crypto/tsp-core.cpp \ + common/crypto/tsp-init.cpp \ + common/crypto/tsp-sanity.cpp \ + common/checksum/alt-md2.cpp \ + common/checksum/alt-sha1.cpp \ + common/checksum/alt-sha256.cpp \ + common/checksum/alt-sha512.cpp \ + common/checksum/md2str.cpp \ + common/checksum/md4str.cpp \ + common/checksum/md5str.cpp \ + common/checksum/sha1str.cpp \ + common/checksum/sha224str.cpp \ + common/checksum/sha256str.cpp \ + common/checksum/sha384str.cpp \ + common/checksum/sha512str.cpp \ + common/checksum/sha512t224str.cpp \ + common/checksum/sha512t256str.cpp \ + common/err/errinfolog.cpp \ + common/path/RTPathFilenameUtf16.cpp \ + common/path/RTPathChangeToUnixSlashes.cpp \ + common/math/bignum.cpp \ + common/misc/zero.asm \ + common/string/RTStrPrintHexBytes.cpp \ + common/string/RTUtf16Copy.cpp \ + common/string/RTUtf16CopyAscii.cpp \ + common/string/RTUtf16Cat.cpp \ + common/string/RTUtf16CatAscii.cpp \ + common/string/RTUtf16End.cpp \ + common/string/RTUtf16NLen.cpp \ + common/string/RTUtf16NLenEx.cpp \ + common/string/RTUtf16PrintHexBytes.cpp \ + common/string/strstrip.cpp \ + generic/memsafer-generic.cpp \ + common/misc/thread.cpp \ + common/string/memcmp.asm \ + common/string/memchr.asm \ + common/string/memcpy.asm \ + common/string/memset.asm \ + common/string/memmove.asm \ + common/string/strlen.asm \ + common/string/strncmp.cpp \ + common/string/strpbrk.cpp \ + generic/RTAssertShouldPanic-generic.cpp \ + generic/RTLogWriteStdOut-stub-generic.cpp \ + generic/RTTimerCreate-generic.cpp \ + generic/mppresent-generic-online.cpp \ + generic/RTMpGetCoreCount-generic.cpp \ + generic/rtStrFormatKernelAddress-generic.cpp \ + nt/RTErrConvertFromNtStatus.cpp \ + nt/RTNtPathExpand8dot3Path.cpp \ + nt/RTNtPathFindPossible8dot3Name.cpp \ + r0drv/generic/threadctxhooks-r0drv-generic.cpp \ + r0drv/alloc-ef-r0drv.cpp \ + r0drv/memobj-r0drv.cpp \ + r0drv/mpnotification-r0drv.c \ + r0drv/powernotification-r0drv.c \ + r0drv/nt/alloc-r0drv-nt.cpp \ + r0drv/nt/assert-r0drv-nt.cpp \ + r0drv/nt/dbgkrnlinfo-r0drv-nt.cpp \ + r0drv/nt/initterm-r0drv-nt.cpp \ + r0drv/nt/memobj-r0drv-nt.cpp \ + r0drv/nt/memuserkernel-r0drv-nt.cpp \ + r0drv/nt/mp-r0drv-nt.cpp \ + r0drv/nt/process-r0drv-nt.cpp \ + r0drv/nt/RTLogWriteDebugger-r0drv-nt.cpp \ + r0drv/nt/semevent-r0drv-nt.cpp \ + r0drv/nt/semeventmulti-r0drv-nt.cpp \ + r0drv/nt/semfastmutex-r0drv-nt.cpp \ + r0drv/nt/semmutex-r0drv-nt.cpp \ + r0drv/nt/spinlock-r0drv-nt.cpp \ + r0drv/nt/thread-r0drv-nt.cpp \ + r0drv/nt/thread2-r0drv-nt.cpp \ + r0drv/nt/time-r0drv-nt.cpp \ + r0drv/nt/timer-r0drv-nt.cpp \ + r0drv/nt/toxic-chkstk-r0drv-nt.asm \ + r0drv/nt/RTTimerGetSystemGranularity-r0drv-nt.cpp + +RuntimeR0Drv_SOURCES.win.amd64 := $(RuntimeWin64ASM_SOURCES) +RuntimeR0Drv_SOURCES.win.x86 := $(RuntimeWin32ASM_SOURCES) \ + r0drv/nt/nt3fakes-stub-r0drv-nt.cpp + + +RuntimeR0Drv_SOURCES.darwin = \ + common/ldr/ldr.cpp \ + common/ldr/ldrEx.cpp \ + common/ldr/ldrMachO.cpp \ + common/ldr/ldrMemory.cpp \ + common/asn1/asn1-basics.cpp \ + common/asn1/asn1-dump.cpp \ + common/asn1/asn1-cursor.cpp \ + common/asn1/asn1-default-allocator.cpp \ + common/asn1/asn1-safer-allocator.cpp \ + common/asn1/asn1-encode.cpp \ + common/asn1/asn1-ut-bitstring.cpp \ + common/asn1/asn1-ut-bitstring-decode.cpp \ + common/asn1/asn1-ut-boolean.cpp \ + common/asn1/asn1-ut-boolean-decode.cpp \ + common/asn1/asn1-ut-core.cpp \ + common/asn1/asn1-ut-core-decode.cpp \ + common/asn1/asn1-ut-dyntype.cpp \ + common/asn1/asn1-ut-dyntype-decode.cpp \ + common/asn1/asn1-ut-integer.cpp \ + common/asn1/asn1-ut-integer-decode.cpp \ + common/asn1/asn1-ut-null.cpp \ + common/asn1/asn1-ut-null-decode.cpp \ + common/asn1/asn1-ut-objid.cpp \ + common/asn1/asn1-ut-objid-decode.cpp \ + common/asn1/asn1-ut-octetstring.cpp \ + common/asn1/asn1-ut-octetstring-decode.cpp \ + common/asn1/asn1-ut-string.cpp \ + common/asn1/asn1-ut-string-decode.cpp \ + common/asn1/asn1-ut-time.cpp \ + common/asn1/asn1-ut-time-decode.cpp \ + common/crypto/digest-core.cpp \ + common/crypto/digest-builtin.cpp \ + common/crypto/key.cpp \ + common/crypto/rsa-asn1-decoder.cpp \ + common/crypto/rsa-core.cpp \ + common/crypto/rsa-init.cpp \ + common/crypto/rsa-sanity.cpp \ + common/crypto/pkcs7-asn1-decoder.cpp \ + common/crypto/pkcs7-core.cpp \ + common/crypto/pkcs7-init.cpp \ + common/crypto/pkcs7-sanity.cpp \ + common/crypto/pkcs7-verify.cpp \ + common/crypto/pkix-signature-builtin.cpp \ + common/crypto/pkix-signature-core.cpp \ + common/crypto/pkix-signature-rsa.cpp \ + common/crypto/pkix-util.cpp \ + common/crypto/pkix-verify.cpp \ + common/crypto/spc-asn1-decoder.cpp \ + common/crypto/spc-core.cpp \ + common/crypto/spc-init.cpp \ + common/crypto/spc-sanity.cpp \ + common/crypto/x509-asn1-decoder.cpp \ + common/crypto/x509-certpaths.cpp \ + common/crypto/x509-core.cpp \ + common/crypto/x509-init.cpp \ + common/crypto/x509-sanity.cpp \ + common/crypto/x509-verify.cpp \ + common/crypto/store.cpp \ + common/crypto/store-inmem.cpp \ + common/crypto/taf-asn1-decoder.cpp \ + common/crypto/taf-core.cpp \ + common/crypto/taf-init.cpp \ + common/crypto/taf-sanity.cpp \ + common/crypto/tsp-asn1-decoder.cpp \ + common/crypto/tsp-core.cpp \ + common/crypto/tsp-init.cpp \ + common/crypto/tsp-sanity.cpp \ + common/checksum/alt-md2.cpp \ + common/checksum/alt-sha1.cpp \ + common/checksum/alt-sha256.cpp \ + common/checksum/alt-sha512.cpp \ + common/checksum/md2str.cpp \ + common/checksum/md4str.cpp \ + common/checksum/md5str.cpp \ + common/checksum/sha1str.cpp \ + common/checksum/sha224str.cpp \ + common/checksum/sha256str.cpp \ + common/checksum/sha384str.cpp \ + common/checksum/sha512str.cpp \ + common/checksum/sha512t224str.cpp \ + common/checksum/sha512t256str.cpp \ + common/err/errinfolog.cpp \ + common/math/bignum.cpp \ + common/misc/thread.cpp \ + common/string/base64.cpp \ + common/string/memchr.asm \ + common/string/strpbrk.cpp \ + common/string/RTStrPrintHexBytes.cpp \ + darwin/RTErrConvertFromDarwin.cpp \ + darwin/RTErrConvertFromDarwinIO.cpp \ + darwin/RTErrConvertFromDarwinKern.cpp \ + generic/RTAssertShouldPanic-generic.cpp \ + generic/RTFileReadAll-generic.cpp \ + generic/RTFileReadAllByHandle-generic.cpp \ + generic/RTFileReadAllByHandleEx-generic.cpp \ + generic/RTFileReadAllEx-generic.cpp \ + generic/RTFileReadAllFree-generic.cpp \ + generic/RTMpGetCoreCount-generic.cpp \ + generic/RTMpOnPair-generic.cpp \ + generic/RTTimerCreate-generic.cpp \ + generic/memsafer-generic.cpp \ + generic/mppresent-generic.cpp \ + generic/timer-generic.cpp \ + r0drv/generic/mpnotification-r0drv-generic.cpp \ + r0drv/generic/threadctxhooks-r0drv-generic.cpp \ + r0drv/darwin/alloc-r0drv-darwin.cpp \ + r0drv/darwin/assert-r0drv-darwin.cpp \ + r0drv/darwin/initterm-r0drv-darwin.cpp \ + r0drv/darwin/dbgkrnlinfo-r0drv-darwin.cpp \ + r0drv/darwin/fileio-r0drv-darwin.cpp \ + r0drv/darwin/memobj-r0drv-darwin.cpp \ + r0drv/darwin/mp-r0drv-darwin.cpp \ + r0drv/darwin/memuserkernel-r0drv-darwin.cpp \ + r0drv/darwin/process-r0drv-darwin.cpp \ + r0drv/darwin/RTLogWriteDebugger-r0drv-darwin.cpp \ + r0drv/darwin/RTLogWriteStdOut-r0drv-darwin.cpp \ + r0drv/darwin/rtStrFormatKernelAddress-r0drv-darwin.cpp \ + r0drv/darwin/semevent-r0drv-darwin.cpp \ + r0drv/darwin/semeventmulti-r0drv-darwin.cpp \ + r0drv/darwin/semfastmutex-r0drv-darwin.cpp \ + r0drv/darwin/semmutex-r0drv-darwin.cpp \ + r0drv/darwin/spinlock-r0drv-darwin.cpp \ + r0drv/darwin/thread-r0drv-darwin.cpp \ + r0drv/darwin/thread2-r0drv-darwin.cpp \ + r0drv/darwin/threadpreempt-r0drv-darwin.cpp \ + r0drv/darwin/time-r0drv-darwin.cpp \ + r0drv/alloc-ef-r0drv.cpp \ + r0drv/memobj-r0drv.cpp \ + r0drv/powernotification-r0drv.c + +RuntimeR0Drv_SOURCES.os2 = \ + common/path/RTPathFilenameUtf16.cpp \ + common/string/RTUtf16Chr.cpp \ + common/string/RTUtf16CmpAscii.cpp \ + common/string/memchr.asm \ + common/string/memcmp.asm \ + common/string/memcpy.asm \ + common/string/mempcpy.asm \ + common/string/memmove.asm \ + common/string/memset.asm \ + common/string/strchr.asm \ + common/string/strcmp.asm \ + common/string/strcpy.asm \ + common/string/strlen.asm \ + common/string/strncmp.cpp \ + common/string/strpbrk.cpp \ + common/misc/thread.cpp \ + generic/RTAssertShouldPanic-generic.cpp \ + generic/RTLogWriteDebugger-generic.cpp \ + generic/RTLogWriteStdOut-stub-generic.cpp \ + generic/RTMpCpuId-generic.cpp \ + generic/RTMpCpuIdFromSetIndex-generic.cpp \ + generic/RTMpCpuIdToSetIndex-generic.cpp \ + generic/RTMpIsCpuPossible-generic.cpp \ + generic/RTMpGetCount-generic.cpp \ + generic/RTMpGetMaxCpuId-generic.cpp \ + generic/RTMpGetOnlineCount-generic.cpp \ + generic/RTMpGetOnlineSet-generic.cpp \ + generic/RTMpGetSet-generic.cpp \ + generic/RTMpIsCpuOnline-generic.cpp \ + generic/RTTimerCreate-generic.cpp \ + generic/mppresent-generic.cpp \ + generic/rtStrFormatKernelAddress-generic.cpp \ + os2/RTErrConvertFromOS2.cpp \ + os2/rtSemWaitOs2ConvertTimeout.cpp \ + os2/sys0.asm \ + r0drv/generic/RTMpIsCpuWorkPending-r0drv-generic.cpp \ + r0drv/generic/RTMpOn-r0drv-generic.cpp \ + r0drv/generic/mpnotification-r0drv-generic.cpp \ + r0drv/generic/threadctxhooks-r0drv-generic.cpp \ + r0drv/memobj-r0drv.cpp \ + r0drv/powernotification-r0drv.c \ + r0drv/os2/alloc-r0drv-os2.cpp \ + r0drv/os2/assert-r0drv-os2.cpp \ + r0drv/os2/assertA-r0drv-os2.asm \ + r0drv/os2/initterm-r0drv-os2.cpp \ + r0drv/os2/memobj-r0drv-os2.cpp \ + r0drv/os2/memuserkernel-r0drv-os2.cpp \ + r0drv/os2/os2imports.imp \ + r0drv/os2/process-r0drv-os2.cpp \ + r0drv/os2/RTR0AssertPanicSystem-r0drv-os2.asm \ + r0drv/os2/RTR0Os2DHQueryDOSVar.asm \ + r0drv/os2/RTR0Os2DHVMGlobalToProcess.asm \ + r0drv/os2/semevent-r0drv-os2.cpp \ + r0drv/os2/semeventmulti-r0drv-os2.cpp \ + r0drv/os2/semfastmutex-r0drv-os2.cpp \ + r0drv/os2/spinlock-r0drv-os2.cpp \ + r0drv/os2/thread-r0drv-os2.cpp \ + r0drv/os2/thread2-r0drv-os2.cpp \ + r0drv/os2/time-r0drv-os2.cpp \ + r0drv/os2/timer-r0drv-os2.cpp \ + r0drv/os2/timerA-r0drv-os2.asm +ifndef VBOX_USE_WATCOM_FOR_OS2 + RuntimeR0Drv_SOURCES.os2 += \ + common/math/gcc/adddi3.c \ + common/math/gcc/anddi3.c \ + common/math/gcc/ashldi3.c \ + common/math/gcc/ashrdi3.c \ + common/math/gcc/cmpdi2.c \ + common/math/gcc/divdi3.c \ + common/math/gcc/iordi3.c \ + common/math/gcc/lshldi3.c \ + common/math/gcc/lshrdi3.c \ + common/math/gcc/moddi3.c \ + common/math/gcc/muldi3.c \ + common/math/gcc/negdi2.c \ + common/math/gcc/notdi2.c \ + common/math/gcc/qdivrem.c \ + common/math/gcc/subdi3.c \ + common/math/gcc/ucmpdi2.c \ + common/math/gcc/udivdi3.c \ + common/math/gcc/udivmoddi4.c \ + common/math/gcc/umoddi3.c \ + common/math/gcc/xordi3.c +else + RuntimeR0Drv_SOURCES.os2 += \ + common/math/watcom/I8D-x86-32.asm \ + common/math/watcom/U8D-x86-32.asm \ + common/math/watcom/RTWatcomUInt64Div.c \ + common/math/watcom/U8LS-x86-32.asm \ + common/math/watcom/U8RS-x86-32.asm \ + common/math/watcom/U8M-I8M-x86-32.asm \ + common/string/watcom/bzero.asm \ + common/string/watcom/memchr.asm \ + common/string/watcom/memcmp.asm \ + common/string/watcom/memcpy.asm \ + common/string/watcom/memmove.asm \ + common/string/watcom/mempcpy.asm \ + common/string/watcom/memrchr.asm \ + common/string/watcom/memset.asm \ + common/string/watcom/strchr.asm \ + common/string/watcom/strcmp.asm \ + common/string/watcom/strcpy.asm \ + common/string/watcom/strlen.asm \ + common/string/watcom/strncmp.asm \ + common/string/watcom/strncpy.asm +endif + +RuntimeR0Drv_SOURCES.freebsd = \ + common/misc/thread.cpp \ + common/string/memchr.asm \ + common/string/memmove.asm \ + common/string/strpbrk.cpp \ + common/string/memcmp.asm \ + common/string/strchr.asm \ + generic/RTAssertShouldPanic-generic.cpp \ + generic/RTLogWriteDebugger-generic.cpp \ + generic/RTLogWriteStdOut-stub-generic.cpp \ + generic/RTMpOnPair-generic.cpp \ + generic/RTTimerCreate-generic.cpp \ + generic/mppresent-generic.cpp \ + generic/rtStrFormatKernelAddress-generic.cpp \ + r0drv/generic/RTMpIsCpuWorkPending-r0drv-generic.cpp \ + r0drv/generic/mpnotification-r0drv-generic.cpp \ + r0drv/generic/threadctxhooks-r0drv-generic.cpp \ + r0drv/freebsd/alloc-r0drv-freebsd.c \ + r0drv/freebsd/assert-r0drv-freebsd.c \ + r0drv/freebsd/initterm-r0drv-freebsd.c \ + r0drv/freebsd/memobj-r0drv-freebsd.c \ + r0drv/freebsd/memuserkernel-r0drv-freebsd.c \ + r0drv/freebsd/process-r0drv-freebsd.c \ + r0drv/freebsd/semevent-r0drv-freebsd.c \ + r0drv/freebsd/semeventmulti-r0drv-freebsd.c \ + r0drv/freebsd/semfastmutex-r0drv-freebsd.c \ + r0drv/freebsd/semmutex-r0drv-freebsd.c \ + r0drv/freebsd/spinlock-r0drv-freebsd.c \ + r0drv/freebsd/thread-r0drv-freebsd.c \ + r0drv/freebsd/thread2-r0drv-freebsd.c \ + r0drv/freebsd/time-r0drv-freebsd.c \ + r0drv/freebsd/mp-r0drv-freebsd.c \ + generic/timer-generic.cpp \ + r0drv/alloc-ef-r0drv.cpp \ + r0drv/memobj-r0drv.cpp \ + r0drv/powernotification-r0drv.c + +RuntimeR0Drv_SOURCES.netbsd = \ + common/misc/thread.cpp \ + common/string/strpbrk.cpp \ + generic/RTAssertShouldPanic-generic.cpp \ + generic/RTLogWriteDebugger-generic.cpp \ + generic/RTTimerCreate-generic.cpp \ + generic/mppresent-generic.cpp \ + generic/rtStrFormatKernelAddress-generic.cpp \ + r0drv/generic/RTMpIsCpuWorkPending-r0drv-generic.cpp \ + r0drv/generic/mpnotification-r0drv-generic.cpp \ + r0drv/generic/threadctxhooks-r0drv-generic.cpp \ + r0drv/netbsd/RTLogWriteStdOut-r0drv-netbsd.c \ + r0drv/netbsd/alloc-r0drv-netbsd.c \ + r0drv/netbsd/assert-r0drv-netbsd.c \ + r0drv/netbsd/initterm-r0drv-netbsd.c \ + r0drv/netbsd/memobj-r0drv-netbsd.c \ + r0drv/netbsd/memuserkernel-r0drv-netbsd.c \ + r0drv/netbsd/process-r0drv-netbsd.c \ + r0drv/netbsd/semevent-r0drv-netbsd.c \ + r0drv/netbsd/semeventmulti-r0drv-netbsd.c \ + r0drv/netbsd/semfastmutex-r0drv-netbsd.c \ + r0drv/netbsd/spinlock-r0drv-netbsd.c \ + r0drv/netbsd/thread-r0drv-netbsd.c \ + r0drv/netbsd/thread2-r0drv-netbsd.c \ + r0drv/netbsd/time-r0drv-netbsd.c \ + r0drv/netbsd/mp-r0drv-netbsd.c \ + generic/timer-generic.cpp \ + r0drv/memobj-r0drv.cpp \ + r0drv/powernotification-r0drv.c + +RuntimeR0Drv_SOURCES.solaris = \ + common/misc/thread.cpp \ + common/string/memchr.asm \ + generic/RTAssertShouldPanic-generic.cpp \ + generic/RTLogWriteStdOut-stub-generic.cpp \ + generic/RTMpGetCoreCount-generic.cpp \ + generic/RTTimerCreate-generic.cpp \ + generic/mppresent-generic.cpp \ + generic/rtStrFormatKernelAddress-generic.cpp \ + r0drv/memobj-r0drv.cpp \ + r0drv/mpnotification-r0drv.c \ + r0drv/powernotification-r0drv.c \ + r0drv/solaris/RTLogWriteDebugger-r0drv-solaris.c \ + r0drv/solaris/RTMpPokeCpu-r0drv-solaris.c \ + r0drv/solaris/alloc-r0drv-solaris.c \ + r0drv/solaris/assert-r0drv-solaris.c \ + r0drv/solaris/dbgkrnlinfo-r0drv-solaris.c \ + r0drv/solaris/initterm-r0drv-solaris.c \ + r0drv/solaris/memuserkernel-r0drv-solaris.c \ + r0drv/solaris/mpnotification-r0drv-solaris.c \ + r0drv/solaris/memobj-r0drv-solaris.c \ + r0drv/solaris/mp-r0drv-solaris.c \ + r0drv/solaris/process-r0drv-solaris.c \ + r0drv/solaris/semevent-r0drv-solaris.c \ + r0drv/solaris/semeventmulti-r0drv-solaris.c \ + r0drv/solaris/semfastmutex-r0drv-solaris.c \ + r0drv/solaris/semmutex-r0drv-solaris.c \ + r0drv/solaris/spinlock-r0drv-solaris.c \ + r0drv/solaris/thread-r0drv-solaris.c \ + r0drv/solaris/thread2-r0drv-solaris.c \ + r0drv/solaris/threadctxhooks-r0drv-solaris.c \ + r0drv/solaris/time-r0drv-solaris.c \ + r0drv/solaris/timer-r0drv-solaris.c + +RuntimeR0Drv_SOURCES.haiku = \ + common/misc/thread.cpp \ + common/string/memchr.asm \ + common/string/memmove.asm \ + common/string/strpbrk.cpp \ + common/string/memcmp.asm \ + common/string/strchr.asm \ + generic/RTAssertShouldPanic-generic.cpp \ + generic/RTMpOnPair-generic.cpp \ + generic/RTTimerCreate-generic.cpp \ + generic/mppresent-generic.cpp \ + generic/rtStrFormatKernelAddress-generic.cpp \ + r0drv/generic/RTMpIsCpuWorkPending-r0drv-generic.cpp \ + r0drv/generic/mpnotification-r0drv-generic.cpp \ + r0drv/generic/threadctxhooks-r0drv-generic.cpp \ + r0drv/haiku/alloc-r0drv-haiku.c \ + r0drv/haiku/assert-r0drv-haiku.c \ + r0drv/haiku/initterm-r0drv-haiku.c \ + r0drv/haiku/memobj-r0drv-haiku.c \ + r0drv/haiku/mp-r0drv-haiku.c \ + r0drv/haiku/process-r0drv-haiku.c \ + r0drv/haiku/RTLogWriteDebugger-r0drv-haiku.c \ + r0drv/haiku/RTLogWriteStdOut-r0drv-haiku.c \ + r0drv/haiku/semevent-r0drv-haiku.c \ + r0drv/haiku/semeventmulti-r0drv-haiku.c \ + r0drv/haiku/semfastmutex-r0drv-haiku.c \ + r0drv/haiku/semmutex-r0drv-haiku.c \ + r0drv/haiku/spinlock-r0drv-haiku.c \ + r0drv/haiku/thread-r0drv-haiku.c \ + r0drv/haiku/thread2-r0drv-haiku.c \ + r0drv/haiku/time-r0drv-haiku.c \ + generic/timer-generic.cpp \ + r0drv/memobj-r0drv.cpp \ + r0drv/powernotification-r0drv.c + +## PORTME: Porters create and add their selection of platform specific Ring-0 Driver files here. + +RuntimeR0Drv_ORDERDEPS.freebsd = \ + $(PATH_STAGE)/gen-sys-hdrs/bus_if.h \ + $(PATH_STAGE)/gen-sys-hdrs/device_if.h + + +# +# RuntimeGuestR0 - Guest driver runtime. +# This is almost the same as the RuntimeR0Drv, the main difference +# is in the backdoor logging and the lack of sup.h (which should be +# made irrelevant even for RuntimeR0Drv). +# +RuntimeGuestR0_TEMPLATE := VBOXGUESTR0LIB +RuntimeGuestR0_EXTENDS = RuntimeR0Drv +RuntimeGuestR0_DEFS.win.x86 = $(RuntimeR0Drv_DEFS.win.x86) IPRT_TARGET_NT4 # The 32-bit version needs to work on NT4 too. +RuntimeGuestR0_SOURCES := $(filter-out generic/RTLogWriteUser-generic.cpp, $(RuntimeR0Drv_SOURCES)) +RuntimeGuestR0_SOURCES += \ + VBox/logbackdoor.cpp +RuntimeGuestR0_SOURCES.win := \ + $(filter-out common/checksum/md% common/checksum/sha%, $(RuntimeR0Drv_SOURCES.win)) + + +ifdef VBOX_WITH_RAW_MODE + # + # RuntimeRC - Raw-mode context library. + # + RuntimeRC_TEMPLATE = VBoxRc + RuntimeRC_DEFS = IN_RT_RC RT_WITH_VBOX IN_SUP_RC IN_VMM_RC NOFILEID + RuntimeRC_INCS = include + RuntimeRC_SOURCES := \ + common/asm/ASMMemFirstMismatchingU8.asm \ + common/asm/ASMGetXcr0.asm \ + common/asm/ASMSetXcr0.asm \ + common/asm/ASMXSave.asm \ + common/asm/ASMXRstor.asm \ + common/asm/ASMFxSave.asm \ + common/asm/ASMFxRstor.asm \ + common/checksum/alt-md5.cpp \ + common/checksum/crc32.cpp \ + common/checksum/crc64.cpp \ + common/log/log.cpp \ + common/log/logellipsis.cpp \ + common/log/logrel.cpp \ + common/log/logrelellipsis.cpp \ + common/log/logcom.cpp \ + common/log/logformat.cpp \ + common/log/tracebuf.cpp \ + common/log/tracedefault.cpp \ + common/misc/RTAssertMsg1Weak.cpp \ + common/misc/RTAssertMsg2.cpp \ + common/misc/RTAssertMsg2Add.cpp \ + common/misc/RTAssertMsg2AddWeak.cpp \ + common/misc/RTAssertMsg2AddWeakV.cpp \ + common/misc/RTAssertMsg2Weak.cpp \ + common/misc/RTAssertMsg2WeakV.cpp \ + common/misc/assert.cpp \ + common/misc/buildconfig.cpp \ + common/misc/sanity-c.c \ + common/misc/sanity-cpp.cpp \ + common/path/RTPathFilename.cpp \ + common/string/strformat.cpp \ + common/string/strformatnum.cpp \ + common/string/strformatrt.cpp \ + common/string/strformattype.cpp \ + common/string/strncmp.cpp \ + common/string/strpbrk.cpp \ + common/string/strprintf.cpp \ + common/string/strprintf2.cpp \ + common/string/RTStrCmp.cpp \ + common/string/RTStrCopy.cpp \ + common/string/RTStrCopyEx.cpp \ + common/string/RTStrICmpAscii.cpp \ + common/table/avllu32.cpp \ + common/table/avlou32.cpp \ + common/table/avlogcphys.cpp \ + common/table/avlogcptr.cpp \ + common/table/avlohcphys.cpp \ + common/table/avloioport.cpp \ + common/table/avlrogcphys.cpp \ + common/table/avlrogcptr.cpp \ + common/table/avlroioport.cpp \ + common/table/avlroogcptr.cpp \ + common/table/avlu32.cpp \ + common/time/timeprog.cpp \ + common/time/timesup.cpp \ + gc/initterm-gc.cpp \ + generic/RTAssertShouldPanic-generic.cpp \ + generic/rtStrFormatKernelAddress-generic.cpp \ + generic/errvars-generic.cpp \ + \ + $(RuntimeNoCrt_SOURCES) + + #if1of ($(KBUILD_TARGET_ARCH),amd64 x86) + # RuntimeRC_SOURCES += common/time/timesupA.asm + #else + RuntimeRC_SOURCES += common/time/timesupref.cpp + #endif + + RuntimeRC_SOURCES.win.x86 = $(RuntimeWin32ASM_SOURCES) + + ifeq ($(VBOX_LDR_FMT32),lx) + RuntimeRC_SOURCES += os2/sys0.asm + endif + + if1of ($(KBUILD_TARGET), darwin solaris freebsd os2) + RuntimeRC_SOURCES += \ + common/math/gcc/adddi3.c \ + common/math/gcc/anddi3.c \ + common/math/gcc/ashldi3.c \ + common/math/gcc/ashrdi3.c \ + common/math/gcc/cmpdi2.c \ + common/math/gcc/divdi3.c \ + common/math/gcc/iordi3.c \ + common/math/gcc/lshldi3.c \ + common/math/gcc/lshrdi3.c \ + common/math/gcc/moddi3.c \ + common/math/gcc/muldi3.c \ + common/math/gcc/negdi2.c \ + common/math/gcc/notdi2.c \ + common/math/gcc/qdivrem.c \ + common/math/gcc/subdi3.c \ + common/math/gcc/ucmpdi2.c \ + common/math/gcc/udivdi3.c \ + common/math/gcc/udivmoddi4.c \ + common/math/gcc/umoddi3.c \ + common/math/gcc/xordi3.c + endif + + + # + # RuntimeRCStub - Raw-mode context startup stub for Windows. + # + RuntimeRCStub_TEMPLATE = VBoxRc + RuntimeRCStub_SOURCES.win = \ + nt/NtProcessStartup-stub.cpp + + +endif # VBOX_WITH_RAW_MODE + + +# +# Static library for new & delete for the electric fence. +# +RuntimeEFCPP_TEMPLATE := $(VBoxRT_TEMPLATE) +RuntimeEFCPP_SDKS := $(RuntimeR3_SDKS) +RuntimeEFCPP_SDKS.$(KBUILD_TARGET) := $(RuntimeR3_SDKS.$(KBUILD_TARGET)) +RuntimeEFCPP_DEFS := $(RuntimeR3_DEFS) +RuntimeEFCPP_DEFS.$(KBUILD_TARGET) := $(RuntimeR3_DEFS.$(KBUILD_TARGET)) +RuntimeEFCPP_INCS := $(RuntimeR3_INCS) +RuntimeEFCPP_INCS.$(KBUILD_TARGET) := $(RuntimeR3_INCS.$(KBUILD_TARGET)) +RuntimeEFCPP_SOURCES := r3/alloc-ef-cpp.cpp + + + +# +# The NTDLL mini import library. +# +# Note! The reason for doing this is to avoid importing CRT symbols from the +# NTDLL. We do not wish to do this because: +# - Our compiler is usually a different one and we should use the +# matching CRT, +# - Older versions of NTDLL may not sport all the exports our w2k3 or +# later WINDDK ntdll.lib have and thus we may easily end up with +# images that does not load on older windows versions. +# +if1of (win,$(KBUILD_TARGET) $(KBUILD_HOST)) +RuntimeR3NtDll-amd64_TEMPLATE = VBoxR3Dll +RuntimeR3NtDll-amd64_BLD_TRG_ARCH = amd64 +RuntimeR3NtDll-amd64_ARFLAGS = /NODEFAULTLIB /MACHINE:amd64 +RuntimeR3NtDll-amd64_SOURCES = \ + r3/win/ntdll-mini-implib.def + +RuntimeR3NtDll-x86_TEMPLATE = VBoxR3Dll +RuntimeR3NtDll-x86_BLD_TRG_ARCH = x86 +RuntimeR3NtDll-x86_ARFLAGS = /NODEFAULTLIB /MACHINE:x86 +RuntimeR3NtDll-x86_SOURCES = \ + r3/win/ntdll-mini-implib.def \ + $(RuntimeR3NtDll-x86_0_OUTDIR)/ntdll-mini-implib.asm +RuntimeR3NtDll-x86_CLEAN = \ + $(RuntimeR3NtDll-x86_0_OUTDIR)/ntdll-mini-implib.asm + +$$(RuntimeR3NtDll-x86_0_OUTDIR)/ntdll-mini-implib.asm: $(PATH_SUB_CURRENT)/r3/win/ntdll-mini-implib.def | $$(dir $$@) + $(call MSG_GENERATE,,$@,$<) + $(QUIET)$(APPEND) -nt "$@" \ + ';Autogenerated, do not edit' \ + '%include "iprt/asmdefs.mac"' \ + 'BEGINCODE' \ + '%macro IMPLIB_EXPORT 1' \ + 'global %1:function' \ + '%1: nop' \ + '%endm' \ + '' + $(QUIET)$(SED) -e '1,/EXPORTS/d' \ + -e 's/^.*;;=[[:space:]]*\([^[:space:]]*\)[[:space:]]*$$/IMPLIB_EXPORT \1/' \ + $< --append $@ +endif + +# +# Bag of tricks required for making VCC100 output binaries work on NT4, W2K +# early XP and early W2K3. Used by validation kit. +# +RuntimeR3VccTricks_TEMPLATE = VBoxR3Static +RuntimeR3VccTricks_SOURCES = \ + r3/win/vcc100-kernel32-fakes.cpp \ + r3/win/vcc100-kernel32-fakesA.asm \ + r3/win/vcc100-shell32-fakes.cpp \ + r3/win/vcc100-shell32-fakesA.asm + +if defined(VBOX_WITH_MORE_NT4_COMPAT_BINARIES) && "$(KBUILD_TARGET).$(KBUILD_TARGET_ARCH)" == "win.x86" # Ugly hacks... :-) +LIBRARIES += RuntimeR3VccTricks2 +RuntimeR3VccTricks2_TEMPLATE = VBoxR3Dll +RuntimeR3VccTricks2_SOURCES = $(RuntimeR3VccTricks_SOURCES) +RuntimeR3VccTricks2_SOURCES += $(RuntimeR3VccTricks2_0_OUTDIR)/dynobjs.lib +RuntimeR3VccTricks2_CLEAN = $(RuntimeR3VccTricks2_0_OUTDIR)/dynobjs.lib +RuntimeR3VccTricks2_VBOX_LIBCMT_NEEDED = + +$$(RuntimeR3VccTricks2_0_OUTDIR)/dynobjs.lib: \ + $$(PATH_TOOL_$$(TEMPLATE_VBoxR3Dll_TOOL.win.x86)_LIB)/msvcrt$(VBOX_VCC_CRT_TYPE).lib \ + $$(PATH_TOOL_$$(TEMPLATE_VBoxR3Dll_TOOL.win.x86)_LIB)/libcmt$(VBOX_VCC_CRT_TYPE).lib \ + $$(LIB_RUNTIME) \ + $(MAKEFILE) | $$(dir $$@) + $(RM) -f -- "$@" +# $(REDIRECT) -C $(dir $@) -- $(KBUILD_DEVTOOLS)/common/openwatcom/v1.9-r2/binnt/wlib \ +# $(PATH_TOOL_$(TEMPLATE_VBoxR3Dll_TOOL.win.x86)_LIB)/libcmt$(VBOX_VCC_CRT_TYPE).lib \ +# $(foreach file, $(RuntimeR3VccTricks2_VBOX_LIBCMT_NEEDED), *$(file)) + $(KBUILD_DEVTOOLS)/common/openwatcom/v1.9-r2/binnt/wlib -o=$@.tmp.lib $< \ + -MSVCR100.dll \ + $(addprefix $(RuntimeR3VccTricks2_0_OUTDIR)/, $(RuntimeR3VccTricks2_VBOX_LIBCMT_NEEDED)) \ + -chandler4gs.obj + $(KBUILD_DEVTOOLS)/common/openwatcom/v1.9-r2/binnt/wlib -o=$@ \ + $(LIB_RUNTIME) \ + +$@.tmp.lib + $(RM) -f -- $@.tmp.lib $(addprefix $(RuntimeR3VccTricks2_0_OUTDIR)/, $(RuntimeR3VccTricks_VBOX_LIBCMT_NEEDED)) +endif + + +# +# errmsg.cpp depends on a generated header. +# +common/err/errmsg.cpp_DEPS = $(IPRT_OUT_DIR)/errmsgdata.h +common/err/errmsg.cpp_INCS = $(IPRT_OUT_DIR) + +win/errmsgwin.cpp_DEPS = $(IPRT_OUT_DIR)/errmsgcomdata.h +win/errmsgwin.cpp_INCS = $(IPRT_OUT_DIR) + +# Our COM errors only for R3 libraries on the host +define def_errmsgwin_deps + $(lib)_win/errmsgwin.cpp_DEPS = $(IPRT_OUT_DIR)/errmsgvboxcomdata.h + $(lib)_common/err/errmsgxpcom.cpp_INCS = $(IPRT_OUT_DIR) + $(lib)_common/err/errmsgxpcom.cpp_DEPS = $(IPRT_OUT_DIR)/errmsgvboxcomdata.h +endef +$(foreach lib,RuntimeR3 RuntimeBldProg VBoxRT VBoxRT-x86,$(eval $(def_errmsgwin_deps))) + + +# +# Generate the status code data. +# +$(IPRT_OUT_DIR)/errmsgdata.h: \ + $(VBOX_PATH_RUNTIME_SRC)/common/err/errmsg.sed \ + $(PATH_ROOT)/include/iprt/err.h \ + $(PATH_ROOT)/include/VBox/err.h \ + | $$(dir $$@) + $(call MSG_GENERATE,,$@,$(filter %.h,$^)) + $(QUIET)$(REDIRECT) -wo $@ -- $(SED) -f $< $(filter %.h,$^) + +## @todo r=bird: rename this to indicate that it's not only COM errors, but all win32/64 errors. +$(IPRT_OUT_DIR)/errmsgcomdata.h: \ + $(VBOX_PATH_RUNTIME_SRC)/common/err/errmsgcom.sed \ + $$(PATH_SDK_$(VBOX_WINPSDK)_INC)/WinError.h \ + | $$(dir $$@) + $(call MSG_GENERATE,,$@,$(filter %.h,$^)) + $(QUIET)$(REDIRECT) -wo $@ -- $(SED) -f $< $(filter %.h,$^) + +$(IPRT_OUT_DIR)/errmsgvboxcomdata.h.ts +| $(IPRT_OUT_DIR)/errmsgvboxcomdata.h: \ + $(VBOX_PATH_RUNTIME_SRC)/VBox/errmsgvboxcom.xsl \ + $(VBOX_XIDL_FILE_SRC) \ + | $$(dir $$@) + $(call MSG_GENERATE,,$@,$(filter %.xidl,$^)) + $(QUIET)$(VBOX_XSLTPROC) -o $(IPRT_OUT_DIR)/errmsgvboxcomdata.h.ts $< $(filter %.xidl,$^) + $(QUIET)$(CP) --changed -fv $(IPRT_OUT_DIR)/errmsgvboxcomdata.h.ts $(IPRT_OUT_DIR)/errmsgvboxcomdata.h + + +if "$(KBUILD_TARGET)" == "freebsd" +# +# FreeBSDGeneratedKernelHeaders - Generate some kernel interface headers. +# +# These are used by: +# - The RTMp* API in IPRT. +# - VBoxGuest +# +# Note! We cannot give a output path to the awk program, it will always +# generate the header next to the source. So, we'll have to temporarily copy +# the source file to the destination directory to work. +# +VBOX_AWK := /usr/bin/awk +INSTALLS += FreeBSDGeneratedKernelHeaders +FreeBSDGeneratedKernelHeaders_INST = gen-sys-hdrs/ +FreeBSDGeneratedKernelHeaders_SOURCES = \ + $(FreeBSDGeneratedKernelHeaders_0_OUTDIR)/bus_if.h \ + $(FreeBSDGeneratedKernelHeaders_0_OUTDIR)/device_if.h \ + $(FreeBSDGeneratedKernelHeaders_0_OUTDIR)/pci_if.h +FreeBSDGeneratedKernelHeaders_CLEAN = $(FreeBSDGeneratedKernelHeaders_SOURCES) + +$$(FreeBSDGeneratedKernelHeaders_0_OUTDIR)/bus_if.h: $(VBOX_FREEBSD_SRC)/kern/bus_if.m | $$(dir $$@) + $(call MSG_TOOL,awk,FreeBSDGeneratedKernelHeaders,$<,$@) + $(QUIET)$(CP) -f $< $(@D)/bus_if.m + $(QUIET)$(VBOX_AWK) -f $(VBOX_FREEBSD_SRC)/tools/makeobjops.awk $(@D)/bus_if.m -h -p + $(QUIET)$(RM) $(@D)/bus_if.m + +$$(FreeBSDGeneratedKernelHeaders_0_OUTDIR)/device_if.h: $(VBOX_FREEBSD_SRC)/kern/device_if.m | $$(dir $$@) + $(call MSG_TOOL,awk,FreeBSDGeneratedKernelHeaders,$<,$@) + $(QUIET)$(CP) -f $< $(@D)/device_if.m + $(QUIET)$(VBOX_AWK) -f $(VBOX_FREEBSD_SRC)/tools/makeobjops.awk $(@D)/device_if.m -h -p + $(QUIET)$(RM) $(@D)/device_if.m + +$$(FreeBSDGeneratedKernelHeaders_0_OUTDIR)/pci_if.h: $(VBOX_FREEBSD_SRC)/dev/pci/pci_if.m | $$(dir $$@) + $(call MSG_TOOL,awk,FreeBSDGeneratedKernelHeaders,$<,$@) + $(QUIET)$(CP) -f $< $(@D)/pci_if.m + $(QUIET)$(VBOX_AWK) -f $(VBOX_FREEBSD_SRC)/tools/makeobjops.awk $(@D)/pci_if.m -h -p + $(QUIET)$(RM) $(@D)/pci_if.m +endif # FreeBSD + + +# +# Aliases for .cpp.h files so we can more easily do syntax checking from the editor. +# +ldrELFRelocatable.cpp.o: ldrELF.o +ldrELFRelocatable.cpp.obj: ldrELF.obj + + +# +# Doxygen documentation. +# +IPRT_DOXYFILE_INPUT_DIRS = \ + $(PATH_ROOT)/include/iprt \ + $(PATH_ROOT)/include/iprt/cpp \ + $(PATH_ROOT)/include/iprt/linux \ + $(PATH_ROOT)/include/iprt/nocrt \ + $(PATH_ROOT)/include/iprt/nocrt/x86 \ + $(PATH_ROOT)/include/iprt/nocrt/amd64 \ + $(PATH_ROOT)/include/iprt/nocrt/compiler \ + $(VBOX_PATH_RUNTIME_SRC)/include/internal \ + $(VBOX_PATH_RUNTIME_SRC)/common/alloc \ + $(VBOX_PATH_RUNTIME_SRC)/common/asm \ + $(VBOX_PATH_RUNTIME_SRC)/common/checksum \ + $(VBOX_PATH_RUNTIME_SRC)/common/dbg \ + $(VBOX_PATH_RUNTIME_SRC)/common/err \ + $(VBOX_PATH_RUNTIME_SRC)/common/ldr \ + $(VBOX_PATH_RUNTIME_SRC)/common/log \ + $(VBOX_PATH_RUNTIME_SRC)/common/math \ + $(VBOX_PATH_RUNTIME_SRC)/common/math/amd64 \ + $(VBOX_PATH_RUNTIME_SRC)/common/math/gcc \ + $(VBOX_PATH_RUNTIME_SRC)/common/math/x86 \ + $(VBOX_PATH_RUNTIME_SRC)/common/misc \ + $(VBOX_PATH_RUNTIME_SRC)/common/path \ + $(VBOX_PATH_RUNTIME_SRC)/common/rand \ + $(VBOX_PATH_RUNTIME_SRC)/common/string \ + $(VBOX_PATH_RUNTIME_SRC)/common/table \ + $(VBOX_PATH_RUNTIME_SRC)/common/time \ + $(VBOX_PATH_RUNTIME_SRC)/VBox \ + $(foreach dir, $(VBOX_PATH_RUNTIME_SRC) $(VBOX_PATH_RUNTIME_SRC)/r3 $(VBOX_PATH_RUNTIME_SRC)/r0drv,\ + $(dir) \ + $(dir)/darwin \ + $(dir)/haiku \ + $(dir)/linux \ + $(dir)/nt \ + $(dir)/os2 \ + $(dir)/solaris \ + $(dir)/win \ + $(dir)/win32 \ + $(dir)/win64 \ + $(dir)/generic \ + ) + +# These must come first in order to make things look nice. +IPRT_DOXYFILE_INPUT_FIRST =\ + $(PATH_ROOT)/include/iprt/cdefs.h \ + $(PATH_ROOT)/include/iprt/types.h \ + $(PATH_ROOT)/include/iprt/runtime.h \ + $(PATH_ROOT)/include/iprt/param.h \ + $(PATH_ROOT)/include/iprt/assert.h \ + $(PATH_ROOT)/include/iprt/asm.h \ + +IPRT_DOXYFILE_INPUT := \ + $(filter-out %.cpp.h, $(sort $(wildcard $(addsuffix /*.h, $(IPRT_DOXYFILE_INPUT_DIRS)))) ) \ + $(foreach dir, $(IPRT_DOXYFILE_INPUT_DIRS), $(wildcard $(dir)/*.cpp $(dir)/.c $(dir)/.asm)) +IPRT_DOXYFILE_INPUT := \ + $(IPRT_DOXYFILE_INPUT_FIRST) \ + $(sort $(filter-out $(IPRT_DOXYFILE_INPUT_FIRST), $(IPRT_DOXYFILE_INPUT))) + + +IPRT_DOXYFILE_OUTPUT = $(PATH_OUT)/docs/iprt +BLDDIRS += $(IPRT_DOXYFILE_OUTPUT) + +includedep $(IPRT_DOXYFILE_OUTPUT)/Doxyfile.iprt.dep + +# Generate the Doxyfile +$(IPRT_DOXYFILE_OUTPUT)/Doxyfile.iprt: \ + $(VBOX_PATH_RUNTIME_SRC)/Doxyfile \ + $(VBOX_PATH_RUNTIME_SRC)/Makefile.kmk \ + $(comp-vars IPRT_DOXYFILE_INPUT,DOXYGEN_IPRT_INPUT_PREV,FORCE) \ + $(comp-vars IPRT_DOXYFILE_OUTPUT,DOXYGEN_IPRT_OUTPUT_PREV,FORCE) \ + | $$(dir $$@) + $(QUIET)$(RM) -f $@ $@.tmp $@.dep + $(QUIET)$(CP) -f $(VBOX_PATH_RUNTIME_SRC)/Doxyfile $@.tmp + $(QUIET)$(APPEND) $@.tmp + $(QUIET)$(APPEND) $@.tmp "OUTPUT_DIRECTORY = $(IPRT_DOXYFILE_OUTPUT)" + $(QUIET)$(APPEND) $@.tmp "WARN_LOGFILE = $(IPRT_DOXYFILE_OUTPUT)/errors" + $(QUIET)$(APPEND) $@.tmp 'INCLUDE_PATH = ' \ + '$(PATH_ROOT)/include' \ + '$(VBOX_PATH_RUNTIME_SRC)/include' \ + '$(VBOX_PATH_RUNTIME_SRC)/' \ + '$(VBOX_PATH_RUNTIME_SRC)/common/table' + $(QUIET)$(APPEND) $@.tmp "INCLUDE_FILE_PATTERNS = *.cpp.h" + $(QUIET)$(APPEND) $@.tmp "PREDEFINED += $(ARCH_BITS_DEFS)" + $(QUIET)$(APPEND) $@.tmp 'EXCLUDE = '\ + '$(VBOX_PATH_RUNTIME_SRC)/common/string/unidata-flags.cpp' \ + '$(VBOX_PATH_RUNTIME_SRC)/common/string/unidata-lower.cpp' \ + '$(VBOX_PATH_RUNTIME_SRC)/common/string/unidata-upper.cpp' \ + $(QUIET)$(APPEND) $@.tmp + $(QUIET)$(APPEND) $@.tmp 'INPUT = $(foreach x,$(IPRT_DOXYFILE_INPUT),\$(NLTAB)$(x))' + $(QUIET)$(APPEND) $@.tmp + $(QUIET)$(MV) -f $@.tmp $@ + $(QUIET)$(APPEND) $@.dep "DOXYGEN_IPRT_OUTPUT_PREV = $(IPRT_DOXYFILE_OUTPUT)" + $(QUIET)$(APPEND) $@.dep "DOXYGEN_IPRT_INPUT_PREV = $(IPRT_DOXYFILE_INPUT)" + +# Do the actual job. +$(IPRT_DOXYFILE_OUTPUT)/docs.iprt: $(IPRT_DOXYFILE_OUTPUT)/Doxyfile.iprt $$(IPRT_DOXYFILE_INPUT) \ + | $(IPRT_DOXYFILE_OUTPUT)/ + $(QUIET)$(RM) -f $@ + $(QUIET)$(RM) -Rf $(IPRT_DOXYFILE_OUTPUT)/html/ + doxygen $(DOXYGEN_OPTS) $(IPRT_DOXYFILE_OUTPUT)/Doxyfile.iprt + $(SED) -e '/warning. Unexpected tag .dd. found/d' \ + -e '/warning. Unsupported xml.html tag .globalScope. found/d' \ + --output $(IPRT_DOXYFILE_OUTPUT)/errors2 \ + $(IPRT_DOXYFILE_OUTPUT)/errors + $(CAT) $(IPRT_DOXYFILE_OUTPUT)/errors2 + $(SED) -e "/[^ ]/q 1" $(IPRT_DOXYFILE_OUTPUT)/errors2 + $(APPEND) $@ + +# aliases +docs.iprt: $(IPRT_DOXYFILE_OUTPUT)/docs.iprt +if !defined(VBOX_ONLY_DOCS) && defined(VBOX_WITH_ALL_DOXYGEN_TARGETS) +docs: $(IPRT_DOXYFILE_OUTPUT)/docs.iprt +endif + +test-doxygen:: + @echo test-$(comp-vars IPRT_DOXYFILE_OUTPUT,DOXYGEN_IPRT_OUTPUT_PREV,FORCE) + @echo $(IPRT_DOXYFILE_OUTPUT) + @echo $(DOXYGEN_IPRT_OUTPUT_PREV) + @echo $(IPRT_DOXYFILE_INPUT) + + +# +# Test mangling. +# +if1of ($(LIBRARIES),RuntimeR3 RuntimeR0 RuntimeR0Drv RuntimeRC) + test-mangling:: $(IPRT_OUT_DIR)/mangling.run + OTHERS += $(IPRT_OUT_DIR)/mangling.run + CLEANS += $(IPRT_OUT_DIR)/mangling.run + $(IPRT_OUT_DIR)/mangling.run: \ + $$(RuntimeR3_1_TARGET) \ + $$(RuntimeR0_1_TARGET) \ + $$(RuntimeR0Drv_1_TARGET) \ + $$(RuntimeRC_1_TARGET) + if1of ($(KBUILD_TARGET), win os2) + $(call MSG_L1,IPRT: skipped mangling test.) + else +# Generate a SED script from mangling.h that checks for known symbols. + $(QUIET)$(SED) \ + -e '/^# *define.*RT_MANGLER/!d' \ + -e 's/^.*RT_MANGLER(\([^)][^)]*\)).*$(DOLLAR)/\/^\1$(DOLLAR)\/b ok/' \ + $(PATH_ROOT)/include/iprt/mangling.h \ + --output "$@" + $(QUIET)$(APPEND) -n '$@' \ + ':bad' \ + 's/^\(.*\)$(DOLLAR)/error: Missing # define \1 /' \ + ':bad-pad' \ + '/^.\{0,70\}$(DOLLAR)/ { s/$(DOLLAR)/ /; bbad-pad; }' \ + 's/define \([^ ]*\) \([ ]*\)$(DOLLAR)/define \1 \2RT_MANGLER(\1)/' \ + 'p' \ + $(if-expr !defined(IPRT_IGNORE_TEST_MANGLING),'q 1') \ + '' \ + ':ok' \ + 'd' +# Find the best way to generate a symbol list and subject it to mangling.h. + if $(intersects $(KBUILD_TARGET), linux) && "$(VBOX_GCC_fvisibility-hidden)" + $(call MSG_L1,IPRT: Testing mangling and visiblity for newer gcc...) + $(QUIET)readelf -Ws $^ \ + | $(SED) \ + -e 's/[[:space:]]\+/ /g' \ + -e '/^ *[[:digit:]]\+:/!d' \ + -e 's/^ \+[[:digit:]]\+: \+[[:xdigit:]]\+ \+[[:digit:]]\+ \+//' \ + -e '/^SECTION/d' \ + -e '/^FILE/d' \ + -e 's/^[[:alpha:]]\+ \+//' \ + -e '/LOCAL/d' \ + -e 's/^[[:alpha:]]\+ \+//' \ + -e '/^HIDDEN [[:xdigit:]]\+ RT/bkeep-hidden' \ + -e '/^HIDDEN [[:xdigit:]]\+ g_[a-z0-9]*RT/bkeep-hidden' \ + -e '/^HIDDEN/d' \ + -e ':keep-hidden' \ + -e 's/^[[:alpha:]]\+ \+//' \ + -e '/^UND/d' \ + -e 's/^[[:digit:]]\+ \+//' \ + \ + -e '/^nocrt_/d' \ + -e '/^bzero/d' \ + -e '/^memchr/d' \ + -e '/^memcmp/d' \ + -e '/^memcpy/d' \ + -e '/^mempcpy/d' \ + -e '/^memmove/d' \ + -e '/^memset/d' \ + -e '/^strchr/d' \ + -e '/^strpbrk/d' \ + -e '/^_Z7strpbrk/d' \ + -e '/^strcmp/d' \ + -e '/^strcpy/d' \ + -e '/^strncpy/d' \ + -e '/^strlen/d' \ + -e '/^_Z[[:alpha:]]*[[:digit:]]\+RTC/d' \ + -e '/^_Z[[:alpha:]]*[[:digit:]]\+RTC/d' \ + \ + -e '/^_ZnwjPv/d' \ + -e '/^_ZnwmPv/d' \ + -e '/^_ZNSt9bad_allocC1Ev/d' \ + -e '/^_ZNSt9bad_allocC[12]ERKS_/d' \ + -e '/^_ZNSt9exceptionC2Ev/d' \ + -e '/^_ZNSt9exceptionC[12]ERKS_/d' \ + \ + -e '/^_ZN[a-zA-Z]*St[[:digit:]]*_*[lL]ist/d' \ + -e '/^_ZN[a-zA-Z]*[[:digit:]]*__gnu_cxx/d' \ + -e '/^_ZNSa.*ElementNode.*/d' \ + -e '/^_ZSt.*ElementNode.*/d' \ + \ + -e '/^_Z[[:digit:]]\+dbus/d' \ + -e '/^_Z13RTDBusLoadLibv/d' \ + \ + -e '/^g_[ac]VTG/d' \ + -e '/^g_VTGObjHeader/d' \ + -e '/^g_VTGProbeData/d' \ + -e '/^VTGProbeStub/d' \ + -e '/^g_achVTGStringTable/d' \ + -e '/^g_acVTGProbeEnabled/d' \ + \ + -e '/^VBoxHost_/d'\ + -e '/^VBoxGuest_/d'\ + | $(SED) -nf "$@" + endif + $(call MSG_L1,IPRT: Testing mangling using nm...) + $(QUIET)$(VBOX_NM) $^ 2> /dev/null \ + | $(SED) -n \ + -e 's/^[0-9a-f][0-9a-f]* //' \ + -e '/^[TUDB] /!d' \ + -e 's/^. //' \ + $(if-expr "$(KBUILD_TARGET)" == "darwin" || "$(KBUILD_TARGET)" == "os2" || "$(KBUILD_TARGET).$(KBUILD_TARGET_ARCH)" == "win.x86", \ + -e 's/^_//',) \ + \ + -e '/^g_cchrt/d'\ + -e '/^g_frt/d'\ + -e '/^g_offrt/d'\ + -e '/^g_pfnrt/d'\ + -e '/^g_rt/d'\ + -e '/^g_szrt/d'\ + -e '/^g_ProcessSelf/d'\ + -e '/^g_u64ProgramStart/d'\ + -e '/^g_enmProcessPriority/d'\ + -e '/^g_hDbgModStrCache/d'\ + -e '/^g_pfnR0Darwin/d'\ + -e '/^g_pDarwinLockGroup/d'\ + $(if-expr "$(KBUILD_TARGET)" == "solaris", \ + -e '/^g_kLdrRdrFileOps/d' \ + -e '/^g_pSUPGlobalInfoPage/d' \ + -e '/^g_Logger/d' \ + -e '/^g_RelLogger/d' \ + -e '/^g_VM/d',) \ + $(if-expr "$(KBUILD_TARGET)" == "linux", \ + -e '/^g_kLdrRdrFileOps/d',) \ + \ + -e '/^g_[ac]VTG/d' \ + -e '/^g_VTGObjHeader/d' \ + -e '/^g_VTGProbeData/d' \ + -e '/^VTGProbeStub/d' \ + -e '/^g_achVTGStringTable/d' \ + -e '/^g_acVTGProbeEnabled/d' \ + \ + -e '/^RTDBusLoadLib/d' \ + \ + -e '/^RT/p' \ + -e '/^g_/p' \ + | $(SED) -nf "$@" + endif +endif + $(QUIET)$(APPEND) -t $@ + +if !defined(VBOX_ONLY_ADDITIONS) && !defined(VBOX_ONLY_VALIDATIONKIT) && !defined(VBOX_ONLY_DOCS) +# +# Windows build tool. +# +BLDPROGS.win += ntBldSymDb +ntBldSymDb_TEMPLATE = VBoxAdvBldProg +ntBldSymDb_INCS = . +ntBldSymDb_SOURCES = r0drv/nt/ntBldSymDb.cpp +endif + + +# +# Generate the rules (we're the to sub-makefile). +# +include $(FILE_KBUILD_SUB_FOOTER) + + +# +# Aliases for code templates. +# +rsa-template.o rsa-template.obj: rsa-core.o rsa-asn1-decoder.o rsa-sanity.o rsa-init.o +spc-template.o spc-template.obj: spc-core.o spc-asn1-decoder.o spc-sanity.o spc-init.o +taf-template.o taf-template.obj: taf-core.o taf-asn1-decoder.o taf-sanity.o taf-init.o +tsp-template.o tsp-template.obj: tsp-core.o tsp-asn1-decoder.o tsp-sanity.o tsp-init.o +x509-template.o x509-template.obj: x509-core.o x509-asn1-decoder.o x509-sanity.o x509-init.o +pkcs7-template.o pkcs7-template.obj: pkcs7-core.o pkcs7-asn1-decoder.o pkcs7-sanity.o pkcs7-init.o + |