]> git.ipfire.org Git - thirdparty/kernel/stable-queue.git/commitdiff
6.1-stable patches
authorGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 31 Jul 2024 06:08:27 +0000 (08:08 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 31 Jul 2024 06:08:27 +0000 (08:08 +0200)
added patches:
powerpc-pseries-avoid-hcall-in-plpks_is_available-on-non-pseries.patch

queue-6.1/powerpc-pseries-avoid-hcall-in-plpks_is_available-on-non-pseries.patch [new file with mode: 0644]
queue-6.1/series

diff --git a/queue-6.1/powerpc-pseries-avoid-hcall-in-plpks_is_available-on-non-pseries.patch b/queue-6.1/powerpc-pseries-avoid-hcall-in-plpks_is_available-on-non-pseries.patch
new file mode 100644 (file)
index 0000000..78f60c0
--- /dev/null
@@ -0,0 +1,44 @@
+From f82cdc37c4bd4ba905bf99ade9782a639b5c12e9 Mon Sep 17 00:00:00 2001
+From: Russell Currey <ruscur@russell.cc>
+Date: Wed, 22 Feb 2023 13:17:08 +1100
+Subject: powerpc/pseries: Avoid hcall in plpks_is_available() on non-pseries
+
+From: Russell Currey <ruscur@russell.cc>
+
+commit f82cdc37c4bd4ba905bf99ade9782a639b5c12e9 upstream.
+
+plpks_is_available() can be called on any platform via kexec but calls
+_plpks_get_config() which makes a hcall, which will only work on pseries.
+Fix this by returning early in plpks_is_available() if hcalls aren't
+possible.
+
+Fixes: 119da30d037d ("powerpc/pseries: Expose PLPKS config values, support additional fields")
+Reported-by: Murphy Zhou <jencce.kernel@gmail.com>
+Signed-off-by: Russell Currey <ruscur@russell.cc>
+Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
+Link: https://lore.kernel.org/r/20230222021708.146257-1-ruscur@russell.cc
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+---
+ arch/powerpc/platforms/pseries/plpks.c |    4 ++++
+ 1 file changed, 4 insertions(+)
+
+--- a/arch/powerpc/platforms/pseries/plpks.c
++++ b/arch/powerpc/platforms/pseries/plpks.c
+@@ -19,6 +19,7 @@
+ #include <asm/hvcall.h>
+ #include <asm/machdep.h>
+ #include <asm/plpks.h>
++#include <asm/firmware.h>
+ static u8 *ospassword;
+ static u16 ospasswordlength;
+@@ -357,6 +358,9 @@ bool plpks_is_available(void)
+ {
+       int rc;
++      if (!firmware_has_feature(FW_FEATURE_LPAR))
++              return false;
++
+       rc = _plpks_get_config();
+       if (rc)
+               return false;
index e891f43fff531b6f499d967f54f597c882059ed9..5a80f6be7e8ac2f665adff0124a9e437c75cae3a 100644 (file)
@@ -438,3 +438,4 @@ iommu-sprd-avoid-null-deref-in-sprd_iommu_hw_en.patch
 io_uring-fix-io_match_task-must_hold.patch
 nvme-pci-add-missing-condition-check-for-existence-o.patch
 fs-don-t-allow-non-init-s_user_ns-for-filesystems-wi.patch
+powerpc-pseries-avoid-hcall-in-plpks_is_available-on-non-pseries.patch