[PATCH v2] arm64: poe: fix stale POR_EL0 values for ptrace
Joey Gouly
joey.gouly at arm.com
Tue Jan 27 05:39:26 PST 2026
If a process wrote to POR_EL0 and then crashed before a context switch
happened, the coredump would contain an incorrect value for POR_EL0.
The value read in poe_get() would be a stale value left in thread.por_el0. Fix
this by reading the value from the system register, if the target thread is the
current thread.
This matches what gcs/fpsimd do.
Fixes: 175198199262 ("arm64/ptrace: add support for FEAT_POE")
Reported-by: David Spickett <david.spickett at arm.com>
Cc: stable at vger.kernel.org
Signed-off-by: Joey Gouly <joey.gouly at arm.com>
Cc: Kevin Brodsky <kevin.brodsky at arm.com>
Cc: Mark Rutland <mark.rutland at arm.com>
Reviewed-by: Kevin Brodsky <kevin.brodsky at arm.com>
Acked-by: Mark Rutland <mark.rutland at arm.com>
---
arch/arm64/kernel/ptrace.c | 3 +++
1 file changed, 3 insertions(+)
diff --git a/arch/arm64/kernel/ptrace.c b/arch/arm64/kernel/ptrace.c
index b9bdd83fbbca..8a14b86cd066 100644
--- a/arch/arm64/kernel/ptrace.c
+++ b/arch/arm64/kernel/ptrace.c
@@ -1486,6 +1486,9 @@ static int poe_get(struct task_struct *target,
if (!system_supports_poe())
return -EINVAL;
+ if (target == current)
+ current->thread.por_el0 = read_sysreg_s(SYS_POR_EL0);
+
return membuf_write(&to, &target->thread.por_el0,
sizeof(target->thread.por_el0));
}
--
2.25.1
More information about the linux-arm-kernel
mailing list