VirtualBox

source: vbox/trunk/src/VBox/VMM/testcase/Makefile.kmk@ 74524

Last change on this file since 74524 was 74524, checked in by vboxsync, 6 years ago

VMM/testcase: Added simple native NEM engine benchmark, currently only supporting windows. bugref:9044

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 21.6 KB
Line 
1# $Id: Makefile.kmk 74524 2018-09-28 14:00:23Z vboxsync $
2## @file
3# Sub-Makefile for the VMM testcases.
4#
5
6#
7# Copyright (C) 2006-2017 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
18SUB_DEPTH = ../../../..
19include $(KBUILD_PATH)/subheader.kmk
20
21#
22# Include sub-makefiles.
23#
24if 0 # Not ready for general consumption yet.
25 include $(PATH_SUB_CURRENT)/Instructions/Makefile.kmk
26endif
27
28#
29# Target lists.
30#
31PROGRAMS += tstVMStructSize tstAsmStructs
32ifdef VBOX_WITH_RAW_MODE
33 PROGRAMS += tstVMStructRC tstAsmStructsRC
34endif
35if !defined(VBOX_ONLY_EXTPACKS) \
36 && ( defined(VBOX_WITH_DTRACE_R3) \
37 || defined(VBOX_WITH_DTRACE_R0) \
38 || defined(VBOX_WITH_DTRACE_RC))
39 PROGRAMS += tstVMStructDTrace
40 INSTALLS += VMMLibDTraceStructTest
41endif
42ifndef VBOX_ONLY_EXTPACKS_USE_IMPLIBS
43 if defined(VBOX_WITH_HARDENING) && "$(KBUILD_TARGET)" == "win"
44 PROGRAMS += tstGlobalConfigHardened
45 DLL += tstGlobalConfig
46 else
47 PROGRAMS += tstGlobalConfig
48 endif
49
50 ifdef VBOX_WITH_RAW_MODE
51 if defined(VBOX_WITH_HARDENING) && "$(KBUILD_TARGET)" == "win"
52 PROGRAMS += tstVMMHardened
53 DLLS += tstVMM
54 else
55 PROGRAMS += tstVMM tstVMM-HM
56 endif
57 ifneq ($(KBUILD_TARGET),win)
58 PROGRAMS += tstVMMFork
59 endif
60 endif
61 ifdef VBOX_WITH_TESTCASES
62 if defined(VBOX_WITH_HARDENING) && "$(KBUILD_TARGET)" == "win"
63 PROGRAMS += tstCFGMHardened tstSSMHardened tstVMREQHardened tstMMHyperHeapHardened tstAnimateHardened
64 DLLS += tstCFGM tstSSM tstVMREQ tstMMHyperHeap tstAnimate
65 else
66 PROGRAMS += tstCFGM tstSSM tstVMREQ tstMMHyperHeap tstAnimate
67 endif
68 PROGRAMS += \
69 tstCompressionBenchmark \
70 tstIEMCheckMc \
71 tstVMMR0CallHost-1 \
72 tstVMMR0CallHost-2 \
73 tstX86-FpuSaveRestore
74 ifn1of ($(KBUILD_TARGET).$(KBUILD_TARGET_ARCH), solaris.x86 solaris.amd64 win.amd64 ) ## TODO: Fix the code.
75 PROGRAMS += tstX86-1
76 endif
77 ifdef VBOX_WITH_RAW_MODE
78 if defined(VBOX_WITH_HARDENING) && "$(KBUILD_TARGET)" == "win"
79 PROGRAMS += tstMicroHardened
80 DLLS += tstMicro
81 else
82 PROGRAMS += tstMicro
83 endif
84 SYSMODS += tstMicroRC
85 endif
86 ifdef VBOX_WITH_PDM_ASYNC_COMPLETION
87 if defined(VBOX_WITH_HARDENING) && "$(KBUILD_TARGET)" == "win"
88 PROGRAMS += tstPDMAsyncCompletionHardened tstPDMAsyncCompletionStressHardened
89 DLLS += tstPDMAsyncCompletion tstPDMAsyncCompletionStress
90 else
91 PROGRAMS += tstPDMAsyncCompletion tstPDMAsyncCompletionStress
92 endif
93 endif
94 endif # VBOX_WITH_TESTCASES
95endif # !VBOX_ONLY_EXTPACKS_USE_IMPLIBS
96
97# Where we put our temporary files (just for simplicity)
98VBOX_VMM_TESTCASE_OUT_DIR := $(PATH_TARGET)/VMM
99BLDDIRS += $(VBOX_VMM_TESTCASE_OUT_DIR)
100
101#
102# We setup two 'other' targets for executing the two structure & alignment
103# validation testcases. Perhaps a bit hackish, but extremely useful.
104#
105ifeq ($(KBUILD_TARGET),$(KBUILD_HOST))
106 ifeq ($(filter-out x86.x86 amd64.amd64 x86.amd64, $(KBUILD_TARGET_ARCH).$(KBUILD_HOST_ARCH)),)
107 OTHERS += \
108 $(VBOX_VMM_TESTCASE_OUT_DIR)/tstAsmStructs.run \
109 $(VBOX_VMM_TESTCASE_OUT_DIR)/tstVMStructSize.run
110 endif
111endif
112
113# The normal testing pass.
114TESTING += \
115 $(VBOX_VMM_TESTCASE_OUT_DIR)/tstAsmStructs.run \
116 $(VBOX_VMM_TESTCASE_OUT_DIR)/tstVMStructSize.run
117
118OTHER_CLEAN += \
119 $(VBOX_VMM_TESTCASE_OUT_DIR)/tstAsmStructs.run \
120 $(VBOX_VMM_TESTCASE_OUT_DIR)/tstVMStructSize.run \
121 $(VBOX_VMM_TESTCASE_OUT_DIR)/tstAsmStructsAsm.o \
122 $(VBOX_VMM_TESTCASE_OUT_DIR)/tstAsmStructsAsm.o.dep \
123 $(VBOX_VMM_TESTCASE_OUT_DIR)/tstAsmStructsAsm.mac \
124 $(VBOX_VMM_TESTCASE_OUT_DIR)/tstAsmStructsAsm.mac.o \
125 $(VBOX_VMM_TESTCASE_OUT_DIR)/tstAsmStructsAsm.mac.lst \
126 $(VBOX_VMM_TESTCASE_OUT_DIR)/tstAsmStructsRC.h \
127 $(VBOX_VMM_TESTCASE_OUT_DIR)/tstAsmStructsHC.h \
128 $(VBOX_VMM_TESTCASE_OUT_DIR)/tstVMStructRC.h
129
130#
131# Globals
132#
133VBOX_PATH_VMM_SRC = $(PATH_ROOT)/src/VBox/VMM
134
135#
136# Targets
137#
138ifdef VBOX_WITH_RAW_MODE
139 tstVMStructRC_TEMPLATE = VBoxRcExe
140 tstVMStructRC_DEFS = IN_VMM_RC IN_DIS IN_RT_RC VBOX_WITH_RAW_MODE $(VMM_COMMON_DEFS)
141 ifdef VBOX_WITH_R0_LOGGING
142 tstVMStructRC_DEFS += VBOX_WITH_R0_LOGGING
143 endif
144 ifdef VBOX_WITH_VMMR0_DISABLE_LAPIC_NMI
145 tstVMStructRC_DEFS += VBOX_WITH_VMMR0_DISABLE_LAPIC_NMI
146 endif
147 tstVMStructRC_SOURCES = tstVMStructRC.cpp
148 tstVMStructRC_INCS = \
149 $(VBOX_PATH_VMM_SRC)/include \
150 $(VBOX_PATH_VMM_SRC)/PATM
151endif
152
153tstVMStructSize_TEMPLATE= VBOXR3AUTOTST
154tstVMStructSize_DEFS = IN_VMM_R3 IN_DIS $(VMM_COMMON_DEFS)
155ifdef VBOX_WITH_RAW_MODE
156 tstVMStructSize_DEFS += VBOX_WITH_RAW_MODE
157endif
158tstVMStructSize_INCS = \
159 $(VBOX_PATH_VMM_SRC)/include \
160 $(VBOX_PATH_VMM_SRC)/PATM \
161 $(VBOX_VMM_TESTCASE_OUT_DIR)
162tstVMStructSize_SOURCES = tstVMStructSize.cpp
163ifdef VBOX_WITH_RAW_MODE
164 tstVMStructSize.cpp_DEPS= $(VBOX_VMM_TESTCASE_OUT_DIR)/tstVMStructRC.h
165endif
166ifdef VBOX_WITH_R0_LOGGING
167 tstVMStructSize_DEFS += VBOX_WITH_R0_LOGGING
168endif
169ifdef VBOX_WITH_VMMR0_DISABLE_LAPIC_NMI
170 tstVMStructSize_DEFS += VBOX_WITH_VMMR0_DISABLE_LAPIC_NMI
171endif
172
173tstAsmStructs_TEMPLATE = VBOXR3AUTOTST
174tstAsmStructs_DEFS = IN_VMM_R3 IN_DIS $(VMM_COMMON_DEFS)
175ifdef VBOX_WITH_RAW_MODE
176 tstAsmStructs_DEFS += VBOX_WITH_RAW_MODE
177endif
178ifdef VBOX_WITH_R0_LOGGING
179 tstAsmStructs_DEFS += VBOX_WITH_R0_LOGGING
180endif
181ifdef VBOX_WITH_VMMR0_DISABLE_LAPIC_NMI
182 tstAsmStructs_DEFS += VBOX_WITH_VMMR0_DISABLE_LAPIC_NMI
183endif
184tstAsmStructs_INCS = \
185 $(VBOX_PATH_VMM_SRC)/include \
186 $(VBOX_VMM_TESTCASE_OUT_DIR)
187tstAsmStructs_SOURCES = tstAsmStructs.cpp
188tstAsmStructs.cpp_DEPS = $(VBOX_VMM_TESTCASE_OUT_DIR)/tstAsmStructsHC.h
189
190ifdef VBOX_WITH_RAW_MODE
191 tstAsmStructsRC_TEMPLATE= VBoxRcExe
192 tstAsmStructsRC_DEFS = IN_VMM_RC IN_DIS IN_RT_RC VBOX_WITH_RAW_MODE $(VMM_COMMON_DEFS)
193 ifdef VBOX_WITH_R0_LOGGING
194 tstAsmStructsRC_DEFS += VBOX_WITH_R0_LOGGING
195 endif
196 ifdef VBOX_WITH_VMMR0_DISABLE_LAPIC_NMI
197 tstAsmStructsRC_DEFS += VBOX_WITH_VMMR0_DISABLE_LAPIC_NMI
198 endif
199 tstAsmStructsRC_INCS = \
200 $(VBOX_PATH_VMM_SRC)/include \
201 $(VBOX_VMM_TESTCASE_OUT_DIR)
202 tstAsmStructsRC_SOURCES = tstAsmStructs.cpp
203 tstAsmStructs.cpp_DEPS += $(VBOX_VMM_TESTCASE_OUT_DIR)/tstAsmStructsRC.h
204endif # VBOX_WITH_RAW_MODE
205
206
207#
208# Glboal config tool.
209#
210if defined(VBOX_WITH_HARDENING) && "$(KBUILD_TARGET)" == "win"
211 tstGlobalConfigHardened_TEMPLATE = VBoxR3HardenedTstExe
212 tstGlobalConfigHardened_NAME = tstGlobalConfig
213 tstGlobalConfigHardened_DEFS = PROGRAM_NAME_STR=\"tstGlobalConfig\"
214 tstGlobalConfigHardened_SOURCES = ../../HostDrivers/Support/SUPR3HardenedMainTemplateTestcase.cpp
215 tstGlobalConfig_TEMPLATE = VBoxR3HardenedTstDll
216else
217 tstGlobalConfig_TEMPLATE = VBOXR3TSTEXE
218endif
219tstGlobalConfig_SOURCES = tstGlobalConfig.cpp
220tstGlobalConfig_LIBS = $(LIB_RUNTIME)
221
222#
223# Testcase for checking the repurposing of the IEM instruction code.
224#
225tstIEMCheckMc_TEMPLATE = VBOXR3TSTEXE
226tstIEMCheckMc_SOURCES = tstIEMCheckMc.cpp
227tstIEMCheckMc_DEFS = $(VMM_COMMON_DEFS)
228tstIEMCheckMc_LIBS = $(LIB_RUNTIME)
229ifeq ($(KBUILD_TARGET),win)
230 tstIEMCheckMc_CXXFLAGS = $(VBOX_C_CXX_FLAGS_NO_UNUSED_PARAMETERS) -wd4189 # local variable is initialized but not used.
231else
232 tstIEMCheckMc_CXXFLAGS = $(VBOX_C_CXX_FLAGS_NO_UNUSED_PARAMETERS) -Wno-unused-value -Wno-unused-variable
233endif
234
235#
236# VMM heap testcase.
237#
238if defined(VBOX_WITH_HARDENING) && "$(KBUILD_TARGET)" == "win"
239 tstMMHyperHeapHardened_TEMPLATE = VBoxR3HardenedTstExe
240 tstMMHyperHeapHardened_NAME = tstMMHyperHeap
241 tstMMHyperHeapHardened_DEFS = PROGRAM_NAME_STR=\"tstMMHyperHeap\"
242 tstMMHyperHeapHardened_SOURCES = ../../HostDrivers/Support/SUPR3HardenedMainTemplateTestcase.cpp
243 tstMMHyperHeap_TEMPLATE = VBoxR3HardenedTstDll
244else
245 tstMMHyperHeap_TEMPLATE = VBOXR3TSTEXE
246endif
247tstMMHyperHeap_SOURCES = tstMMHyperHeap.cpp
248tstMMHyperHeap_LIBS = $(LIB_VMM) $(LIB_REM) $(LIB_RUNTIME)
249
250#
251# Saved state manager testcase.
252#
253if defined(VBOX_WITH_HARDENING) && "$(KBUILD_TARGET)" == "win"
254 tstSSMHardened_TEMPLATE = VBoxR3HardenedTstExe
255 tstSSMHardened_NAME = tstSSM
256 tstSSMHardened_DEFS = PROGRAM_NAME_STR=\"tstSSM\"
257 tstSSMHardened_SOURCES = ../../HostDrivers/Support/SUPR3HardenedMainTemplateTestcase.cpp
258 tstSSM_TEMPLATE = VBoxR3HardenedTstDll
259else
260 tstSSM_TEMPLATE = VBOXR3TSTEXE
261endif
262tstSSM_INCS = $(VBOX_PATH_VMM_SRC)/include
263tstSSM_SOURCES = tstSSM.cpp
264tstSSM_LIBS = $(LIB_VMM) $(LIB_REM) $(LIB_RUNTIME)
265
266#
267# VMM configuration manager tests.
268#
269if defined(VBOX_WITH_HARDENING) && "$(KBUILD_TARGET)" == "win"
270 tstCFGMHardened_TEMPLATE = VBoxR3HardenedTstExe
271 tstCFGMHardened_NAME = tstCFGM
272 tstCFGMHardened_DEFS = PROGRAM_NAME_STR=\"tstCFGM\"
273 tstCFGMHardened_SOURCES = ../../HostDrivers/Support/SUPR3HardenedMainTemplateTestcase.cpp
274 tstCFGM_TEMPLATE = VBoxR3HardenedTstDll
275else
276 tstCFGM_TEMPLATE = VBOXR3TSTEXE
277endif
278tstCFGM_SOURCES = tstCFGM.cpp
279tstCFGM_LIBS = $(LIB_VMM) $(LIB_REM) $(LIB_RUNTIME)
280
281#
282# Comparing some compression algorithms considered for SSM usage.
283#
284tstCompressionBenchmark_TEMPLATE = VBOXR3TSTEXE
285tstCompressionBenchmark_SOURCES = tstCompressionBenchmark.cpp
286
287#
288# Two testcases for checking the ring-3 "long jump" code.
289#
290tstVMMR0CallHost-1_TEMPLATE = VBOXR3TSTEXE
291tstVMMR0CallHost-1_DEFS = VMM_R0_NO_SWITCH_STACK
292tstVMMR0CallHost-1_INCS = $(VBOX_PATH_VMM_SRC)/include
293tstVMMR0CallHost-1_SOURCES = \
294 tstVMMR0CallHost-1.cpp
295tstVMMR0CallHost-1_SOURCES.amd64 = \
296 $(VBOX_PATH_VMM_SRC)/VMMR0/VMMR0JmpA-amd64.asm
297tstVMMR0CallHost-1_SOURCES.x86 = \
298 $(VBOX_PATH_VMM_SRC)/VMMR0/VMMR0JmpA-x86.asm
299
300tstVMMR0CallHost-2_EXTENDS = tstVMMR0CallHost-1
301tstVMMR0CallHost-2_DEFS = VMM_R0_SWITCH_STACK
302
303#
304# For testing the VM request queue code.
305#
306if defined(VBOX_WITH_HARDENING) && "$(KBUILD_TARGET)" == "win"
307 tstVMREQHardened_TEMPLATE = VBOXR3HARDENEDEXE
308 tstVMREQHardened_NAME = tstVMREQ
309 tstVMREQHardened_DEFS = PROGRAM_NAME_STR=\"tstVMREQ\"
310 tstVMREQHardened_SOURCES = ../../HostDrivers/Support/SUPR3HardenedMainTemplate.cpp
311 tstVMREQ_TEMPLATE = VBOXR3
312else
313 tstVMREQ_TEMPLATE = VBOXR3EXE
314endif
315tstVMREQ_SOURCES = tstVMREQ.cpp
316tstVMREQ_LIBS = $(LIB_VMM) $(LIB_REM) $(LIB_RUNTIME)
317
318#
319# Tool for reanimate things like OS/2 dumps.
320#
321if defined(VBOX_WITH_HARDENING) && "$(KBUILD_TARGET)" == "win"
322 tstAnimateHardened_TEMPLATE = VBOXR3HARDENEDEXE
323 tstAnimateHardened_NAME = tstAnimate
324 tstAnimateHardened_DEFS = PROGRAM_NAME_STR=\"tstAnimate\"
325 tstAnimateHardened_SOURCES = ../../HostDrivers/Support/SUPR3HardenedMainTemplate.cpp
326 tstAnimate_TEMPLATE = VBOXR3
327else
328 tstAnimate_TEMPLATE = VBOXR3EXE
329endif
330tstAnimate_SOURCES = tstAnimate.cpp
331tstAnimate_LIBS = $(LIB_VMM) $(LIB_REM) $(LIB_RUNTIME)
332
333tstX86-1_TEMPLATE = VBOXR3TSTEXE
334tstX86-1_SOURCES = tstX86-1.cpp tstX86-1A.asm
335tstX86-1_LIBS = $(LIB_RUNTIME)
336tstX86-1_LDFLAGS.linux = $(VBOX_GCC_no-pie)
337
338tstX86-FpuSaveRestore_TEMPLATE = VBOXR3TSTEXE
339tstX86-FpuSaveRestore_SOURCES = tstX86-FpuSaveRestore.cpp tstX86-FpuSaveRestoreA.asm
340tstX86-FpuSaveRestore_LIBS = $(LIB_RUNTIME)
341
342ifdef VBOX_WITH_RAW_MODE
343
344 #
345 # Raw-mode VMM testcase.
346 #
347 if defined(VBOX_WITH_HARDENING) && "$(KBUILD_TARGET)" == "win"
348 tstVMMHardened_TEMPLATE = VBOXR3HARDENEDEXE
349 tstVMMHardened_NAME = tstVMM
350 tstVMMHardened_DEFS = PROGRAM_NAME_STR=\"tstVMM\"
351 tstVMMHardened_SOURCES = ../../HostDrivers/Support/SUPR3HardenedMainTemplate.cpp
352 tstVMM_TEMPLATE = VBOXR3
353 else
354 tstVMM_TEMPLATE = VBOXR3EXE
355 endif
356 tstVMM_SOURCES = tstVMM.cpp
357 tstVMM_LIBS = $(LIB_VMM) $(LIB_REM) $(LIB_RUNTIME)
358
359 #
360 # HM VMM testcase.
361 #
362 tstVMM-HM_TEMPLATE = VBOXR3EXE
363 tstVMM-HM_SOURCES = tstVMM-HM.cpp
364 tstVMM-HM_LIBS = $(LIB_VMM) $(LIB_REM) $(LIB_RUNTIME)
365
366 #
367 # VMM host process fork test case (memory ++).
368 #
369 tstVMMFork_TEMPLATE = VBOXR3EXE
370 tstVMMFork_SOURCES = tstVMMFork.cpp
371 tstVMMFork_LIBS = $(LIB_VMM) $(LIB_REM) $(LIB_RUNTIME)
372
373 #
374 # Raw-mode micro benchmark.
375 #
376 if defined(VBOX_WITH_HARDENING) && "$(KBUILD_TARGET)" == "win"
377 tstMicroHardened_TEMPLATE = VBOXR3HARDENEDEXE
378 tstMicroHardened_NAME = tstMicro
379 tstMicroHardened_DEFS = PROGRAM_NAME_STR=\"tstMicro\"
380 tstMicroHardened_SOURCES = ../../HostDrivers/Support/SUPR3HardenedMainTemplate.cpp
381 tstMicro_TEMPLATE = VBOXR3
382 else
383 tstMicro_TEMPLATE = VBOXR3EXE
384 endif
385 tstMicro_SOURCES = tstMicro.cpp
386 tstMicro_LIBS = $(LIB_VMM) $(LIB_REM) $(LIB_RUNTIME)
387 tstMicro_DEFS = $(if $(VBOX_WITH_RAW_MODE),VBOX_WITH_RAW_MODE,)
388
389 tstMicroRC_TEMPLATE = VBoxRc
390 tstMicroRC_SOURCES = tstMicroRC.cpp tstMicroRCA.asm
391 tstMicroRC_DEFS = $(if $(VBOX_WITH_RAW_MODE),VBOX_WITH_RAW_MODE,)
392 tstMicroRC_INCS = $(VBOX_PATH_VMM_SRC)/testcase
393 ifeq ($(VBOX_LDR_FMT32),pe)
394 tstMicroRC_LDFLAGS = -Entry:tstMicroRC
395 endif
396 tstMicroRC_SYSSUFF = .gc
397 tstMicroRC_LIBS = \
398 $(PATH_STAGE_LIB)/DisasmRC$(VBOX_SUFF_LIB) \
399 $(PATH_STAGE_LIB)/RuntimeRC$(VBOX_SUFF_LIB)
400 ifeq ($(filter-out pe lx,$(VBOX_LDR_FMT32)),)
401 tstMicroRC_LIBS += \
402 $(PATH_STAGE_LIB)/VMMRCBuiltin$(VBOX_SUFF_LIB) \
403 $(LIB_VMMRC)
404 endif
405 tstMicroRC_SOURCES.win = tstMicroRC.def
406
407endif # VBOX_WITH_RAW_MODE
408
409
410#
411# Special NEM host testcase.
412#
413if1of ($(KBUILD_TARGET).$(KBUILD_TARGET_ARCH),win.amd64)
414 PROGRAMS += NemRawBench-1
415 NemRawBench-1_TEMPLATE = VBoxR3Static
416 NemRawBench-1_SOURCES = NemRawBench-1.cpp
417 NemRawBench-1_BLD_TYPE = release
418 NemRawBench-1_INCS.win = \
419 $(KBUILD_DEVTOOLS)/win.x86/sdk/v10.0.17134.0/include/10.0.17134.0/um \
420 $(KBUILD_DEVTOOLS)/win.x86/sdk/v10.0.17134.0/include/10.0.17134.0/shared
421endif
422
423
424ifdef VBOX_WITH_PDM_ASYNC_COMPLETION
425 #
426 # PDM asynchronous completation test.
427 #
428 if defined(VBOX_WITH_HARDENING) && "$(KBUILD_TARGET)" == "win"
429 tstPDMAsyncCompletionHardened_TEMPLATE = VBOXR3HARDENEDEXE
430 tstPDMAsyncCompletionHardened_NAME = tstPDMAsyncCompletion
431 tstPDMAsyncCompletionHardened_DEFS = PROGRAM_NAME_STR=\"tstPDMAsyncCompletion\"
432 tstPDMAsyncCompletionHardened_SOURCES = ../../HostDrivers/Support/SUPR3HardenedMainTemplate.cpp
433 tstPDMAsyncCompletion_TEMPLATE = VBOXR3
434 else
435 tstPDMAsyncCompletion_TEMPLATE = VBOXR3EXE
436 endif
437 tstPDMAsyncCompletion_INCS = $(VBOX_PATH_VMM_SRC)/include
438 tstPDMAsyncCompletion_SOURCES = tstPDMAsyncCompletion.cpp
439 tstPDMAsyncCompletion_LIBS = $(LIB_VMM) $(LIB_REM) $(LIB_RUNTIME)
440
441 #
442 # PDM asynchronous completation stress test.
443 #
444 if defined(VBOX_WITH_HARDENING) && "$(KBUILD_TARGET)" == "win"
445 tstPDMAsyncCompletionStressHardened_TEMPLATE = VBOXR3HARDENEDEXE
446 tstPDMAsyncCompletionStressHardened_NAME = tstPDMAsyncCompletionStress
447 tstPDMAsyncCompletionStressHardened_DEFS = PROGRAM_NAME_STR=\"tstPDMAsyncCompletionStress\"
448 tstPDMAsyncCompletionStressHardened_SOURCES = ../../HostDrivers/Support/SUPR3HardenedMainTemplate.cpp
449 tstPDMAsyncCompletionStress_TEMPLATE = VBOXR3
450 else
451 tstPDMAsyncCompletionStress_TEMPLATE = VBOXR3EXE
452 endif
453 tstPDMAsyncCompletionStress_INCS = $(VBOX_PATH_VMM_SRC)/include
454 tstPDMAsyncCompletionStress_SOURCES = tstPDMAsyncCompletionStress.cpp
455 tstPDMAsyncCompletionStress_LIBS = $(LIB_VMM) $(LIB_REM) $(LIB_RUNTIME)
456endif
457
458ifndef VBOX_ONLY_EXTPACKS
459PROGRAMS += tstSSM-2
460tstSSM-2_TEMPLATE = VBOXR3TSTEXE
461tstSSM-2_DEFS = IN_VMM_STATIC
462tstSSM-2_SOURCES = tstSSM-2.cpp
463tstSSM-2_LIBS = $(PATH_STAGE_LIB)/SSMStandalone$(VBOX_SUFF_LIB)
464endif
465
466#
467# Generate VM structure tests.
468#
469if !defined(VBOX_ONLY_EXTPACKS) \
470 && ( defined(VBOX_WITH_DTRACE_R3) \
471 || defined(VBOX_WITH_DTRACE_R0) \
472 || defined(VBOX_WITH_DTRACE_RC))
473 tstVMStructDTrace_TEMPLATE= VBOXR3AUTOTST
474 tstVMStructDTrace_DEFS = IN_VMM_R3 IN_DIS $(VMM_COMMON_DEFS)
475 ifdef VBOX_WITH_RAW_MODE
476 tstVMStructDTrace_DEFS += VBOX_WITH_RAW_MODE
477 endif
478 tstVMStructDTrace_INCS = \
479 $(VBOX_PATH_VMM_SRC)/include \
480 $(VBOX_PATH_VMM_SRC)/PATM \
481 $(VBOX_VMM_TESTCASE_OUT_DIR)
482 tstVMStructDTrace_SOURCES = tstVMStructDTrace.cpp
483 ifdef VBOX_WITH_R0_LOGGING
484 tstVMStructDTrace_DEFS += VBOX_WITH_R0_LOGGING
485 endif
486 ifdef VBOX_WITH_VMMR0_DISABLE_LAPIC_NMI
487 tstVMStructDTrace_DEFS += VBOX_WITH_VMMR0_DISABLE_LAPIC_NMI
488 endif
489
490
491 VMMLibDTraceStructTest_INST = $(VBOX_INST_DTRACE_TST)$(KBUILD_TARGET_ARCH)/
492 VMMLibDTraceStructTest_SOURCES = \
493 $(tstVMStructDTrace_0_OUTDIR)/vbox-vm-struct-test.d
494
495 $$(tstVMStructDTrace_0_OUTDIR)/vbox-vm-struct-test.d: \
496 $$(tstVMStructDTrace_1_STAGE_TARGET) | $$(dir $$@)
497 $(QUIET)$(RM) -f $@
498 $< > $@
499
500endif
501
502
503include $(FILE_KBUILD_SUB_FOOTER)
504
505
506#
507# Some handcrafted support targets for tstAsmStructs.
508#
509MY_ASA_ASM_STUFF = \
510 $(addprefix -D, \
511 $(DEFS) \
512 $(DEFS.$(KBUILD_TYPE)) \
513 $(DEFS.$(KBUILD_TARGET)) \
514 IN_RING3 $(ARCH_BITS_DEFS) \
515 $(DEFS.$(KBUILD_TARGET_ARCH)) \
516 $(DEFS.$(KBUILD_TARGET).$(KBUILD_TARGET_ARCH)) \
517 $(if $(VBOX_WITH_VMMR0_DISABLE_LAPIC_NMI),VBOX_WITH_VMMR0_DISABLE_LAPIC_NMI,) \
518 ) \
519 -f $(if $(eq $(KBUILD_TARGET),darwin),macho,elf) \
520 $(foreach inc,$(INCS) $(VBOX_PATH_VMM_SRC)/testcase $(VBOX_PATH_VMM_SRC)/include $(VBOX_VMM_TESTCASE_OUT_DIR)\
521 ,-I$(inc)/)
522
523# 1a. make a header file which makes all the structures+members globals.
524$(VBOX_VMM_TESTCASE_OUT_DIR)/tstAsmStructsAsm.mac: \
525 $(VBOX_PATH_VMM_SRC)/testcase/tstAsmStructsAsm.asm \
526 $(VBOX_PATH_VMM_SRC)/testcase/tstAsmStructsAsm-lst.sed \
527 $(DEPTH)/include/iprt/asmdefs.mac \
528 $(DEPTH)/include/VBox/vmm/cpum.mac \
529 $(DEPTH)/include/VBox/vmm/vm.mac \
530 $(DEPTH)/include/VBox/sup.mac \
531 $(DEPTH)/include/iprt/x86.mac \
532 $(VBOX_PATH_VMM_SRC)/include/CPUMInternal.mac \
533 $(VBOX_PATH_VMM_SRC)/include/TRPMInternal.mac \
534 $(VBOX_PATH_VMM_SRC)/include/HMInternal.mac \
535 $(VBOX_PATH_VMM_SRC)/include/VMMInternal.mac \
536 $(VBOX_PATH_VMM_SRC)/testcase/Makefile.kmk \
537 $(PATH_ROOT)/Config.kmk $(LOCALCFG) $(AUTOCFG) \
538 | $$(dir $$@)
539 $(call MSG_GENERATE,tstVMStructSize,$@,$<)
540ifndef DONT_USE_YASM
541 $(QUIET)$(TOOL_YASM_AS) $(MY_ASA_ASM_STUFF) -o [email protected] -l [email protected] $<
542 $(SED) -f $(VBOX_PATH_VMM_SRC)/testcase/tstAsmStructsAsm-lst.sed --output $@ [email protected]
543else
544 $(QUIET)$(TOOL_NASM_AS) -g $(MY_ASA_ASM_STUFF) -o [email protected] -l [email protected] $<
545 $(VBOX_NM) [email protected] | $(SED) \
546 -e '/[0-9a-fA-F][0-9a-fA-F]* [^a] /d' \
547 -e 's/[0-9a-fA-F][0-9a-fA-F]* a \([^ ]*\)/global \1/' \
548 > $@
549endif
550
551# 1b. make an elf/macho object containing the offsets.
552includedep $(VBOX_VMM_TESTCASE_OUT_DIR)/tstAsmStructsAsm.o.dep
553$(VBOX_VMM_TESTCASE_OUT_DIR)/tstAsmStructsAsm.o: \
554 $(VBOX_PATH_VMM_SRC)/testcase/tstAsmStructsAsm.asm \
555 $(VBOX_VMM_TESTCASE_OUT_DIR)/tstAsmStructsAsm.mac \
556 $(DEPTH)/include/iprt/asmdefs.mac \
557 $(DEPTH)/include/VBox/vmm/cpum.mac \
558 $(DEPTH)/include/VBox/vmm/hm_vmx.mac \
559 $(DEPTH)/include/VBox/vmm/stam.mac \
560 $(DEPTH)/include/VBox/vmm/trpm.mac \
561 $(DEPTH)/include/VBox/vmm/vm.mac \
562 $(DEPTH)/include/VBox/sup.mac \
563 $(DEPTH)/include/iprt/x86.mac \
564 $(VBOX_PATH_VMM_SRC)/include/CPUMInternal.mac \
565 $(VBOX_PATH_VMM_SRC)/include/HMInternal.mac \
566 $(VBOX_PATH_VMM_SRC)/include/VMMInternal.mac \
567 $(VBOX_PATH_VMM_SRC)/include/VMMSwitcher.mac \
568 $(VBOX_PATH_VMM_SRC)/testcase/Makefile.kmk \
569 $$(if $$(eq $$(tstAsmStructsAsmDep_STUFF),$$(MY_ASA_ASM_STUFF)),,FORCE) \
570 | $$(dir $$@)
571 $(call MSG_COMPILE,tstAsmStructsasm,$<,$@,AS)
572ifndef DONT_USE_YASM
573 $(QUIET)$(TOOL_YASM_AS) $(MY_ASA_ASM_STUFF) -DDO_GLOBALS -o $@ $<
574else
575 $(QUIET)$(TOOL_NASM_AS) $(MY_ASA_ASM_STUFF) -DDO_GLOBALS -o $@ $<
576endif
577 %$(QUIET2)$(RM) -f -- $(VBOX_VMM_TESTCASE_OUT_DIR)/tstAsmStructsAsm.o.dep
578 %$(QUIET2)$(APPEND) '$(VBOX_VMM_TESTCASE_OUT_DIR)/tstAsmStructsAsm.o.dep' 'tstAsmStructsAsmDep_STUFF=$(MY_ASA_ASM_STUFF)'
579
580# 2. use nm and sed to transform this into the header we want.
581$(VBOX_VMM_TESTCASE_OUT_DIR)/tstAsmStructsHC.h: $(VBOX_VMM_TESTCASE_OUT_DIR)/tstAsmStructsAsm.o
582 $(call MSG_GENERATE,tstVMStructSize,$@,$<)
583 $(QUIET)$(RM) -f $@ [email protected] [email protected]
584 $(QUIET)$(REDIRECT) -wo [email protected] -- $(VBOX_NM) $<
585 $(QUIET)$(SED) \
586 -e '/STAMPROFILEADV/d' \
587 \
588 -e '/^\(0x\)\{0,1\}00[0-9a-fA-F]* [aAnN] [^_.]*\./!d' \
589 -e 's/^\(0x\)\{0,1\}\(00[0-9a-fA-F]*\) [aAnN] \([^.]*\)\.\(.*$$\)/ CHECK_OFF(\3, 0x0\2, \4);/' \
590 --output [email protected] [email protected]
591 $(QUIET)$(SED) \
592 -e '/VM_size$$/d' \
593 -e '/VMCPU_size$$/d' \
594 -e '/VMMCPU_size$$/d' \
595 -e '/SUPDRVTRACERUSRCTX32_size$$/d' \
596 -e '/HMCPU_size$$/d' \
597 \
598 -e '/^\(0x\)\{0,1\}00[0-9a-fA-F]* [aAnN] [^_.]*_size$$/!d' \
599 -e 's/^\(0x\)\{0,1\}\(00[0-9a-fA-F]*\) [aAnN] \([^_.]*\)_size/ CHECK_SIZE(\3, 0x0\2);/' \
600 --append [email protected] [email protected]
601 $(QUIET)$(MV) -f [email protected] $@
602 $(QUIET)$(RM) -f [email protected]
603
604ifdef VBOX_WITH_RAW_MODE
605# 3. transform the HC header into a RC one by omitting some HC only structures.
606$(VBOX_VMM_TESTCASE_OUT_DIR)/tstAsmStructsRC.h: $(VBOX_VMM_TESTCASE_OUT_DIR)/tstAsmStructsHC.h
607 $(call MSG_GENERATE,tstVMStructSize,$@,$<)
608 $(QUIET)$(SED) -e '/VMMSWITCHERDEF/d' --output $@ $^
609endif
610
611# 4. run it.
612$(VBOX_VMM_TESTCASE_OUT_DIR)/tstAsmStructs.run: \
613 $$(tstAsmStructs_1_STAGE_TARGET) \
614 $(if-expr defined(VBOX_WITH_RAW_MODE),$$(tstAsmStructsRC_1_STAGE_TARGET),)
615 $(QUIET)$(RM) -f $@
616 $(tstAsmStructs_1_STAGE_TARGET)
617ifdef VBOX_WITH_RAW_MODE
618 $(tstAsmStructsRC_1_STAGE_TARGET)
619endif
620 $(QUIET)$(APPEND) "$@" "done"
621
622
623
624#
625# Run rule for tstVMStructSize.
626#
627
628ifdef VBOX_WITH_RAW_MODE
629# 1. Manually dump selected structures and members.
630$(VBOX_VMM_TESTCASE_OUT_DIR)/tstVMStructRC.h: $$(tstVMStructRC_1_STAGE_TARGET) | $$(dir $$@)
631 $(call MSG_GENERATE,tstVMStructSize,$@)
632 $(QUIET)$(REDIRECT) -wo $@ -- $<
633endif # VBOX_WITH_RAW_MODE
634
635# 2. run it.
636$(VBOX_VMM_TESTCASE_OUT_DIR)/tstVMStructSize.run: $$(tstVMStructSize_1_STAGE_TARGET) | $$(dir $$@)
637 $(QUIET)$(RM) -f $@
638 $<
639 $(QUIET)$(APPEND) "$@" "done"
640
641# alias for the two struct tests.
642run-struct-tests: $(VBOX_VMM_TESTCASE_OUT_DIR)/tstAsmStructs.run $(VBOX_VMM_TESTCASE_OUT_DIR)/tstVMStructSize.run
643
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