All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] arm64/sme: Fix EFI save/restore
@ 2022-06-02  9:45 Mark Brown
  2022-06-02 12:17 ` Catalin Marinas
  0 siblings, 1 reply; 2+ messages in thread
From: Mark Brown @ 2022-06-02  9:45 UTC (permalink / raw)
  To: Catalin Marinas, Will Deacon
  Cc: linux-arm-kernel, Mark Brown, kernel test robot

The EFI save/restore code is confused. When saving the check for saving
FFR is inverted due to confusion with the streaming mode check, and when
restoring we check if we need to restore FFR by checking the percpu
efi_sm_state without the required wrapper rather than based on the
combination of FA64 support and streaming mode.

Fixes: e0838f6373e5 ("arm64/sme: Save and restore streaming mode over EFI runtime calls")
Reported-by: kernel test robot <lkp@intel.com>
Signed-off-by: Mark Brown <broonie@kernel.org>
---

Compile tested only at this point.

 arch/arm64/kernel/fpsimd.c | 9 +++++----
 1 file changed, 5 insertions(+), 4 deletions(-)

diff --git a/arch/arm64/kernel/fpsimd.c b/arch/arm64/kernel/fpsimd.c
index 819979398127..3c66a061ff6f 100644
--- a/arch/arm64/kernel/fpsimd.c
+++ b/arch/arm64/kernel/fpsimd.c
@@ -1916,10 +1916,11 @@ void __efi_fpsimd_begin(void)
 			if (system_supports_sme()) {
 				svcr = read_sysreg_s(SYS_SVCR);
 
-				if (!system_supports_fa64())
-					ffr = svcr & SVCR_SM_MASK;
+				__this_cpu_write(efi_sm_state,
+						 svcr & SVCR_SM_MASK);
 
-				__this_cpu_write(efi_sm_state, ffr);
+				if (!system_supports_fa64())
+					ffr = !(svcr & SVCR_SM_MASK);
 			}
 
 			sve_save_state(sve_state + sve_ffr_offset(sve_max_vl()),
@@ -1965,7 +1966,7 @@ void __efi_fpsimd_end(void)
 							   0,
 							   SVCR_SM_MASK);
 					if (!system_supports_fa64())
-						ffr = efi_sm_state;
+						ffr = false;
 				}
 			}
 
-- 
2.30.2


_______________________________________________
linux-arm-kernel mailing list
linux-arm-kernel@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-arm-kernel

^ permalink raw reply related	[flat|nested] 2+ messages in thread

* Re: [PATCH] arm64/sme: Fix EFI save/restore
  2022-06-02  9:45 [PATCH] arm64/sme: Fix EFI save/restore Mark Brown
@ 2022-06-02 12:17 ` Catalin Marinas
  0 siblings, 0 replies; 2+ messages in thread
From: Catalin Marinas @ 2022-06-02 12:17 UTC (permalink / raw)
  To: Mark Brown; +Cc: Will Deacon, linux-arm-kernel, kernel test robot

On Thu, Jun 02, 2022 at 11:45:44AM +0200, Mark Brown wrote:
> diff --git a/arch/arm64/kernel/fpsimd.c b/arch/arm64/kernel/fpsimd.c
> index 819979398127..3c66a061ff6f 100644
> --- a/arch/arm64/kernel/fpsimd.c
> +++ b/arch/arm64/kernel/fpsimd.c
> @@ -1916,10 +1916,11 @@ void __efi_fpsimd_begin(void)
>  			if (system_supports_sme()) {
>  				svcr = read_sysreg_s(SYS_SVCR);
>  
> -				if (!system_supports_fa64())
> -					ffr = svcr & SVCR_SM_MASK;
> +				__this_cpu_write(efi_sm_state,
> +						 svcr & SVCR_SM_MASK);
>  
> -				__this_cpu_write(efi_sm_state, ffr);
> +				if (!system_supports_fa64())
> +					ffr = !(svcr & SVCR_SM_MASK);
>  			}
>  
>  			sve_save_state(sve_state + sve_ffr_offset(sve_max_vl()),
> @@ -1965,7 +1966,7 @@ void __efi_fpsimd_end(void)
>  							   0,
>  							   SVCR_SM_MASK);
>  					if (!system_supports_fa64())
> -						ffr = efi_sm_state;
> +						ffr = false;
>  				}
>  			}

This looks fine to me:

Reviewed-by: Catalin Marinas <catalin.marinas@arm.com>

Please add some comments to the code for when we need to save/restore
the FFR state and let me know when you got a chance to test it so that I
can send it upstream.

Thanks.

-- 
Catalin

_______________________________________________
linux-arm-kernel mailing list
linux-arm-kernel@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-arm-kernel

^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2022-06-02 12:18 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2022-06-02  9:45 [PATCH] arm64/sme: Fix EFI save/restore Mark Brown
2022-06-02 12:17 ` Catalin Marinas

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.