]> www.infradead.org Git - users/jedix/linux-maple.git/commitdiff
sparc64: fix for user probes in high memory
authorEric Saint-Etienne <eric.saint.etienne@oracle.com>
Mon, 30 Jan 2017 12:27:49 +0000 (04:27 -0800)
committerChuck Anderson <chuck.anderson@oracle.com>
Thu, 9 Mar 2017 03:30:12 +0000 (19:30 -0800)
Orabug 25428066

When returning from the user probe code into userspace process, PC & NPC are
truncated to 32 bits.

As a result of shared libraries get loaded very high in the virtual address
space of the process, placing a user probe inside a shared library makes the
kernel return into the process at the wrong address, causing it to seg'fault
most of the time.

This patch prevents truncating PC and NPC.

Signed-off-by: Eric Saint Etienne <eric.saint.etienne@oracle.com>
Reviewed-by: David Aldridge <david.j.aldridge@oracle.com>
Signed-off-by: Allen Pais <allen.pais@oracle.com>
arch/sparc/include/asm/uprobes.h

index f87aae5a908e668a9d458a3c45724448b26bb72c..36196c17aff8ed886a4c1f6e11248ea06f8341b7 100644 (file)
@@ -42,8 +42,8 @@ struct arch_uprobe {
 };
 
 struct arch_uprobe_task {
-       u32 saved_tpc;
-       u32 saved_tnpc;
+       u64 saved_tpc;
+       u64 saved_tnpc;
 };
 
 struct task_struct;