[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PULL 22/23] tests/plugin: allow memory plugin to do both inline and cal
From: |
Alex Bennée |
Subject: |
[PULL 22/23] tests/plugin: allow memory plugin to do both inline and callbacks |
Date: |
Thu, 18 Feb 2021 09:47:05 +0000 |
This is going to be useful for acceptance tests that check both types
are being called the same number of times, especially when icount is
enabled.
Signed-off-by: Alex Bennée <alex.bennee@linaro.org>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
Message-Id: <20210213130325.14781-23-alex.bennee@linaro.org>
diff --git a/tests/plugin/mem.c b/tests/plugin/mem.c
index 4725bd851d..afd1d27e5c 100644
--- a/tests/plugin/mem.c
+++ b/tests/plugin/mem.c
@@ -16,9 +16,10 @@
QEMU_PLUGIN_EXPORT int qemu_plugin_version = QEMU_PLUGIN_VERSION;
-static uint64_t mem_count;
+static uint64_t inline_mem_count;
+static uint64_t cb_mem_count;
static uint64_t io_count;
-static bool do_inline;
+static bool do_inline, do_callback;
static bool do_haddr;
static enum qemu_plugin_mem_rw rw = QEMU_PLUGIN_MEM_RW;
@@ -26,7 +27,12 @@ static void plugin_exit(qemu_plugin_id_t id, void *p)
{
g_autoptr(GString) out = g_string_new("");
- g_string_printf(out, "mem accesses: %" PRIu64 "\n", mem_count);
+ if (do_inline) {
+ g_string_printf(out, "inline mem accesses: %" PRIu64 "\n",
inline_mem_count);
+ }
+ if (do_callback) {
+ g_string_append_printf(out, "callback mem accesses: %" PRIu64 "\n",
cb_mem_count);
+ }
if (do_haddr) {
g_string_append_printf(out, "io accesses: %" PRIu64 "\n", io_count);
}
@@ -42,10 +48,10 @@ static void vcpu_mem(unsigned int cpu_index,
qemu_plugin_meminfo_t meminfo,
if (qemu_plugin_hwaddr_is_io(hwaddr)) {
io_count++;
} else {
- mem_count++;
+ cb_mem_count++;
}
} else {
- mem_count++;
+ cb_mem_count++;
}
}
@@ -60,8 +66,9 @@ static void vcpu_tb_trans(qemu_plugin_id_t id, struct
qemu_plugin_tb *tb)
if (do_inline) {
qemu_plugin_register_vcpu_mem_inline(insn, rw,
QEMU_PLUGIN_INLINE_ADD_U64,
- &mem_count, 1);
- } else {
+ &inline_mem_count, 1);
+ }
+ if (do_callback) {
qemu_plugin_register_vcpu_mem_cb(insn, vcpu_mem,
QEMU_PLUGIN_CB_NO_REGS,
rw, NULL);
@@ -90,6 +97,12 @@ QEMU_PLUGIN_EXPORT int qemu_plugin_install(qemu_plugin_id_t
id,
}
if (!strcmp(argv[0], "inline")) {
do_inline = true;
+ do_callback = false;
+ } else if (!strcmp(argv[0], "both")) {
+ do_inline = true;
+ do_callback = true;
+ } else {
+ do_callback = true;
}
}
--
2.20.1
- [PULL 03/23] plugins: new hwprofile plugin, (continued)
- [PULL 03/23] plugins: new hwprofile plugin, Alex Bennée, 2021/02/18
- [PULL 05/23] contrib: Fix some code style problems, ERROR: "foo * bar" should be "foo *bar", Alex Bennée, 2021/02/18
- [PULL 07/23] contrib: space required after that ',', Alex Bennée, 2021/02/18
- [PULL 08/23] contrib: Open brace '{' following struct go on the same line, Alex Bennée, 2021/02/18
- [PULL 06/23] contrib: Add spaces around operator, Alex Bennée, 2021/02/18
- [PULL 11/23] accel/tcg: Create io_recompile_replay_branch hook, Alex Bennée, 2021/02/18
- [PULL 15/23] tests/acceptance: add a new set of tests to exercise plugins, Alex Bennée, 2021/02/18
- [PULL 18/23] accel/tcg: re-factor non-RAM execution code, Alex Bennée, 2021/02/18
- [PULL 21/23] tests/acceptance: add a new tests to detect counting errors, Alex Bennée, 2021/02/18
- [PULL 16/23] accel/tcg: actually cache our partial icount TB, Alex Bennée, 2021/02/18
- [PULL 22/23] tests/plugin: allow memory plugin to do both inline and callbacks,
Alex Bennée <=
- [PULL 13/23] target/sh4: Create superh_io_recompile_replay_branch, Alex Bennée, 2021/02/18
- [PULL 09/23] accel/tcg/plugin-gen: fix the call signature for inline callbacks, Alex Bennée, 2021/02/18
- [PULL 19/23] accel/tcg: remove CF_NOCACHE and special cases, Alex Bennée, 2021/02/18
- [PULL 23/23] tests/acceptance: add a memory callback check, Alex Bennée, 2021/02/18
- [PULL 17/23] accel/tcg: cache single instruction TB on pending replay exception, Alex Bennée, 2021/02/18
- [PULL 20/23] accel/tcg: allow plugin instrumentation to be disable via cflags, Alex Bennée, 2021/02/18
- [PULL 14/23] tests/plugin: expand insn test to detect duplicate instructions, Alex Bennée, 2021/02/18
- Re: [PULL 00/23] plugin updates (hwprofile, CF_NOCACHE, io_recompile), Peter Maydell, 2021/02/18