]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
scripts/gdb: fix aarch64 userspace detection in get_current_task
authorJan Kiszka <jan.kiszka@siemens.com>
Fri, 10 Jan 2025 10:36:33 +0000 (11:36 +0100)
committerAndrew Morton <akpm@linux-foundation.org>
Sat, 1 Feb 2025 11:53:24 +0000 (03:53 -0800)
At least recent gdb releases (seen with 14.2) return SP_EL0 as signed long
which lets the right-shift always return 0.

Link: https://lkml.kernel.org/r/dcd2fabc-9131-4b48-8419-6444e2d67454@siemens.com
Signed-off-by: Jan Kiszka <jan.kiszka@siemens.com>
Cc: Barry Song <baohua@kernel.org>
Cc: Kieran Bingham <kbingham@kernel.org>
Cc: <stable@vger.kernel.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
scripts/gdb/linux/cpus.py

index 2f11c4f9c345a0fba8fd79d021c2727dad1cb2de..13eb8b3901b8fc5e2500138c7d204ac5f7c9858c 100644 (file)
@@ -167,7 +167,7 @@ def get_current_task(cpu):
             var_ptr = gdb.parse_and_eval("&pcpu_hot.current_task")
             return per_cpu(var_ptr, cpu).dereference()
     elif utils.is_target_arch("aarch64"):
-        current_task_addr = gdb.parse_and_eval("$SP_EL0")
+        current_task_addr = gdb.parse_and_eval("(unsigned long)$SP_EL0")
         if (current_task_addr >> 63) != 0:
             current_task = current_task_addr.cast(task_ptr_type)
             return current_task.dereference()