]> git.baikalelectronics.ru Git - kernel.git/commit
drm/ttm: fix use-after-free races in vm fault handling
authorNicolai Hähnle <nicolai.haehnle@amd.com>
Sat, 18 Feb 2017 21:59:56 +0000 (22:59 +0100)
committerAlex Deucher <alexander.deucher@amd.com>
Tue, 21 Feb 2017 21:48:45 +0000 (16:48 -0500)
commit5461775cc6b327065d46dd5058f40a57bde16dfc
treedfcf8846b214b4b340ed5eac64cc1810219d4ecb
parent26412cae801ed87bea7f1e6e15471466b0c0192c
drm/ttm: fix use-after-free races in vm fault handling

The vm fault handler relies on the fact that the VMA owns a reference
to the BO. However, once mmap_sem is released, other tasks are free to
destroy the VMA, which can lead to the BO being freed. Fix two code
paths where that can happen, both related to vm fault retries.

Found via a lock debugging warning which flagged &bo->wu_mutex as
locked while being destroyed.

Fixes: 02f4040a295c ("drm/ttm: Allow vm fault retries")
Signed-off-by: Nicolai Hähnle <nicolai.haehnle@amd.com>
Reviewed-by: Christian König <christian.koenig@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/ttm/ttm_bo_vm.c