# $Id: Makefile.kmk 4071 2007-08-07 17:07:59Z vboxsync $ ## @file # Sub-Makefile for the VMM testcases. # # # Copyright (C) 2006-2007 innotek GmbH # # This file is part of VirtualBox Open Source Edition (OSE), as # available from http://www.virtualbox.org. This file is free software; # you can redistribute it and/or modify it under the terms of the GNU # General Public License as published by the Free Software Foundation, # in version 2 as it comes in the "COPYING" file of the VirtualBox OSE # distribution. VirtualBox OSE is distributed in the hope that it will # be useful, but WITHOUT ANY WARRANTY of any kind. DEPTH ?= ../../../.. SUB_DEPTH = .. include $(PATH_KBUILD)/subheader.kmk # # Target lists. # PROGRAMS += tstVMStructSize tstVMStructGC tstAsmStructs tstAsmStructsGC tstVMM tstVMM-HwAccm ifdef VBOX_WITH_TESTCASES PROGRAMS += tstCFGM tstSSM tstMMHyperHeap tstVMM-2 tstVMREQ tstMicro tstCompiler tstVMMR0CallHost-1 ifneq ($(BUILD_TARGET),l4) PROGRAMS += tstAnimate endif SYSMODS += tstMicroGC endif # VBOX_WITH_TESTCASES # # We setup two 'other' targets for executing the two structure & alignment # validation testcases. Perhaps a bit hackish, but extremely useful. # ifeq ($(BUILD_TARGET),$(BUILD_PLATFORM)) ifeq ($(filter-out x86.x86 amd64.amd64 x86.amd64, $(BUILD_TARGET_ARCH).$(BUILD_PLATFORM_ARCH)),) OTHERS += \ $(PATH_TARGET)/tstAsmStructs.run \ $(PATH_TARGET)/tstVMStructSize.run endif endif OTHER_CLEAN += \ $(PATH_TARGET)/tstAsmStructs.run \ $(PATH_TARGET)/tstVMStructSize.run \ $(PATH_TARGET)/tstAsmStructs.h \ $(PATH_TARGET)/tstAsmStructsAsm.o \ $(PATH_TARGET)/tstAsmStructsAsm.mac \ $(PATH_TARGET)/tstAsmStructsAsm.mac.o \ $(PATH_TARGET)/tstAsmStructsAsm.mac.lst \ $(PATH_TARGET)/tstAsmStructs.h.dump \ $(PATH_TARGET)/tstAsmStructsGC.h \ $(PATH_TARGET)/tstAsmStructsHC.h \ $(PATH_TARGET)/tstVMStructGC.h # # Globals # VBOX_PATH_VMM_SRC = $(PATH_SUB_ROOT) # # Targets # tstVMStructGC_TEMPLATE = VBOXGCEXE tstVMStructGC_DEFS = IN_VMM_GC IN_PDM_GC IN_CFGM_GC IN_IOM_GC IN_VM_GC IN_CPUM_GC IN_SELM_GC IN_PGM_GC IN_TRPM_GC IN_MM_GC IN_PDM_GC IN_DBGF_GC IN_PATM_GC IN_DIS_GC IN_STAM_GC IN_VGADEVICE_GC IN_CSAM_GC IN_SSM_GC IN_REM_GC IN_RRM_GC tstVMStructGC_SOURCES = tstVMStructGC.cpp tstVMStructGC_INCS = $(VBOX_PATH_VMM_SRC) $(VBOX_PATH_VMM_SRC)/PATM tstVMStructSize_TEMPLATE= VBOXR3TSTEXE tstVMStructSize_DEFS = IN_VMM_R3 IN_PDM_R3 IN_CFGM_R3 IN_IOM_R3 IN_VM_R3 IN_CPUM_R3 IN_SELM_R3 IN_PGM_R3 IN_TRPM_R3 IN_MM_R3 IN_PDM_R3 IN_DBGF_R3 IN_PATM_R3 IN_DIS_R3 IN_STAM_R3 IN_VGADEVICE_R3 IN_CSAM_R3 IN_SSM_R3 IN_REM_R3 tstVMStructSize_INCS = $(VBOX_PATH_VMM_SRC) $(VBOX_PATH_VMM_SRC)/PATM $(PATH_TARGET) tstVMStructSize_SOURCES = tstVMStructSize.cpp tstVMStructSize_LIBS.l4 = $(LIB_RUNTIME) tstVMStructSize.cpp_DEPS= $(PATH_TARGET)/tstVMStructGC.h tstAsmStructs_TEMPLATE = VBOXR3TSTEXE tstAsmStructs_DEFS = IN_VMM_R3 IN_PDM_R3 IN_CFGM_R3 IN_IOM_R3 IN_VM_R3 IN_CPUM_R3 IN_SELM_R3 IN_PGM_R3 IN_TRPM_R3 IN_MM_R3 IN_PDM_R3 IN_DBGF_R3 IN_PATM_R3 IN_DIS_R3 IN_STAM_R3 IN_VGADEVICE_R3 IN_CSAM_R3 IN_SSM_R3 tstAsmStructs_INCS = $(VBOX_PATH_VMM_SRC) $(PATH_TARGET) tstAsmStructs_SOURCES = tstAsmStructs.cpp tstAsmStructs_LIBS.l4 = $(LIB_RUNTIME) tstAsmStructsGC_TEMPLATE= VBOXGCEXE tstAsmStructsGC_DEFS = IN_VMM_GC IN_PDM_GC IN_CFGM_GC IN_IOM_GC IN_VM_GC IN_CPUM_GC IN_SELM_GC IN_PGM_GC IN_TRPM_GC IN_MM_GC IN_PDM_GC IN_DBGF_GC IN_PATM_GC IN_DIS_GC IN_STAM_GC IN_VGADEVICE_GC IN_CSAM_GC IN_SSM_GC IN_RRM_GC tstAsmStructsGC_INCS = $(VBOX_PATH_VMM_SRC) $(PATH_TARGET) tstAsmStructsGC_SOURCES = tstAsmStructs.cpp tstAsmStructs.cpp_DEPS = $(PATH_TARGET)/tstAsmStructsHC.h $(PATH_TARGET)/tstAsmStructsGC.h tstMMHyperHeap_TEMPLATE = VBOXR3TSTEXE tstMMHyperHeap_SOURCES = tstMMHyperHeap.cpp tstMMHyperHeap_LIBS = $(LIB_VMM) $(LIB_REM) $(LIB_RUNTIME) tstSSM_TEMPLATE = VBOXR3TSTEXE tstSSM_SOURCES = tstSSM.cpp tstSSM_LIBS = $(LIB_VMM) $(LIB_REM) $(LIB_RUNTIME) tstCFGM_TEMPLATE = VBOXR3TSTEXE tstCFGM_SOURCES = tstCFGM.cpp tstCFGM_LIBS = $(LIB_VMM) $(LIB_REM) $(LIB_RUNTIME) tstVMM_TEMPLATE = VBOXR3EXE tstVMM_SOURCES = tstVMM.cpp tstVMM_LIBS = $(LIB_VMM) $(LIB_REM) $(LIB_RUNTIME) tstVMM-HwAccm_TEMPLATE = VBOXR3EXE tstVMM-HwAccm_SOURCES = tstVMM-HwAccm.cpp tstVMM-HwAccm_LIBS = $(LIB_VMM) $(LIB_REM) $(LIB_RUNTIME) tstVMM-2_TEMPLATE = VBOXR3EXE tstVMM-2_SOURCES = tstVMM-2.cpp tstVMM-2_LIBS = $(LIB_VMM) $(LIB_REM) $(LIB_RUNTIME) tstVMMR0CallHost-1_TEMPLATE = VBOXR3EXE tstVMMR0CallHost-1_INCS = $(VBOX_PATH_VMM_SRC) tstVMMR0CallHost-1_SOURCES = \ tstVMMR0CallHost-1.cpp \ $(VBOX_PATH_VMM_SRC)/VMMR0/VMMR0A.asm tstVMMR0CallHost-1_LIBS = $(LIB_VMM) $(LIB_REM) $(LIB_RUNTIME) tstVMREQ_TEMPLATE = VBOXR3EXE tstVMREQ_SOURCES = tstVMREQ.cpp tstVMREQ_LIBS = $(LIB_VMM) $(LIB_REM) $(LIB_RUNTIME) tstAnimate_TEMPLATE = VBOXR3EXE tstAnimate_SOURCES = tstAnimate.cpp tstAnimate_LIBS = $(LIB_VMM) $(LIB_REM) $(LIB_RUNTIME) tstCompiler_TEMPLATE = VBOXR3TSTEXE tstCompiler_SOURCES = tstCompiler.cpp tstCompiler_LIBS = $(LIB_VMM) $(LIB_REM) $(LIB_RUNTIME) tstMicro_TEMPLATE = VBOXR3EXE tstMicro_SOURCES = tstMicro.cpp tstMicro_LIBS = $(LIB_VMM) $(LIB_REM) $(LIB_RUNTIME) # tstMicroGC.gc tstMicroGC_TEMPLATE = VBOXGC tstMicroGC_SOURCES = tstMicroGC.cpp tstMicroGCA.asm tstMicroGC_DEFS = tstMicroGC_INCS = $(VBOX_PATH_VMM_SRC)/testcase ifeq ($(VBOX_LDR_FMT32),pe) tstMicroGC_LDFLAGS = -Entry:tstMicroGC endif tstMicroGC_SYSSUFF = .gc tstMicroGC_LIBS = \ $(PATH_LIB)/DisasmGC$(VBOX_SUFF_LIB) \ $(PATH_LIB)/RuntimeGC$(VBOX_SUFF_LIB) ifeq ($(filter-out pe lx,$(VBOX_LDR_FMT32)),) tstMicroGC_LIBS += \ $(PATH_LIB)/VMMGCBuiltin$(VBOX_SUFF_LIB) \ $(LIB_VMMGC) endif tstMicroGC_SOURCES.win = tstMicroGC.def include $(PATH_KBUILD)/subfooter.kmk ifndef USE_MULTI_TARGET # temporary hack. .NOTPARALLEL: $(TARGET_tstMicroGC) $(LIB_VMMGC) endif # # Some handcrafted support targets for tstAsmStructs. # ifeq ($(BUILD_PLATFORM),win) include $(PATH_KBUILD)/tools/MINGW32.kmk VBOX_NM ?= $(PATH_TOOL_MINGW32)/bin/nm.exe -p else VBOX_NM ?= nm -p endif # 1a. make a header file which makes all the structures+members globals. $(PATH_TARGET)/tstAsmStructsAsm.mac: \ $(VBOX_PATH_VMM_SRC)/testcase/tstAsmStructsAsm.asm \ $(VBOX_PATH_VMM_SRC)/testcase/tstAsmStructsAsm-lst.sed \ $(DEPTH)/include/iprt/asmdefs.mac \ $(DEPTH)/include/VBox/cpum.mac \ $(DEPTH)/include/VBox/vm.mac \ $(VBOX_PATH_VMM_SRC)/CPUMInternal.mac \ $(VBOX_PATH_VMM_SRC)/TRPMInternal.mac \ $(VBOX_PATH_VMM_SRC)/VMMInternal.mac \ $(VBOX_PATH_VMM_SRC)/testcase/Makefile.kmk \ | $(call DIRDEP,$(PATH_TARGET)) $(call MSG_GENERATE,tstVMStructSize,$@,$<) ifndef DONT_USE_YASM $(QUIET)$(TOOL_YASM_AS) \ $(addprefix -D, \ $(DEFS) \ $(DEFS.$(BUILD_TYPE)) \ $(DEFS.$(BUILD_TARGET)) \ IN_RING3 \ $(DEFS.$(BUILD_TARGET_ARCH)) \ $(DEFS.$(BUILD_TARGET).$(BUILD_TARGET_ARCH)) \ ) \ -f $(if $(eq $(BUILD_TARGET),darwin),macho,elf) \ $(foreach inc,$(INCS),-I$(inc)/) -o $@.o -l $@.lst $< $(SED) -f $(VBOX_PATH_VMM_SRC)/testcase/tstAsmStructsAsm-lst.sed $@.lst > $@ else $(QUIET)$(TOOL_NASM_AS) \ -g \ $(addprefix -D, \ $(DEFS) \ $(DEFS.$(BUILD_TYPE)) \ $(DEFS.$(BUILD_TARGET)) \ IN_RING3 \ $(DEFS.$(BUILD_TARGET_ARCH)) \ $(DEFS.$(BUILD_TARGET).$(BUILD_TARGET_ARCH)) \ ) \ -f $(if $(eq $(BUILD_TARGET),darwin),macho,elf) \ $(foreach inc,$(INCS) $(VBOX_PATH_VMM_SRC)/testcase,-I$(inc)/) -o $@.o -l $@.lst $< $(VBOX_NM) $@.o | $(SED) \ -e '/[0-9a-fA-F][0-9a-fA-F]* [^a] /d' \ -e 's/[0-9a-fA-F][0-9a-fA-F]* a \([^ ]*\)/global \1/' \ > $@ endif # 1b. make an elf/macho object containing the offsets. $(PATH_TARGET)/tstAsmStructsAsm.o: \ $(VBOX_PATH_VMM_SRC)/testcase/tstAsmStructsAsm.asm \ $(PATH_TARGET)/tstAsmStructsAsm.mac \ $(VBOX_PATH_VMM_SRC)/testcase/Makefile.kmk \ | $(call DIRDEP,$(PATH_TARGET)) $(call MSG_COMPILE,tstAsmStructsasm,$<,$@,AS) ifndef DONT_USE_YASM $(QUIET)$(TOOL_YASM_AS) \ $(addprefix -D, \ DO_GLOBALS \ $(DEFS) \ $(DEFS.$(BUILD_TYPE)) \ $(DEFS.$(BUILD_TARGET)) \ IN_RING3 \ $(DEFS.$(BUILD_TARGET_ARCH)) \ $(DEFS.$(BUILD_TARGET).$(BUILD_TARGET_ARCH)) \ ) \ -f $(if $(eq $(BUILD_TARGET),darwin),macho,elf -g stabs) \ $(foreach inc,$(INCS) $(PATH_TARGET),-I$(inc)/) -o $@ $< else $(QUIET)$(TOOL_NASM_AS) \ $(addprefix -D, \ DO_GLOBALS \ $(DEFS) \ $(DEFS.$(BUILD_TYPE)) \ $(DEFS.$(BUILD_TARGET)) \ IN_RING3 \ $(DEFS.$(BUILD_TARGET_ARCH)) \ $(DEFS.$(BUILD_TARGET).$(BUILD_TARGET_ARCH)) \ ) \ -f $(if $(eq $(BUILD_TARGET),darwin),macho,elf) \ $(foreach inc,$(INCS) $(PATH_TARGET) $(VBOX_PATH_VMM_SRC)/testcase,-I$(inc)/) -o $@ $< endif # 2. use nm and sed to transform this into the header we want. $(PATH_TARGET)/tstAsmStructsHC.h: $(PATH_TARGET)/tstAsmStructsAsm.o $(call MSG_GENERATE,tstVMStructSize,$@,$<) $(QUIET)$(RM) -f $@ $@.dump $@.tmp $(VBOX_NM) $< > $@.dump $(QUIET)$(SED) -e '/STAMPROFILEADV/d' \ -e '/00[0-9a-fA-F]* [aA] [^_.]*\./!d' -e 's/\(00[0-9a-fA-F]*\) [aA] \([^.]*\)\.\(.*$$\)/ CHECK_OFF(\2, 0x0\1, \3);/' \ $@.dump > $@.tmp $(QUIET)$(SED) -e '/VM_size$$/d' \ -e '/00[0-9a-fA-F]* [aA] [^_.]*_size$$/!d' -e 's/\(00[0-9a-fA-F]*\) [aA] \([^_.]*\)_size/ CHECK_SIZE(\2, 0x0\1);/' \ $@.dump >> $@.tmp $(QUIET)$(MV) -f $@.tmp $@ $(QUIET)$(RM) -f $@.dump # 3. transform the HC header into a GC one by omitting some HC only structures. $(PATH_TARGET)/tstAsmStructsGC.h: $(PATH_TARGET)/tstAsmStructsHC.h $(call MSG_GENERATE,tstVMStructSize,$@,$<) $(QUIET)$(SED) -e '/VMMSWITCHERDEF/d' \ $^ > $@ ## @todo make this default kBuild behaviour. .SECONDEXPANSION: # 4. run it. $(PATH_TARGET)/tstAsmStructs.run: $$(INSTARGET_tstAsmStructs) $$(INSTARGET_tstAsmStructsGC) $(QUIET)$(RM) -f $@ $(INSTARGET_tstAsmStructs) $(INSTARGET_tstAsmStructsGC) $(QUIET)$(APPEND) "$@" "done" # # Run rule for tstVMStructSize. # # 1. Manually dump selected structures and members. $(PATH_TARGET)/tstVMStructGC.h: $$(INSTARGET_tstVMStructGC) $(call MSG_GENERATE,tstVMStructSize,$@) $(QUIET)$(INSTARGET_tstVMStructGC) > $@ # 2. run it. $(PATH_TARGET)/tstVMStructSize.run: $$(INSTARGET_tstVMStructSize) $(QUIET)$(RM) -f $@ $^ $(QUIET)$(APPEND) "$@" "done" # alias for the two struct tests. run-struct-tests: $(PATH_TARGET)/tstAsmStructs.run $(PATH_TARGET)/tstVMStructSize.run