From Peter Schauer: Fix Solaris/x86 threads by copying linux code.
authorAndrew Cagney <cagney@redhat.com>
Tue, 29 Feb 2000 13:53:59 +0000 (13:53 +0000)
committerAndrew Cagney <cagney@redhat.com>
Tue, 29 Feb 2000 13:53:59 +0000 (13:53 +0000)
gdb/ChangeLog
gdb/inferior.h
gdb/procfs.c
gdb/sol-thread.c

index 420316a4f33f27b7f485c848f67fb8ddd3fe3830..9f8b50c800e9db162e681a5e545ad69f4afb3be9 100644 (file)
@@ -1,3 +1,13 @@
+Wed Mar  1 00:49:06 2000  Andrew Cagney  <cagney@b1.cygnus.com>
+
+       From 2000-02-28 Peter Schauer <pes@regent.e-technik.tu-muenchen.de>:
+       Make NEW_PROC_ABI interface functional on Solaris x86.
+       * sol-thread.c (ps_lgetLDT): Rewrite to use new
+       procfs_find_LDT_entry function from procfs.c, mostly copied from
+       lin-thread.c.
+       * inferior.h, procfs.c (procfs_get_pid_fd): Removed, no longer
+       needed.
+
 Wed Mar  1 00:34:55 2000  Andrew Cagney  <cagney@b1.cygnus.com>
 
        From 2000-02-26 Peter Schauer <pes@regent.e-technik.tu-muenchen.de>:
index 38c9ed625449886ff812ef9c651614d4d20c30a8..5965f045ee8e7b1d2a39ee96894d4825f6394e3f 100644 (file)
@@ -224,8 +224,6 @@ extern int proc_iterate_over_mappings PARAMS ((int (*)(int, CORE_ADDR)));
 
 extern int procfs_first_available PARAMS ((void));
 
-extern int procfs_get_pid_fd PARAMS ((int));
-
 /* From fork-child.c */
 
 extern void fork_inferior PARAMS ((char *, char *, char **,
index b108078349871da592b9351d324a68511c3809b6..257de1291d1ac9565e41efcacd92eabfcf3b46f3 100644 (file)
@@ -5254,20 +5254,3 @@ procfs_first_available ()
   else
     return -1;
 }
-
-int
-procfs_get_pid_fd (pid)
-     int pid;
-{
-  procinfo *pi;
-
-  if (pid == -1 && inferior_pid != 0)
-    pi = find_procinfo (PIDGET (inferior_pid), 0);
-  else
-    pi = find_procinfo (PIDGET (pid), 0);
-
-  if (pi)
-    return pi->ctl_fd;
-  else
-    return -1;
-}
index 71e92167bdfa149419f0fad4cc1fec462355c9ab..0ec10a46f70c1740ff3b63e536e5a4ad8d4cc6be 100644 (file)
@@ -1318,61 +1318,24 @@ ps_lsetfpregs (gdb_ps_prochandle_t ph, lwpid_t lwpid,
 
 #ifdef TM_I386SOL2_H
 
-/* Get local descriptor table.  */
-
-#include <sys/procfs.h>
-#include <sys/reg.h>
-#include <sys/sysi86.h>
-
-static int nldt_allocated = 0;
-static struct ssd *ldt_bufp = NULL;
-
 /* Reads the local descriptor table of a LWP.  */
 
 ps_err_e
 ps_lgetLDT (gdb_ps_prochandle_t ph, lwpid_t lwpid,
            struct ssd *pldt)
 {
-  gregset_t gregset;
-  int lwp_fd;
-  ps_err_e val;
-  int nldt;
-  int i;
-
-  /* Get procfs file descriptor for the LWP.  */
-  lwp_fd = procfs_get_pid_fd (BUILD_LWP (lwpid, PIDGET (inferior_pid)));
-  if (lwp_fd < 0)
-    return PS_BADLID;
-
-  /* Fetch registers und LDT descriptors.  */
-  if (ioctl (lwp_fd, PIOCGREG, &gregset) == -1)
-    return PS_ERR;
+  /* NOTE: only used on Solaris, therefore OK to refer to procfs.c */
+  extern struct ssd *procfs_find_LDT_entry (int);
+  struct ssd *ret;
 
-  if (ioctl (lwp_fd, PIOCNLDT, &nldt) == -1)
-    return PS_ERR;
-
-  if (nldt_allocated < nldt)
+  ret = procfs_find_LDT_entry (BUILD_LWP (lwpid, PIDGET (inferior_pid)));
+  if (ret)
     {
-      ldt_bufp
-       = (struct ssd *) xrealloc (ldt_bufp, (nldt + 1) * sizeof (struct ssd));
-      nldt_allocated = nldt;
+      memcpy (pldt, ret, sizeof (struct ssd));
+      return PS_OK;
     }
-
-  if (ioctl (lwp_fd, PIOCLDT, ldt_bufp) == -1)
+  else /* LDT not found. */
     return PS_ERR;
-
-  /* Search LDT for the LWP via register GS.  */
-  for (i = 0; i < nldt; i++)
-    {
-      if (ldt_bufp[i].sel == (gregset[GS] & 0xffff))
-       {
-         *pldt = ldt_bufp[i];
-         return PS_OK;
-       }
-    }
-
-  /* LDT not found.  */
-  return PS_ERR;
 }
 #endif /* TM_I386SOL2_H */
 \f