[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v2 60/71] linux-user/aarch64: Reset PSTATE.SM on syscalls
From: |
Richard Henderson |
Subject: |
[PATCH v2 60/71] linux-user/aarch64: Reset PSTATE.SM on syscalls |
Date: |
Tue, 7 Jun 2022 13:32:55 -0700 |
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
---
linux-user/aarch64/cpu_loop.c | 9 +++++++++
1 file changed, 9 insertions(+)
diff --git a/linux-user/aarch64/cpu_loop.c b/linux-user/aarch64/cpu_loop.c
index 3b273f6299..4af6996d57 100644
--- a/linux-user/aarch64/cpu_loop.c
+++ b/linux-user/aarch64/cpu_loop.c
@@ -89,6 +89,15 @@ void cpu_loop(CPUARMState *env)
switch (trapnr) {
case EXCP_SWI:
+ /*
+ * On syscall, PSTATE.ZA is preserved, along with the ZA matrix.
+ * PSTATE.SM is cleared, per SMSTOP, which does ResetSVEState.
+ */
+ if (FIELD_EX64(env->svcr, SVCR, SM)) {
+ env->svcr = FIELD_DP64(env->svcr, SVCR, SM, 0);
+ arm_rebuild_hflags(env);
+ arm_reset_sve_state(env);
+ }
ret = do_syscall(env,
env->xregs[8],
env->xregs[0],
--
2.34.1
- [PATCH v2 54/71] target/arm: Implement PSEL, (continued)
- [PATCH v2 54/71] target/arm: Implement PSEL, Richard Henderson, 2022/06/07
- [PATCH v2 50/71] target/arm: Implement FMOPA, FMOPS (non-widening), Richard Henderson, 2022/06/07
- [PATCH v2 52/71] target/arm: Implement FMOPA, FMOPS (widening), Richard Henderson, 2022/06/07
- [PATCH v2 57/71] target/arm: Reset streaming sve state on exception boundaries, Richard Henderson, 2022/06/07
- [PATCH v2 59/71] linux-user/aarch64: Clear tpidr2_el0 if CLONE_SETTLS, Richard Henderson, 2022/06/07
- [PATCH v2 61/71] linux-user/aarch64: Add SM bit to SVE signal context, Richard Henderson, 2022/06/07
- [PATCH v2 55/71] target/arm: Implement REVD, Richard Henderson, 2022/06/07
- [PATCH v2 56/71] target/arm: Implement SCLAMP, UCLAMP, Richard Henderson, 2022/06/07
- [PATCH v2 58/71] target/arm: Enable SME for -cpu max, Richard Henderson, 2022/06/07
- [PATCH v2 62/71] linux-user/aarch64: Tidy target_restore_sigframe error return, Richard Henderson, 2022/06/07
- [PATCH v2 60/71] linux-user/aarch64: Reset PSTATE.SM on syscalls,
Richard Henderson <=
- [PATCH v2 65/71] linux-user/aarch64: Move sve record checks into restore, Richard Henderson, 2022/06/07
- [PATCH v2 63/71] linux-user/aarch64: Do not allow duplicate or short sve records, Richard Henderson, 2022/06/07
- [PATCH v2 64/71] linux-user/aarch64: Verify extra record lock succeeded, Richard Henderson, 2022/06/07
- [PATCH v2 67/71] linux-user: Rename sve prctls, Richard Henderson, 2022/06/07
- [PATCH v2 68/71] linux-user/aarch64: Implement PR_SME_GET_VL, PR_SME_SET_VL, Richard Henderson, 2022/06/07
- [PATCH v2 66/71] linux-user/aarch64: Implement SME signal handling, Richard Henderson, 2022/06/07
- [PATCH v2 71/71] linux-user/aarch64: Add SME related hwcap entries, Richard Henderson, 2022/06/07
- [PATCH v2 69/71] target/arm: Only set ZEN in reset if SVE present, Richard Henderson, 2022/06/07
- [PATCH v2 70/71] target/arm: Enable SME for user-only, Richard Henderson, 2022/06/07
- Re: [PATCH v2 00/71] target/arm: Scalable Matrix Extension, Peter Maydell, 2022/06/09