>On Wed, Jul 19, 2017 at 08:17:49PM +0100, Dr. David Alan Gilbert wrote:
>> * Eduardo Habkost (address@hidden) wrote:
>> > On Wed, Jul 19, 2017 at 10:17:36AM -0500, Eric Blake wrote:
>> > > On 07/19/2017 10:07 AM, Daniel P. Berrange wrote:
>> > > >> It doesn't. Perhaps we should add that as a future libvirt-qemu.so API
>> > > >> addition, although it's probably easier to just use QMP than HMP when
>> > > >> using 'virsh qemu-monitor-command' if HMP doesn't do what you want.
>> > > >
>> > > > Or special case the "cpu 1" command - ie notice that it is being
>> > > > requested and don't execute 'human-montor-command'. Instead just
>> > > > record the CPU index, and use that for future "human-monitor-command"
>> > > > invokations, so we get full compat with the (dubious) stateful HMP
>> > > > semantics that traditionally existed.
>> > >
>> > > Is 'cpu' (and the followup commands affected by it) the only stateful
>> > > HMP command pairing? Is there a way to specify multiple HMP commands in
>> > > a single human-monitor-command QMP call?
>> > >
>> > > Indeed, tweaking qemu's human-monitor-command call to track the state
>> > > might be cleaner than having libvirt have to tweak API to work around
>> > > this wart of HMP.
>> >
>> > The CPU index was the only state kept by the human monitor, and I
>> > think it's by design that it stopped being considered "monitor
>> > state" to be tracked, and became just an argument to
>> > human-monitor-command.
>> >
>> > It's true that it broke compatibility of
>> > "virsh qemu-monitor-command <domain> --hmp 'cpu <n>'",
>> > when we moved to QMP, but this happened years ago, and it looks
>> > like nobody was relying on it. I don't see the point of trying
>> > to emulate the previous stateful interface.
>>
>> IMHO Yi's fix (once reworked) is the right fix - it removes the
>> use of that piece of state, when the optional parameter is used.
>> (OK, so it needs rework not to change that state and to
>> come to some agreement as to what to use instead of cpu index number
>> etc).
>
>Agreed, as it helps us to keep the "virsh qemu-monitor-command"
>interface simpler. But we have 8 commands that use
>mon_get_cpu(), we shouldn't fix only "info lapic".
Thank you all!
I will rework this patch in this way:
- extend 'info registers' with apic id value instead of current, like this:
CPU#1 (socket-id: a, core-id: b, thread-id: c, apic-id: d)
- add parameter 'apic id' for 'info lapic'
As to other commands, I want to send some other patches 'cause in my opinion not
all commands need 'apic-id' as index.
---
Best wishes
Yi Wang