Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/external/gpl3/gdb/dist/gdb Add "Xhandle*" interrupt handling.



details:   https://anonhg.NetBSD.org/src/rev/097f8a060ebe
branches:  trunk
changeset: 322201:097f8a060ebe
user:      christos <christos%NetBSD.org@localhost>
date:      Mon Apr 23 14:53:07 2018 +0000

description:
Add "Xhandle*" interrupt handling.

diffstat:

 external/gpl3/gdb/dist/gdb/amd64-nbsd-tdep.c |  47 +++++++++++++++++++--------
 external/gpl3/gdb/dist/gdb/i386-nbsd-tdep.c  |  26 ++++++++------
 2 files changed, 48 insertions(+), 25 deletions(-)

diffs (114 lines):

diff -r c81b63c20a4a -r 097f8a060ebe external/gpl3/gdb/dist/gdb/amd64-nbsd-tdep.c
--- a/external/gpl3/gdb/dist/gdb/amd64-nbsd-tdep.c      Mon Apr 23 10:35:20 2018 +0000
+++ b/external/gpl3/gdb/dist/gdb/amd64-nbsd-tdep.c      Mon Apr 23 14:53:07 2018 +0000
@@ -148,10 +148,21 @@
 
   /* There is an extra 'call' in the interrupt sequence - ignore the extra
    * return address */
-  if (name && strncmp (name, "Xintr", 5) == 0)
-    addr = sp + 8;             /* It's an interrupt frame.  */
-  else
-    addr = sp;
+
+  addr = sp;
+  if (name) {
+       if (strncmp (name, "Xintr", 5) == 0
+        || strncmp (name, "Xhandle", 7) == 0) {
+               addr += 8;              /* It's an interrupt frame.  */
+       }
+  }
+
+#ifdef DEBUG_TRAPFRAME
+  for (i = 0; i < 50; i++) {
+    cs = read_memory_unsigned_integer (addr + i * 8, 8, byte_order);
+    printf("%s i=%d r=%#jx\n", name, i, (intmax_t)cs);
+  }
+#endif
 
   for (i = 0; i < ARRAY_SIZE (amd64nbsd_tf_reg_offset); i++)
     if (amd64nbsd_tf_reg_offset[i] != -1)
@@ -163,6 +174,10 @@
   rip = read_memory_unsigned_integer (addr
     + amd64nbsd_tf_reg_offset[AMD64_RIP_REGNUM], 8, byte_order);
 
+#ifdef DEBUG_TRAPFRAME
+  printf("%s cs=%#jx rip=%#jx\n", name, (intmax_t)cs, (intmax_t)rip);
+#endif
+
   /* The trap frame layout was changed lf the %rip value is less than 2^16 it
    * is almost certainly the %ss of the old format. */
   if (rip < (1 << 16))
@@ -243,16 +258,20 @@
 
   find_pc_partial_function (get_frame_pc (this_frame), &name, NULL, NULL);
   return (name && ((strcmp (name, "alltraps") == 0)
-                  || (strcmp (name, "calltrap") == 0)
-                  || (strncmp (name, "Xtrap", 5) == 0)
-                  || (strcmp (name, "osyscall1") == 0)
-                  || (strcmp (name, "Xsyscall") == 0)
-                  || (strncmp (name, "Xintr", 5) == 0)
-                  || (strncmp (name, "Xresume", 7) == 0)
-                  || (strncmp (name, "Xstray", 6) == 0)
-                  || (strncmp (name, "Xrecurse", 8) == 0)
-                  || (strncmp (name, "Xsoft", 5) == 0)
-                  || (strcmp (name, "Xdoreti") == 0)));
+               || (strcmp (name, "calltrap") == 0)
+               || (strcmp (name, "handle_syscall") == 0)
+               || (strcmp (name, "Xdoreti") == 0)
+               || (strcmp (name, "Xspllower") == 0)
+               || (strncmp (name, "Xhandle", 7) == 0)
+               || (strncmp (name, "Xintr", 5) == 0)
+               || (strncmp (name, "Xpreempt", 8) == 0)
+               || (strncmp (name, "Xrecurse", 8) == 0)
+               || (strncmp (name, "Xresume", 7) == 0)
+               || (strncmp (name, "Xsoft", 5) == 0)
+               || (strncmp (name, "Xstray", 6) == 0)
+               || (strncmp (name, "Xsyscall", 8) == 0)
+               || (strncmp (name, "Xtrap", 5) == 0)
+           ));
 }
 
 static const struct frame_unwind amd64nbsd_trapframe_unwind = {
diff -r c81b63c20a4a -r 097f8a060ebe external/gpl3/gdb/dist/gdb/i386-nbsd-tdep.c
--- a/external/gpl3/gdb/dist/gdb/i386-nbsd-tdep.c       Mon Apr 23 10:35:20 2018 +0000
+++ b/external/gpl3/gdb/dist/gdb/i386-nbsd-tdep.c       Mon Apr 23 14:53:07 2018 +0000
@@ -312,7 +312,8 @@
   sp = get_frame_register_unsigned (this_frame, I386_ESP_REGNUM);
 
   find_pc_partial_function (func, &name, NULL, NULL);
-  if (name && strncmp (name, "Xintr", 5) == 0)
+  if (name && (strncmp (name, "Xintr", 5) == 0 ||
+               strncmp (name, "Xhandle", 7) == 0))
     {
       /* It's an interrupt frame. */
       tmp = read_memory_unsigned_integer (sp + 4, 4, byte_order);
@@ -391,16 +392,19 @@
 
   find_pc_partial_function (get_frame_pc (this_frame), &name, NULL, NULL);
   return (name && ((strcmp (name, "alltraps") == 0)
-                  || (strcmp (name, "calltrap") == 0)
-                  || (strncmp (name, "Xtrap", 5) == 0)
-                  || (strcmp (name, "syscall1") == 0)
-                  || (strcmp (name, "Xsyscall") == 0)
-                  || (strncmp (name, "Xintr", 5) == 0)
-                  || (strncmp (name, "Xresume", 7) == 0)
-                  || (strncmp (name, "Xstray", 6) == 0)
-                  || (strncmp (name, "Xrecurse", 8) == 0)
-                  || (strncmp (name, "Xsoft", 5) == 0)
-                  || (strncmp (name, "Xdoreti", 5) == 0)));
+               || (strcmp (name, "calltrap") == 0)
+               || (strcmp (name, "syscall1") == 0)
+               || (strcmp (name, "Xdoreti") == 0)
+               || (strncmp (name, "Xintr", 5) == 0)
+               || (strncmp (name, "Xhandle", 7) == 0)
+               || (strncmp (name, "Xpreempt", 8) == 0)
+               || (strncmp (name, "Xrecurse", 8) == 0)
+               || (strncmp (name, "Xresume", 7) == 0)
+               || (strncmp (name, "Xsoft", 5) == 0)
+               || (strncmp (name, "Xstray", 6) == 0)
+               || (strncmp (name, "Xsyscall", 8) == 0)
+               || (strncmp (name, "Xtrap", 5) == 0)
+           ));
 }
 
 const struct frame_unwind i386nbsd_trapframe_unwind = {



Home | Main Index | Thread Index | Old Index