[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [PATCH v3 21/27] plugins: add an API to read registers
From: |
Alex Bennée |
Subject: |
Re: [PATCH v3 21/27] plugins: add an API to read registers |
Date: |
Tue, 27 Feb 2024 10:08:32 +0000 |
User-agent: |
mu4e 1.12.0; emacs 29.1 |
Akihiko Odaki <akihiko.odaki@daynix.com> writes:
> On 2024/02/27 1:56, Alex Bennée wrote:
>> We can only request a list of registers once the vCPU has been
>> initialised so the user needs to use either call the get function on
>> vCPU initialisation or during the translation phase.
>> We don't expose the reg number to the plugin instead hiding it
>> behind
>> an opaque handle. For now this is just the gdb_regnum encapsulated in
>> an anonymous GPOINTER but in future as we add more state for plugins
>> to track we can expand it.
>> Resolves: https://gitlab.com/qemu-project/qemu/-/issues/1706
>> Cc: Akihiko Odaki <akihiko.odaki@daynix.com>
>> Message-Id: <20240103173349.398526-39-alex.bennee@linaro.org>
>> Based-on: <20231025093128.33116-18-akihiko.odaki@daynix.com>
>> Signed-off-by: Alex Bennée <alex.bennee@linaro.org>
>> Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
>
> Hi,
>
> Mostly looks good. I have a few trivial comments so please have a look
> at them.
Done
<snip>
>> + g_array_append_val(find_data, desc);
>> + }
>> +
>> + return find_data;
>> +}
>> +
>> +GArray *qemu_plugin_get_registers(void)
>> +{
>> + g_assert(current_cpu);
>> +
>> + g_autoptr(GArray) regs = gdb_get_register_list(current_cpu);
>> + return regs->len ? create_register_handles(current_cpu, regs) : NULL;
>
> Why do you need regs->len check?
Not all guests expose register to gdb so we need to catch that:
TEST catch-syscalls-with-libinsn.so on alpha
**
ERROR:../../plugins/api.c:459:qemu_plugin_get_registers: assertion failed:
(regs->len)
Aborted
<snip>
--
Alex Bennée
Virtualisation Tech Lead @ Linaro
- [PATCH v3 25/27] docs/devel: lift example and plugin API sections up, (continued)
- [PATCH v3 25/27] docs/devel: lift example and plugin API sections up, Alex Bennée, 2024/02/26
- [PATCH v3 19/27] gdbstub: expose api to find registers, Alex Bennée, 2024/02/26
- [PATCH v3 18/27] plugins: Use different helpers when reading registers, Alex Bennée, 2024/02/26
- [PATCH v3 24/27] contrib/plugins: extend execlog to track register changes, Alex Bennée, 2024/02/26
- [PATCH v3 20/27] plugins: create CPUPluginState and migrate plugin_mask, Alex Bennée, 2024/02/26
- [PATCH v3 22/27] tests/tcg: expand insn test case to exercise register API, Alex Bennée, 2024/02/26
- [PATCH v3 23/27] contrib/plugins: fix imatch, Alex Bennée, 2024/02/26
- [PATCH v3 17/27] cpu: call plugin init hook asynchronously, Alex Bennée, 2024/02/26
- [PATCH v3 21/27] plugins: add an API to read registers, Alex Bennée, 2024/02/26