diff options
author | Demi Marie Obenour <demi@invisiblethingslab.com> | 2022-06-22 05:27:26 +0300 |
---|---|---|
committer | Juergen Gross <jgross@suse.com> | 2022-06-23 16:29:18 +0300 |
commit | dbe97cff7dd9f0f75c524afdd55ad46be3d15295 (patch) | |
tree | 6cba9fb08860510bcb596ae1ee906c9c2934b88f /drivers/i2c | |
parent | ca6969013d13282b42cb5edcc13db731a08e0ad8 (diff) | |
download | linux-dbe97cff7dd9f0f75c524afdd55ad46be3d15295.tar.xz |
xen/gntdev: Avoid blocking in unmap_grant_pages()
unmap_grant_pages() currently waits for the pages to no longer be used.
In https://github.com/QubesOS/qubes-issues/issues/7481, this lead to a
deadlock against i915: i915 was waiting for gntdev's MMU notifier to
finish, while gntdev was waiting for i915 to free its pages. I also
believe this is responsible for various deadlocks I have experienced in
the past.
Avoid these problems by making unmap_grant_pages async. This requires
making it return void, as any errors will not be available when the
function returns. Fortunately, the only use of the return value is a
WARN_ON(), which can be replaced by a WARN_ON when the error is
detected. Additionally, a failed call will not prevent further calls
from being made, but this is harmless.
Because unmap_grant_pages is now async, the grant handle will be sent to
INVALID_GRANT_HANDLE too late to prevent multiple unmaps of the same
handle. Instead, a separate bool array is allocated for this purpose.
This wastes memory, but stuffing this information in padding bytes is
too fragile. Furthermore, it is necessary to grab a reference to the
map before making the asynchronous call, and release the reference when
the call returns.
It is also necessary to guard against reentrancy in gntdev_map_put(),
and to handle the case where userspace tries to map a mapping whose
contents have not all been freed yet.
Fixes: 745282256c75 ("xen/gntdev: safely unmap grants in case they are still in use")
Cc: stable@vger.kernel.org
Signed-off-by: Demi Marie Obenour <demi@invisiblethingslab.com>
Reviewed-by: Juergen Gross <jgross@suse.com>
Link: https://lore.kernel.org/r/20220622022726.2538-1-demi@invisiblethingslab.com
Signed-off-by: Juergen Gross <jgross@suse.com>
Diffstat (limited to 'drivers/i2c')
0 files changed, 0 insertions, 0 deletions