On 2018/7/18 0:33, Peter Maydell wrote: > 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) sure, can expand it. serror_pending means whether KVM is pending Serror for guest. serror_has_esr means whether KVM or user space can set the SError syndrome for guest. serror_esr means the value of SError syndrome. Anyway, I will expand this to explain 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 > > . >