All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH v5 0/6] arm/arm64: vgic-new: Implement API for vGICv3 live migration
@ 2016-09-16 12:20 ` vijay.kilari at gmail.com
  0 siblings, 0 replies; 36+ messages in thread
From: vijay.kilari @ 2016-09-16 12:20 UTC (permalink / raw)
  To: marc.zyngier, christoffer.dall, peter.maydell
  Cc: kvmarm, linux-arm-kernel, Vijaya Kumar K

From: Vijaya Kumar K <Vijaya.Kumar@cavium.com>

This patchset adds API for saving and restoring
of VGICv3 registers to support live migration with new vgic feature.
This API definition is as per version of VGICv3 specification
http://lists.infradead.org/pipermail/linux-arm-kernel/2016-July/445611.html

Compatible live migration QEMU patches will be sent later.

The patch 3 & 4 are picked from the Pavel's previous implementation.
http://www.spinics.net/lists/kvm/msg122040.html

v4 => v5:
 - ICC_CTLR_EL1 access is updated to reflect HW values
 - Updated ICC reg access mask and shift macros
 - Introduced patch 4 for VMCR changes
 - Other minor fixes.
v3 => v4:
 - Rebased to latest code base
 - Moved vgic_uaccess() from vgic-mmio-v2.c to vgic-mmio.c
 - Dropped macro REGISTER_DESC_WITH_BITS_PER_IRQ_SHARED_UACCESS
 - Dropped LE conversion for userspace access
 - Introduced vgic_uaccess_write_pending() for ISPENDR write
 - Change macro KVM_DEV_ARM_VGIC_V3_CPUID_MASK to KVM_DEV_ARM_VGIC_V3_MIDR_MASK
 - Refactored some code as common code.
 - Changed handing of ICC_* registers
 - Allowed ICC_SRE_EL1 read by userspace
 - Fixed KVM_DEV_ARM_VGIC_LINE_LEVEL_INFO_* macros

v2 => v3:
 - Implemented separate API for ISPENDR and ICPENDR to
   read soft_pending instead of pending for level triggerred interrupts
 - Implemented ioctl KVM_DEV_ARM_VGIC_GRP_LEVEL_INFO to access line level
 - Rebased on top of Christoffer's patch set
   http://www.spinics.net/lists/kvm/msg136840.html

 NOTE: GICD_STATUSR and GICR_STATUSR are implemented as RAZ/WI.

v1 => v2:
 - The init sequence change patch is no more required.
   Fixed in patch 2 by using static vgic_io_dev regions structure instead
   of using dynamic allocation pointer.
 - Updated commit message of patch 4.
 - Dropped usage of union to manage 32-bit and 64-bit access in patch 1.
   Used local variable for 32-bit access.
 - Updated macro __ARM64_SYS_REG and ARM64_SYS_REG in
   arch/arm64/include/uapi/asm/kvm.h as per qemu requirements.


Vijaya Kumar K (6):
  arm/arm64: vgic-new: Implement support for userspace access
  arm/arm64: vgic-new: Add distributor and redistributor access
  arm/arm64: vgic-new: Introduce find_reg_by_id()
  arm/arm64: vgic-new: Introduce VENG0 and VENG1 fields to vmcr struct
  arm/arm64: vgic-new: Implement VGICv3 CPU interface access
  arm/arm64: vgic-new: Implement KVM_DEV_ARM_VGIC_GRP_LEVEL_INFO ioctl

 arch/arm64/include/uapi/asm/kvm.h   |  13 ++
 arch/arm64/kvm/Makefile             |   1 +
 arch/arm64/kvm/sys_regs.c           |  22 ++-
 arch/arm64/kvm/sys_regs.h           |   4 +
 include/linux/irqchip/arm-gic-v3.h  |  45 +++++-
 virt/kvm/arm/vgic/vgic-kvm-device.c | 226 +++++++++++++++++++++++++--
 virt/kvm/arm/vgic/vgic-mmio-v2.c    |  57 +------
 virt/kvm/arm/vgic/vgic-mmio-v3.c    | 199 +++++++++++++++++++++---
 virt/kvm/arm/vgic/vgic-mmio.c       | 149 +++++++++++++++++-
 virt/kvm/arm/vgic/vgic-mmio.h       |  28 ++++
 virt/kvm/arm/vgic/vgic-sys-reg-v3.c | 296 ++++++++++++++++++++++++++++++++++++
 virt/kvm/arm/vgic/vgic-v3.c         |  10 +-
 virt/kvm/arm/vgic/vgic.h            |  23 +++
 13 files changed, 969 insertions(+), 104 deletions(-)
 create mode 100644 virt/kvm/arm/vgic/vgic-sys-reg-v3.c

-- 
1.9.1

^ permalink raw reply	[flat|nested] 36+ messages in thread

end of thread, other threads:[~2016-09-19 10:11 UTC | newest]

Thread overview: 36+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2016-09-16 12:20 [PATCH v5 0/6] arm/arm64: vgic-new: Implement API for vGICv3 live migration vijay.kilari
2016-09-16 12:20 ` vijay.kilari at gmail.com
2016-09-16 12:20 ` [PATCH v5 1/6] arm/arm64: vgic-new: Implement support for userspace access vijay.kilari
2016-09-16 12:20   ` vijay.kilari at gmail.com
2016-09-16 16:31   ` Marc Zyngier
2016-09-16 16:31     ` Marc Zyngier
2016-09-16 12:20 ` [PATCH v5 2/6] arm/arm64: vgic-new: Add distributor and redistributor access vijay.kilari
2016-09-16 12:20   ` vijay.kilari at gmail.com
2016-09-16 12:20 ` [PATCH v5 3/6] arm/arm64: vgic-new: Introduce find_reg_by_id() vijay.kilari
2016-09-16 12:20   ` vijay.kilari at gmail.com
2016-09-16 12:20 ` [PATCH v5 4/6] arm/arm64: vgic-new: Introduce VENG0 and VENG1 fields to vmcr struct vijay.kilari
2016-09-16 12:20   ` vijay.kilari at gmail.com
2016-09-16 13:54   ` Marc Zyngier
2016-09-16 13:54     ` Marc Zyngier
2016-09-16 12:20 ` [PATCH 5/6] arm/arm64: vgic-new: Implement VGICv3 CPU interface access vijay.kilari
2016-09-16 12:20   ` vijay.kilari at gmail.com
2016-09-16 14:36   ` Marc Zyngier
2016-09-16 14:36     ` Marc Zyngier
2016-09-16 16:57     ` Vijay Kilari
2016-09-16 16:57       ` Vijay Kilari
2016-09-16 17:07       ` Marc Zyngier
2016-09-16 17:07         ` Marc Zyngier
2016-09-17  6:28         ` Vijay Kilari
2016-09-17  6:28           ` Vijay Kilari
2016-09-17 11:37           ` Marc Zyngier
2016-09-17 11:37             ` Marc Zyngier
2016-09-19  7:36             ` Vijay Kilari
2016-09-19  7:36               ` Vijay Kilari
2016-09-19 10:11               ` Peter Maydell
2016-09-19 10:11                 ` Peter Maydell
2016-09-18  6:30         ` Vijay Kilari
2016-09-18  6:30           ` Vijay Kilari
2016-09-18  9:27           ` Marc Zyngier
2016-09-18  9:27             ` Marc Zyngier
2016-09-16 12:20 ` [PATCH v5 6/6] arm/arm64: vgic-new: Implement KVM_DEV_ARM_VGIC_GRP_LEVEL_INFO ioctl vijay.kilari
2016-09-16 12:20   ` vijay.kilari at gmail.com

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.