]> git.ipfire.org Git - thirdparty/kernel/stable-queue.git/commitdiff
5.14-stable patches
authorGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 15 Nov 2021 16:16:16 +0000 (17:16 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 15 Nov 2021 16:16:16 +0000 (17:16 +0100)
added patches:
drm-amd-display-look-at-firmware-version-to-determine-using-dmub-on-dcn21.patch

queue-5.14/drm-amd-display-look-at-firmware-version-to-determine-using-dmub-on-dcn21.patch [new file with mode: 0644]
queue-5.14/series

diff --git a/queue-5.14/drm-amd-display-look-at-firmware-version-to-determine-using-dmub-on-dcn21.patch b/queue-5.14/drm-amd-display-look-at-firmware-version-to-determine-using-dmub-on-dcn21.patch
new file mode 100644 (file)
index 0000000..c91c712
--- /dev/null
@@ -0,0 +1,50 @@
+From 91adec9e07097e538691daed5d934e7886dd1dc3 Mon Sep 17 00:00:00 2001
+From: Mario Limonciello <mario.limonciello@amd.com>
+Date: Tue, 2 Nov 2021 10:04:37 -0500
+Subject: drm/amd/display: Look at firmware version to determine using dmub on dcn21
+
+From: Mario Limonciello <mario.limonciello@amd.com>
+
+commit 91adec9e07097e538691daed5d934e7886dd1dc3 upstream.
+
+commit 652de07addd2 ("drm/amd/display: Fully switch to dmub for all dcn21
+asics") switched over to using dmub on Renoir to fix Gitlab 1735, but this
+implied a new dependency on newer firmware which might not be met on older
+kernel versions.
+
+Since sw_init runs before hw_init, there is an opportunity to determine
+whether or not the firmware version is new to adjust the behavior.
+
+Cc: Roman.Li@amd.com
+BugLink: https://gitlab.freedesktop.org/drm/amd/-/issues/1772
+BugLink: https://gitlab.freedesktop.org/drm/amd/-/issues/1735
+Fixes: 652de07addd2 ("drm/amd/display: Fully switch to dmub for all dcn21 asics")
+Signed-off-by: Mario Limonciello <mario.limonciello@amd.com>
+Acked-by: Alex Deucher <alexander.deucher@amd.com>
+Reviewed-by: Roman Li <Roman.Li@amd.com>
+Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+
+---
+ drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c |    9 ++++++++-
+ 1 file changed, 8 insertions(+), 1 deletion(-)
+
+--- a/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c
++++ b/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c
+@@ -1143,8 +1143,15 @@ static int amdgpu_dm_init(struct amdgpu_
+       case CHIP_RAVEN:
+       case CHIP_RENOIR:
+               init_data.flags.gpu_vm_support = true;
+-              if (ASICREV_IS_GREEN_SARDINE(adev->external_rev_id))
++              switch (adev->dm.dmcub_fw_version) {
++              case 0: /* development */
++              case 0x1: /* linux-firmware.git hash 6d9f399 */
++              case 0x01000000: /* linux-firmware.git hash 9a0b0f4 */
++                      init_data.flags.disable_dmcu = false;
++                      break;
++              default:
+                       init_data.flags.disable_dmcu = true;
++              }
+               break;
+       case CHIP_VANGOGH:
+       case CHIP_YELLOW_CARP:
index 712592a6b767e4e3584306b07583c8e5c6fc8605..099858002d220407e785dcc704fa66189d8f8820 100644 (file)
@@ -846,3 +846,4 @@ pci-aardvark-fix-pcie-max-payload-size-setting.patch
 sunrpc-partial-revert-of-commit-6f9f17287e78.patch
 pinctrl-amd-add-irq-field-data.patch
 pinctrl-amd-handle-wake-up-interrupt.patch
+drm-amd-display-look-at-firmware-version-to-determine-using-dmub-on-dcn21.patch