]> git.ipfire.org Git - thirdparty/kernel/stable-queue.git/commitdiff
4.4-stable patches
authorGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 4 Dec 2017 12:02:44 +0000 (13:02 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 4 Dec 2017 12:02:44 +0000 (13:02 +0100)
added patches:
drm-panel-simple-add-missing-panel_simple_unprepare-calls.patch
drm-radeon-fix-atombios-on-big-endian.patch
revert-drm-radeon-dont-switch-vt-on-suspend.patch

queue-4.4/drm-panel-simple-add-missing-panel_simple_unprepare-calls.patch [new file with mode: 0644]
queue-4.4/drm-radeon-fix-atombios-on-big-endian.patch [new file with mode: 0644]
queue-4.4/revert-drm-radeon-dont-switch-vt-on-suspend.patch [new file with mode: 0644]
queue-4.4/series

diff --git a/queue-4.4/drm-panel-simple-add-missing-panel_simple_unprepare-calls.patch b/queue-4.4/drm-panel-simple-add-missing-panel_simple_unprepare-calls.patch
new file mode 100644 (file)
index 0000000..1852cbe
--- /dev/null
@@ -0,0 +1,41 @@
+From f3621a8eb59a913612c8e6e37d81f16b649f8b6c Mon Sep 17 00:00:00 2001
+From: Jonathan Liu <net147@gmail.com>
+Date: Mon, 7 Aug 2017 21:55:45 +1000
+Subject: drm/panel: simple: Add missing panel_simple_unprepare() calls
+
+From: Jonathan Liu <net147@gmail.com>
+
+commit f3621a8eb59a913612c8e6e37d81f16b649f8b6c upstream.
+
+During panel removal or system shutdown panel_simple_disable() is called
+which disables the panel backlight but the panel is still powered due to
+missing calls to panel_simple_unprepare().
+
+Fixes: d02fd93e2cd8 ("drm/panel: simple - Disable panel on shutdown")
+Signed-off-by: Jonathan Liu <net147@gmail.com>
+Signed-off-by: Thierry Reding <treding@nvidia.com>
+Link: https://patchwork.freedesktop.org/patch/msgid/20170807115545.27747-1-net147@gmail.com
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+
+---
+ drivers/gpu/drm/panel/panel-simple.c |    2 ++
+ 1 file changed, 2 insertions(+)
+
+--- a/drivers/gpu/drm/panel/panel-simple.c
++++ b/drivers/gpu/drm/panel/panel-simple.c
+@@ -352,6 +352,7 @@ static int panel_simple_remove(struct de
+       drm_panel_remove(&panel->base);
+       panel_simple_disable(&panel->base);
++      panel_simple_unprepare(&panel->base);
+       if (panel->ddc)
+               put_device(&panel->ddc->dev);
+@@ -367,6 +368,7 @@ static void panel_simple_shutdown(struct
+       struct panel_simple *panel = dev_get_drvdata(dev);
+       panel_simple_disable(&panel->base);
++      panel_simple_unprepare(&panel->base);
+ }
+ static const struct drm_display_mode ampire_am800480r3tmqwa1h_mode = {
diff --git a/queue-4.4/drm-radeon-fix-atombios-on-big-endian.patch b/queue-4.4/drm-radeon-fix-atombios-on-big-endian.patch
new file mode 100644 (file)
index 0000000..d114ab3
--- /dev/null
@@ -0,0 +1,140 @@
+From 4f626a4ac8f57ddabf06d03870adab91e463217f Mon Sep 17 00:00:00 2001
+From: Roman Kapl <rka@sysgo.com>
+Date: Mon, 30 Oct 2017 11:56:13 +0100
+Subject: drm/radeon: fix atombios on big endian
+
+From: Roman Kapl <rka@sysgo.com>
+
+commit 4f626a4ac8f57ddabf06d03870adab91e463217f upstream.
+
+The function for byteswapping the data send to/from atombios was buggy for
+num_bytes not divisible by four. The function must be aware of the fact
+that after byte-swapping the u32 units, valid bytes might end up after the
+num_bytes boundary.
+
+This patch was tested on kernel 3.12 and allowed us to sucesfully use
+DisplayPort on and Radeon SI card. Namely it fixed the link training and
+EDID readout.
+
+The function is patched both in radeon and amd drivers, since the functions
+and the fixes are identical.
+
+Signed-off-by: Roman Kapl <rka@sysgo.com>
+Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+
+---
+ drivers/gpu/drm/amd/amdgpu/amdgpu_atombios.c |   38 ++++++++++++---------------
+ drivers/gpu/drm/radeon/atombios_dp.c         |   38 ++++++++++++---------------
+ 2 files changed, 36 insertions(+), 40 deletions(-)
+
+--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_atombios.c
++++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_atombios.c
+@@ -1575,34 +1575,32 @@ void amdgpu_atombios_scratch_regs_restor
+               WREG32(mmBIOS_SCRATCH_0 + i, adev->bios_scratch[i]);
+ }
+-/* Atom needs data in little endian format
+- * so swap as appropriate when copying data to
+- * or from atom. Note that atom operates on
+- * dw units.
++/* Atom needs data in little endian format so swap as appropriate when copying
++ * data to or from atom. Note that atom operates on dw units.
++ *
++ * Use to_le=true when sending data to atom and provide at least
++ * ALIGN(num_bytes,4) bytes in the dst buffer.
++ *
++ * Use to_le=false when receiving data from atom and provide ALIGN(num_bytes,4)
++ * byes in the src buffer.
+  */
+ void amdgpu_atombios_copy_swap(u8 *dst, u8 *src, u8 num_bytes, bool to_le)
+ {
+ #ifdef __BIG_ENDIAN
+-      u8 src_tmp[20], dst_tmp[20]; /* used for byteswapping */
+-      u32 *dst32, *src32;
++      u32 src_tmp[5], dst_tmp[5];
+       int i;
++      u8 align_num_bytes = ALIGN(num_bytes, 4);
+-      memcpy(src_tmp, src, num_bytes);
+-      src32 = (u32 *)src_tmp;
+-      dst32 = (u32 *)dst_tmp;
+       if (to_le) {
+-              for (i = 0; i < ((num_bytes + 3) / 4); i++)
+-                      dst32[i] = cpu_to_le32(src32[i]);
+-              memcpy(dst, dst_tmp, num_bytes);
++              memcpy(src_tmp, src, num_bytes);
++              for (i = 0; i < align_num_bytes / 4; i++)
++                      dst_tmp[i] = cpu_to_le32(src_tmp[i]);
++              memcpy(dst, dst_tmp, align_num_bytes);
+       } else {
+-              u8 dws = num_bytes & ~3;
+-              for (i = 0; i < ((num_bytes + 3) / 4); i++)
+-                      dst32[i] = le32_to_cpu(src32[i]);
+-              memcpy(dst, dst_tmp, dws);
+-              if (num_bytes % 4) {
+-                      for (i = 0; i < (num_bytes % 4); i++)
+-                              dst[dws+i] = dst_tmp[dws+i];
+-              }
++              memcpy(src_tmp, src, align_num_bytes);
++              for (i = 0; i < align_num_bytes / 4; i++)
++                      dst_tmp[i] = le32_to_cpu(src_tmp[i]);
++              memcpy(dst, dst_tmp, num_bytes);
+       }
+ #else
+       memcpy(dst, src, num_bytes);
+--- a/drivers/gpu/drm/radeon/atombios_dp.c
++++ b/drivers/gpu/drm/radeon/atombios_dp.c
+@@ -45,34 +45,32 @@ static char *pre_emph_names[] = {
+ /***** radeon AUX functions *****/
+-/* Atom needs data in little endian format
+- * so swap as appropriate when copying data to
+- * or from atom. Note that atom operates on
+- * dw units.
++/* Atom needs data in little endian format so swap as appropriate when copying
++ * data to or from atom. Note that atom operates on dw units.
++ *
++ * Use to_le=true when sending data to atom and provide at least
++ * ALIGN(num_bytes,4) bytes in the dst buffer.
++ *
++ * Use to_le=false when receiving data from atom and provide ALIGN(num_bytes,4)
++ * byes in the src buffer.
+  */
+ void radeon_atom_copy_swap(u8 *dst, u8 *src, u8 num_bytes, bool to_le)
+ {
+ #ifdef __BIG_ENDIAN
+-      u8 src_tmp[20], dst_tmp[20]; /* used for byteswapping */
+-      u32 *dst32, *src32;
++      u32 src_tmp[5], dst_tmp[5];
+       int i;
++      u8 align_num_bytes = ALIGN(num_bytes, 4);
+-      memcpy(src_tmp, src, num_bytes);
+-      src32 = (u32 *)src_tmp;
+-      dst32 = (u32 *)dst_tmp;
+       if (to_le) {
+-              for (i = 0; i < ((num_bytes + 3) / 4); i++)
+-                      dst32[i] = cpu_to_le32(src32[i]);
+-              memcpy(dst, dst_tmp, num_bytes);
++              memcpy(src_tmp, src, num_bytes);
++              for (i = 0; i < align_num_bytes / 4; i++)
++                      dst_tmp[i] = cpu_to_le32(src_tmp[i]);
++              memcpy(dst, dst_tmp, align_num_bytes);
+       } else {
+-              u8 dws = num_bytes & ~3;
+-              for (i = 0; i < ((num_bytes + 3) / 4); i++)
+-                      dst32[i] = le32_to_cpu(src32[i]);
+-              memcpy(dst, dst_tmp, dws);
+-              if (num_bytes % 4) {
+-                      for (i = 0; i < (num_bytes % 4); i++)
+-                              dst[dws+i] = dst_tmp[dws+i];
+-              }
++              memcpy(src_tmp, src, align_num_bytes);
++              for (i = 0; i < align_num_bytes / 4; i++)
++                      dst_tmp[i] = le32_to_cpu(src_tmp[i]);
++              memcpy(dst, dst_tmp, num_bytes);
+       }
+ #else
+       memcpy(dst, src, num_bytes);
diff --git a/queue-4.4/revert-drm-radeon-dont-switch-vt-on-suspend.patch b/queue-4.4/revert-drm-radeon-dont-switch-vt-on-suspend.patch
new file mode 100644 (file)
index 0000000..21b084b
--- /dev/null
@@ -0,0 +1,37 @@
+From 18c437caa5b18a235dd65cec224eab54bebcee65 Mon Sep 17 00:00:00 2001
+From: Alex Deucher <alexander.deucher@amd.com>
+Date: Tue, 14 Nov 2017 17:19:29 -0500
+Subject: Revert "drm/radeon: dont switch vt on suspend"
+MIME-Version: 1.0
+Content-Type: text/plain; charset=UTF-8
+Content-Transfer-Encoding: 8bit
+
+From: Alex Deucher <alexander.deucher@amd.com>
+
+commit 18c437caa5b18a235dd65cec224eab54bebcee65 upstream.
+
+Fixes distorted colors on some cards on resume from suspend.
+
+This reverts commit b9729b17a414f99c61f4db9ac9f9ed987fa0cbfe.
+
+Bug: https://bugs.freedesktop.org/show_bug.cgi?id=98832
+Bug: https://bugs.freedesktop.org/show_bug.cgi?id=99163
+Bug: https://bugzilla.kernel.org/show_bug.cgi?id=107001
+Reviewed-by: Michel Dänzer <michel.daenzer@amd.com>
+Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+
+---
+ drivers/gpu/drm/radeon/radeon_fb.c |    1 -
+ 1 file changed, 1 deletion(-)
+
+--- a/drivers/gpu/drm/radeon/radeon_fb.c
++++ b/drivers/gpu/drm/radeon/radeon_fb.c
+@@ -226,7 +226,6 @@ static int radeonfb_create(struct drm_fb
+       }
+       info->par = rfbdev;
+-      info->skip_vt_switch = true;
+       ret = radeon_framebuffer_init(rdev->ddev, &rfbdev->rfb, &mode_cmd, gobj);
+       if (ret) {
index 8d4dd58b3c139b524cfbd22e92b1955dfb1abdcb..77a5c0270eeb04163496c7cb3b725bbc1c975c46 100644 (file)
@@ -15,3 +15,6 @@ kvm-x86-inject-exceptions-produced-by-x86_decode_insn.patch
 mmc-core-do-not-leave-the-block-driver-in-a-suspended-state.patch
 eeprom-at24-check-at24_read-write-arguments.patch
 bcache-fix-building-error-on-mips.patch
+revert-drm-radeon-dont-switch-vt-on-suspend.patch
+drm-radeon-fix-atombios-on-big-endian.patch
+drm-panel-simple-add-missing-panel_simple_unprepare-calls.patch