aboutsummaryrefslogtreecommitdiffstats
path: root/common/recipes-kernel/linux/files/0936-drm-amdgpu-Don-t-hang-in-amdgpu_flip_work_func-on-di.patch
diff options
context:
space:
mode:
Diffstat (limited to 'common/recipes-kernel/linux/files/0936-drm-amdgpu-Don-t-hang-in-amdgpu_flip_work_func-on-di.patch')
-rw-r--r--common/recipes-kernel/linux/files/0936-drm-amdgpu-Don-t-hang-in-amdgpu_flip_work_func-on-di.patch112
1 files changed, 0 insertions, 112 deletions
diff --git a/common/recipes-kernel/linux/files/0936-drm-amdgpu-Don-t-hang-in-amdgpu_flip_work_func-on-di.patch b/common/recipes-kernel/linux/files/0936-drm-amdgpu-Don-t-hang-in-amdgpu_flip_work_func-on-di.patch
deleted file mode 100644
index 751f78d0..00000000
--- a/common/recipes-kernel/linux/files/0936-drm-amdgpu-Don-t-hang-in-amdgpu_flip_work_func-on-di.patch
+++ /dev/null
@@ -1,112 +0,0 @@
-From e5602933b9f018623616e1fd14e2649f50fa7783 Mon Sep 17 00:00:00 2001
-From: Mario Kleiner <mario.kleiner.de@gmail.com>
-Date: Fri, 19 Feb 2016 02:06:39 +0100
-Subject: [PATCH 0936/1565] drm/amdgpu: Don't hang in amdgpu_flip_work_func on
- disabled crtc.
-MIME-Version: 1.0
-Content-Type: text/plain; charset=UTF-8
-Content-Transfer-Encoding: 8bit
-
-This fixes a regression introduced in Linux 4.4.
-
-This is a port of the same fix for radeon-kms in the
-patch "drm/radeon: Don't hang in radeon_flip_work_func
-on disabled crtc. (v2)"
-
-Limit the amount of time amdgpu_flip_work_func can
-delay programming a page flip, by both limiting the
-maximum amount of time per wait cycle and the maximum
-number of wait cycles. Continue the flip if the limit
-is exceeded, even if that may result in a visual or
-timing glitch.
-
-This is to prevent a hang of page flips, as reported
-in fdo bug #93746: Disconnecting a DisplayPort display
-in parallel to a kms pageflip getting queued can cause
-the following hang of page flips and thereby an unusable
-desktop:
-
-1. kms pageflip ioctl() queues pageflip -> queues execution
- of amdgpu_flip_work_func.
-
-2. Hotunplug of display causes the driver to DPMS OFF
- the unplugged display. Display engine shuts down,
- scanout no longer moves, but stays at its resting
- position at start line of vblank.
-
-3. amdgpu_flip_work_func executes while crtc is off, and
- due to the non-moving scanout position, the new flip
- delay code introduced into Linux 4.4 by
- commit 8e36f9d33c13 ("drm/amdgpu: Fixup hw vblank counter/ts..")
- enters an infinite wait loop.
-
-4. After reconnecting the display, the pageflip continues
- to hang in 3. and the display doesn't update its view
- of the desktop.
-
-This patch fixes the Linux 4.4 regression from fdo bug #93746
-
-<https://bugs.freedesktop.org/show_bug.cgi?id=93746>
-
-Reported-by: Bernd Steinhauser <linux@bernd-steinhauser.de>
-Signed-off-by: Mario Kleiner <mario.kleiner.de@gmail.com>
-
-Cc: <stable@vger.kernel.org> # 4.4+
-Cc: Michel Dänzer <michel.daenzer@amd.com>
-Cc: Alex Deucher <alexander.deucher@amd.com>
-Reviewed-by: Michel Dänzer <michel.daenzer@amd.com>
-Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
----
- drivers/gpu/drm/amd/amdgpu/amdgpu_display.c | 18 +++++++++++++++---
- 1 file changed, 15 insertions(+), 3 deletions(-)
-
-diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_display.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_display.c
-index 5580d34..0c713a9 100644
---- a/drivers/gpu/drm/amd/amdgpu/amdgpu_display.c
-+++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_display.c
-@@ -72,8 +72,8 @@ static void amdgpu_flip_work_func(struct work_struct *__work)
-
- struct drm_crtc *crtc = &amdgpuCrtc->base;
- unsigned long flags;
-- unsigned i;
-- int vpos, hpos, stat, min_udelay;
-+ unsigned i, repcnt = 4;
-+ int vpos, hpos, stat, min_udelay = 0;
- struct drm_vblank_crtc *vblank = &crtc->dev->vblank[work->crtc_id];
-
- amdgpu_flip_wait_fence(adev, &work->excl);
-@@ -96,7 +96,7 @@ static void amdgpu_flip_work_func(struct work_struct *__work)
- * In practice this won't execute very often unless on very fast
- * machines because the time window for this to happen is very small.
- */
-- for (;;) {
-+ while (amdgpuCrtc->enabled && repcnt--) {
- /* GET_DISTANCE_TO_VBLANKSTART returns distance to real vblank
- * start in hpos, and to the "fudged earlier" vblank start in
- * vpos.
-@@ -114,10 +114,22 @@ static void amdgpu_flip_work_func(struct work_struct *__work)
- /* Sleep at least until estimated real start of hw vblank */
- spin_unlock_irqrestore(&crtc->dev->event_lock, flags);
- min_udelay = (-hpos + 1) * max(vblank->linedur_ns / 1000, 5);
-+ if (min_udelay > vblank->framedur_ns / 2000) {
-+ /* Don't wait ridiculously long - something is wrong */
-+ repcnt = 0;
-+ break;
-+ }
- usleep_range(min_udelay, 2 * min_udelay);
- spin_lock_irqsave(&crtc->dev->event_lock, flags);
- };
-
-+ if (!repcnt)
-+ DRM_DEBUG_DRIVER("Delay problem on crtc %d: min_udelay %d, "
-+ "framedur %d, linedur %d, stat %d, vpos %d, "
-+ "hpos %d\n", work->crtc_id, min_udelay,
-+ vblank->framedur_ns / 1000,
-+ vblank->linedur_ns / 1000, stat, vpos, hpos);
-+
- /* do the flip (mmio) */
- adev->mode_info.funcs->page_flip(adev, work->crtc_id, work->base);
- /* set the flip status */
---
-1.9.1
-