VirtualBox

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

Last change on this file since 52600 was 52600, checked in by vboxsync, 11 years ago

IPRT: Added support for microsoft timestamp counter signatures. This required making the PKCS #7 code accept some of the CMS (RFC-5652) stuff.

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

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