[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v2 26/26] tests/plugin: Remove duplicate insn log from libinsn.so
From: |
Alex Bennée |
Subject: |
[PATCH v2 26/26] tests/plugin: Remove duplicate insn log from libinsn.so |
Date: |
Mon, 26 Jun 2023 22:59:26 +0100 |
From: Richard Henderson <richard.henderson@linaro.org>
This is a perfectly natural occurrence for x86 "rep movb",
where the "rep" prefix forms a counted loop of the one insn.
During the tests/tcg/multiarch/memory test, this logging is
triggered over 350000 times. Within the context of cross-i386-tci
build, which is already slow by nature, the logging is sufficient
to push the test into timeout.
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
Message-Id: <20230621111520.1390967-1-richard.henderson@linaro.org>
Signed-off-by: Alex Bennée <alex.bennee@linaro.org>
---
tests/plugin/insn.c | 9 +--------
tests/tcg/i386/Makefile.softmmu-target | 9 ---------
tests/tcg/i386/Makefile.target | 6 ------
tests/tcg/x86_64/Makefile.softmmu-target | 9 ---------
4 files changed, 1 insertion(+), 32 deletions(-)
diff --git a/tests/plugin/insn.c b/tests/plugin/insn.c
index e251a84d86..5fd3017c2b 100644
--- a/tests/plugin/insn.c
+++ b/tests/plugin/insn.c
@@ -19,7 +19,6 @@ QEMU_PLUGIN_EXPORT int qemu_plugin_version =
QEMU_PLUGIN_VERSION;
#define MAX_CPUS 8 /* lets not go nuts */
typedef struct {
- uint64_t last_pc;
uint64_t insn_count;
} InstructionCount;
@@ -51,13 +50,7 @@ static void vcpu_insn_exec_before(unsigned int cpu_index,
void *udata)
{
unsigned int i = cpu_index % MAX_CPUS;
InstructionCount *c = &counts[i];
- uint64_t this_pc = GPOINTER_TO_UINT(udata);
- if (this_pc == c->last_pc) {
- g_autofree gchar *out = g_strdup_printf("detected repeat execution @
0x%"
- PRIx64 "\n", this_pc);
- qemu_plugin_outs(out);
- }
- c->last_pc = this_pc;
+
c->insn_count++;
}
diff --git a/tests/tcg/i386/Makefile.softmmu-target
b/tests/tcg/i386/Makefile.softmmu-target
index ed922d59c8..5266f2335a 100644
--- a/tests/tcg/i386/Makefile.softmmu-target
+++ b/tests/tcg/i386/Makefile.softmmu-target
@@ -33,14 +33,5 @@ EXTRA_RUNS+=$(MULTIARCH_RUNS)
memory: CFLAGS+=-DCHECK_UNALIGNED=1
-# non-inline runs will trigger the duplicate instruction heuristics in
libinsn.so
-run-plugin-%-with-libinsn.so:
- $(call run-test, $@, \
- $(QEMU) -monitor none -display none \
- -chardev file$(COMMA)path=$@.out$(COMMA)id=output \
- -plugin ../../plugin/libinsn.so$(COMMA)inline=on \
- -d plugin -D $*-with-libinsn.so.pout \
- $(QEMU_OPTS) $*)
-
# Running
QEMU_OPTS+=-device isa-debugcon,chardev=output -device
isa-debug-exit,iobase=0xf4,iosize=0x4 -kernel
diff --git a/tests/tcg/i386/Makefile.target b/tests/tcg/i386/Makefile.target
index 821822ed0c..f2ee7a4db7 100644
--- a/tests/tcg/i386/Makefile.target
+++ b/tests/tcg/i386/Makefile.target
@@ -63,12 +63,6 @@ else
SKIP_I386_TESTS+=test-i386-fprem
endif
-# non-inline runs will trigger the duplicate instruction heuristics in
libinsn.so
-run-plugin-%-with-libinsn.so:
- $(call run-test, $@, $(QEMU) $(QEMU_OPTS) \
- -plugin ../../plugin/libinsn.so$(COMMA)inline=on \
- -d plugin -D $*-with-libinsn.so.pout $*)
-
# Update TESTS
I386_TESTS:=$(filter-out $(SKIP_I386_TESTS), $(ALL_X86_TESTS))
TESTS=$(MULTIARCH_TESTS) $(I386_TESTS)
diff --git a/tests/tcg/x86_64/Makefile.softmmu-target
b/tests/tcg/x86_64/Makefile.softmmu-target
index 7207fee94c..1bd763f2e6 100644
--- a/tests/tcg/x86_64/Makefile.softmmu-target
+++ b/tests/tcg/x86_64/Makefile.softmmu-target
@@ -33,14 +33,5 @@ EXTRA_RUNS+=$(MULTIARCH_RUNS)
memory: CFLAGS+=-DCHECK_UNALIGNED=1
-# non-inline runs will trigger the duplicate instruction heuristics in
libinsn.so
-run-plugin-%-with-libinsn.so:
- $(call run-test, $@, \
- $(QEMU) -monitor none -display none \
- -chardev file$(COMMA)path=$@.out$(COMMA)id=output \
- -plugin ../../plugin/libinsn.so$(COMMA)inline=on \
- -d plugin -D $*-with-libinsn.so.pout \
- $(QEMU_OPTS) $*)
-
# Running
QEMU_OPTS+=-device isa-debugcon,chardev=output -device
isa-debug-exit,iobase=0xf4,iosize=0x4 -kernel
--
2.39.2
- [PATCH v2 19/26] plugins: update lockstep to use g_memdup2, (continued)
- [PATCH v2 19/26] plugins: update lockstep to use g_memdup2, Alex Bennée, 2023/06/26
- [PATCH v2 16/26] tests/avocado: update firmware to enable sbsa-ref/max, Alex Bennée, 2023/06/26
- [PATCH v2 15/26] tests/docker: convert riscv64-cross to lcitool, Alex Bennée, 2023/06/26
- [PATCH v2 05/26] tests/tcg: add mechanism to handle plugin arguments, Alex Bennée, 2023/06/26
- [PATCH v2 13/26] tests/lcitool: add an explicit gcc-native package, Alex Bennée, 2023/06/26
- [PATCH v2 21/26] include/migration: mark vmstate_register() as a legacy function, Alex Bennée, 2023/06/26
- [PATCH v2 24/26] docs/devel: split qom-api reference into new file, Alex Bennée, 2023/06/26
- [PATCH v2 25/26] docs/devel: introduce some key concepts for QOM development, Alex Bennée, 2023/06/26
- [PATCH v2 22/26] include/hw/qdev-core: fixup kerneldoc annotations, Alex Bennée, 2023/06/26
- [PATCH v2 23/26] docs/devel/qom.rst: Correct code style, Alex Bennée, 2023/06/26
- [PATCH v2 26/26] tests/plugin: Remove duplicate insn log from libinsn.so,
Alex Bennée <=
- [PATCH v2 20/26] docs/devel: add some front matter to the devel index, Alex Bennée, 2023/06/26
- [PATCH v2 18/26] plugins: fix memory leak while parsing options, Alex Bennée, 2023/06/26
- [PATCH v2 17/26] plugins: force slow path when plugins instrument memory ops, Alex Bennée, 2023/06/26