This is a note to let you know that I've just added the patch titled powerpc/security: Fix Speculation_Store_Bypass reporting on Power10 to the 5.15-stable tree which can be found at: http://www.kernel.org/git/?p=linux/kernel/git/stable/stable-queue.git;a=summary The filename of the patch is: powerpc-security-fix-speculation_store_bypass-reporting-on-power10.patch and it can be found in the queue-5.15 subdirectory. If you, or anyone else, feels it should not be added to the stable tree, please let <stable@xxxxxxxxxxxxxxx> know about it. >From 5bcedc5931e7bd6928a2d8207078d4cb476b3b55 Mon Sep 17 00:00:00 2001 From: Michael Ellerman <mpe@xxxxxxxxxxxxxx> Date: Wed, 17 May 2023 17:49:45 +1000 Subject: powerpc/security: Fix Speculation_Store_Bypass reporting on Power10 From: Michael Ellerman <mpe@xxxxxxxxxxxxxx> commit 5bcedc5931e7bd6928a2d8207078d4cb476b3b55 upstream. Nageswara reported that /proc/self/status was showing "vulnerable" for the Speculation_Store_Bypass feature on Power10, eg: $ grep Speculation_Store_Bypass: /proc/self/status Speculation_Store_Bypass: vulnerable But at the same time the sysfs files, and lscpu, were showing "Not affected". This turns out to simply be a bug in the reporting of the Speculation_Store_Bypass, aka. PR_SPEC_STORE_BYPASS, case. When SEC_FTR_STF_BARRIER was added, so that firmware could communicate the vulnerability was not present, the code in ssb_prctl_get() was not updated to check the new flag. So add the check for SEC_FTR_STF_BARRIER being disabled. Rather than adding the new check to the existing if block and expanding the comment to cover both cases, rewrite the three cases to be separate so they can be commented separately for clarity. Fixes: 84ed26fd00c5 ("powerpc/security: Add a security feature for STF barrier") Cc: stable@xxxxxxxxxxxxxxx # v5.14+ Reported-by: Nageswara R Sastry <rnsastry@xxxxxxxxxxxxx> Tested-by: Nageswara R Sastry <rnsastry@xxxxxxxxxxxxx> Reviewed-by: Russell Currey <ruscur@xxxxxxxxxx> Signed-off-by: Michael Ellerman <mpe@xxxxxxxxxxxxxx> Link: https://msgid.link/20230517074945.53188-1-mpe@xxxxxxxxxxxxxx Signed-off-by: Greg Kroah-Hartman <gregkh@xxxxxxxxxxxxxxxxxxx> --- arch/powerpc/kernel/security.c | 35 ++++++++++++++++++----------------- 1 file changed, 18 insertions(+), 17 deletions(-) --- a/arch/powerpc/kernel/security.c +++ b/arch/powerpc/kernel/security.c @@ -363,26 +363,27 @@ ssize_t cpu_show_spec_store_bypass(struc static int ssb_prctl_get(struct task_struct *task) { + /* + * The STF_BARRIER feature is on by default, so if it's off that means + * firmware has explicitly said the CPU is not vulnerable via either + * the hypercall or device tree. + */ + if (!security_ftr_enabled(SEC_FTR_STF_BARRIER)) + return PR_SPEC_NOT_AFFECTED; + + /* + * If the system's CPU has no known barrier (see setup_stf_barrier()) + * then assume that the CPU is not vulnerable. + */ if (stf_enabled_flush_types == STF_BARRIER_NONE) - /* - * We don't have an explicit signal from firmware that we're - * vulnerable or not, we only have certain CPU revisions that - * are known to be vulnerable. - * - * We assume that if we're on another CPU, where the barrier is - * NONE, then we are not vulnerable. - */ return PR_SPEC_NOT_AFFECTED; - else - /* - * If we do have a barrier type then we are vulnerable. The - * barrier is not a global or per-process mitigation, so the - * only value we can report here is PR_SPEC_ENABLE, which - * appears as "vulnerable" in /proc. - */ - return PR_SPEC_ENABLE; - return -EINVAL; + /* + * Otherwise the CPU is vulnerable. The barrier is not a global or + * per-process mitigation, so the only value that can be reported here + * is PR_SPEC_ENABLE, which appears as "vulnerable" in /proc. + */ + return PR_SPEC_ENABLE; } int arch_prctl_spec_ctrl_get(struct task_struct *task, unsigned long which) Patches currently in stable-queue which might be from mpe@xxxxxxxxxxxxxx are queue-5.15/crypto-nx-fix-build-warnings-when-debug_fs-is-not-en.patch queue-5.15/watchdog-perf-define-dummy-watchdog_update_hrtimer_t.patch queue-5.15/soc-fsl-qe-fix-usb.c-build-errors.patch queue-5.15/powerpc-security-fix-speculation_store_bypass-reporting-on-power10.patch queue-5.15/powerpc-interrupt-don-t-read-msr-from-interrupt_exit.patch queue-5.15/powerpc-simplify-ppc_save_regs.patch queue-5.15/powerpc-64s-fix-vas-mm-use-after-free.patch queue-5.15/powerpc-fail-build-if-using-recordmcount-with-binutils-v2.37.patch queue-5.15/watchdog-perf-more-properly-prevent-false-positives-.patch queue-5.15/powerpc-mm-dax-fix-the-condition-when-checking-if-al.patch queue-5.15/powerpc-allow-ppc_early_debug_cpm-only-when-serial_c.patch queue-5.15/powerpc-signal32-force-inlining-of-__unsafe_save_use.patch queue-5.15/powerpc-update-ppc_save_regs-to-save-current-r1-in-p.patch queue-5.15/kcsan-don-t-expect-64-bits-atomic-builtins-from-32-b.patch queue-5.15/powerpc-book3s64-mm-fix-directmap-stats-in-proc-memi.patch queue-5.15/powerpc-powernv-sriov-perform-null-check-on-iov-befo.patch