1 | # $Id: Makefile.kmk 98437 2023-02-02 12:46:41Z vboxsync $
|
---|
2 | ## @file
|
---|
3 | # Sub-Makefile for the X86 and AMD64 Instruction Tests.
|
---|
4 | #
|
---|
5 |
|
---|
6 | #
|
---|
7 | # Copyright (C) 2006-2023 Oracle and/or its affiliates.
|
---|
8 | #
|
---|
9 | # This file is part of VirtualBox base platform packages, as
|
---|
10 | # available from https://www.virtualbox.org.
|
---|
11 | #
|
---|
12 | # This program is free software; you can redistribute it and/or
|
---|
13 | # modify it under the terms of the GNU General Public License
|
---|
14 | # as published by the Free Software Foundation, in version 3 of the
|
---|
15 | # License.
|
---|
16 | #
|
---|
17 | # This program is distributed in the hope that it will be useful, but
|
---|
18 | # WITHOUT ANY WARRANTY; without even the implied warranty of
|
---|
19 | # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
---|
20 | # General Public License for more details.
|
---|
21 | #
|
---|
22 | # You should have received a copy of the GNU General Public License
|
---|
23 | # along with this program; if not, see <https://www.gnu.org/licenses>.
|
---|
24 | #
|
---|
25 | # SPDX-License-Identifier: GPL-3.0-only
|
---|
26 | #
|
---|
27 |
|
---|
28 | SUB_DEPTH = ../../../../..
|
---|
29 | include $(KBUILD_PATH)/subheader.kmk
|
---|
30 |
|
---|
31 | #
|
---|
32 | # Python linting (can't live without pylint!).
|
---|
33 | #
|
---|
34 | ifdef VBOX_WITH_PYLINT
|
---|
35 | TESTING +=
|
---|
36 | endif
|
---|
37 | BLDDIRS += $(PATH_TARGET)/pylint
|
---|
38 |
|
---|
39 | define def_vbox_instructions_py_check
|
---|
40 | $(eval name:=$(basename $(notdir $(py))))
|
---|
41 |
|
---|
42 | pylint: $(name)-py-phony.o
|
---|
43 | $(name).o: $(name)-py-phony.o
|
---|
44 | $(PATH_TARGET)/pylint/$(name).o $(name)-py-phony.o:: $(py) | $(PATH_TARGET)/pylint/
|
---|
45 | ifdef VBOX_WITH_PYLINT
|
---|
46 | $(QUIET2)$(call MSG_L1,Subjecting $(py) to pylint...)
|
---|
47 | $(QUIET)$(REDIRECT_EXT) -E LC_ALL=C -E PYTHONPATH="$(dir $(py))" -C $(dir $(py)) \
|
---|
48 | -- $$(VBOX_PYLINT) $$(VBOX_PYLINT_FLAGS) $$($(py)_VBOX_PYLINT_FLAGS) ./$(notdir $(py))
|
---|
49 | endif
|
---|
50 | $(QUIET)$(APPEND) -t "$(PATH_TARGET)/pylint/$(name).o"
|
---|
51 |
|
---|
52 | TESTING += $(name)-py-phony.o
|
---|
53 | endef # def_vbox_instructions_py_check
|
---|
54 |
|
---|
55 |
|
---|
56 | $(foreach py, $(addprefix $(PATH_SUB_CURRENT)/, InstructionTestGen.py ) , $(eval $(def_vbox_instructions_py_check)))
|
---|
57 |
|
---|
58 |
|
---|
59 |
|
---|
60 | #
|
---|
61 | # Ring-3 test program based on IPRT.
|
---|
62 | #
|
---|
63 | PROGRAMS += tstVBInsTstR3
|
---|
64 | tstVBInsTstR3_TEMPLATE = VBoxR3TstExe
|
---|
65 | tstVBInsTstR3_INCS = .
|
---|
66 | tstVBInsTstR3_SOURCES = \
|
---|
67 | tstVBInsTstR3.cpp \
|
---|
68 | $(tstVBInsTstR3_0_OUTDIR)/tstVBInsTstR3A.asm
|
---|
69 | tstVBInsTstR3_CLEAN = \
|
---|
70 | $(tstVBInsTstR3_0_OUTDIR)/tstVBInsTstR3A.asm
|
---|
71 |
|
---|
72 | $$(tstVBInsTstR3_0_OUTDIR)/tstVBInsTstR3A.asm: $(PATH_SUB_CURRENT)/InstructionTestGen.py
|
---|
73 | $(VBOX_BLD_PYTHON) $(PATH_SUB_CURRENT)/InstructionTestGen.py \
|
---|
74 | --target iprt-r3-$(if-expr $(intersects $(KBUILD_TARGET_ARCH), $(KBUILD_ARCHES_64)),64,32) \
|
---|
75 | --output-base $(basename $@)
|
---|
76 |
|
---|
77 |
|
---|
78 | include $(FILE_KBUILD_SUB_FOOTER)
|
---|
79 |
|
---|