On 13 July 2018 at 16:47, James Morse <james.morse@xxxxxxx> wrote: > From: Dongjiu Geng <gengdongjiu@xxxxxxxxxx> > > For the migrating VMs, user space may need to know the exception > state. For example, in the machine A, KVM make an SError pending, > when migrate to B, KVM also needs to pend an SError. > > This new IOCTL exports user-invisible states related to SError. > Together with appropriate user space changes, user space can get/set > the SError exception state to do migrate/snapshot/suspend. > > Signed-off-by: Dongjiu Geng <gengdongjiu@xxxxxxxxxx> > Reviewed-by: James Morse <james.morse@xxxxxxx> > Signed-off-by: James Morse <james.morse@xxxxxxx> > --- > Documentation/virtual/kvm/api.txt | 33 +++++++++++++++++--- > arch/arm64/include/asm/kvm_emulate.h | 5 +++ > arch/arm64/include/asm/kvm_host.h | 7 +++++ > arch/arm64/include/uapi/asm/kvm.h | 13 ++++++++ > arch/arm64/kvm/guest.c | 46 ++++++++++++++++++++++++++++ > arch/arm64/kvm/inject_fault.c | 6 ++-- > arch/arm64/kvm/reset.c | 1 + > virt/kvm/arm/arm.c | 21 +++++++++++++ > 8 files changed, 125 insertions(+), 7 deletions(-) > > diff --git a/Documentation/virtual/kvm/api.txt b/Documentation/virtual/kvm/api.txt > index d10944e619d3..e3940f8715a5 100644 > --- a/Documentation/virtual/kvm/api.txt > +++ b/Documentation/virtual/kvm/api.txt > @@ -835,11 +835,13 @@ struct kvm_clock_data { > > Capability: KVM_CAP_VCPU_EVENTS > Extended by: KVM_CAP_INTR_SHADOW > -Architectures: x86 > -Type: vm ioctl > +Architectures: x86, arm64 > +Type: vcpu ioctl > Parameters: struct kvm_vcpu_event (out) > Returns: 0 on success, -1 on error > > +X86: > + > Gets currently pending exceptions, interrupts, and NMIs as well as related > states of the vcpu. > > @@ -881,15 +883,32 @@ Only two fields are defined in the flags field: > - KVM_VCPUEVENT_VALID_SMM may be set in the flags field to signal that > smi contains a valid state. > > +ARM64: > + > +Gets currently pending SError exceptions as well as related states of the vcpu. Any chance of expanding this to explain what this state actually is? (ie something you could use to implement or review the userspace code which has to manipulate it). > + > +struct kvm_vcpu_events { > + struct { > + __u8 serror_pending; > + __u8 serror_has_esr; > + /* Align it to 8 bytes */ > + __u8 pad[6]; > + __u64 serror_esr; > + } exception; > + __u32 reserved[12]; > +}; > + > 4.32 KVM_SET_VCPU_EVENTS thanks -- PMM