drm/amd/display: Fix race.
authorAndrey Grodzovsky <Andrey.Grodzovsky@amd.com>
Fri, 5 May 2017 15:30:06 +0000 (11:30 -0400)
committerAlex Deucher <alexander.deucher@amd.com>
Tue, 26 Sep 2017 22:07:00 +0000 (18:07 -0400)
Problem :
A race between two adjecent page flips makes the earlier one
to release an alocated frame buffer for the subsequent one -
since there are 2 frambuffer swapped back and forth between flips,
the 'new' fb of the later flip is actually the 'previous' fb for the earlier flip.
Fix:
Don't set fb->address = 0 in cleanup hook, this is unnecessery and
erases the newly cached adress that was set in prepare_fb of the second
flip.

Signed-off-by: Andrey Grodzovsky <Andrey.Grodzovsky@amd.com>
Reviewed-by: Andrey Grodzovsky <Andrey.Grodzovsky@amd.com>
Acked-by: Harry Wentland <Harry.Wentland@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm_types.c

index 6bd8048ba21ee5cff899092cc66d95d6528879e3..9c0dc9d0762601bbe3d7c9dfedce8e487281d1da 100644 (file)
@@ -1622,9 +1622,7 @@ static void dm_plane_helper_cleanup_fb(
                amdgpu_bo_unpin(rbo);
                amdgpu_bo_unreserve(rbo);
                amdgpu_bo_unref(&rbo);
-       }
-
-       afb->address = 0;
+       };
 }
 
 int dm_create_validation_set_for_connector(struct drm_connector *connector,