VirtualBox

source: vbox/trunk/src/VBox/HostDrivers/Support/Makefile.kmk@ 80651

Last change on this file since 80651 was 80220, checked in by vboxsync, 5 years ago

SUPHardNt: Check register context of suspended child main thread, correcting RIP if bogus. Another way to deal with easyhook/mactype.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 30.5 KB
Line 
1# $Id: Makefile.kmk 80220 2019-08-12 07:54:30Z vboxsync $
2## @file
3# Sub-Makefile for the support library and the drivers/modules/kexts it uses.
4#
5
6#
7# Copyright (C) 2006-2019 Oracle Corporation
8#
9# This file is part of VirtualBox Open Source Edition (OSE), as
10# available from http://www.virtualbox.org. This file is free software;
11# you can redistribute it and/or modify it under the terms of the GNU
12# General Public License (GPL) as published by the Free Software
13# Foundation, in version 2 as it comes in the "COPYING" file of the
14# VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15# hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16#
17# The contents of this file may alternatively be used under the terms
18# of the Common Development and Distribution License Version 1.0
19# (CDDL) only, as it comes in the "COPYING.CDDL" file of the
20# VirtualBox OSE distribution, in which case the provisions of the
21# CDDL are applicable instead of those of the GPL.
22#
23# You may elect to license modified versions of this file under the
24# terms and conditions of either the GPL or the CDDL or both.
25#
26
27SUB_DEPTH = ../../../..
28include $(KBUILD_PATH)/subheader.kmk
29
30#
31# Targets
32#
33LIBRARIES += SUPR3 SUPR3Static
34if defined(VBOX_WITH_HARDENING) \
35 && !defined(VBOX_ONLY_VALIDATIONKIT)
36 LIBRARIES += SUPR3HardenedStatic
37endif
38DLLS.win += VBoxSupLib
39ifdef VBOX_WITH_32_ON_64_MAIN_API
40 LIBRARIES += SUPR3-x86
41endif
42if !defined(VBOX_ONLY_DOCS)
43 if1of ($(VBOX_LDR_FMT), pe lx)
44 LIBRARIES += SUPR0
45 endif
46endif
47if !defined(VBOX_ONLY_BUILD) && defined(VBOX_WITH_RAW_MODE)
48 LIBRARIES += SUPRC
49endif
50if !defined(VBOX_ONLY_DOCS) \
51 && !defined(VBOX_ONLY_EXTPACKS) \
52 && !defined(VBOX_ONLY_VALIDATIONKIT) \
53 && "$(intersects $(KBUILD_TARGET_ARCH),$(VBOX_SUPPORTED_HOST_ARCHS))" != ""
54 ifdef VBOX_WITH_SUPSVC
55 PROGRAMS += VBoxSupSvc
56 endif
57 ifdef VBOX_WITH_VBOXDRV
58 LIBRARIES += SUPR0IdcClient
59 SYSMODS.os2 += VBoxDrv
60 endif
61 INSTALLS.linux += vboxdrv-src
62 INSTALLS.freebsd += vboxdrv-src
63
64 #
65 # Include sub-makefile(s).
66 #
67 include $(PATH_SUB_CURRENT)/testcase/Makefile.kmk
68
69 #
70 # Populate FILES_VBOXDRV_NOBIN and FILES_VBOXDRV_BIN
71 #
72 ifeq ($(KBUILD_TARGET),linux)
73 include $(PATH_SUB_CURRENT)/linux/files_vboxdrv
74 endif
75 ifeq ($(KBUILD_TARGET),freebsd)
76 include $(PATH_SUB_CURRENT)/freebsd/files_vboxdrv
77 endif
78endif # !VBOX_ONLY_DOCS && !VBOX_ONLY_EXTPACKS && !VBOX_ONLY_VALIDATIONKIT
79
80#
81# Authenticode related trust anchors and certificates -> .cpp
82#
83VBOX_SUP_WIN_CERTS_FILE = $(SUPR3_0_OUTDIR)/TrustAnchorsAndCerts.cpp
84VBOX_SUP_WIN_CERTS := \
85 SpcRootMicrosoft0=SpcRoot-MicrosoftAuthenticodeTmRootAuthority-01.taf \
86 SpcRootMicrosoft1=SpcRoot-MicrosoftRootAuthority-00c1008b3c3c8811d13ef663ecdf40.taf \
87 SpcRootMicrosoft2=SpcRoot-MicrosoftRootCertificateAuthority-79ad16a14aa0a5ad4c7358f407132e65.taf \
88 SpcRootMicrosoft3=SpcRoot-MicrosoftRootCertificateAuthority2010-28cc3a25bfba44ac449a9b586b4339aa.taf \
89 SpcRootMicrosoft4=SpcRoot-MicrosoftRootCertificateAuthority2011-3f8bc8b5fc9fb29643b569d66c42e144.taf \
90 SpcRootMicrosoft5=SpcRoot-MicrosoftDigitalMediaAuthority2005-6eff330eb6e7569740680870104baaba.taf \
91 SpcRootMicrosoft6=SpcRoot-MicrosoftDevelopmentRootCertificateAuthority2014-078f0a9d03df119e434e4fec1bf0235a.taf \
92 NtRootMicrosoft7=NtRoot-MicrosoftCodeVerificationRoot-729404101f3e0ca347837fca175a8438.taf \
93 TimeRootMicrosoft0=Timestamp-CopyrightC1997MicrosoftCorp-01.taf \
94 TrustedCertVBox0=Trusted-OracleCorporationVirtualBox-05308b76ac2e15b29720fb4395f65f38.taf \
95 AppleRoot0=AppleRoot-2bd06947947609fef46b8d2e40a6f7474d7f085e.taf \
96 AppleRoot1=AppleRoot-G2-c499136c1803c27bc0a3a00d7f72807a1c77268d.taf
97VBOX_SUP_WIN_CERT_NAMES := $(foreach cert,$(VBOX_SUP_WIN_CERTS),$(firstword $(subst =,$(SPACE) ,$(cert))))
98VBOX_PATH_SUPR3_CERTIFICATES := $(PATH_SUB_CURRENT)/Certificates
99
100# 1=name, 2=filter, 3=buildcert?.
101if "$(KBUILD_TARGET)" == "win" && defined(VBOX_WITH_HARDENING)
102 VBOX_SUP_GEN_CERT_MACRO = 'SUPTAENTRY const g_aSUP$(1)TAs[] =' '{' \
103 $(if-expr "$(3)" == "",,' SUPTAENTRY_GEN(g_abSUPBuildCert),') \
104 $(foreach certnm,$(filter $(2),$(VBOX_SUP_WIN_CERT_NAMES)), ' SUPTAENTRY_GEN(g_abSUP$(certnm)),') \
105 '};' 'unsigned const g_cSUP$(1)TAs = RT_ELEMENTS(g_aSUP$(1)TAs);' '' ''
106else
107 VBOX_SUP_GEN_CERT_MACRO = 'SUPTAENTRY const g_aSUP$(1)TAs[] =' '{' \
108 $(foreach certnm,$(filter $(2),$(VBOX_SUP_WIN_CERT_NAMES)), ' SUPTAENTRY_GEN(g_abSUP$(certnm)),') \
109 '};' 'unsigned const g_cSUP$(1)TAs = RT_ELEMENTS(g_aSUP$(1)TAs);' '' ''
110endif
111
112$$(VBOX_SUP_WIN_CERTS_FILE): $(MAKEFILE_CURRENT) \
113 $(foreach cert,$(VBOX_SUP_WIN_CERTS),$(VBOX_PATH_SUPR3_CERTIFICATES)/$(lastword $(subst =,$(SPACE) ,$(cert)))) \
114 $(VBOX_BIN2C) \
115 $(if-expr ("$(KBUILD_TARGET)" == "win" && defined(VBOX_WITH_HARDENING)) \
116 || ("$(KBUILD_TARGET)" == "darwin" && defined(VBOX_WITH_DARWIN_R0_DARWIN_IMAGE_VERIFICATION) && defined(VBOX_SIGNING_MODE)) \
117 ,$(VBOX_RTSIGNTOOL)) \
118 | $$(dir $$@)
119 $(QUIET)$(RM) -f -- $@ $@.cer
120 $(QUIET)$(APPEND) -n "$@" \
121 '' \
122 '#include <VBox/sup.h>' \
123 ''
124 $(foreach cert,$(VBOX_SUP_WIN_CERTS), $(NLTAB)$(VBOX_BIN2C) -ascii --append --static --no-size \
125 "SUP$(firstword $(subst =,$(SP) ,$(cert)))" \
126 "$(VBOX_PATH_SUPR3_CERTIFICATES)/$(lastword $(subst =,$(SP) ,$(cert)))" \
127 "$@")
128# The build certificate.
129if ("$(KBUILD_TARGET)" == "win" && defined(VBOX_WITH_HARDENING) && defined(VBOX_SIGNING_MODE)) \
130 || ("$(KBUILD_TARGET)" == "darwin" && defined(VBOX_WITH_DARWIN_R0_DARWIN_IMAGE_VERIFICATION) && defined(VBOX_SIGNING_MODE))
131 $(VBOX_RTSIGNTOOL) extract-exe-signer-cert --exe $(VBOX_RTSIGNTOOL) --output "$@.cer" --der
132 $(VBOX_BIN2C) -ascii --append SUPBuildCert "$@.cer" $@
133 $(QUIET)$(RM) -f -- $@.cer
134endif
135# Generate certificate lists.
136 $(QUIET)$(APPEND) -n "$@" '' \
137 $(call VBOX_SUP_GEN_CERT_MACRO,All,%,build) \
138 $(call VBOX_SUP_GEN_CERT_MACRO,SpcRoot,SpcRoot%) \
139 $(call VBOX_SUP_GEN_CERT_MACRO,NtKernelRoot,NtRoot%) \
140 $(call VBOX_SUP_GEN_CERT_MACRO,Timestamp,TimeRoot%) \
141 $(call VBOX_SUP_GEN_CERT_MACRO,AppleRoot,AppleRoot%) \
142 $(call VBOX_SUP_GEN_CERT_MACRO,Trusted,TrustedCert%,build)
143
144tst: $(VBOX_SUP_WIN_CERTS_FILE)
145
146
147#
148# The Ring-3 Support Library (this is linked into the IPRT dll, VBoxRT).
149#
150SUPR3_TEMPLATE = VBOXR3
151SUPR3_DEFS = \
152 IN_SUP_R3 IN_RT_R3 \
153 $(if $(VBOX_WITH_SUPSVC),VBOX_WITH_SUPSVC) \
154 $(if $(VBOX_WITH_MAIN),VBOX_WITH_MAIN,) \
155 $(if $(VBOX_WITH_RAW_MODE),VBOX_WITH_RAW_MODE,) \
156 $(if $(VBOX_WITH_REM),VBOX_WITH_REM,) \
157 VBOX_PERMIT_MORE \
158 VBOX_PERMIT_EVEN_MORE
159SUPR3_INCS := $(PATH_SUB_CURRENT)
160SUPR3_SOURCES = \
161 SUPLib.cpp \
162 SUPLibLdr.cpp \
163 SUPLibSem.cpp \
164 SUPLibTracerA.asm \
165 SUPLibAll.cpp \
166 SUPR3HardenedIPRT.cpp \
167 SUPR3HardenedVerify.cpp \
168 $(KBUILD_TARGET)/SUPLib-$(KBUILD_TARGET).cpp \
169 $(VBOX_SUP_WIN_CERTS_FILE)
170ifdef VBOX_WITH_HARDENING
171 SUPR3_SOURCES.win = \
172 win/SUPHardenedVerifyImage-win.cpp
173endif
174
175SUPR3-x86_TEMPLATE = VBoxR3Dll-x86
176SUPR3-x86_EXTENDS = SUPR3
177
178
179#
180# Static version of SUPR3. This is more of a stub than anything else in a
181# hardened build, at least on windows.
182#
183SUPR3Static_TEMPLATE = VBOXR3STATIC
184SUPR3Static_EXTENDS = SUPR3
185SUPR3Static_DEFS = $(SUPR3_DEFS) IN_SUP_R3_STATIC
186SUPR3Static_SOURCES.win = $(filter-out win/SUPHardenedVerifyImage-win.cpp, $(SUPR3_SOURCES.win))
187
188
189#
190# The static part of the hardened support library (ring-3).
191#
192VBOX_PATH_RUNTIME_SRC ?= $(PATH_ROOT)/src/VBox/Runtime
193SUPR3HardenedStatic_TEMPLATE = VBOXR3HARDENEDLIB
194SUPR3HardenedStatic_DEFS = IN_SUP_HARDENED_R3
195SUPR3HardenedStatic_DEFS += \
196 $(if $(VBOX_WITH_SUPSVC),VBOX_WITH_SUPSVC,) \
197 $(if $(VBOX_WITH_MAIN),VBOX_WITH_MAIN,) \
198 $(if $(VBOX_WITH_RAW_MODE),VBOX_WITH_RAW_MODE,) \
199 $(if $(VBOX_WITH_REM),VBOX_WITH_REM,) \
200 $(if $(VBOX_WITHOUT_DEBUGGER_CHECKS),VBOX_WITHOUT_DEBUGGER_CHECKS,) \
201 $(if $(VBOX_PERMIT_VISUAL_STUDIO_PROFILING),VBOX_PERMIT_VISUAL_STUDIO_PROFILING,) \
202 VBOX_PERMIT_MORE \
203 VBOX_PERMIT_EVEN_MORE
204ifdef VBOX_WITH_VISTA_NO_SP
205 SUPR3HardenedStatic_DEFS.win += VBOX_WITH_VISTA_NO_SP
206endif
207SUPR3HardenedStatic_INCS = .
208SUPR3HardenedStatic_SOURCES = \
209 SUPR3HardenedMain.cpp \
210 SUPR3HardenedVerify.cpp \
211 SUPR3HardenedNoCrt.cpp \
212 $(KBUILD_TARGET)/SUPLib-$(KBUILD_TARGET).cpp
213SUPR3HardenedStatic_SOURCES.win = \
214 win/SUPR3HardenedMain-win.cpp \
215 win/SUPR3HardenedMainA-win.asm \
216 win/SUPR3HardenedMainImports-win.cpp \
217 win/SUPHardenedVerifyProcess-win.cpp \
218 win/SUPHardenedVerifyImage-win.cpp \
219 $(VBOX_SUP_WIN_CERTS_FILE)
220SUPR3HardenedStatic_SOURCES.x86 += \
221 $(VBOX_PATH_RUNTIME_SRC)/common/asm/ASMMemFirstMismatchingU8.asm
222SUPR3HardenedStatic_SOURCES.amd64 += \
223 $(VBOX_PATH_RUNTIME_SRC)/common/asm/ASMMemFirstMismatchingU8.asm
224
225
226if "$(KBUILD_TARGET)" == "win" && defined(VBOX_WITH_HARDENING) ## @todo some of this move up.
227 SUPR3HardenedStatic_DEFS += \
228 IN_RT_R3 \
229 IN_RT_STATIC \
230 IN_DIS \
231 IN_DIS_STATIC \
232 DIS_CORE_ONLY \
233 IPRT_NO_CRT \
234 RT_WITH_NOCRT_ALIASES \
235 LOG_DISABLED \
236 IPRT_NO_ERROR_DATA \
237 IPRT_WITHOUT_DIGEST_MD4
238 SUPR3HardenedStatic_DEFS.win += LDR_ONLY_PE __STRALIGN_H_
239
240 SUPR3HardenedStatic_INCS += $(PATH_ROOT)/include/iprt/nocrt $(VBOX_PATH_RUNTIME_SRC)/include
241
242 SUPR3HardenedStatic_SOURCES += \
243 $(VBOX_PATH_RUNTIME_SRC)/common/ldr/ldr.cpp \
244 $(VBOX_PATH_RUNTIME_SRC)/common/ldr/ldrEx.cpp \
245 $(VBOX_PATH_RUNTIME_SRC)/common/ldr/ldrPE.cpp \
246 $(VBOX_PATH_RUNTIME_SRC)/common/alloc/heapsimple.cpp \
247 $(VBOX_PATH_RUNTIME_SRC)/common/asn1/asn1-basics.cpp \
248 $(VBOX_PATH_RUNTIME_SRC)/common/asn1/asn1-cursor.cpp \
249 $(VBOX_PATH_RUNTIME_SRC)/common/asn1/asn1-default-allocator.cpp \
250 $(VBOX_PATH_RUNTIME_SRC)/common/asn1/asn1-safer-allocator.cpp \
251 $(VBOX_PATH_RUNTIME_SRC)/common/asn1/asn1-dump.cpp \
252 $(VBOX_PATH_RUNTIME_SRC)/common/asn1/asn1-encode.cpp \
253 $(VBOX_PATH_RUNTIME_SRC)/common/asn1/asn1-ut-bitstring.cpp \
254 $(VBOX_PATH_RUNTIME_SRC)/common/asn1/asn1-ut-bitstring-decode.cpp \
255 $(VBOX_PATH_RUNTIME_SRC)/common/asn1/asn1-ut-boolean.cpp \
256 $(VBOX_PATH_RUNTIME_SRC)/common/asn1/asn1-ut-boolean-decode.cpp \
257 $(VBOX_PATH_RUNTIME_SRC)/common/asn1/asn1-ut-core.cpp \
258 $(VBOX_PATH_RUNTIME_SRC)/common/asn1/asn1-ut-core-decode.cpp \
259 $(VBOX_PATH_RUNTIME_SRC)/common/asn1/asn1-ut-dyntype.cpp \
260 $(VBOX_PATH_RUNTIME_SRC)/common/asn1/asn1-ut-dyntype-decode.cpp \
261 $(VBOX_PATH_RUNTIME_SRC)/common/asn1/asn1-ut-integer.cpp \
262 $(VBOX_PATH_RUNTIME_SRC)/common/asn1/asn1-ut-integer-decode.cpp \
263 $(VBOX_PATH_RUNTIME_SRC)/common/asn1/asn1-ut-null.cpp \
264 $(VBOX_PATH_RUNTIME_SRC)/common/asn1/asn1-ut-null-decode.cpp \
265 $(VBOX_PATH_RUNTIME_SRC)/common/asn1/asn1-ut-objid.cpp \
266 $(VBOX_PATH_RUNTIME_SRC)/common/asn1/asn1-ut-objid-decode.cpp \
267 $(VBOX_PATH_RUNTIME_SRC)/common/asn1/asn1-ut-octetstring.cpp \
268 $(VBOX_PATH_RUNTIME_SRC)/common/asn1/asn1-ut-octetstring-decode.cpp \
269 $(VBOX_PATH_RUNTIME_SRC)/common/asn1/asn1-ut-string.cpp \
270 $(VBOX_PATH_RUNTIME_SRC)/common/asn1/asn1-ut-string-decode.cpp \
271 $(VBOX_PATH_RUNTIME_SRC)/common/asn1/asn1-ut-time.cpp \
272 $(VBOX_PATH_RUNTIME_SRC)/common/asn1/asn1-ut-time-decode.cpp \
273 $(VBOX_PATH_RUNTIME_SRC)/common/crypto/digest-core.cpp \
274 $(VBOX_PATH_RUNTIME_SRC)/common/crypto/digest-builtin.cpp \
275 $(VBOX_PATH_RUNTIME_SRC)/common/crypto/key.cpp \
276 $(VBOX_PATH_RUNTIME_SRC)/common/crypto/pkcs7-asn1-decoder.cpp \
277 $(VBOX_PATH_RUNTIME_SRC)/common/crypto/pkcs7-core.cpp \
278 $(VBOX_PATH_RUNTIME_SRC)/common/crypto/pkcs7-init.cpp \
279 $(VBOX_PATH_RUNTIME_SRC)/common/crypto/pkcs7-sanity.cpp \
280 $(VBOX_PATH_RUNTIME_SRC)/common/crypto/pkcs7-verify.cpp \
281 $(VBOX_PATH_RUNTIME_SRC)/common/crypto/pkix-signature-builtin.cpp \
282 $(VBOX_PATH_RUNTIME_SRC)/common/crypto/pkix-signature-core.cpp \
283 $(VBOX_PATH_RUNTIME_SRC)/common/crypto/pkix-signature-rsa.cpp \
284 $(VBOX_PATH_RUNTIME_SRC)/common/crypto/pkix-verify.cpp \
285 $(VBOX_PATH_RUNTIME_SRC)/common/crypto/pkix-util.cpp \
286 $(VBOX_PATH_RUNTIME_SRC)/common/crypto/rsa-asn1-decoder.cpp \
287 $(VBOX_PATH_RUNTIME_SRC)/common/crypto/rsa-core.cpp \
288 $(VBOX_PATH_RUNTIME_SRC)/common/crypto/rsa-init.cpp \
289 $(VBOX_PATH_RUNTIME_SRC)/common/crypto/rsa-sanity.cpp \
290 $(VBOX_PATH_RUNTIME_SRC)/common/crypto/spc-asn1-decoder.cpp \
291 $(VBOX_PATH_RUNTIME_SRC)/common/crypto/spc-core.cpp \
292 $(VBOX_PATH_RUNTIME_SRC)/common/crypto/spc-init.cpp \
293 $(VBOX_PATH_RUNTIME_SRC)/common/crypto/spc-sanity.cpp \
294 $(VBOX_PATH_RUNTIME_SRC)/common/crypto/x509-asn1-decoder.cpp \
295 $(VBOX_PATH_RUNTIME_SRC)/common/crypto/x509-certpaths.cpp \
296 $(VBOX_PATH_RUNTIME_SRC)/common/crypto/x509-core.cpp \
297 $(VBOX_PATH_RUNTIME_SRC)/common/crypto/x509-init.cpp \
298 $(VBOX_PATH_RUNTIME_SRC)/common/crypto/x509-sanity.cpp \
299 $(VBOX_PATH_RUNTIME_SRC)/common/crypto/x509-verify.cpp \
300 $(VBOX_PATH_RUNTIME_SRC)/common/crypto/store.cpp \
301 $(VBOX_PATH_RUNTIME_SRC)/common/crypto/store-inmem.cpp \
302 $(VBOX_PATH_RUNTIME_SRC)/common/crypto/taf-asn1-decoder.cpp \
303 $(VBOX_PATH_RUNTIME_SRC)/common/crypto/taf-core.cpp \
304 $(VBOX_PATH_RUNTIME_SRC)/common/crypto/taf-init.cpp \
305 $(VBOX_PATH_RUNTIME_SRC)/common/crypto/taf-sanity.cpp \
306 $(VBOX_PATH_RUNTIME_SRC)/common/crypto/tsp-asn1-decoder.cpp \
307 $(VBOX_PATH_RUNTIME_SRC)/common/crypto/tsp-core.cpp \
308 $(VBOX_PATH_RUNTIME_SRC)/common/crypto/tsp-init.cpp \
309 $(VBOX_PATH_RUNTIME_SRC)/common/crypto/tsp-sanity.cpp \
310 $(VBOX_PATH_RUNTIME_SRC)/common/checksum/alt-md2.cpp \
311 $(VBOX_PATH_RUNTIME_SRC)/common/checksum/alt-md5.cpp \
312 $(VBOX_PATH_RUNTIME_SRC)/common/checksum/alt-sha1.cpp \
313 $(VBOX_PATH_RUNTIME_SRC)/common/checksum/alt-sha256.cpp \
314 $(VBOX_PATH_RUNTIME_SRC)/common/checksum/alt-sha512.cpp \
315 $(VBOX_PATH_RUNTIME_SRC)/common/checksum/md2str.cpp \
316 $(VBOX_PATH_RUNTIME_SRC)/common/checksum/md5str.cpp \
317 $(VBOX_PATH_RUNTIME_SRC)/common/checksum/sha1str.cpp \
318 $(VBOX_PATH_RUNTIME_SRC)/common/checksum/sha256str.cpp \
319 $(VBOX_PATH_RUNTIME_SRC)/common/checksum/sha512str.cpp \
320 $(VBOX_PATH_RUNTIME_SRC)/common/err/errinfo.cpp \
321 $(VBOX_PATH_RUNTIME_SRC)/common/path/RTPathChangeToUnixSlashes.cpp \
322 $(VBOX_PATH_RUNTIME_SRC)/common/path/RTPathExt.cpp \
323 $(VBOX_PATH_RUNTIME_SRC)/common/string/RTUtf16PrintHexBytes.cpp \
324 $(VBOX_PATH_RUNTIME_SRC)/common/string/RTUtf16ICmpAscii.cpp \
325 $(VBOX_PATH_RUNTIME_SRC)/common/string/RTUtf16NICmpAscii.cpp \
326 $(VBOX_PATH_RUNTIME_SRC)/common/string/RTUtf16CatAscii.cpp \
327 $(VBOX_PATH_RUNTIME_SRC)/common/string/RTUtf16CopyAscii.cpp \
328 $(VBOX_PATH_RUNTIME_SRC)/common/string/RTUtf16End.cpp \
329 $(VBOX_PATH_RUNTIME_SRC)/common/string/strstrip.cpp \
330 \
331 $(VBOX_PATH_RUNTIME_SRC)/common/err/errmsg.cpp \
332 $(VBOX_PATH_RUNTIME_SRC)/common/math/bignum.cpp \
333 $(VBOX_PATH_RUNTIME_SRC)/common/math/bignum-amd64-x86.asm \
334 $(VBOX_PATH_RUNTIME_SRC)/common/misc/RTAssertMsg1Weak.cpp \
335 $(VBOX_PATH_RUNTIME_SRC)/common/misc/RTAssertMsg2.cpp \
336 $(VBOX_PATH_RUNTIME_SRC)/common/misc/RTAssertMsg2Weak.cpp \
337 $(VBOX_PATH_RUNTIME_SRC)/common/misc/RTAssertMsg2WeakV.cpp \
338 $(VBOX_PATH_RUNTIME_SRC)/common/misc/zero.asm \
339 $(VBOX_PATH_RUNTIME_SRC)/common/path/RTPathAbsEx.cpp \
340 $(VBOX_PATH_RUNTIME_SRC)/common/path/RTPathFilename.cpp \
341 $(VBOX_PATH_RUNTIME_SRC)/common/path/RTPathParse.cpp \
342 $(VBOX_PATH_RUNTIME_SRC)/common/path/RTPathParsedReassemble.cpp \
343 $(VBOX_PATH_RUNTIME_SRC)/common/string/memchr.asm \
344 $(VBOX_PATH_RUNTIME_SRC)/common/string/memcmp.asm \
345 $(VBOX_PATH_RUNTIME_SRC)/common/string/memcpy.asm \
346 $(VBOX_PATH_RUNTIME_SRC)/common/string/memmove.asm \
347 $(VBOX_PATH_RUNTIME_SRC)/common/string/mempcpy.asm \
348 $(VBOX_PATH_RUNTIME_SRC)/common/string/memset.asm \
349 $(VBOX_PATH_RUNTIME_SRC)/common/string/strversion.cpp \
350 $(VBOX_PATH_RUNTIME_SRC)/common/string/RTStrPrintHexBytes.cpp \
351 $(VBOX_PATH_RUNTIME_SRC)/common/string/RTStrCat.cpp \
352 $(VBOX_PATH_RUNTIME_SRC)/common/string/RTStrCmp.cpp \
353 $(VBOX_PATH_RUNTIME_SRC)/common/string/RTStrCopy.cpp \
354 $(VBOX_PATH_RUNTIME_SRC)/common/string/RTStrICmpAscii.cpp \
355 $(VBOX_PATH_RUNTIME_SRC)/common/string/RTStrNCmp.cpp \
356 $(VBOX_PATH_RUNTIME_SRC)/common/string/RTStrNLen.cpp \
357 $(VBOX_PATH_RUNTIME_SRC)/common/string/RTUtf16Copy.cpp \
358 $(VBOX_PATH_RUNTIME_SRC)/common/string/RTUtf16NLenEx.cpp \
359 $(VBOX_PATH_RUNTIME_SRC)/common/string/strchr.asm \
360 $(VBOX_PATH_RUNTIME_SRC)/common/string/strcmp.asm \
361 $(VBOX_PATH_RUNTIME_SRC)/common/string/strcpy.asm \
362 $(VBOX_PATH_RUNTIME_SRC)/common/string/strformat.cpp \
363 $(VBOX_PATH_RUNTIME_SRC)/common/string/strformatrt.cpp \
364 $(VBOX_PATH_RUNTIME_SRC)/common/string/strformattype.cpp \
365 $(VBOX_PATH_RUNTIME_SRC)/common/string/strformatnum.cpp \
366 $(VBOX_PATH_RUNTIME_SRC)/common/string/stringalloc.cpp \
367 $(VBOX_PATH_RUNTIME_SRC)/common/string/strlen.asm \
368 $(VBOX_PATH_RUNTIME_SRC)/common/string/strncmp.asm \
369 $(VBOX_PATH_RUNTIME_SRC)/common/string/strncpy.asm \
370 $(VBOX_PATH_RUNTIME_SRC)/common/string/strprintf.cpp \
371 $(VBOX_PATH_RUNTIME_SRC)/common/string/strtonum.cpp \
372 $(VBOX_PATH_RUNTIME_SRC)/common/string/utf-16.cpp \
373 $(VBOX_PATH_RUNTIME_SRC)/common/string/utf-8.cpp \
374 $(VBOX_PATH_RUNTIME_SRC)/common/string/utf-8-case.cpp \
375 $(VBOX_PATH_RUNTIME_SRC)/common/string/unidata-upper.cpp \
376 $(VBOX_PATH_RUNTIME_SRC)/common/string/unidata-lower.cpp \
377 $(VBOX_PATH_RUNTIME_SRC)/common/time/time.cpp \
378 $(VBOX_PATH_RUNTIME_SRC)/generic/RTAssertShouldPanic-generic.cpp \
379 $(VBOX_PATH_RUNTIME_SRC)/generic/RTPathGetCurrentDrive-generic.cpp \
380 $(VBOX_PATH_RUNTIME_SRC)/generic/RTPathGetCurrentOnDrive-generic.cpp \
381 $(VBOX_PATH_RUNTIME_SRC)/generic/rtStrFormatKernelAddress-generic.cpp \
382 $(VBOX_PATH_RUNTIME_SRC)/generic/memsafer-generic.cpp \
383 $(VBOX_PATH_RUNTIME_SRC)/generic/uuid-generic.cpp \
384 \
385 ../../Disassembler/DisasmCore.cpp \
386 ../../Disassembler/DisasmTables.cpp \
387 ../../Disassembler/DisasmTablesX64.cpp \
388 ../../Disassembler/DisasmReg.cpp
389
390 SUPR3HardenedStatic_SOURCES.amd64 += \
391 $(VBOX_PATH_RUNTIME_SRC)/common/math/RTUInt128MulByU64.asm \
392 $(VBOX_PATH_RUNTIME_SRC)/win/amd64/ASMGetCS.asm \
393 $(VBOX_PATH_RUNTIME_SRC)/win/amd64/ASMGetSS.asm
394
395 SUPR3HardenedStatic_SOURCES.win += \
396 win/SUPR3HardenedNoCrt-win.cpp \
397 $(VBOX_PATH_RUNTIME_SRC)/nt/RTErrConvertFromNtStatus.cpp \
398 $(VBOX_PATH_RUNTIME_SRC)/nt/RTNtPathFindPossible8dot3Name.cpp \
399 $(VBOX_PATH_RUNTIME_SRC)/nt/RTNtPathExpand8dot3Path.cpp \
400 $(VBOX_PATH_RUNTIME_SRC)/nt/RTNtPathExpand8dot3PathA.cpp \
401 $(VBOX_PATH_RUNTIME_SRC)/r3/nt/pathint-nt.cpp \
402 $(VBOX_PATH_RUNTIME_SRC)/win/RTErrConvertFromWin32.cpp \
403 $(VBOX_PATH_RUNTIME_SRC)/win/errmsgwin.cpp
404
405 # Add necessary compiler specific files from libcmt.lib and the lib dir.
406 ifeq ($(KBUILD_TARGET),win)
407 SUPR3HardenedStatic_VBOX_LIBC_OBJS = chkstk.obj
408 ifeq ($(KBUILD_TARGET_ARCH),x86)
409 SUPR3HardenedStatic_VBOX_LIBC_OBJS += \
410 alloca16.obj \
411 ulldiv.obj \
412 ulldvrm.obj \
413 ullrem.obj \
414 ullshr.obj \
415 lldiv.obj \
416 lldvrm.obj \
417 llmul.obj \
418 llrem.obj \
419 llshl.obj \
420 llshr.obj \
421 rotl.obj \
422 rotr.obj
423 endif
424 SUPR3HardenedStatic_SOURCES.win += $(addprefix $(SUPR3HardenedStatic_0_OUTDIR)/,$(SUPR3HardenedStatic_VBOX_LIBC_OBJS))
425
426 $(addprefix $$(SUPR3HardenedStatic_0_OUTDIR)/,$(SUPR3HardenedStatic_VBOX_LIBC_OBJS)): \
427 $$(PATH_TOOL_$(TEMPLATE_VBOXR3EXE_TOOL.win.$(KBUILD_TARGET_ARCH))_LIB)/libcmt.lib | $$(dir $$@)
428 $(TOOL_$(TEMPLATE_VBOXR3HARDENEDEXE_TOOL.win.$(KBUILD_TARGET_ARCH))_AR) "$<" \
429 /EXTRACT:`$(TOOL_$(TEMPLATE_VBOXR3HARDENEDEXE_TOOL.win.$(KBUILD_TARGET_ARCH))_AR) "$<" /LIST \
430 | $(SED_EXT) -n -e '/[\\/:]$(notdir $@)/p'` \
431 "/OUT:$@"
432 endif
433endif
434
435# Things specific to the posix crowd.
436if1of ($(KBUILD_TARGET), linux darwin solaris)
437 SUPR3HardenedStatic_DEFS += \
438 IN_DIS \
439 IN_DIS_STATIC \
440 DIS_CORE_ONLY \
441 LOG_DISABLED
442 SUPR3HardenedStatic_DEFS.linux += \
443 SUP_HARDENED_WITH_DLMOPEN
444 SUPR3HardenedStatic_DEFS.solaris += \
445 SUP_HARDENED_WITH_DLMOPEN
446
447 SUPR3HardenedStatic_INCS += $(VBOX_PATH_RUNTIME_SRC)/include
448
449 SUPR3HardenedStatic_SOURCES += \
450 posix/SUPR3HardenedMain-posix.cpp \
451 posix/SUPR3HardenedMainA-posix.asm \
452 \
453 $(VBOX_PATH_RUNTIME_SRC)/common/misc/RTAssertMsg1Weak.cpp \
454 $(VBOX_PATH_RUNTIME_SRC)/common/misc/RTAssertMsg2.cpp \
455 $(VBOX_PATH_RUNTIME_SRC)/common/misc/RTAssertMsg2Weak.cpp \
456 $(VBOX_PATH_RUNTIME_SRC)/common/misc/RTAssertMsg2WeakV.cpp \
457 $(VBOX_PATH_RUNTIME_SRC)/generic/RTAssertShouldPanic-generic.cpp \
458 \
459 ../../Disassembler/DisasmCore.cpp \
460 ../../Disassembler/DisasmTables.cpp \
461 ../../Disassembler/DisasmTablesX64.cpp \
462 ../../Disassembler/DisasmReg.cpp
463endif
464
465SUPR3HardenedMain.cpp_DEFS = VBOX_SVN_REV=$(VBOX_SVN_REV)
466
467
468#
469# VBoxSupLib - Windows DLL for catching thread creation and termination.
470#
471VBoxSupLib_TEMPLATE = $(if-expr "$(KBUILD_TARGET)" == "win" && defined(VBOX_WITH_HARDENING),VBOXR3HARDENEDLIB,VBOXR3)
472VBoxSupLib_SDKS.win = VBOX_NTDLL
473VBoxSupLib_LDFLAGS.win.amd64 = -Entry:DllMainEntrypoint
474VBoxSupLib_LDFLAGS.win.x86 = -Entry:DllMainEntrypoint
475VBoxSupLib_DEFS = \
476 $(if $(VBOX_WITHOUT_DEBUGGER_CHECKS),VBOX_WITHOUT_DEBUGGER_CHECKS,)
477VBoxSupLib_SOURCES = \
478 $(KBUILD_TARGET)/VBoxSupLib-$(KBUILD_TARGET).cpp
479VBoxSupLib_SOURCES.win = \
480 win/VBoxSupLib.rc
481VBoxSupLib_LIBS.win.x86 = \
482 $(PATH_TOOL_$(TEMPLATE_VBOXR3STATIC_TOOL.win.x86)_LIB)/libcmt.lib # for __chkstk
483VBoxSupLib_LIBS.win.amd64 = \
484 $(PATH_TOOL_$(TEMPLATE_VBOXR3STATIC_TOOL.win.amd64)_LIB)/libcmt.lib # for __chkstk
485
486
487#
488# VBoxSupSvc - The system wide service/daemon.
489#
490VBoxSupSvc_TEMPLATE = VBOXR3EXE
491VBoxSupSvc_SOURCES = \
492 SUPSvc.cpp \
493 SUPSvcGlobal.cpp \
494 $(KBUILD_TARGET)/SUPSvc-$(KBUILD_TARGET).cpp
495if1of ($(KBUILD_TARGET), win)
496 VBoxSupSvc_SOURCES += \
497 SUPSvcGrant.cpp
498endif
499ifn1of ($(KBUILD_TARGET), win)
500 VBoxSupSvc_SOURCES += \
501 SUPSvcMain-posix.cpp
502endif
503VBoxSupSvc_LIBS = \
504 $(LIB_RUNTIME)
505
506
507#
508# SUPR0 - The Ring-0 Import library.
509#
510SUPR0_TEMPLATE = VBoxR0
511if1of ($(VBOX_LDR_FMT), pe lx)
512 SUPR0_SOURCES = $(SUPR0_0_OUTDIR)/SUPR0.def
513 SUPR0_CLEAN = $(SUPR0_0_OUTDIR)/SUPR0.def
514$$(SUPR0_0_OUTDIR)/SUPR0.def: \
515 $(PATH_SUB_CURRENT)/SUPDrv.cpp \
516 $(PATH_SUB_CURRENT)/SUPR0-def-$(VBOX_LDR_FMT).sed \
517 | $$(dir $$@)
518 $(SED) \
519 -f $(dir $<)/SUPR0-def-$(VBOX_LDR_FMT).sed \
520 --output $@ \
521 $<
522 # Experiment: Let's see how blunt the ones messing our NULL_THUNK_DATA entries on W10 are.
523 ifeq ($(KBUILD_TARGET),win)
524 ifdef KLIBTWEAKER_EXT
525 SUPR0_POST_CMDS = $(KLIBTWEAKER_EXT) --clear-timestamps --fill-null_thunk_data $(out)
526 endif
527 endif
528endif
529
530
531#
532# SUPRC - The raw-mode context library.
533#
534SUPRC_TEMPLATE := VBoxRc
535SUPRC_DEFS := IN_SUP_RC IN_RT_RC IN_VMM_RC
536SUPRC_SOURCES := SUPLibAll.cpp
537
538
539#
540# SUPR0IdcClient - The Ring-0 IDC client driver library.
541#
542SUPR0IdcClient_TEMPLATE = VBoxR0DrvLib
543SUPR0IdcClient_DEFS = IN_RT_R0 IN_SUP_R0 IN_SUP_STATIC
544SUPR0IdcClient_SDKS.win = ReorderCompilerIncs $(VBOX_WINDDK) $(VBOX_WINPSDK)INCS
545SUPR0IdcClient_SOURCES.$(KBUILD_TARGET) = \
546 $(KBUILD_TARGET)/SUPR0IdcClient-$(KBUILD_TARGET).c
547SUPR0IdcClient_SOURCES = \
548 SUPR0IdcClient.c \
549 SUPR0IdcClientComponent.c \
550 SUPR0IdcClientStubs.c
551
552
553
554if !defined(VBOX_ONLY_DOCS) \
555 && !defined(VBOX_ONLY_EXTPACKS) \
556 && !defined(VBOX_ONLY_VALIDATIONKIT)
557
558ifeq ($(KBUILD_TARGET),os2)
559
560#
561# VBoxDrv.sys - The OS/2 driver.
562#
563VBoxDrv_TEMPLATE = VBOXR0DRV
564VBoxDrv_DEFS = IN_RT_R0 IN_SUP_R0
565VBoxDrv_INCS := $(PATH_SUB_CURRENT)
566#VBoxDrv_LDFLAGS = -s -t -v
567VBoxDrv_SOURCES = \
568 os2/SUPDrvA-os2.asm \
569 os2/SUPDrv-os2.def
570VBoxDrv_LIBS = \
571 $(VBoxDrvLib_1_TARGET) \
572 $(PATH_STAGE_LIB)/RuntimeR0Drv$(VBOX_SUFF_LIB) \
573 $(VBOX_GCC_LIBGCC) \
574 end
575
576# temp hack to ensure that SUPDrvA-os2.asm is first in the link.
577LIBRARIES += VBoxDrvLib
578VBoxDrvLib_TEMPLATE = VBOXR0DRV
579VBoxDrvLib_INSTTYPE = none
580VBoxDrvLib_DEFS = IN_RT_R0 IN_SUP_R0
581VBoxDrvLib_INCS := \
582 . \
583 $(PATH_ROOT)/src/VBox/Runtime/include
584VBoxDrvLib_SOURCES = \
585 os2/SUPDrv-os2.cpp \
586 SUPDrv.cpp \
587 SUPDrvGip.cpp \
588 SUPDrvSem.cpp \
589 SUPLibAll.cpp
590
591endif # os2
592
593
594#
595# New VBoxDrv target. TODO: Convert all the above to use this!
596#
597if1of ($(KBUILD_TARGET), darwin freebsd solaris win)
598 ifdef VBOX_WITH_VBOXDRV
599 SYSMODS += VBoxDrv
600 endif
601 VBoxDrv_TEMPLATE = VBOXR0DRV
602 VBoxDrv_NAME.freebsd = vboxdrv
603 VBoxDrv_NAME.solaris = vboxdrv
604 ifdef VBOX_SIGNING_MODE
605 VBoxDrv_INSTTYPE.win = none
606 VBoxDrv_DEBUG_INSTTYPE.win = both
607 endif
608 VBoxDrv_INST.darwin = $(INST_VBOXDRV)Contents/MacOS/
609 VBoxDrv_DEBUG_INST.darwin= $(patsubst %/,%,$(INST_VBOXDRV))
610 VBoxDrv_SDKS.win = ReorderCompilerIncs $(VBOX_WINDDK) $(VBOX_WINPSDK)INCS
611
612 VBoxDrv_DEFS := IN_RT_R0 IN_SUP_R0 SUPDRV_WITH_RELEASE_LOGGER VBOX_SVN_REV=$(VBOX_SVN_REV)
613 ifdef VBOX_WITH_DTRACE_R0DRV
614 VBoxDrv_DEFS += VBOX_WITH_DTRACE VBOX_WITH_DTRACE_R0DRV
615 endif
616 ifdef VBOX_WITHOUT_DEBUGGER_CHECKS
617 VBoxDrv_DEFS += VBOX_WITHOUT_DEBUGGER_CHECKS
618 endif
619 ifdef VBOX_PERMIT_VISUAL_STUDIO_PROFILING
620 VBoxDrv_DEFS += VBOX_PERMIT_VISUAL_STUDIO_PROFILING
621 endif
622 VBoxDrv_DEFS += VBOX_PERMIT_MORE VBOX_PERMIT_EVEN_MORE
623 #VBoxDrv_DEFS.debug += DEBUG_DARWIN_GIP
624 VBoxDrv_DEFS.darwin := VBOX_WITH_HOST_VMX
625 ifdef VBOX_WITH_RAW_MODE
626 VBoxDrv_DEFS.darwin += VBOX_WITH_RAW_MODE
627 endif
628 ifdef VBOX_WITH_DARWIN_R0_DARWIN_IMAGE_VERIFICATION
629 VBoxDrv_DEFS.darwin += VBOX_WITH_DARWIN_R0_DARWIN_IMAGE_VERIFICATION
630 endif
631 ifdef VBOX_WITH_NETFLT
632 VBoxDrv_DEFS.solaris += VBOX_WITH_NETFLT
633 endif
634 ifdef VBOX_WITH_NATIVE_SOLARIS_LOADING
635 VBoxDrv_DEFS.solaris += VBOX_WITH_NATIVE_SOLARIS_LOADING
636 endif
637 ifdef VBOX_WITHOUT_NATIVE_R0_LOADER
638 VBoxDrv_DEFS.win += VBOX_WITHOUT_NATIVE_R0_LOADER
639 endif
640 ifdef VBOX_WITH_VISTA_NO_SP
641 VBoxDrv_DEFS.win += VBOX_WITH_VISTA_NO_SP
642 endif
643 ifdef VBOX_WITH_HARDENING
644 VBoxDrv_ASDEFS += VBOX_WITH_HARDENING
645 endif
646 if ($(VBOX_VERSION_BUILD) % 2) == 1
647 VBoxDrv_DEFS += VBOX_WITH_EFLAGS_AC_SET_IN_VBOXDRV IPRT_WITH_EFLAGS_AC_PRESERVING
648 endif
649
650 VBoxDrv_INCS = . $(VBoxDrv_0_OUTDIR)
651 VBoxDrv_INCS.darwin = ./darwin
652
653 VBoxDrv_LIBS = $(PATH_STAGE_LIB)/RuntimeR0Drv$(VBOX_SUFF_LIB)
654 VBoxDrv_LIBS.win = \
655 $(PATH_STAGE_LIB)/RuntimeR0Drv$(VBOX_SUFF_LIB) \
656 $(PATH_SDK_$(VBOX_WINDDK)_LIB)/ntoskrnl.lib \
657 $(PATH_SDK_$(VBOX_WINDDK)_LIB)/hal.lib
658
659 #VBoxDrv_LDFLAGS.darwin = -Wl,-sectcreate,__TEXT,__info_plist,$(VBoxDrv.kext_0_OUTDIR)/Info.plist
660 #VBoxDrv_LDFLAGS.darwin = -v -Wl,-whyload -Wl,-v -Wl,-whatsloaded
661 VBoxDrv_LDFLAGS.solaris += -N misc/ctf
662 ifdef VBOX_WITH_NATIVE_DTRACE
663 VBoxDrv_LDFLAGS.solaris += -N drv/dtrace
664 endif
665 VBoxDrv_LDFLAGS.win.x86 = -Entry:DriverEntry@8
666 VBoxDrv_LDFLAGS.win.amd64= -Entry:DriverEntry
667
668 VBoxDrv_SOURCES.darwin = \
669 darwin/SUPDrv-darwin.cpp
670 ifdef VBOX_WITH_DARWIN_R0_DARWIN_IMAGE_VERIFICATION
671 VBoxDrv_SOURCES.darwin += \
672 $(VBOX_SUP_WIN_CERTS_FILE)
673 endif
674 VBoxDrv_SOURCES.solaris = \
675 solaris/SUPDrv-solaris.c
676 VBoxDrv_SOURCES.win = \
677 win/SUPDrv-win.cpp \
678 win/SUPDrvA-win.asm \
679 win/VBoxDrv.rc
680 ifdef VBOX_WITH_HARDENING
681 VBoxDrv_SOURCES.win += \
682 win/SUPHardenedVerifyImage-win.cpp \
683 win/SUPHardenedVerifyProcess-win.cpp \
684 $(VBOX_SUP_WIN_CERTS_FILE)
685 endif
686 VBoxDrv_SOURCES = \
687 SUPDrv.d \
688 SUPDrv.cpp \
689 SUPDrvGip.cpp \
690 SUPDrvSem.cpp \
691 SUPDrvTracer.cpp \
692 SUPLibAll.cpp
693 ifdef VBOX_WITH_NATIVE_DTRACE
694 VBoxDrv_SOURCES += \
695 SUPDrv-dtrace.cpp
696 SUPDrv-dtrace.cpp_DEFS.darwin += VBOX_PATH_MACOSX_DTRACE_H=\"$(VBOX_PATH_MACOSX_SDK)/usr/include/sys/dtrace.h\"
697 endif
698 ifn1of ($(KBUILD_TARGET), linux freebsd)
699 VBoxDrv_SOURCES += \
700 SUPDrvTracerA.asm
701 endif
702
703 linux/SUPDrv-linux.c_DEPS = $(VBOX_SVN_REV_HEADER)
704
705endif
706
707
708
709if1of ($(KBUILD_TARGET), darwin)
710 # Files necessary to make a darwin kernel extension bundle.
711 INSTALLS.darwin += VBoxDrv.kext
712 VBoxDrv.kext_INST = $(INST_VBOXDRV)Contents/
713 VBoxDrv.kext_SOURCES = $(VBoxDrv.kext_0_OUTDIR)/Contents/Info.plist
714 VBoxDrv.kext_CLEAN = $(VBoxDrv.kext_0_OUTDIR)/Contents/Info.plist
715 VBoxDrv.kext_BLDDIRS = $(VBoxDrv.kext_0_OUTDIR)/Contents/
716
717 $$(VBoxDrv.kext_0_OUTDIR)/Contents/Info.plist: \
718 $(PATH_SUB_CURRENT)/darwin/Info.plist \
719 $(VBOX_VERSION_MK) | $$(dir $$@)
720 $(call MSG_GENERATE,VBoxDrv,$@,$<)
721 $(QUIET)$(RM) -f $@
722 $(QUIET)$(SED) \
723 -e 's/@VBOX_VERSION_STRING@/$(if !defined(VBOX_MAVERICS_CODE_SIGNING_HACK),$(VBOX_VERSION_STRING),4.2.51)/g' \
724 -e 's/@VBOX_VERSION_MAJOR@/$(if !defined(VBOX_MAVERICS_CODE_SIGNING_HACK),$(VBOX_VERSION_MAJOR),4)/g' \
725 -e 's/@VBOX_VERSION_MINOR@/$(if !defined(VBOX_MAVERICS_CODE_SIGNING_HACK),$(VBOX_VERSION_MINOR),2)/g' \
726 -e 's/@VBOX_VERSION_BUILD@/$(if !defined(VBOX_MAVERICS_CODE_SIGNING_HACK),$(VBOX_VERSION_BUILD),51)/g' \
727 -e 's/@VBOX_VENDOR@/$(VBOX_VENDOR)/g' \
728 -e 's/@VBOX_PRODUCT@/$(VBOX_PRODUCT)/g' \
729 -e 's/@VBOX_C_YEAR@/$(VBOX_C_YEAR)/g' \
730 --output $@ \
731 $<
732
733 $(evalcall2 VBOX_TEST_SIGN_KEXT,VBoxDrv)
734endif
735
736
737if1of ($(KBUILD_TARGET), darwin solaris)
738 # Common manual loader script.
739 INSTALLS += SUPDrvScripts
740 SUPDrvScripts_INST = $(INST_DIST)
741 SUPDrvScripts_EXEC_SOURCES = \
742 $(KBUILD_TARGET)/load.sh
743endif
744
745
746if1of ($(KBUILD_TARGET), linux freebsd)
747 if1of ($(KBUILD_TARGET_ARCH), $(VBOX_SUPPORTED_HOST_ARCHS))
748 #
749 # Targets for installing the linux sources.
750 #
751 vboxdrv-src_INST = bin/src/vboxdrv/
752 vboxdrv-src_SOURCES = \
753 $(subst $(DQUOTE),,$(FILES_VBOXDRV_NOBIN)) \
754 $(vboxdrv-src_0_OUTDIR)/Makefile
755 vboxdrv-src_EXEC_SOURCES = \
756 $(subst $(DQUOTE),,$(FILES_VBOXDRV_BIN))
757 vboxdrv-src_CLEAN = \
758 $(vboxdrv-src_0_OUTDIR)/Makefile \
759 $(PATH_TARGET)/vboxdrv-src-1.dep \
760
761 # Scripts needed for building the kernel modules
762 includedep $(PATH_TARGET)/vboxdrv-src-1.dep
763 $$(vboxdrv-src_0_OUTDIR)/Makefile: \
764 $(PATH_SUB_CURRENT)/$(KBUILD_TARGET)/Makefile \
765 $$(if $$(eq $$(Support/$(KBUILD_TARGET)/Makefile_VBOX_HARDENED),$$(VBOX_WITH_HARDENING)),,FORCE) \
766 | $$(dir $$@)
767 $(call MSG_TOOL,Creating,,$@)
768 $(QUIET)$(SED) -e "" \
769 $(if-expr !defined(VBOX_WITH_HARDENING) ,-e "s;VBOX_WITH_HARDENING;;g",) \
770 $(if-expr ($(VBOX_VERSION_BUILD) % 2) == 0 \
771 , -e "s;VBOX_WITH_EFLAGS_AC_SET_IN_VBOXDRV;;g" -e "s;IPRT_WITH_EFLAGS_AC_PRESERVING;;g",) \
772 --output $@ $<
773 %$(QUIET2)$(APPEND) -t '$(PATH_TARGET)/vboxdrv-src-1.dep' \
774 'Support/$(KBUILD_TARGET)/Makefile_VBOX_HARDENED=$(VBOX_WITH_HARDENING)'
775
776 #
777 # Build test for the linux host kernel modules.
778 #
779 $(evalcall2 VBOX_LINUX_KMOD_TEST_BUILD_RULE_FN,vboxdrv-src,,save_symvers)
780 endif # supported host arch
781endif # linux freebsd
782
783
784ifeq ($(KBUILD_TARGET), win)
785 INSTALLS.win += VBoxDrv-inf
786 VBoxDrv-inf_TEMPLATE = VBoxR0DrvInfCat
787 VBoxDrv-inf_SOURCES = \
788 $(PATH_TARGET)/VBoxDrvCat.dir/VBoxDrv.inf
789 VBoxDrv-inf_CLEAN = $(VBoxDrv-inf_SOURCES)
790 VBoxDrv-inf_BLDDIRS = $(PATH_TARGET)/VBoxDrvCat.dir
791
792 $(PATH_TARGET)/VBoxDrvCat.dir/VBoxDrv.inf: $(PATH_SUB_CURRENT)/win/VBoxDrv.inf $(MAKEFILE_CURRENT) | $$(dir $$@)
793 $(call MSG_GENERATE,VBoxDrv-inf,$@,$<)
794 $(call VBOX_EDIT_INF_FN,$<,$@)
795
796 ifdef VBOX_SIGNING_MODE
797 VBoxDrv-inf_SOURCES += \
798 $(PATH_TARGET)/VBoxDrvCat.dir/VBoxDrv.sys \
799 $(PATH_TARGET)/VBoxDrvCat.dir/VBoxDrv.cat \
800 $(PATH_TARGET)/VBoxDrvCat.dir/VBoxDrv.cat=>VBoxDrv-PreW10.cat
801
802 $(PATH_TARGET)/VBoxDrvCat.dir/VBoxDrv.sys: $$(VBoxDrv_1_TARGET) | $$(dir $$@)
803 $(INSTALL) -m 644 $< $(@D)
804
805 $(PATH_TARGET)/VBoxDrvCat.dir/VBoxDrv.cat: \
806 $(PATH_TARGET)/VBoxDrvCat.dir/VBoxDrv.inf \
807 $(PATH_TARGET)/VBoxDrvCat.dir/VBoxDrv.sys
808 $(call MSG_TOOL,Inf2Cat,VBoxDrv-inf,$@,$<)
809 $(call VBOX_MAKE_CAT_FN, $(@D),$@)
810 endif # signing
811endif # win
812
813
814endif # !VBOX_ONLY_DOCS && !VBOX_ONLY_EXTPACKS && !VBOX_ONLY_VALIDATIONKIT
815include $(FILE_KBUILD_SUB_FOOTER)
816
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette