gdb: add target_ops::supports_displaced_step
[deliverable/binutils-gdb.git] / gdb / sol2-tdep.c
index 9e9358950f34b7c5d5af9717d343763c487c6f52..03b510c9adedbbbad25a6ba95d3190cefaff04ba 100644 (file)
@@ -1,6 +1,6 @@
 /* Target-dependent code for Solaris.
 
-   Copyright (C) 2006, 2007, 2008 Free Software Foundation, Inc.
+   Copyright (C) 2006-2020 Free Software Foundation, Inc.
 
    This file is part of GDB.
 
 #include "defs.h"
 #include "frame.h"
 #include "symtab.h"
+#include "inferior.h"
+#include "objfiles.h"
 
 #include "sol2-tdep.h"
 
 CORE_ADDR
 sol2_skip_solib_resolver (struct gdbarch *gdbarch, CORE_ADDR pc)
 {
-  struct minimal_symbol *msym;
+  struct bound_minimal_symbol msym;
 
   msym = lookup_minimal_symbol("elf_bndr", NULL, NULL);
-  if (msym && SYMBOL_VALUE_ADDRESS (msym) == pc)
-    return frame_pc_unwind (get_current_frame ());
+  if (msym.minsym && BMSYMBOL_VALUE_ADDRESS (msym) == pc)
+    return frame_unwind_caller_pc (get_current_frame ());
 
   return 0;
 }
+
+/* This is how we want PTIDs from Solaris core files to be
+   printed.  */
+
+std::string
+sol2_core_pid_to_str (struct gdbarch *gdbarch, ptid_t ptid)
+{
+  struct inferior *inf;
+  int pid;
+
+  /* Check whether we're printing an LWP (gdb thread) or a
+     process.  */
+  pid = ptid.lwp ();
+  if (pid != 0)
+    {
+      /* A thread.  */
+      return string_printf ("LWP %ld", ptid.lwp ());
+    }
+
+  /* GDB didn't use to put a NT_PSTATUS note in Solaris cores.  If
+     that's missing, then we're dealing with a fake PID corelow.c made
+     up.  */
+  inf = find_inferior_ptid (current_inferior ()->process_target (), ptid);
+  if (inf == NULL || inf->fake_pid_p)
+    return "<core>";
+
+  /* Not fake; print as usual.  */
+  return normal_pid_to_str (ptid);
+}
This page took 0.025359 seconds and 4 git commands to generate.