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