[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v4 16/29] plugins: add qemu_plugin_num_vcpus function
From: |
Alex Bennée |
Subject: |
[PATCH v4 16/29] plugins: add qemu_plugin_num_vcpus function |
Date: |
Tue, 27 Feb 2024 14:43:22 +0000 |
From: Pierrick Bouvier <pierrick.bouvier@linaro.org>
We now keep track of how many vcpus were started. This way, a plugin can
easily query number of any vcpus at any point of execution, which
unifies user and system mode workflows.
Signed-off-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
Message-Id: <20240213094009.150349-3-pierrick.bouvier@linaro.org>
Signed-off-by: Alex Bennée <alex.bennee@linaro.org>
---
include/qemu/qemu-plugin.h | 3 +++
plugins/plugin.h | 4 ++++
plugins/api.c | 5 +++++
plugins/core.c | 6 ++++++
plugins/qemu-plugins.symbols | 1 +
5 files changed, 19 insertions(+)
diff --git a/include/qemu/qemu-plugin.h b/include/qemu/qemu-plugin.h
index e45181c793c..93981f8f89f 100644
--- a/include/qemu/qemu-plugin.h
+++ b/include/qemu/qemu-plugin.h
@@ -645,6 +645,9 @@ QEMU_PLUGIN_API
void qemu_plugin_register_atexit_cb(qemu_plugin_id_t id,
qemu_plugin_udata_cb_t cb, void *userdata);
+/* returns how many vcpus were started at this point */
+int qemu_plugin_num_vcpus(void);
+
/**
* qemu_plugin_outs() - output string via QEMU's logging system
* @string: a string
diff --git a/plugins/plugin.h b/plugins/plugin.h
index 90f3f324ab6..00b3509f708 100644
--- a/plugins/plugin.h
+++ b/plugins/plugin.h
@@ -44,6 +44,8 @@ struct qemu_plugin_state {
* the code cache is flushed.
*/
struct qht dyn_cb_arr_ht;
+ /* How many vcpus were started */
+ int num_vcpus;
};
@@ -97,4 +99,6 @@ void plugin_register_vcpu_mem_cb(GArray **arr,
void exec_inline_op(struct qemu_plugin_dyn_cb *cb);
+int plugin_num_vcpus(void);
+
#endif /* PLUGIN_H */
diff --git a/plugins/api.c b/plugins/api.c
index 2926b1961a8..116b8bd603c 100644
--- a/plugins/api.c
+++ b/plugins/api.c
@@ -342,6 +342,11 @@ const char *qemu_plugin_hwaddr_device_name(const struct
qemu_plugin_hwaddr *h)
#endif
}
+int qemu_plugin_num_vcpus(void)
+{
+ return plugin_num_vcpus();
+}
+
/*
* Plugin output
*/
diff --git a/plugins/core.c b/plugins/core.c
index ee2fa41af9e..caa66311351 100644
--- a/plugins/core.c
+++ b/plugins/core.c
@@ -213,6 +213,7 @@ void qemu_plugin_vcpu_init_hook(CPUState *cpu)
bool success;
qemu_rec_mutex_lock(&plugin.lock);
+ plugin.num_vcpus = MAX(plugin.num_vcpus, cpu->cpu_index + 1);
plugin_cpu_update__locked(&cpu->cpu_index, NULL, NULL);
success = g_hash_table_insert(plugin.cpu_ht, &cpu->cpu_index,
&cpu->cpu_index);
@@ -570,3 +571,8 @@ static void __attribute__((__constructor__))
plugin_init(void)
QHT_MODE_AUTO_RESIZE);
atexit(qemu_plugin_atexit_cb);
}
+
+int plugin_num_vcpus(void)
+{
+ return plugin.num_vcpus;
+}
diff --git a/plugins/qemu-plugins.symbols b/plugins/qemu-plugins.symbols
index ca806000d54..adb67608598 100644
--- a/plugins/qemu-plugins.symbols
+++ b/plugins/qemu-plugins.symbols
@@ -16,6 +16,7 @@
qemu_plugin_mem_is_sign_extended;
qemu_plugin_mem_is_store;
qemu_plugin_mem_size_shift;
+ qemu_plugin_num_vcpus;
qemu_plugin_outs;
qemu_plugin_path_to_binary;
qemu_plugin_register_atexit_cb;
--
2.39.2
- [PATCH v4 09/29] gdbstub: Use GDBFeature for GDBRegisterState, (continued)
- [PATCH v4 09/29] gdbstub: Use GDBFeature for GDBRegisterState, Alex Bennée, 2024/02/27
- [PATCH v4 11/29] gdbstub: Simplify XML lookup, Alex Bennée, 2024/02/27
- [PATCH v4 07/29] target/riscv: Use GDBFeature for dynamic XML, Alex Bennée, 2024/02/27
- [PATCH v4 12/29] gdbstub: Infer number of core registers from XML, Alex Bennée, 2024/02/27
- [PATCH v4 10/29] gdbstub: Change gdb_get_reg_cb and gdb_set_reg_cb, Alex Bennée, 2024/02/27
- [PATCH v4 05/29] target/arm: Use GDBFeature for dynamic XML, Alex Bennée, 2024/02/27
- [PATCH v4 06/29] target/ppc: Use GDBFeature for dynamic XML, Alex Bennée, 2024/02/27
- [PATCH v4 08/29] gdbstub: Use GDBFeature for gdb_register_coprocessor, Alex Bennée, 2024/02/27
- [PATCH v4 14/29] gdbstub: Add members to identify registers to GDBFeature, Alex Bennée, 2024/02/27
- [PATCH v4 29/29] docs/devel: plugins can trigger a tb flush, Alex Bennée, 2024/02/27
- [PATCH v4 16/29] plugins: add qemu_plugin_num_vcpus function,
Alex Bennée <=
- [PATCH v4 17/29] plugins: fix order of init/idle/resume callback, Alex Bennée, 2024/02/27
- [PATCH v4 13/29] hw/core/cpu: Remove gdb_get_dynamic_xml member, Alex Bennée, 2024/02/27
- [PATCH v4 25/29] contrib/plugins: fix imatch, Alex Bennée, 2024/02/27
- [PATCH v4 15/29] plugins: remove previous n_vcpus functions from API, Alex Bennée, 2024/02/27
- [PATCH v4 19/29] cpu: call plugin init hook asynchronously, Alex Bennée, 2024/02/27
- [PATCH v4 28/29] docs/devel: document some plugin assumptions, Alex Bennée, 2024/02/27
- [PATCH v4 21/29] gdbstub: expose api to find registers, Alex Bennée, 2024/02/27
- [PATCH v4 26/29] contrib/plugins: extend execlog to track register changes, Alex Bennée, 2024/02/27
- [PATCH v4 27/29] docs/devel: lift example and plugin API sections up, Alex Bennée, 2024/02/27