diff options
| author | Brett Creeley <[email protected]> | 2024-03-08 18:21:49 +0000 |
|---|---|---|
| committer | Alex Williamson <[email protected]> | 2024-03-11 18:10:37 +0000 |
| commit | 6a7e448c6b238c9b256b01eb198b0af93ae3157e (patch) | |
| tree | 8d7a5a61a96a912faf15d609012c206e1a549ba1 /drivers/usb/cdns3/cdns3-trace.c | |
| parent | vfio/pds: Make sure migration file isn't accessed after reset (diff) | |
| download | kernel-6a7e448c6b238c9b256b01eb198b0af93ae3157e.tar.gz kernel-6a7e448c6b238c9b256b01eb198b0af93ae3157e.zip | |
vfio/pds: Refactor/simplify reset logic
The current logic for handling resets is more complicated than it needs
to be. The deferred_reset flag is used to indicate a reset is needed
and the deferred_reset_state is the requested, post-reset, state.
Also, the deferred_reset logic was added to vfio migration drivers to
prevent a circular locking dependency with respect to mm_lock and state
mutex. This is mainly because of the copy_to/from_user() functions(which
takes mm_lock) invoked under state mutex.
Remove all of the deferred reset logic and just pass the requested
next state to pds_vfio_reset() so it can be used for VMM and DSC
initiated resets.
This removes the need for pds_vfio_state_mutex_lock(), so remove that
and replace its use with a simple mutex_unlock().
Also, remove the reset_mutex as it's no longer needed since the
state_mutex can be the driver's primary protector.
Suggested-by: Shameer Kolothum <[email protected]>
Reviewed-by: Shannon Nelson <[email protected]>
Signed-off-by: Brett Creeley <[email protected]>
Link: https://lore.kernel.org/r/[email protected]
Signed-off-by: Alex Williamson <[email protected]>
Diffstat (limited to 'drivers/usb/cdns3/cdns3-trace.c')
0 files changed, 0 insertions, 0 deletions
