[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20221113110630.y4uppv7d4ocm3lej@kamzik>
Date: Sun, 13 Nov 2022 12:06:30 +0100
From: Andrew Jones <ajones@...tanamicro.com>
To: debug@...osinc.com
Cc: palmer@...belt.com, jan.kiszka@...mens.com, kbingham@...nel.org,
paul.walmsley@...ive.com, aou@...s.berkeley.edu,
linux-kernel@...r.kernel.org, linux-riscv@...ts.infradead.org,
linux@...osinc.com
Subject: Re: [PATCH] gdb-script: updated lx_current for riscv
On Fri, Nov 11, 2022 at 11:59:38AM -0800, debug@...osinc.com wrote:
> From: Deepak Gupta <debug@...osinc.com>
>
> lx_current python gdb command defined in scripts/gdb/cpus.py updated
> to support riscv architecture.
>
> Signed-off-by: Deepak Gupta <debug@...osinc.com>
> ---
> scripts/gdb/linux/cpus.py | 8 ++++++++
> 1 file changed, 8 insertions(+)
>
> diff --git a/scripts/gdb/linux/cpus.py b/scripts/gdb/linux/cpus.py
> index 15fc4626d236..ce6703f1e35a 100644
> --- a/scripts/gdb/linux/cpus.py
> +++ b/scripts/gdb/linux/cpus.py
> @@ -173,6 +173,14 @@ def get_current_task(cpu):
> else:
> raise gdb.GdbError("Sorry, obtaining the current task is not allowed "
> "while running in userspace(EL0)")
> + elif utils.is_target_arch("riscv"):
> + current_task_addr = gdb.parse_and_eval("$tp")
> + if((current_task_addr.cast(utils.get_long_type()) >> 63) != 0):
Shouldn't there be a get_long_type().sizeof == 8 check somewhere before
shifting by 63? Or are 32-bit targets not supported at all for some
reason?
Thanks,
drew
> + current_task = current_task_addr.cast(task_ptr_type)
> + return current_task.dereference()
> + else:
> + raise gdb.GdbError("Sorry, obtaining the current task is not allowed "
> + "while running in userspace")
> else:
> raise gdb.GdbError("Sorry, obtaining the current task is not yet "
> "supported with this arch")
> --
> 2.25.1
>
>
> _______________________________________________
> linux-riscv mailing list
> linux-riscv@...ts.infradead.org
> http://lists.infradead.org/mailman/listinfo/linux-riscv
Powered by blists - more mailing lists