Re: [GIT PULL] Add mlx5 live migration driver and v2 migration protocol

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Tue, Mar 01, 2022 at 12:41:12PM -0700, Alex Williamson wrote:
> On Mon, 28 Feb 2022 14:39:34 +0200
> Leon Romanovsky <leon@xxxxxxxxxx> wrote:
> 
> > From: Leon Romanovsky <leonro@xxxxxxxxxx>
> > 
> > Hi Alex,
> > 
> > This pull request contains the v9 version of recently submitted mlx5 live migration
> > driver from Yishai and Jason.
> > 
> > In addition to changes in VFIO, this series extended the ethernet part of mlx5 driver.
> > Such changes have all chances to create merge conflicts between VFIO, netdev and RDMA
> > subsystems, which are eliminated with this PR.
> 
> I know that Connie and perhaps others have spent a good deal of time
> reviewing this, so I'd at least like to give them an opportunity to
> chime in with their Reviewed-by before merging a PR.  For me please add
> my
> 
> Reviewed-by: Alex Williamson <alex.williamson@xxxxxxxxxx>
> 
> to patches 8-15 in Yishai's v9 posting.  If it's easier, I can adjust
> the commits from this PR manually, I see there are just a few minor
> commit log differences versus the v9 post.  Let's give this one more
> day to collect any further outstanding comments or reviews.  Thanks,

Sure, I'll wait till Thursday, collect Acks and repost.

I fixed spelling errors which were spotted by spellcheck when created PR,
so this is probably the reason of commit log differences. The style,
language and grammar are original.

Thanks

> 
> Alex
> 
> > ------------------------------------------------------------------------------------
> > 
> > The following changes since commit cfb92440ee71adcc2105b0890bb01ac3cddb8507:
> > 
> >   Linux 5.17-rc5 (2022-02-20 13:07:20 -0800)
> > 
> > are available in the Git repository at:
> > 
> >   https://git.kernel.org/pub/scm/linux/kernel/git/mellanox/linux.git tags/mlx5-vfio-v9
> > 
> > for you to fetch changes up to d18f3ba69448b8f68caf8592a9abb39e75c76e8d:
> > 
> >   vfio/mlx5: Use its own PCI reset_done error handler (2022-02-27 11:44:00 +0200)
> > 
> > ----------------------------------------------------------------
> > Add mlx5 live migration driver and v2 migration protocol
> > 
> > This series adds mlx5 live migration driver for VFs that are migration
> > capable and includes the v2 migration protocol definition and mlx5
> > implementation.
> > 
> > The mlx5 driver uses the vfio_pci_core split to create a specific VFIO
> > PCI driver that matches the mlx5 virtual functions. The driver provides
> > the same experience as normal vfio-pci with the addition of migration
> > support.
> > 
> > In HW the migration is controlled by the PF function, using its
> > mlx5_core driver, and the VFIO PCI VF driver co-ordinates with the PF to
> > execute the migration actions.
> > 
> > The bulk of the v2 migration protocol is semantically the same v1,
> > however it has been recast into a FSM for the device_state and the
> > actual syscall interface uses normal ioctl(), read() and write() instead
> > of building a syscall interface using the region.
> > 
> > Several bits of infrastructure work are included here:
> >  - pci_iov_vf_id() to help drivers like mlx5 figure out the VF index from
> >    a BDF
> >  - pci_iov_get_pf_drvdata() to clarify the tricky locking protocol when a
> >    VF reaches into its PF's driver
> >  - mlx5_core uses the normal SRIOV lifecycle and disables SRIOV before
> >    driver remove, to be compatible with pci_iov_get_pf_drvdata()
> >  - Lifting VFIO_DEVICE_FEATURE into core VFIO code
> > 
> > This series comes after alot of discussion. Some major points:
> > - v1 ABI compatible migration defined using the same FSM approach:
> >    https://lore.kernel.org/all/0-v1-a4f7cab64938+3f-vfio_mig_states_jgg@xxxxxxxxxx/
> > - Attempts to clarify how the v1 API works:
> >    Alex's:
> >      https://lore.kernel.org/kvm/163909282574.728533.7460416142511440919.stgit@omen/
> >    Jason's:
> >      https://lore.kernel.org/all/0-v3-184b374ad0a8+24c-vfio_mig_doc_jgg@xxxxxxxxxx/
> > - Etherpad exploring the scope and questions of general VFIO migration:
> >      https://lore.kernel.org/kvm/87mtm2loml.fsf@xxxxxxxxxx/
> > 
> > NOTE: As this series touched mlx5_core parts we need to send this in a
> > pull request format to VFIO to avoid conflicts.
> > 
> > Matching qemu changes can be previewed here:
> >  https://github.com/jgunthorpe/qemu/commits/vfio_migration_v2
> > 
> > Link: https://lore.kernel.org/all/20220224142024.147653-1-yishaih@xxxxxxxxxx
> > Signed-of-by: Leon Romanovsky <leonro@xxxxxxxxxx>
> > 
> > ----------------------------------------------------------------
> > Jason Gunthorpe (6):
> >       PCI/IOV: Add pci_iov_vf_id() to get VF index
> >       PCI/IOV: Add pci_iov_get_pf_drvdata() to allow VF reaching the drvdata of a PF
> >       vfio: Have the core code decode the VFIO_DEVICE_FEATURE ioctl
> >       vfio: Define device migration protocol v2
> >       vfio: Extend the device migration protocol with RUNNING_P2P
> >       vfio: Remove migration protocol v1 documentation
> > 
> > Leon Romanovsky (1):
> >       net/mlx5: Reuse exported virtfn index function call
> > 
> > Yishai Hadas (8):
> >       net/mlx5: Disable SRIOV before PF removal
> >       net/mlx5: Expose APIs to get/put the mlx5 core device
> >       net/mlx5: Introduce migration bits and structures
> >       net/mlx5: Add migration commands definitions
> >       vfio/mlx5: Expose migration commands over mlx5 device
> >       vfio/mlx5: Implement vfio_pci driver for mlx5 devices
> >       vfio/pci: Expose vfio_pci_core_aer_err_detected()
> >       vfio/mlx5: Use its own PCI reset_done error handler
> > 
> >  MAINTAINERS                                        |   6 +
> >  drivers/net/ethernet/mellanox/mlx5/core/cmd.c      |  10 +
> >  drivers/net/ethernet/mellanox/mlx5/core/main.c     |  45 ++
> >  .../net/ethernet/mellanox/mlx5/core/mlx5_core.h    |   1 +
> >  drivers/net/ethernet/mellanox/mlx5/core/sriov.c    |  17 +-
> >  drivers/pci/iov.c                                  |  43 ++
> >  drivers/vfio/pci/Kconfig                           |   3 +
> >  drivers/vfio/pci/Makefile                          |   2 +
> >  drivers/vfio/pci/mlx5/Kconfig                      |  10 +
> >  drivers/vfio/pci/mlx5/Makefile                     |   4 +
> >  drivers/vfio/pci/mlx5/cmd.c                        | 259 ++++++++
> >  drivers/vfio/pci/mlx5/cmd.h                        |  36 ++
> >  drivers/vfio/pci/mlx5/main.c                       | 676 +++++++++++++++++++++
> >  drivers/vfio/pci/vfio_pci.c                        |   1 +
> >  drivers/vfio/pci/vfio_pci_core.c                   | 101 ++-
> >  drivers/vfio/vfio.c                                | 295 ++++++++-
> >  include/linux/mlx5/driver.h                        |   3 +
> >  include/linux/mlx5/mlx5_ifc.h                      | 147 ++++-
> >  include/linux/pci.h                                |  15 +-
> >  include/linux/vfio.h                               |  53 ++
> >  include/linux/vfio_pci_core.h                      |   4 +
> >  include/uapi/linux/vfio.h                          | 406 ++++++-------
> >  22 files changed, 1846 insertions(+), 291 deletions(-)
> >  create mode 100644 drivers/vfio/pci/mlx5/Kconfig
> >  create mode 100644 drivers/vfio/pci/mlx5/Makefile
> >  create mode 100644 drivers/vfio/pci/mlx5/cmd.c
> >  create mode 100644 drivers/vfio/pci/mlx5/cmd.h
> >  create mode 100644 drivers/vfio/pci/mlx5/main.c
> > 
> 



[Index of Archives]     [KVM ARM]     [KVM ia64]     [KVM ppc]     [Virtualization Tools]     [Spice Development]     [Libvirt]     [Libvirt Users]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite Questions]     [Linux Kernel]     [Linux SCSI]     [XFree86]

  Powered by Linux