VirtualBox

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

Last change on this file since 95680 was 94934, checked in by vboxsync, 3 years ago

VMM/CPUM: Kicked out the VBOX_WITH_VMMR0_DISABLE_LAPIC_NMI code, as it was for raw-mode use. bugref:9517

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