[PATCH v3 00/27] monitor: Remove need of per-target handlers

Philippe Mathieu-Daudé posted 27 patches 2 weeks, 1 day ago
Failed in applying to current master (apply log)
There is a newer version of this series
MAINTAINERS                                   |  14 ++-
include/hw/core/sysemu-cpu-ops.h              |  14 +++
include/hw/s390x/storage-attributes.h         |   4 -
include/hw/s390x/storage-keys.h               |   3 -
include/monitor/hmp-target.h                  |  46 -------
include/monitor/hmp.h                         |  21 ++++
include/monitor/monitor.h                     |   1 -
.../qemu/base-arch-defs.h                     |  10 +-
include/qemu/typedefs.h                       |   1 +
monitor/monitor-internal.h                    |  13 +-
target/riscv/internals.h                      |   3 +
hw/i386/kvm/xen-stubs.c                       |  12 ++
hw/i386/sgx-hmp-stub.c                        |  16 +++
hw/i386/sgx-stub.c                            |   6 -
hw/i386/sgx.c                                 |   1 -
hw/misc/mos6522-stub.c                        |  16 +++
hw/pci/pci.c                                  |   2 +-
hw/s390x/s390-skeys.c                         |   2 +
hw/s390x/s390-stattrib.c                      |   2 +
monitor/hmp-cmds.c                            |  41 ++++++-
monitor/hmp-target.c                          | 115 ------------------
monitor/hmp.c                                 |  45 ++++++-
stubs/hmp-cmd-info_mem.c                      |  12 ++
stubs/hmp-cmd-info_sev.c                      |  16 +++
stubs/hmp-cmd-info_tlb.c                      |  12 ++
stubs/hmp-cmds-hw-s390x.c                     |  15 +++
stubs/hmp-cmds-target-i386.c                  |  13 ++
stubs/{monitor-arm-gic.c => qmp-arm-gic.c}    |   0
...or-cpu-s390x-kvm.c => qmp-cpu-s390x-kvm.c} |   0
.../{monitor-cpu-s390x.c => qmp-cpu-s390x.c}  |   0
stubs/{monitor-cpu.c => qmp-cpu.c}            |   0
stubs/{monitor-i386-rtc.c => qmp-i386-rtc.c}  |   0
stubs/{monitor-i386-sev.c => qmp-i386-sev.c}  |   0
stubs/{monitor-i386-sgx.c => qmp-i386-sgx.c}  |   0
stubs/{monitor-i386-xen.c => qmp-i386-xen.c}  |   0
stubs/target-get-monitor-def.c                |  29 -----
stubs/target-monitor-defs.c                   |   7 --
system/arch_init.c                            |   2 +-
system/qdev-monitor.c                         |   2 +-
system/vl.c                                   |   2 +-
target/i386/cpu-apic.c                        |   1 -
target/i386/cpu.c                             |  29 +++++
target/i386/monitor.c                         |  26 ----
target/i386/sev-system-stub.c                 |   6 -
target/i386/sev.c                             |   1 -
target/m68k/cpu.c                             |  18 +++
target/m68k/monitor.c                         |  22 ----
target/ppc/monitor.c                          |   2 -
target/riscv/cpu.c                            |   1 +
target/riscv/monitor.c                        |  12 +-
target/sh4/monitor.c                          |   1 -
target/sparc/cpu.c                            |  19 +++
target/sparc/monitor.c                        |  19 ---
target/xtensa/monitor.c                       |   1 -
hmp-commands-info.hx                          |  26 ++--
hmp-commands.hx                               |  13 +-
hw/i386/meson.build                           |   1 +
hw/misc/meson.build                           |   1 +
migration/meson.build                         |   2 +-
monitor/meson.build                           |   5 +-
stubs/meson.build                             |  23 ++--
61 files changed, 375 insertions(+), 352 deletions(-)
delete mode 100644 include/monitor/hmp-target.h
rename system/arch_init.h => include/qemu/base-arch-defs.h (92%)
create mode 100644 hw/i386/sgx-hmp-stub.c
create mode 100644 hw/misc/mos6522-stub.c
delete mode 100644 monitor/hmp-target.c
create mode 100644 stubs/hmp-cmd-info_mem.c
create mode 100644 stubs/hmp-cmd-info_sev.c
create mode 100644 stubs/hmp-cmd-info_tlb.c
create mode 100644 stubs/hmp-cmds-hw-s390x.c
create mode 100644 stubs/hmp-cmds-target-i386.c
rename stubs/{monitor-arm-gic.c => qmp-arm-gic.c} (100%)
rename stubs/{monitor-cpu-s390x-kvm.c => qmp-cpu-s390x-kvm.c} (100%)
rename stubs/{monitor-cpu-s390x.c => qmp-cpu-s390x.c} (100%)
rename stubs/{monitor-cpu.c => qmp-cpu.c} (100%)
rename stubs/{monitor-i386-rtc.c => qmp-i386-rtc.c} (100%)
rename stubs/{monitor-i386-sev.c => qmp-i386-sev.c} (100%)
rename stubs/{monitor-i386-sgx.c => qmp-i386-sgx.c} (100%)
rename stubs/{monitor-i386-xen.c => qmp-i386-xen.c} (100%)
delete mode 100644 stubs/target-get-monitor-def.c
delete mode 100644 stubs/target-monitor-defs.c
[PATCH v3 00/27] monitor: Remove need of per-target handlers
Posted by Philippe Mathieu-Daudé 2 weeks, 1 day ago
Missing review: 1-3, 16, 18

Since v2:
- Addressed rth review comments

Changes needed for the single binary (and heterogeneous emulation).

Convert target_monitor_defs() and target_monitor_defs()
to SysemuCPUOps fields, adapting the 4 targets using these
'legacy' code.

Instead of filtering the commands per target / device at
build time, add a new field to HMPCommand to filter them
at runtime, allowing to compile the command array once.

Philippe Mathieu-Daudé (27):
  stubs: Rename monitor* -> qmp* files
  monitor/meson: Use SPICE with migration HMP commands
  monitor: Restrict monitor_set_cpu() method scope
  monitor: Make 'info via' a generic command
  monitor: Make Xen emulation commands generic ones
  system: Expose 'arch_init.h' as 'qemu/base-arch-defs.h'
  monitor: Introduce HMPCommand::arch_bitmask field
  hw/s390x: Reduce 'monitor/monitor.h' inclusions
  monitor: Do not check TARGET_S390X to build s390x commands
  monitor: Do not check TARGET_I386 to build target/i386/ commands
  monitor: Do not check TARGET_I386 to build 'info sgx' command
  monitor: Do not check TARGET_I386 to build 'info sev' command
  monitor: Do not check TARGET_I386/RISCV to build 'info mem' command
  monitor: Do not check multiple TARGET_* to build 'info tlb' command
  cpus: Introduce SysemuCPUOps::monitor_get_register() hook
  target/riscv: Register target_get_monitor_def in SysemuCPUOps
  monitor: Remove target_get_monitor_def()
  monitor: Have MonitorDef::get_value() always return int64_t type
  monitor: Reduce target-specific methods further
  monitor: Remove 'monitor/hmp-target.h' header
  monitor: Forward-declare the MonitorDef type
  cpus: Introduce SysemuCPUOps::monitor_defs hook
  target/i386: Replace target_monitor_defs -> SysemuCPUOps::monitor_defs
  target/m68k: Replace target_monitor_defs -> SysemuCPUOps::monitor_defs
  target/sparc: Replace target_monitor_defs ->
    SysemuCPUOps::monitor_defs
  monitor: Remove target_monitor_defs()
  monitor: Merge hmp-target.c code within hmp-cmds.c

 MAINTAINERS                                   |  14 ++-
 include/hw/core/sysemu-cpu-ops.h              |  14 +++
 include/hw/s390x/storage-attributes.h         |   4 -
 include/hw/s390x/storage-keys.h               |   3 -
 include/monitor/hmp-target.h                  |  46 -------
 include/monitor/hmp.h                         |  21 ++++
 include/monitor/monitor.h                     |   1 -
 .../qemu/base-arch-defs.h                     |  10 +-
 include/qemu/typedefs.h                       |   1 +
 monitor/monitor-internal.h                    |  13 +-
 target/riscv/internals.h                      |   3 +
 hw/i386/kvm/xen-stubs.c                       |  12 ++
 hw/i386/sgx-hmp-stub.c                        |  16 +++
 hw/i386/sgx-stub.c                            |   6 -
 hw/i386/sgx.c                                 |   1 -
 hw/misc/mos6522-stub.c                        |  16 +++
 hw/pci/pci.c                                  |   2 +-
 hw/s390x/s390-skeys.c                         |   2 +
 hw/s390x/s390-stattrib.c                      |   2 +
 monitor/hmp-cmds.c                            |  41 ++++++-
 monitor/hmp-target.c                          | 115 ------------------
 monitor/hmp.c                                 |  45 ++++++-
 stubs/hmp-cmd-info_mem.c                      |  12 ++
 stubs/hmp-cmd-info_sev.c                      |  16 +++
 stubs/hmp-cmd-info_tlb.c                      |  12 ++
 stubs/hmp-cmds-hw-s390x.c                     |  15 +++
 stubs/hmp-cmds-target-i386.c                  |  13 ++
 stubs/{monitor-arm-gic.c => qmp-arm-gic.c}    |   0
 ...or-cpu-s390x-kvm.c => qmp-cpu-s390x-kvm.c} |   0
 .../{monitor-cpu-s390x.c => qmp-cpu-s390x.c}  |   0
 stubs/{monitor-cpu.c => qmp-cpu.c}            |   0
 stubs/{monitor-i386-rtc.c => qmp-i386-rtc.c}  |   0
 stubs/{monitor-i386-sev.c => qmp-i386-sev.c}  |   0
 stubs/{monitor-i386-sgx.c => qmp-i386-sgx.c}  |   0
 stubs/{monitor-i386-xen.c => qmp-i386-xen.c}  |   0
 stubs/target-get-monitor-def.c                |  29 -----
 stubs/target-monitor-defs.c                   |   7 --
 system/arch_init.c                            |   2 +-
 system/qdev-monitor.c                         |   2 +-
 system/vl.c                                   |   2 +-
 target/i386/cpu-apic.c                        |   1 -
 target/i386/cpu.c                             |  29 +++++
 target/i386/monitor.c                         |  26 ----
 target/i386/sev-system-stub.c                 |   6 -
 target/i386/sev.c                             |   1 -
 target/m68k/cpu.c                             |  18 +++
 target/m68k/monitor.c                         |  22 ----
 target/ppc/monitor.c                          |   2 -
 target/riscv/cpu.c                            |   1 +
 target/riscv/monitor.c                        |  12 +-
 target/sh4/monitor.c                          |   1 -
 target/sparc/cpu.c                            |  19 +++
 target/sparc/monitor.c                        |  19 ---
 target/xtensa/monitor.c                       |   1 -
 hmp-commands-info.hx                          |  26 ++--
 hmp-commands.hx                               |  13 +-
 hw/i386/meson.build                           |   1 +
 hw/misc/meson.build                           |   1 +
 migration/meson.build                         |   2 +-
 monitor/meson.build                           |   5 +-
 stubs/meson.build                             |  23 ++--
 61 files changed, 375 insertions(+), 352 deletions(-)
 delete mode 100644 include/monitor/hmp-target.h
 rename system/arch_init.h => include/qemu/base-arch-defs.h (92%)
 create mode 100644 hw/i386/sgx-hmp-stub.c
 create mode 100644 hw/misc/mos6522-stub.c
 delete mode 100644 monitor/hmp-target.c
 create mode 100644 stubs/hmp-cmd-info_mem.c
 create mode 100644 stubs/hmp-cmd-info_sev.c
 create mode 100644 stubs/hmp-cmd-info_tlb.c
 create mode 100644 stubs/hmp-cmds-hw-s390x.c
 create mode 100644 stubs/hmp-cmds-target-i386.c
 rename stubs/{monitor-arm-gic.c => qmp-arm-gic.c} (100%)
 rename stubs/{monitor-cpu-s390x-kvm.c => qmp-cpu-s390x-kvm.c} (100%)
 rename stubs/{monitor-cpu-s390x.c => qmp-cpu-s390x.c} (100%)
 rename stubs/{monitor-cpu.c => qmp-cpu.c} (100%)
 rename stubs/{monitor-i386-rtc.c => qmp-i386-rtc.c} (100%)
 rename stubs/{monitor-i386-sev.c => qmp-i386-sev.c} (100%)
 rename stubs/{monitor-i386-sgx.c => qmp-i386-sgx.c} (100%)
 rename stubs/{monitor-i386-xen.c => qmp-i386-xen.c} (100%)
 delete mode 100644 stubs/target-get-monitor-def.c
 delete mode 100644 stubs/target-monitor-defs.c

-- 
2.53.0


Re: [PATCH v3 00/27] monitor: Remove need of per-target handlers
Posted by Markus Armbruster 5 days, 13 hours ago
Doesn't apply to current master for me, and patchew couldn't apply it,
either.  Got something I could pull?
Re: [PATCH v3 00/27] monitor: Remove need of per-target handlers
Posted by Philippe Mathieu-Daudé 5 days, 13 hours ago
On 24/4/26 11:49, Markus Armbruster wrote:
> Doesn't apply to current master for me, and patchew couldn't apply it,
> either.  Got something I could pull?

My single-binary tree is having various dependencies on this series,
do you mind if I merged it myself?
Re: [PATCH v3 00/27] monitor: Remove need of per-target handlers
Posted by Markus Armbruster 5 days, 12 hours ago
Philippe Mathieu-Daudé <philmd@linaro.org> writes:

> On 24/4/26 11:49, Markus Armbruster wrote:
>> Doesn't apply to current master for me, and patchew couldn't apply it,
>> either.  Got something I could pull?
>
> My single-binary tree is having various dependencies on this series,
> do you mind if I merged it myself?

Do I mind if you take work off me?  Hell, no!  ;)

I asked because I'd like to give the series a quick eye-over, and I need
to compile locally for that.
Re: [PATCH v3 00/27] monitor: Remove need of per-target handlers
Posted by Philippe Mathieu-Daudé 2 days, 15 hours ago
On 24/4/26 13:17, Markus Armbruster wrote:
> Philippe Mathieu-Daudé <philmd@linaro.org> writes:
> 
>> On 24/4/26 11:49, Markus Armbruster wrote:
>>> Doesn't apply to current master for me, and patchew couldn't apply it,
>>> either.  Got something I could pull?
>>
>> My single-binary tree is having various dependencies on this series,
>> do you mind if I merged it myself?
> 
> Do I mind if you take work off me?  Hell, no!  ;)
> 
> I asked because I'd like to give the series a quick eye-over, and I need
> to compile locally for that.

Rebased as v4: 20260427080738.77138-1-philmd@linaro.org

Thanks for the quick eye-over!