public inbox for gdb-cvs@sourceware.org
help / color / mirror / Atom feed
* [binutils-gdb] gdb: LoongArch: Implement the get_syscall_number gdbarch method
@ 2024-02-06 10:50 Tiezhu Yang
  0 siblings, 0 replies; only message in thread
From: Tiezhu Yang @ 2024-02-06 10:50 UTC (permalink / raw)
  To: gdb-cvs

https://sourceware.org/git/gitweb.cgi?p=binutils-gdb.git;h=be908bd6e7fdcf0b91b949b152a063b5791856b5

commit be908bd6e7fdcf0b91b949b152a063b5791856b5
Author: Tiezhu Yang <yangtiezhu@loongson.cn>
Date:   Wed Jan 31 16:10:30 2024 +0800

    gdb: LoongArch: Implement the get_syscall_number gdbarch method
    
    In the current code, the feature 'catch syscall' is not supported
    on LoongArch, implement the "get_syscall_number" gdbarch method to
    get the system call number from the register a7.
    
    Without this patch:
    
    (gdb) catch syscall
    The feature 'catch syscall' is not supported on this architecture yet.
    
    Signed-off-by: Tiezhu Yang <yangtiezhu@loongson.cn>

Diff:
---
 gdb/loongarch-linux-tdep.c | 28 ++++++++++++++++++++++++++++
 1 file changed, 28 insertions(+)

diff --git a/gdb/loongarch-linux-tdep.c b/gdb/loongarch-linux-tdep.c
index 0e82c09b4ff..f1471d53ff4 100644
--- a/gdb/loongarch-linux-tdep.c
+++ b/gdb/loongarch-linux-tdep.c
@@ -534,6 +534,31 @@ loongarch_linux_syscall_next_pc (frame_info_ptr frame)
   return pc + 4;
 }
 
+/* Implement the "get_syscall_number" gdbarch method.  */
+
+static LONGEST
+loongarch_linux_get_syscall_number (struct gdbarch *gdbarch, thread_info *thread)
+{
+  struct regcache *regcache = get_thread_regcache (thread);
+  enum bfd_endian byte_order = gdbarch_byte_order (gdbarch);
+  int regsize = register_size (gdbarch, LOONGARCH_A7_REGNUM);
+  /* The content of a register.  */
+  gdb_byte buf[8];
+  /* The result.  */
+  LONGEST ret;
+
+  gdb_assert (regsize <= sizeof (buf));
+
+  /* Getting the system call number from the register.
+     When dealing with the LoongArch architecture, this information
+     is stored at the a7 register.  */
+  regcache->cooked_read (LOONGARCH_A7_REGNUM, buf);
+
+  ret = extract_signed_integer (buf, regsize, byte_order);
+
+  return ret;
+}
+
 /* Initialize LoongArch Linux ABI info.  */
 
 static void
@@ -564,6 +589,9 @@ loongarch_linux_init_abi (struct gdbarch_info info, struct gdbarch *gdbarch)
   set_gdbarch_iterate_over_regset_sections (gdbarch, loongarch_iterate_over_regset_sections);
 
   tdep->syscall_next_pc = loongarch_linux_syscall_next_pc;
+
+  /* Get the syscall number from the arch's register.  */
+  set_gdbarch_get_syscall_number (gdbarch, loongarch_linux_get_syscall_number);
 }
 
 /* Initialize LoongArch Linux target support.  */

^ permalink raw reply	[flat|nested] only message in thread

only message in thread, other threads:[~2024-02-06 10:50 UTC | newest]

Thread overview: (only message) (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2024-02-06 10:50 [binutils-gdb] gdb: LoongArch: Implement the get_syscall_number gdbarch method Tiezhu Yang

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).