mirror of https://gitee.com/openkylin/qemu.git
tests/tcg: enable plugin testing
If CONFIG_PLUGINS is enabled then lets enable testing for all our TCG targets. This is a simple smoke test that ensure we don't crash or otherwise barf out by running each plugin against each test. There is a minor knock on effect for additional runners which need specialised QEMU_OPTS which will also need to declare a plugin version of the runner. If this gets onerous we might need to add another helper. Checking the results of the plugins is left for a later exercise. Signed-off-by: Alex Bennée <alex.bennee@linaro.org> Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
This commit is contained in:
parent
eba9ccf8f8
commit
3089e74e67
|
@ -1061,6 +1061,15 @@ check-softfloat:
|
||||||
"SKIPPED for non-TCG builds")
|
"SKIPPED for non-TCG builds")
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
# Plugins
|
||||||
|
ifeq ($(CONFIG_PLUGIN),y)
|
||||||
|
.PHONY: plugins
|
||||||
|
plugins:
|
||||||
|
$(call quiet-command,\
|
||||||
|
$(MAKE) $(SUBDIR_MAKEFLAGS) -C tests/plugin V="$(V)", \
|
||||||
|
"BUILD", "plugins")
|
||||||
|
endif
|
||||||
|
|
||||||
# Per guest TCG tests
|
# Per guest TCG tests
|
||||||
|
|
||||||
BUILD_TCG_TARGET_RULES=$(patsubst %,build-tcg-tests-%, $(TARGET_DIRS))
|
BUILD_TCG_TARGET_RULES=$(patsubst %,build-tcg-tests-%, $(TARGET_DIRS))
|
||||||
|
@ -1071,7 +1080,7 @@ RUN_TCG_TARGET_RULES=$(patsubst %,run-tcg-tests-%, $(TARGET_DIRS))
|
||||||
$(foreach PROBE_TARGET,$(TARGET_DIRS), \
|
$(foreach PROBE_TARGET,$(TARGET_DIRS), \
|
||||||
$(eval -include $(SRC_PATH)/tests/tcg/Makefile.prereqs))
|
$(eval -include $(SRC_PATH)/tests/tcg/Makefile.prereqs))
|
||||||
|
|
||||||
build-tcg-tests-%:
|
build-tcg-tests-%: $(if $(CONFIG_PLUGIN),plugins)
|
||||||
$(call quiet-command,$(MAKE) $(SUBDIR_MAKEFLAGS) \
|
$(call quiet-command,$(MAKE) $(SUBDIR_MAKEFLAGS) \
|
||||||
-f $(SRC_PATH)/tests/tcg/Makefile.qemu \
|
-f $(SRC_PATH)/tests/tcg/Makefile.qemu \
|
||||||
SRC_PATH=$(SRC_PATH) \
|
SRC_PATH=$(SRC_PATH) \
|
||||||
|
|
|
@ -123,11 +123,39 @@ all: $(TESTS) $(EXTRA_TESTS)
|
||||||
#
|
#
|
||||||
|
|
||||||
RUN_TESTS=$(patsubst %,run-%, $(TESTS))
|
RUN_TESTS=$(patsubst %,run-%, $(TESTS))
|
||||||
|
|
||||||
|
# If plugins exist also include those in the tests
|
||||||
|
ifeq ($(CONFIG_PLUGIN),y)
|
||||||
|
PLUGIN_DIR=../../plugin
|
||||||
|
VPATH+=$(PLUGIN_DIR)
|
||||||
|
PLUGINS=$(notdir $(wildcard $(PLUGIN_DIR)/*.so))
|
||||||
|
|
||||||
|
# We need to ensure expand the run-plugin-TEST-with-PLUGIN
|
||||||
|
# pre-requistes manually here as we can't use stems to handle it. We
|
||||||
|
# also add some special helpers the run-plugin- rules can use bellow.
|
||||||
|
|
||||||
|
$(foreach p,$(PLUGINS), \
|
||||||
|
$(foreach t,$(TESTS),\
|
||||||
|
$(eval run-plugin-$(t)-with-$(p): $t $p) \
|
||||||
|
$(eval run-plugin-$(t)-with-$(p): TIMEOUT=30) \
|
||||||
|
$(eval RUN_TESTS+=run-plugin-$(t)-with-$(p))))
|
||||||
|
endif
|
||||||
|
|
||||||
|
strip-plugin = $(wordlist 1, 1, $(subst -with-, ,$1))
|
||||||
|
extract-plugin = $(wordlist 2, 2, $(subst -with-, ,$1))
|
||||||
|
|
||||||
RUN_TESTS+=$(EXTRA_RUNS)
|
RUN_TESTS+=$(EXTRA_RUNS)
|
||||||
|
|
||||||
ifdef CONFIG_USER_ONLY
|
ifdef CONFIG_USER_ONLY
|
||||||
run-%: %
|
run-%: %
|
||||||
$(call run-test, $<, $(QEMU) $(QEMU_OPTS) $<, "$< on $(TARGET_NAME)")
|
$(call run-test, $<, $(QEMU) $(QEMU_OPTS) $<, "$< on $(TARGET_NAME)")
|
||||||
|
|
||||||
|
run-plugin-%:
|
||||||
|
$(call run-test, $@, $(QEMU) $(QEMU_OPTS) \
|
||||||
|
-plugin $(PLUGIN_DIR)/$(call extract-plugin,$@) \
|
||||||
|
-d plugin -D $*.pout \
|
||||||
|
$(call strip-plugin,$<), \
|
||||||
|
"$* on $(TARGET_NAME)")
|
||||||
else
|
else
|
||||||
run-%: %
|
run-%: %
|
||||||
$(call run-test, $<, \
|
$(call run-test, $<, \
|
||||||
|
@ -135,6 +163,15 @@ run-%: %
|
||||||
-chardev file$(COMMA)path=$<.out$(COMMA)id=output \
|
-chardev file$(COMMA)path=$<.out$(COMMA)id=output \
|
||||||
$(QEMU_OPTS) $<, \
|
$(QEMU_OPTS) $<, \
|
||||||
"$< on $(TARGET_NAME)")
|
"$< on $(TARGET_NAME)")
|
||||||
|
|
||||||
|
run-plugin-%:
|
||||||
|
$(call run-test, $@, \
|
||||||
|
$(QEMU) -monitor none -display none \
|
||||||
|
-chardev file$(COMMA)path=$@.out$(COMMA)id=output \
|
||||||
|
-plugin $(PLUGIN_DIR)/$(call extract-plugin,$@) \
|
||||||
|
-d plugin -D $*.pout \
|
||||||
|
$(QEMU_OPTS) $(call strip-plugin,$<), \
|
||||||
|
"$* on $(TARGET_NAME)")
|
||||||
endif
|
endif
|
||||||
|
|
||||||
gdb-%: %
|
gdb-%: %
|
||||||
|
|
|
@ -26,4 +26,10 @@ AARCH64_TESTS += semihosting
|
||||||
run-semihosting: semihosting
|
run-semihosting: semihosting
|
||||||
$(call run-test,$<,$(QEMU) $< 2> $<.err, "$< on $(TARGET_NAME)")
|
$(call run-test,$<,$(QEMU) $< 2> $<.err, "$< on $(TARGET_NAME)")
|
||||||
|
|
||||||
|
run-plugin-semihosting-with-%:
|
||||||
|
$(call run-test, $@, $(QEMU) $(QEMU_OPTS) \
|
||||||
|
-plugin $(PLUGIN_DIR)/$(call extract-plugin,$@) \
|
||||||
|
$(call strip-plugin,$<) 2> $<.err, \
|
||||||
|
"$< on $(TARGET_NAME) with $*")
|
||||||
|
|
||||||
TESTS += $(AARCH64_TESTS)
|
TESTS += $(AARCH64_TESTS)
|
||||||
|
|
|
@ -23,3 +23,4 @@ LDFLAGS+=-nostdlib -N -static
|
||||||
test-armv6m-undef: EXTRA_CFLAGS+=-mcpu=cortex-m0
|
test-armv6m-undef: EXTRA_CFLAGS+=-mcpu=cortex-m0
|
||||||
|
|
||||||
run-test-armv6m-undef: QEMU_OPTS+=-semihosting -M microbit -kernel
|
run-test-armv6m-undef: QEMU_OPTS+=-semihosting -M microbit -kernel
|
||||||
|
run-plugin-test-armv6m-undef-%: QEMU_OPTS+=-semihosting -M microbit -kernel
|
||||||
|
|
|
@ -34,6 +34,12 @@ ARM_TESTS += semihosting
|
||||||
run-semihosting: semihosting
|
run-semihosting: semihosting
|
||||||
$(call run-test,$<,$(QEMU) $< 2> $<.err, "$< on $(TARGET_NAME)")
|
$(call run-test,$<,$(QEMU) $< 2> $<.err, "$< on $(TARGET_NAME)")
|
||||||
|
|
||||||
|
run-plugin-semihosting-with-%:
|
||||||
|
$(call run-test, $@, $(QEMU) $(QEMU_OPTS) \
|
||||||
|
-plugin $(PLUGIN_DIR)/$(call extract-plugin,$@) \
|
||||||
|
$(call strip-plugin,$<) 2> $<.err, \
|
||||||
|
"$< on $(TARGET_NAME) with $*")
|
||||||
|
|
||||||
TESTS += $(ARM_TESTS)
|
TESTS += $(ARM_TESTS)
|
||||||
|
|
||||||
# On ARM Linux only supports 4k pages
|
# On ARM Linux only supports 4k pages
|
||||||
|
|
Loading…
Reference in New Issue