All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH V4 0/5] fixes for virtual address update
@ 2022-12-14 21:24 Steve Sistare
  2022-12-14 21:24 ` [PATCH V4 1/5] vfio/type1: exclude mdevs from VFIO_UPDATE_VADDR Steve Sistare
                   ` (5 more replies)
  0 siblings, 6 replies; 17+ messages in thread
From: Steve Sistare @ 2022-12-14 21:24 UTC (permalink / raw)
  To: kvm; +Cc: Alex Williamson, Cornelia Huck, Jason Gunthorpe, Steve Sistare

Fix bugs in the interfaces that allow the underlying memory object of an
iova range to be mapped in a new address space.  They allow userland to
indefinitely block vfio mediated device kernel threads, and do not
propagate the locked_vm count to a new mm.

The fixes impose restrictions that eliminate waiting conditions, so
revert the dead code:
  commit 898b9eaeb3fe ("vfio/type1: block on invalid vaddr")
  commit 487ace134053 ("vfio/type1: implement notify callback")
  commit ec5e32940cc9 ("vfio: iommu driver notify callback")

Changes in V2 (thanks Alex):
  * do not allow group attach while vaddrs are invalid
  * add patches to delete dead code
  * add WARN_ON for never-should-happen conditions
  * check for changed mm in unmap.
  * check for vfio_lock_acct failure in remap

Changes in V3 (ditto!):
  * return errno at WARN_ON sites, and make it unique
  * correctly check for dma task mm change
  * change dma owner to current when vaddr is updated
  * add Fixes to commit messages
  * refactored new code in vfio_dma_do_map

Changes in V4:
  * misc cosmetic changes

Steve Sistare (5):
  vfio/type1: exclude mdevs from VFIO_UPDATE_VADDR
  vfio/type1: prevent locked_vm underflow
  vfio/type1: revert "block on invalid vaddr"
  vfio/type1: revert "implement notify callback"
  vfio: revert "iommu driver notify callback"

 drivers/vfio/container.c        |   5 -
 drivers/vfio/vfio.h             |   7 --
 drivers/vfio/vfio_iommu_type1.c | 199 +++++++++++++++++++---------------------
 include/uapi/linux/vfio.h       |  15 +--
 4 files changed, 103 insertions(+), 123 deletions(-)

-- 
1.8.3.1


^ permalink raw reply	[flat|nested] 17+ messages in thread
* [PATCH V4 0/5] fixes for virtual address update
@ 2022-12-15 21:53 Steve Sistare
  2022-12-15 21:53 ` [PATCH V4 2/5] vfio/type1: prevent locked_vm underflow Steve Sistare
  0 siblings, 1 reply; 17+ messages in thread
From: Steve Sistare @ 2022-12-15 21:53 UTC (permalink / raw)
  To: kvm
  Cc: Alex Williamson, Cornelia Huck, Jason Gunthorpe, Kevin Tian,
	Steve Sistare

Fix bugs in the interfaces that allow the underlying memory object of an
iova range to be mapped in a new address space.  They allow userland to
indefinitely block vfio mediated device kernel threads, and do not
propagate the locked_vm count to a new mm.

The fixes impose restrictions that eliminate waiting conditions, so
revert the dead code:
  commit 898b9eaeb3fe ("vfio/type1: block on invalid vaddr")
  commit 487ace134053 ("vfio/type1: implement notify callback")
  commit ec5e32940cc9 ("vfio: iommu driver notify callback")

Changes in V2 (thanks Alex):
  * do not allow group attach while vaddrs are invalid
  * add patches to delete dead code
  * add WARN_ON for never-should-happen conditions
  * check for changed mm in unmap.
  * check for vfio_lock_acct failure in remap

Changes in V3 (ditto!):
  * return errno at WARN_ON sites, and make it unique
  * correctly check for dma task mm change
  * change dma owner to current when vaddr is updated
  * add Fixes to commit messages
  * refactored new code in vfio_dma_do_map

Changes in V4:
  * misc cosmetic changes

Steve Sistare (5):
  vfio/type1: exclude mdevs from VFIO_UPDATE_VADDR
  vfio/type1: prevent locked_vm underflow
  vfio/type1: revert "block on invalid vaddr"
  vfio/type1: revert "implement notify callback"
  vfio: revert "iommu driver notify callback"

 drivers/vfio/container.c        |   5 -
 drivers/vfio/vfio.h             |   7 --
 drivers/vfio/vfio_iommu_type1.c | 199 +++++++++++++++++++---------------------
 include/uapi/linux/vfio.h       |  15 +--
 4 files changed, 103 insertions(+), 123 deletions(-)

-- 
1.8.3.1


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

end of thread, other threads:[~2022-12-15 21:54 UTC | newest]

Thread overview: 17+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2022-12-14 21:24 [PATCH V4 0/5] fixes for virtual address update Steve Sistare
2022-12-14 21:24 ` [PATCH V4 1/5] vfio/type1: exclude mdevs from VFIO_UPDATE_VADDR Steve Sistare
2022-12-15  4:34   ` Tian, Kevin
2022-12-15 14:32     ` Steven Sistare
2022-12-14 21:24 ` [PATCH V4 2/5] vfio/type1: prevent locked_vm underflow Steve Sistare
2022-12-15  4:52   ` Tian, Kevin
2022-12-15 14:33     ` Steven Sistare
2022-12-15 14:20   ` Jason Gunthorpe
2022-12-15 14:38     ` Steven Sistare
2022-12-15 15:03       ` Jason Gunthorpe
2022-12-14 21:24 ` [PATCH V4 3/5] vfio/type1: revert "block on invalid vaddr" Steve Sistare
2022-12-14 21:24 ` [PATCH V4 4/5] vfio/type1: revert "implement notify callback" Steve Sistare
2022-12-14 21:24 ` [PATCH V4 5/5] vfio: revert "iommu driver " Steve Sistare
2022-12-14 21:42 ` [PATCH V4 0/5] fixes for virtual address update Alex Williamson
2022-12-15 14:25   ` Jason Gunthorpe
2022-12-15 18:37     ` Alex Williamson
  -- strict thread matches above, loose matches on Subject: below --
2022-12-15 21:53 Steve Sistare
2022-12-15 21:53 ` [PATCH V4 2/5] vfio/type1: prevent locked_vm underflow Steve Sistare

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.