summaryrefslogtreecommitdiffstats
path: root/src/VBox/VMM/testcase/Instructions/Makefile.kmk
blob: 6eb21528e7f35993ac07fed6d3d0354af112835f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
# $Id: Makefile.kmk $
## @file
# Sub-Makefile for the X86 and AMD64 Instruction Tests.
#

#
# Copyright (C) 2006-2023 Oracle and/or its affiliates.
#
# This file is part of VirtualBox base platform packages, as
# available from https://www.virtualbox.org.
#
# This program 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 3 of the
# License.
#
# This program is distributed in the hope that it will be useful, but
# WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
# General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, see <https://www.gnu.org/licenses>.
#
# SPDX-License-Identifier: GPL-3.0-only
#

SUB_DEPTH = ../../../../..
include $(KBUILD_PATH)/subheader.kmk

#
# Python linting (can't live without pylint!).
#
ifdef VBOX_WITH_PYLINT
 TESTING +=
endif
BLDDIRS += $(PATH_TARGET)/pylint

define def_vbox_instructions_py_check
 $(eval name:=$(basename $(notdir $(py))))

 pylint: $(name)-py-phony.o
 $(name).o: $(name)-py-phony.o
 $(PATH_TARGET)/pylint/$(name).o $(name)-py-phony.o:: $(py) | $(PATH_TARGET)/pylint/
 ifdef VBOX_WITH_PYLINT
	$(QUIET2)$(call MSG_L1,Subjecting $(py) to pylint...)
	$(QUIET)$(REDIRECT_EXT) -E LC_ALL=C -E PYTHONPATH="$(dir $(py))" -C $(dir $(py)) \
		-- $$(VBOX_PYLINT) $$(VBOX_PYLINT_FLAGS) $$($(py)_VBOX_PYLINT_FLAGS) ./$(notdir $(py))
 endif
	$(QUIET)$(APPEND) -t "$(PATH_TARGET)/pylint/$(name).o"

 TESTING += $(name)-py-phony.o
endef # def_vbox_instructions_py_check


$(foreach py, $(addprefix $(PATH_SUB_CURRENT)/, InstructionTestGen.py ) , $(eval $(def_vbox_instructions_py_check)))



#
# Ring-3 test program based on IPRT.
#
PROGRAMS += tstVBInsTstR3
tstVBInsTstR3_TEMPLATE = VBoxR3TstExe
tstVBInsTstR3_INCS = .
tstVBInsTstR3_SOURCES = \
	tstVBInsTstR3.cpp \
	$(tstVBInsTstR3_0_OUTDIR)/tstVBInsTstR3A.asm
tstVBInsTstR3_CLEAN = \
	$(tstVBInsTstR3_0_OUTDIR)/tstVBInsTstR3A.asm

$$(tstVBInsTstR3_0_OUTDIR)/tstVBInsTstR3A.asm: $(PATH_SUB_CURRENT)/InstructionTestGen.py
	$(VBOX_BLD_PYTHON) $(PATH_SUB_CURRENT)/InstructionTestGen.py \
		--target iprt-r3-$(if-expr $(intersects $(KBUILD_TARGET_ARCH), $(KBUILD_ARCHES_64)),64,32) \
		--output-base $(basename $@)


include $(FILE_KBUILD_SUB_FOOTER)