Remove relational operators from common/offset-type.h
[external/binutils.git] / gdb / procfs.c
1 /* Machine independent support for Solaris /proc (process file system) for GDB.
2
3    Copyright (C) 1999-2018 Free Software Foundation, Inc.
4
5    Written by Michael Snyder at Cygnus Solutions.
6    Based on work by Fred Fish, Stu Grossman, Geoff Noer, and others.
7
8    This file is part of GDB.
9
10    This program is free software; you can redistribute it and/or modify
11    it under the terms of the GNU General Public License as published by
12    the Free Software Foundation; either version 3 of the License, or
13    (at your option) any later version.
14
15    This program is distributed in the hope that it will be useful,
16    but WITHOUT ANY WARRANTY; without even the implied warranty of
17    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18    GNU General Public License for more details.
19
20    You should have received a copy of the GNU General Public License
21    along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
22
23 #include "defs.h"
24 #include "inferior.h"
25 #include "infrun.h"
26 #include "target.h"
27 #include "gdbcore.h"
28 #include "elf-bfd.h"            /* for elfcore_write_* */
29 #include "gdbcmd.h"
30 #include "gdbthread.h"
31 #include "regcache.h"
32 #include "inf-child.h"
33 #include "nat/fork-inferior.h"
34 #include "filestuff.h"
35
36 #define _STRUCTURED_PROC 1      /* Should be done by configure script.  */
37
38 #include <sys/procfs.h>
39 #include <sys/fault.h>
40 #include <sys/syscall.h>
41 #include "gdb_wait.h"
42 #include <signal.h>
43 #include <ctype.h>
44 #include "gdb_bfd.h"
45 #include "inflow.h"
46 #include "auxv.h"
47 #include "procfs.h"
48 #include "observable.h"
49 #include "common/scoped_fd.h"
50 #include "common/pathstuff.h"
51
52 /* This module provides the interface between GDB and the
53    /proc file system, which is used on many versions of Unix
54    as a means for debuggers to control other processes.
55
56    /proc works by imitating a file system: you open a simulated file
57    that represents the process you wish to interact with, and perform
58    operations on that "file" in order to examine or change the state
59    of the other process.
60
61    The most important thing to know about /proc and this module is
62    that there are two very different interfaces to /proc:
63
64      One that uses the ioctl system call, and another that uses read
65      and write system calls.
66
67    This module supports only the Solaris version of the read/write
68    interface.  */
69
70 #include <sys/types.h>
71 #include <dirent.h>     /* opendir/readdir, for listing the LWP's */
72
73 #include <fcntl.h>      /* for O_RDONLY */
74 #include <unistd.h>     /* for "X_OK" */
75 #include <sys/stat.h>   /* for struct stat */
76
77 /* Note: procfs-utils.h must be included after the above system header
78    files, because it redefines various system calls using macros.
79    This may be incompatible with the prototype declarations.  */
80
81 #include "proc-utils.h"
82
83 /* Prototypes for supply_gregset etc.  */
84 #include "gregset.h"
85
86 /* =================== TARGET_OPS "MODULE" =================== */
87
88 /* This module defines the GDB target vector and its methods.  */
89
90
91 static enum target_xfer_status procfs_xfer_memory (gdb_byte *,
92                                                    const gdb_byte *,
93                                                    ULONGEST, ULONGEST,
94                                                    ULONGEST *);
95
96 class procfs_target final : public inf_child_target
97 {
98 public:
99   void create_inferior (const char *, const std::string &,
100                         char **, int) override;
101
102   void kill () override;
103
104   void mourn_inferior () override;
105
106   void attach (const char *, int) override;
107   void detach (inferior *inf, int) override;
108
109   void resume (ptid_t, int, enum gdb_signal) override;
110   ptid_t wait (ptid_t, struct target_waitstatus *, int) override;
111
112   void fetch_registers (struct regcache *, int) override;
113   void store_registers (struct regcache *, int) override;
114
115   enum target_xfer_status xfer_partial (enum target_object object,
116                                         const char *annex,
117                                         gdb_byte *readbuf,
118                                         const gdb_byte *writebuf,
119                                         ULONGEST offset, ULONGEST len,
120                                         ULONGEST *xfered_len) override;
121
122   void pass_signals (int, unsigned char *) override;
123
124   void files_info () override;
125
126   void update_thread_list () override;
127
128   bool thread_alive (ptid_t ptid) override;
129
130   const char *pid_to_str (ptid_t) override;
131
132   char *pid_to_exec_file (int pid) override;
133
134   thread_control_capabilities get_thread_control_capabilities () override
135   { return tc_schedlock; }
136
137   /* find_memory_regions support method for gcore */
138   int find_memory_regions (find_memory_region_ftype func, void *data)
139     override;
140
141   char *make_corefile_notes (bfd *, int *) override;
142
143   bool info_proc (const char *, enum info_proc_what) override;
144
145 #if PR_MODEL_NATIVE == PR_MODEL_LP64
146   int auxv_parse (gdb_byte **readptr,
147                   gdb_byte *endptr, CORE_ADDR *typep, CORE_ADDR *valp)
148     override;
149 #endif
150
151   bool stopped_by_watchpoint () override;
152
153   int insert_watchpoint (CORE_ADDR, int, enum target_hw_bp_type,
154                          struct expression *) override;
155
156   int remove_watchpoint (CORE_ADDR, int, enum target_hw_bp_type,
157                          struct expression *) override;
158
159   int region_ok_for_hw_watchpoint (CORE_ADDR, int) override;
160
161   int can_use_hw_breakpoint (enum bptype, int, int) override;
162   bool stopped_data_address (CORE_ADDR *) override;
163 };
164
165 static procfs_target the_procfs_target;
166
167 #if PR_MODEL_NATIVE == PR_MODEL_LP64
168 /* When GDB is built as 64-bit application on Solaris, the auxv data
169    is presented in 64-bit format.  We need to provide a custom parser
170    to handle that.  */
171 int
172 procfs_target::auxv_parse (gdb_byte **readptr,
173                            gdb_byte *endptr, CORE_ADDR *typep, CORE_ADDR *valp)
174 {
175   enum bfd_endian byte_order = gdbarch_byte_order (target_gdbarch ());
176   gdb_byte *ptr = *readptr;
177
178   if (endptr == ptr)
179     return 0;
180
181   if (endptr - ptr < 8 * 2)
182     return -1;
183
184   *typep = extract_unsigned_integer (ptr, 4, byte_order);
185   ptr += 8;
186   /* The size of data is always 64-bit.  If the application is 32-bit,
187      it will be zero extended, as expected.  */
188   *valp = extract_unsigned_integer (ptr, 8, byte_order);
189   ptr += 8;
190
191   *readptr = ptr;
192   return 1;
193 }
194 #endif
195
196 /* =================== END, TARGET_OPS "MODULE" =================== */
197
198 /* World Unification:
199
200    Put any typedefs, defines etc. here that are required for the
201    unification of code that handles different versions of /proc.  */
202
203 enum { READ_WATCHFLAG  = WA_READ,
204        WRITE_WATCHFLAG = WA_WRITE,
205        EXEC_WATCHFLAG  = WA_EXEC,
206        AFTER_WATCHFLAG = WA_TRAPAFTER
207 };
208
209
210 /* =================== STRUCT PROCINFO "MODULE" =================== */
211
212      /* FIXME: this comment will soon be out of date W.R.T. threads.  */
213
214 /* The procinfo struct is a wrapper to hold all the state information
215    concerning a /proc process.  There should be exactly one procinfo
216    for each process, and since GDB currently can debug only one
217    process at a time, that means there should be only one procinfo.
218    All of the LWP's of a process can be accessed indirectly thru the
219    single process procinfo.
220
221    However, against the day when GDB may debug more than one process,
222    this data structure is kept in a list (which for now will hold no
223    more than one member), and many functions will have a pointer to a
224    procinfo as an argument.
225
226    There will be a separate procinfo structure for use by the (not yet
227    implemented) "info proc" command, so that we can print useful
228    information about any random process without interfering with the
229    inferior's procinfo information.  */
230
231 /* format strings for /proc paths */
232 #define MAIN_PROC_NAME_FMT   "/proc/%d"
233 #define CTL_PROC_NAME_FMT    "/proc/%d/ctl"
234 #define AS_PROC_NAME_FMT     "/proc/%d/as"
235 #define MAP_PROC_NAME_FMT    "/proc/%d/map"
236 #define STATUS_PROC_NAME_FMT "/proc/%d/status"
237 #define MAX_PROC_NAME_SIZE sizeof("/proc/999999/lwp/0123456789/lwpstatus")
238
239 typedef struct procinfo {
240   struct procinfo *next;
241   int pid;                      /* Process ID    */
242   int tid;                      /* Thread/LWP id */
243
244   /* process state */
245   int was_stopped;
246   int ignore_next_sigstop;
247
248   int ctl_fd;                   /* File descriptor for /proc control file */
249   int status_fd;                /* File descriptor for /proc status file */
250   int as_fd;                    /* File descriptor for /proc as file */
251
252   char pathname[MAX_PROC_NAME_SIZE];    /* Pathname to /proc entry */
253
254   fltset_t saved_fltset;        /* Saved traced hardware fault set */
255   sigset_t saved_sigset;        /* Saved traced signal set */
256   sigset_t saved_sighold;       /* Saved held signal set */
257   sysset_t *saved_exitset;      /* Saved traced system call exit set */
258   sysset_t *saved_entryset;     /* Saved traced system call entry set */
259
260   pstatus_t prstatus;           /* Current process status info */
261
262   struct procinfo *thread_list;
263
264   int status_valid : 1;
265   int gregs_valid  : 1;
266   int fpregs_valid : 1;
267   int threads_valid: 1;
268 } procinfo;
269
270 static char errmsg[128];        /* shared error msg buffer */
271
272 /* Function prototypes for procinfo module: */
273
274 static procinfo *find_procinfo_or_die (int pid, int tid);
275 static procinfo *find_procinfo (int pid, int tid);
276 static procinfo *create_procinfo (int pid, int tid);
277 static void destroy_procinfo (procinfo *p);
278 static void dead_procinfo (procinfo *p, const char *msg, int killp);
279 static int open_procinfo_files (procinfo *p, int which);
280 static void close_procinfo_files (procinfo *p);
281
282 static int iterate_over_mappings
283   (procinfo *pi, find_memory_region_ftype child_func, void *data,
284    int (*func) (struct prmap *map, find_memory_region_ftype child_func,
285                 void *data));
286
287 /* The head of the procinfo list: */
288 static procinfo *procinfo_list;
289
290 /* Search the procinfo list.  Return a pointer to procinfo, or NULL if
291    not found.  */
292
293 static procinfo *
294 find_procinfo (int pid, int tid)
295 {
296   procinfo *pi;
297
298   for (pi = procinfo_list; pi; pi = pi->next)
299     if (pi->pid == pid)
300       break;
301
302   if (pi)
303     if (tid)
304       {
305         /* Don't check threads_valid.  If we're updating the
306            thread_list, we want to find whatever threads are already
307            here.  This means that in general it is the caller's
308            responsibility to check threads_valid and update before
309            calling find_procinfo, if the caller wants to find a new
310            thread.  */
311
312         for (pi = pi->thread_list; pi; pi = pi->next)
313           if (pi->tid == tid)
314             break;
315       }
316
317   return pi;
318 }
319
320 /* Calls find_procinfo, but errors on failure.  */
321
322 static procinfo *
323 find_procinfo_or_die (int pid, int tid)
324 {
325   procinfo *pi = find_procinfo (pid, tid);
326
327   if (pi == NULL)
328     {
329       if (tid)
330         error (_("procfs: couldn't find pid %d "
331                  "(kernel thread %d) in procinfo list."),
332                pid, tid);
333       else
334         error (_("procfs: couldn't find pid %d in procinfo list."), pid);
335     }
336   return pi;
337 }
338
339 /* Wrapper for `open'.  The appropriate open call is attempted; if
340    unsuccessful, it will be retried as many times as needed for the
341    EAGAIN and EINTR conditions.
342
343    For other conditions, retry the open a limited number of times.  In
344    addition, a short sleep is imposed prior to retrying the open.  The
345    reason for this sleep is to give the kernel a chance to catch up
346    and create the file in question in the event that GDB "wins" the
347    race to open a file before the kernel has created it.  */
348
349 static int
350 open_with_retry (const char *pathname, int flags)
351 {
352   int retries_remaining, status;
353
354   retries_remaining = 2;
355
356   while (1)
357     {
358       status = open (pathname, flags);
359
360       if (status >= 0 || retries_remaining == 0)
361         break;
362       else if (errno != EINTR && errno != EAGAIN)
363         {
364           retries_remaining--;
365           sleep (1);
366         }
367     }
368
369   return status;
370 }
371
372 /* Open the file descriptor for the process or LWP.  We only open the
373    control file descriptor; the others are opened lazily as needed.
374    Returns the file descriptor, or zero for failure.  */
375
376 enum { FD_CTL, FD_STATUS, FD_AS };
377
378 static int
379 open_procinfo_files (procinfo *pi, int which)
380 {
381   char tmp[MAX_PROC_NAME_SIZE];
382   int  fd;
383
384   /* This function is getting ALMOST long enough to break up into
385      several.  Here is some rationale:
386
387      There are several file descriptors that may need to be open
388        for any given process or LWP.  The ones we're intereted in are:
389          - control       (ctl)    write-only    change the state
390          - status        (status) read-only     query the state
391          - address space (as)     read/write    access memory
392          - map           (map)    read-only     virtual addr map
393        Most of these are opened lazily as they are needed.
394        The pathnames for the 'files' for an LWP look slightly
395        different from those of a first-class process:
396          Pathnames for a process (<proc-id>):
397            /proc/<proc-id>/ctl
398            /proc/<proc-id>/status
399            /proc/<proc-id>/as
400            /proc/<proc-id>/map
401          Pathnames for an LWP (lwp-id):
402            /proc/<proc-id>/lwp/<lwp-id>/lwpctl
403            /proc/<proc-id>/lwp/<lwp-id>/lwpstatus
404        An LWP has no map or address space file descriptor, since
405        the memory map and address space are shared by all LWPs.  */
406
407   /* In this case, there are several different file descriptors that
408      we might be asked to open.  The control file descriptor will be
409      opened early, but the others will be opened lazily as they are
410      needed.  */
411
412   strcpy (tmp, pi->pathname);
413   switch (which) {      /* Which file descriptor to open?  */
414   case FD_CTL:
415     if (pi->tid)
416       strcat (tmp, "/lwpctl");
417     else
418       strcat (tmp, "/ctl");
419     fd = open_with_retry (tmp, O_WRONLY);
420     if (fd < 0)
421       return 0;         /* fail */
422     pi->ctl_fd = fd;
423     break;
424   case FD_AS:
425     if (pi->tid)
426       return 0;         /* There is no 'as' file descriptor for an lwp.  */
427     strcat (tmp, "/as");
428     fd = open_with_retry (tmp, O_RDWR);
429     if (fd < 0)
430       return 0;         /* fail */
431     pi->as_fd = fd;
432     break;
433   case FD_STATUS:
434     if (pi->tid)
435       strcat (tmp, "/lwpstatus");
436     else
437       strcat (tmp, "/status");
438     fd = open_with_retry (tmp, O_RDONLY);
439     if (fd < 0)
440       return 0;         /* fail */
441     pi->status_fd = fd;
442     break;
443   default:
444     return 0;           /* unknown file descriptor */
445   }
446
447   return 1;             /* success */
448 }
449
450 /* Allocate a data structure and link it into the procinfo list.
451    First tries to find a pre-existing one (FIXME: why?).  Returns the
452    pointer to new procinfo struct.  */
453
454 static procinfo *
455 create_procinfo (int pid, int tid)
456 {
457   procinfo *pi, *parent = NULL;
458
459   pi = find_procinfo (pid, tid);
460   if (pi != NULL)
461     return pi;                  /* Already exists, nothing to do.  */
462
463   /* Find parent before doing malloc, to save having to cleanup.  */
464   if (tid != 0)
465     parent = find_procinfo_or_die (pid, 0);     /* FIXME: should I
466                                                    create it if it
467                                                    doesn't exist yet?  */
468
469   pi = XNEW (procinfo);
470   memset (pi, 0, sizeof (procinfo));
471   pi->pid = pid;
472   pi->tid = tid;
473
474   pi->saved_entryset = XNEW (sysset_t);
475   pi->saved_exitset = XNEW (sysset_t);
476
477   /* Chain into list.  */
478   if (tid == 0)
479     {
480       xsnprintf (pi->pathname, sizeof (pi->pathname), MAIN_PROC_NAME_FMT, pid);
481       pi->next = procinfo_list;
482       procinfo_list = pi;
483     }
484   else
485     {
486       xsnprintf (pi->pathname, sizeof (pi->pathname), "/proc/%d/lwp/%d",
487                  pid, tid);
488       pi->next = parent->thread_list;
489       parent->thread_list = pi;
490     }
491   return pi;
492 }
493
494 /* Close all file descriptors associated with the procinfo.  */
495
496 static void
497 close_procinfo_files (procinfo *pi)
498 {
499   if (pi->ctl_fd > 0)
500     close (pi->ctl_fd);
501   if (pi->as_fd > 0)
502     close (pi->as_fd);
503   if (pi->status_fd > 0)
504     close (pi->status_fd);
505   pi->ctl_fd = pi->as_fd = pi->status_fd = 0;
506 }
507
508 /* Destructor function.  Close, unlink and deallocate the object.  */
509
510 static void
511 destroy_one_procinfo (procinfo **list, procinfo *pi)
512 {
513   procinfo *ptr;
514
515   /* Step one: unlink the procinfo from its list.  */
516   if (pi == *list)
517     *list = pi->next;
518   else
519     for (ptr = *list; ptr; ptr = ptr->next)
520       if (ptr->next == pi)
521         {
522           ptr->next =  pi->next;
523           break;
524         }
525
526   /* Step two: close any open file descriptors.  */
527   close_procinfo_files (pi);
528
529   /* Step three: free the memory.  */
530   xfree (pi->saved_entryset);
531   xfree (pi->saved_exitset);
532   xfree (pi);
533 }
534
535 static void
536 destroy_procinfo (procinfo *pi)
537 {
538   procinfo *tmp;
539
540   if (pi->tid != 0)     /* Destroy a thread procinfo.  */
541     {
542       tmp = find_procinfo (pi->pid, 0); /* Find the parent process.  */
543       destroy_one_procinfo (&tmp->thread_list, pi);
544     }
545   else                  /* Destroy a process procinfo and all its threads.  */
546     {
547       /* First destroy the children, if any; */
548       while (pi->thread_list != NULL)
549         destroy_one_procinfo (&pi->thread_list, pi->thread_list);
550       /* Then destroy the parent.  Genocide!!!  */
551       destroy_one_procinfo (&procinfo_list, pi);
552     }
553 }
554
555 /* A deleter that calls destroy_procinfo.  */
556 struct procinfo_deleter
557 {
558   void operator() (procinfo *pi) const
559   {
560     destroy_procinfo (pi);
561   }
562 };
563
564 typedef std::unique_ptr<procinfo, procinfo_deleter> procinfo_up;
565
566 enum { NOKILL, KILL };
567
568 /* To be called on a non_recoverable error for a procinfo.  Prints
569    error messages, optionally sends a SIGKILL to the process, then
570    destroys the data structure.  */
571
572 static void
573 dead_procinfo (procinfo *pi, const char *msg, int kill_p)
574 {
575   char procfile[80];
576
577   if (pi->pathname)
578     print_sys_errmsg (pi->pathname, errno);
579   else
580     {
581       xsnprintf (procfile, sizeof (procfile), "process %d", pi->pid);
582       print_sys_errmsg (procfile, errno);
583     }
584   if (kill_p == KILL)
585     kill (pi->pid, SIGKILL);
586
587   destroy_procinfo (pi);
588   error ("%s", msg);
589 }
590
591 /* =================== END, STRUCT PROCINFO "MODULE" =================== */
592
593 /* ===================  /proc  "MODULE" =================== */
594
595 /* This "module" is the interface layer between the /proc system API
596    and the gdb target vector functions.  This layer consists of access
597    functions that encapsulate each of the basic operations that we
598    need to use from the /proc API.
599
600    The main motivation for this layer is to hide the fact that there
601    are two very different implementations of the /proc API.  Rather
602    than have a bunch of #ifdefs all thru the gdb target vector
603    functions, we do our best to hide them all in here.  */
604
605 static long proc_flags (procinfo *pi);
606 static int proc_why (procinfo *pi);
607 static int proc_what (procinfo *pi);
608 static int proc_set_current_signal (procinfo *pi, int signo);
609 static int proc_get_current_thread (procinfo *pi);
610 static int proc_iterate_over_threads
611   (procinfo *pi,
612    int (*func) (procinfo *, procinfo *, void *),
613    void *ptr);
614
615 static void
616 proc_warn (procinfo *pi, const char *func, int line)
617 {
618   xsnprintf (errmsg, sizeof (errmsg), "procfs: %s line %d, %s",
619              func, line, pi->pathname);
620   print_sys_errmsg (errmsg, errno);
621 }
622
623 static void
624 proc_error (procinfo *pi, const char *func, int line)
625 {
626   xsnprintf (errmsg, sizeof (errmsg), "procfs: %s line %d, %s",
627              func, line, pi->pathname);
628   perror_with_name (errmsg);
629 }
630
631 /* Updates the status struct in the procinfo.  There is a 'valid'
632    flag, to let other functions know when this function needs to be
633    called (so the status is only read when it is needed).  The status
634    file descriptor is also only opened when it is needed.  Returns
635    non-zero for success, zero for failure.  */
636
637 static int
638 proc_get_status (procinfo *pi)
639 {
640   /* Status file descriptor is opened "lazily".  */
641   if (pi->status_fd == 0 && open_procinfo_files (pi, FD_STATUS) == 0)
642     {
643       pi->status_valid = 0;
644       return 0;
645     }
646
647   if (lseek (pi->status_fd, 0, SEEK_SET) < 0)
648     pi->status_valid = 0;                       /* fail */
649   else
650     {
651       /* Sigh... I have to read a different data structure,
652          depending on whether this is a main process or an LWP.  */
653       if (pi->tid)
654         pi->status_valid = (read (pi->status_fd,
655                                   (char *) &pi->prstatus.pr_lwp,
656                                   sizeof (lwpstatus_t))
657                             == sizeof (lwpstatus_t));
658       else
659         {
660           pi->status_valid = (read (pi->status_fd,
661                                     (char *) &pi->prstatus,
662                                     sizeof (pstatus_t))
663                               == sizeof (pstatus_t));
664         }
665     }
666
667   if (pi->status_valid)
668     {
669       PROC_PRETTYFPRINT_STATUS (proc_flags (pi),
670                                 proc_why (pi),
671                                 proc_what (pi),
672                                 proc_get_current_thread (pi));
673     }
674
675   /* The status struct includes general regs, so mark them valid too.  */
676   pi->gregs_valid  = pi->status_valid;
677   /* In the read/write multiple-fd model, the status struct includes
678      the fp regs too, so mark them valid too.  */
679   pi->fpregs_valid = pi->status_valid;
680   return pi->status_valid;      /* True if success, false if failure.  */
681 }
682
683 /* Returns the process flags (pr_flags field).  */
684
685 static long
686 proc_flags (procinfo *pi)
687 {
688   if (!pi->status_valid)
689     if (!proc_get_status (pi))
690       return 0; /* FIXME: not a good failure value (but what is?)  */
691
692   return pi->prstatus.pr_lwp.pr_flags;
693 }
694
695 /* Returns the pr_why field (why the process stopped).  */
696
697 static int
698 proc_why (procinfo *pi)
699 {
700   if (!pi->status_valid)
701     if (!proc_get_status (pi))
702       return 0; /* FIXME: not a good failure value (but what is?)  */
703
704   return pi->prstatus.pr_lwp.pr_why;
705 }
706
707 /* Returns the pr_what field (details of why the process stopped).  */
708
709 static int
710 proc_what (procinfo *pi)
711 {
712   if (!pi->status_valid)
713     if (!proc_get_status (pi))
714       return 0; /* FIXME: not a good failure value (but what is?)  */
715
716   return pi->prstatus.pr_lwp.pr_what;
717 }
718
719 /* This function is only called when PI is stopped by a watchpoint.
720    Assuming the OS supports it, write to *ADDR the data address which
721    triggered it and return 1.  Return 0 if it is not possible to know
722    the address.  */
723
724 static int
725 proc_watchpoint_address (procinfo *pi, CORE_ADDR *addr)
726 {
727   if (!pi->status_valid)
728     if (!proc_get_status (pi))
729       return 0;
730
731   *addr = (CORE_ADDR) gdbarch_pointer_to_address (target_gdbarch (),
732             builtin_type (target_gdbarch ())->builtin_data_ptr,
733             (gdb_byte *) &pi->prstatus.pr_lwp.pr_info.si_addr);
734   return 1;
735 }
736
737 /* Returns the pr_nsysarg field (number of args to the current
738    syscall).  */
739
740 static int
741 proc_nsysarg (procinfo *pi)
742 {
743   if (!pi->status_valid)
744     if (!proc_get_status (pi))
745       return 0;
746
747   return pi->prstatus.pr_lwp.pr_nsysarg;
748 }
749
750 /* Returns the pr_sysarg field (pointer to the arguments of current
751    syscall).  */
752
753 static long *
754 proc_sysargs (procinfo *pi)
755 {
756   if (!pi->status_valid)
757     if (!proc_get_status (pi))
758       return NULL;
759
760   return (long *) &pi->prstatus.pr_lwp.pr_sysarg;
761 }
762
763 /* Set or reset any of the following process flags:
764       PR_FORK   -- forked child will inherit trace flags
765       PR_RLC    -- traced process runs when last /proc file closed.
766       PR_KLC    -- traced process is killed when last /proc file closed.
767       PR_ASYNC  -- LWP's get to run/stop independently.
768
769    This function is done using read/write [PCSET/PCRESET/PCUNSET].
770
771    Arguments:
772       pi   -- the procinfo
773       flag -- one of PR_FORK, PR_RLC, or PR_ASYNC
774       mode -- 1 for set, 0 for reset.
775
776    Returns non-zero for success, zero for failure.  */
777
778 enum { FLAG_RESET, FLAG_SET };
779
780 static int
781 proc_modify_flag (procinfo *pi, long flag, long mode)
782 {
783   long win = 0;         /* default to fail */
784
785   /* These operations affect the process as a whole, and applying them
786      to an individual LWP has the same meaning as applying them to the
787      main process.  Therefore, if we're ever called with a pointer to
788      an LWP's procinfo, let's substitute the process's procinfo and
789      avoid opening the LWP's file descriptor unnecessarily.  */
790
791   if (pi->pid != 0)
792     pi = find_procinfo_or_die (pi->pid, 0);
793
794   procfs_ctl_t arg[2];
795
796   if (mode == FLAG_SET) /* Set the flag (RLC, FORK, or ASYNC).  */
797     arg[0] = PCSET;
798   else                  /* Reset the flag.  */
799     arg[0] = PCUNSET;
800
801   arg[1] = flag;
802   win = (write (pi->ctl_fd, (void *) &arg, sizeof (arg)) == sizeof (arg));
803
804   /* The above operation renders the procinfo's cached pstatus
805      obsolete.  */
806   pi->status_valid = 0;
807
808   if (!win)
809     warning (_("procfs: modify_flag failed to turn %s %s"),
810              flag == PR_FORK  ? "PR_FORK"  :
811              flag == PR_RLC   ? "PR_RLC"   :
812              flag == PR_ASYNC ? "PR_ASYNC" :
813              flag == PR_KLC   ? "PR_KLC"   :
814              "<unknown flag>",
815              mode == FLAG_RESET ? "off" : "on");
816
817   return win;
818 }
819
820 /* Set the run_on_last_close flag.  Process with all threads will
821    become runnable when debugger closes all /proc fds.  Returns
822    non-zero for success, zero for failure.  */
823
824 static int
825 proc_set_run_on_last_close (procinfo *pi)
826 {
827   return proc_modify_flag (pi, PR_RLC, FLAG_SET);
828 }
829
830 /* Reset the run_on_last_close flag.  The process will NOT become
831    runnable when debugger closes its file handles.  Returns non-zero
832    for success, zero for failure.  */
833
834 static int
835 proc_unset_run_on_last_close (procinfo *pi)
836 {
837   return proc_modify_flag (pi, PR_RLC, FLAG_RESET);
838 }
839
840 /* Reset inherit_on_fork flag.  If the process forks a child while we
841    are registered for events in the parent, then we will NOT recieve
842    events from the child.  Returns non-zero for success, zero for
843    failure.  */
844
845 static int
846 proc_unset_inherit_on_fork (procinfo *pi)
847 {
848   return proc_modify_flag (pi, PR_FORK, FLAG_RESET);
849 }
850
851 /* Set PR_ASYNC flag.  If one LWP stops because of a debug event
852    (signal etc.), the remaining LWPs will continue to run.  Returns
853    non-zero for success, zero for failure.  */
854
855 static int
856 proc_set_async (procinfo *pi)
857 {
858   return proc_modify_flag (pi, PR_ASYNC, FLAG_SET);
859 }
860
861 /* Reset PR_ASYNC flag.  If one LWP stops because of a debug event
862    (signal etc.), then all other LWPs will stop as well.  Returns
863    non-zero for success, zero for failure.  */
864
865 static int
866 proc_unset_async (procinfo *pi)
867 {
868   return proc_modify_flag (pi, PR_ASYNC, FLAG_RESET);
869 }
870
871 /* Request the process/LWP to stop.  Does not wait.  Returns non-zero
872    for success, zero for failure.  */
873
874 static int
875 proc_stop_process (procinfo *pi)
876 {
877   int win;
878
879   /* We might conceivably apply this operation to an LWP, and the
880      LWP's ctl file descriptor might not be open.  */
881
882   if (pi->ctl_fd == 0 && open_procinfo_files (pi, FD_CTL) == 0)
883     return 0;
884   else
885     {
886       procfs_ctl_t cmd = PCSTOP;
887
888       win = (write (pi->ctl_fd, (char *) &cmd, sizeof (cmd)) == sizeof (cmd));
889     }
890
891   return win;
892 }
893
894 /* Wait for the process or LWP to stop (block until it does).  Returns
895    non-zero for success, zero for failure.  */
896
897 static int
898 proc_wait_for_stop (procinfo *pi)
899 {
900   int win;
901
902   /* We should never have to apply this operation to any procinfo
903      except the one for the main process.  If that ever changes for
904      any reason, then take out the following clause and replace it
905      with one that makes sure the ctl_fd is open.  */
906
907   if (pi->tid != 0)
908     pi = find_procinfo_or_die (pi->pid, 0);
909
910   procfs_ctl_t cmd = PCWSTOP;
911
912   win = (write (pi->ctl_fd, (char *) &cmd, sizeof (cmd)) == sizeof (cmd));
913   /* We been runnin' and we stopped -- need to update status.  */
914   pi->status_valid = 0;
915
916   return win;
917 }
918
919 /* Make the process or LWP runnable.
920
921    Options (not all are implemented):
922      - single-step
923      - clear current fault
924      - clear current signal
925      - abort the current system call
926      - stop as soon as finished with system call
927      - (ioctl): set traced signal set
928      - (ioctl): set held   signal set
929      - (ioctl): set traced fault  set
930      - (ioctl): set start pc (vaddr)
931
932    Always clears the current fault.  PI is the process or LWP to
933    operate on.  If STEP is true, set the process or LWP to trap after
934    one instruction.  If SIGNO is zero, clear the current signal if
935    any; if non-zero, set the current signal to this one.  Returns
936    non-zero for success, zero for failure.  */
937
938 static int
939 proc_run_process (procinfo *pi, int step, int signo)
940 {
941   int win;
942   int runflags;
943
944   /* We will probably have to apply this operation to individual
945      threads, so make sure the control file descriptor is open.  */
946
947   if (pi->ctl_fd == 0 && open_procinfo_files (pi, FD_CTL) == 0)
948     return 0;
949
950   runflags    = PRCFAULT;       /* Always clear current fault.  */
951   if (step)
952     runflags |= PRSTEP;
953   if (signo == 0)
954     runflags |= PRCSIG;
955   else if (signo != -1)         /* -1 means do nothing W.R.T. signals.  */
956     proc_set_current_signal (pi, signo);
957
958   procfs_ctl_t cmd[2];
959
960   cmd[0]  = PCRUN;
961   cmd[1]  = runflags;
962   win = (write (pi->ctl_fd, (char *) &cmd, sizeof (cmd)) == sizeof (cmd));
963
964   return win;
965 }
966
967 /* Register to trace signals in the process or LWP.  Returns non-zero
968    for success, zero for failure.  */
969
970 static int
971 proc_set_traced_signals (procinfo *pi, sigset_t *sigset)
972 {
973   int win;
974
975   /* We should never have to apply this operation to any procinfo
976      except the one for the main process.  If that ever changes for
977      any reason, then take out the following clause and replace it
978      with one that makes sure the ctl_fd is open.  */
979
980   if (pi->tid != 0)
981     pi = find_procinfo_or_die (pi->pid, 0);
982
983   struct {
984     procfs_ctl_t cmd;
985     /* Use char array to avoid alignment issues.  */
986     char sigset[sizeof (sigset_t)];
987   } arg;
988
989   arg.cmd = PCSTRACE;
990   memcpy (&arg.sigset, sigset, sizeof (sigset_t));
991
992   win = (write (pi->ctl_fd, (char *) &arg, sizeof (arg)) == sizeof (arg));
993
994   /* The above operation renders the procinfo's cached pstatus obsolete.  */
995   pi->status_valid = 0;
996
997   if (!win)
998     warning (_("procfs: set_traced_signals failed"));
999   return win;
1000 }
1001
1002 /* Register to trace hardware faults in the process or LWP.  Returns
1003    non-zero for success, zero for failure.  */
1004
1005 static int
1006 proc_set_traced_faults (procinfo *pi, fltset_t *fltset)
1007 {
1008   int win;
1009
1010   /* We should never have to apply this operation to any procinfo
1011      except the one for the main process.  If that ever changes for
1012      any reason, then take out the following clause and replace it
1013      with one that makes sure the ctl_fd is open.  */
1014
1015   if (pi->tid != 0)
1016     pi = find_procinfo_or_die (pi->pid, 0);
1017
1018   struct {
1019     procfs_ctl_t cmd;
1020     /* Use char array to avoid alignment issues.  */
1021     char fltset[sizeof (fltset_t)];
1022   } arg;
1023
1024   arg.cmd = PCSFAULT;
1025   memcpy (&arg.fltset, fltset, sizeof (fltset_t));
1026
1027   win = (write (pi->ctl_fd, (char *) &arg, sizeof (arg)) == sizeof (arg));
1028
1029   /* The above operation renders the procinfo's cached pstatus obsolete.  */
1030   pi->status_valid = 0;
1031
1032   return win;
1033 }
1034
1035 /* Register to trace entry to system calls in the process or LWP.
1036    Returns non-zero for success, zero for failure.  */
1037
1038 static int
1039 proc_set_traced_sysentry (procinfo *pi, sysset_t *sysset)
1040 {
1041   int win;
1042
1043   /* We should never have to apply this operation to any procinfo
1044      except the one for the main process.  If that ever changes for
1045      any reason, then take out the following clause and replace it
1046      with one that makes sure the ctl_fd is open.  */
1047
1048   if (pi->tid != 0)
1049     pi = find_procinfo_or_die (pi->pid, 0);
1050
1051   struct {
1052     procfs_ctl_t cmd;
1053     /* Use char array to avoid alignment issues.  */
1054     char sysset[sizeof (sysset_t)];
1055   } arg;
1056
1057   arg.cmd = PCSENTRY;
1058   memcpy (&arg.sysset, sysset, sizeof (sysset_t));
1059
1060   win = (write (pi->ctl_fd, (char *) &arg, sizeof (arg)) == sizeof (arg));
1061
1062   /* The above operation renders the procinfo's cached pstatus
1063      obsolete.  */
1064   pi->status_valid = 0;
1065
1066   return win;
1067 }
1068
1069 /* Register to trace exit from system calls in the process or LWP.
1070    Returns non-zero for success, zero for failure.  */
1071
1072 static int
1073 proc_set_traced_sysexit (procinfo *pi, sysset_t *sysset)
1074 {
1075   int win;
1076
1077   /* We should never have to apply this operation to any procinfo
1078      except the one for the main process.  If that ever changes for
1079      any reason, then take out the following clause and replace it
1080      with one that makes sure the ctl_fd is open.  */
1081
1082   if (pi->tid != 0)
1083     pi = find_procinfo_or_die (pi->pid, 0);
1084
1085   struct gdb_proc_ctl_pcsexit {
1086     procfs_ctl_t cmd;
1087     /* Use char array to avoid alignment issues.  */
1088     char sysset[sizeof (sysset_t)];
1089   } arg;
1090
1091   arg.cmd = PCSEXIT;
1092   memcpy (&arg.sysset, sysset, sizeof (sysset_t));
1093
1094   win = (write (pi->ctl_fd, (char *) &arg, sizeof (arg)) == sizeof (arg));
1095
1096   /* The above operation renders the procinfo's cached pstatus
1097      obsolete.  */
1098   pi->status_valid = 0;
1099
1100   return win;
1101 }
1102
1103 /* Specify the set of blocked / held signals in the process or LWP.
1104    Returns non-zero for success, zero for failure.  */
1105
1106 static int
1107 proc_set_held_signals (procinfo *pi, sigset_t *sighold)
1108 {
1109   int win;
1110
1111   /* We should never have to apply this operation to any procinfo
1112      except the one for the main process.  If that ever changes for
1113      any reason, then take out the following clause and replace it
1114      with one that makes sure the ctl_fd is open.  */
1115
1116   if (pi->tid != 0)
1117     pi = find_procinfo_or_die (pi->pid, 0);
1118
1119   struct {
1120     procfs_ctl_t cmd;
1121     /* Use char array to avoid alignment issues.  */
1122     char hold[sizeof (sigset_t)];
1123   } arg;
1124
1125   arg.cmd  = PCSHOLD;
1126   memcpy (&arg.hold, sighold, sizeof (sigset_t));
1127   win = (write (pi->ctl_fd, (void *) &arg, sizeof (arg)) == sizeof (arg));
1128
1129   /* The above operation renders the procinfo's cached pstatus
1130      obsolete.  */
1131   pi->status_valid = 0;
1132
1133   return win;
1134 }
1135
1136 /* Returns the set of signals that are held / blocked.  Will also copy
1137    the sigset if SAVE is non-zero.  */
1138
1139 static sigset_t *
1140 proc_get_held_signals (procinfo *pi, sigset_t *save)
1141 {
1142   sigset_t *ret = NULL;
1143
1144   /* We should never have to apply this operation to any procinfo
1145      except the one for the main process.  If that ever changes for
1146      any reason, then take out the following clause and replace it
1147      with one that makes sure the ctl_fd is open.  */
1148
1149   if (pi->tid != 0)
1150     pi = find_procinfo_or_die (pi->pid, 0);
1151
1152   if (!pi->status_valid)
1153     if (!proc_get_status (pi))
1154       return NULL;
1155
1156   ret = &pi->prstatus.pr_lwp.pr_lwphold;
1157   if (save && ret)
1158     memcpy (save, ret, sizeof (sigset_t));
1159
1160   return ret;
1161 }
1162
1163 /* Returns the set of signals that are traced / debugged.  Will also
1164    copy the sigset if SAVE is non-zero.  */
1165
1166 static sigset_t *
1167 proc_get_traced_signals (procinfo *pi, sigset_t *save)
1168 {
1169   sigset_t *ret = NULL;
1170
1171   /* We should never have to apply this operation to any procinfo
1172      except the one for the main process.  If that ever changes for
1173      any reason, then take out the following clause and replace it
1174      with one that makes sure the ctl_fd is open.  */
1175
1176   if (pi->tid != 0)
1177     pi = find_procinfo_or_die (pi->pid, 0);
1178
1179   if (!pi->status_valid)
1180     if (!proc_get_status (pi))
1181       return NULL;
1182
1183   ret = &pi->prstatus.pr_sigtrace;
1184   if (save && ret)
1185     memcpy (save, ret, sizeof (sigset_t));
1186
1187   return ret;
1188 }
1189
1190 /* Returns the set of hardware faults that are traced /debugged.  Will
1191    also copy the faultset if SAVE is non-zero.  */
1192
1193 static fltset_t *
1194 proc_get_traced_faults (procinfo *pi, fltset_t *save)
1195 {
1196   fltset_t *ret = NULL;
1197
1198   /* We should never have to apply this operation to any procinfo
1199      except the one for the main process.  If that ever changes for
1200      any reason, then take out the following clause and replace it
1201      with one that makes sure the ctl_fd is open.  */
1202
1203   if (pi->tid != 0)
1204     pi = find_procinfo_or_die (pi->pid, 0);
1205
1206   if (!pi->status_valid)
1207     if (!proc_get_status (pi))
1208       return NULL;
1209
1210   ret = &pi->prstatus.pr_flttrace;
1211   if (save && ret)
1212     memcpy (save, ret, sizeof (fltset_t));
1213
1214   return ret;
1215 }
1216
1217 /* Returns the set of syscalls that are traced /debugged on entry.
1218    Will also copy the syscall set if SAVE is non-zero.  */
1219
1220 static sysset_t *
1221 proc_get_traced_sysentry (procinfo *pi, sysset_t *save)
1222 {
1223   sysset_t *ret = NULL;
1224
1225   /* We should never have to apply this operation to any procinfo
1226      except the one for the main process.  If that ever changes for
1227      any reason, then take out the following clause and replace it
1228      with one that makes sure the ctl_fd is open.  */
1229
1230   if (pi->tid != 0)
1231     pi = find_procinfo_or_die (pi->pid, 0);
1232
1233   if (!pi->status_valid)
1234     if (!proc_get_status (pi))
1235       return NULL;
1236
1237   ret = &pi->prstatus.pr_sysentry;
1238   if (save && ret)
1239     memcpy (save, ret, sizeof (sysset_t));
1240
1241   return ret;
1242 }
1243
1244 /* Returns the set of syscalls that are traced /debugged on exit.
1245    Will also copy the syscall set if SAVE is non-zero.  */
1246
1247 static sysset_t *
1248 proc_get_traced_sysexit (procinfo *pi, sysset_t *save)
1249 {
1250   sysset_t *ret = NULL;
1251
1252   /* We should never have to apply this operation to any procinfo
1253      except the one for the main process.  If that ever changes for
1254      any reason, then take out the following clause and replace it
1255      with one that makes sure the ctl_fd is open.  */
1256
1257   if (pi->tid != 0)
1258     pi = find_procinfo_or_die (pi->pid, 0);
1259
1260   if (!pi->status_valid)
1261     if (!proc_get_status (pi))
1262       return NULL;
1263
1264   ret = &pi->prstatus.pr_sysexit;
1265   if (save && ret)
1266     memcpy (save, ret, sizeof (sysset_t));
1267
1268   return ret;
1269 }
1270
1271 /* The current fault (if any) is cleared; the associated signal will
1272    not be sent to the process or LWP when it resumes.  Returns
1273    non-zero for success, zero for failure.  */
1274
1275 static int
1276 proc_clear_current_fault (procinfo *pi)
1277 {
1278   int win;
1279
1280   /* We should never have to apply this operation to any procinfo
1281      except the one for the main process.  If that ever changes for
1282      any reason, then take out the following clause and replace it
1283      with one that makes sure the ctl_fd is open.  */
1284
1285   if (pi->tid != 0)
1286     pi = find_procinfo_or_die (pi->pid, 0);
1287
1288   procfs_ctl_t cmd = PCCFAULT;
1289
1290   win = (write (pi->ctl_fd, (void *) &cmd, sizeof (cmd)) == sizeof (cmd));
1291
1292   return win;
1293 }
1294
1295 /* Set the "current signal" that will be delivered next to the
1296    process.  NOTE: semantics are different from those of KILL.  This
1297    signal will be delivered to the process or LWP immediately when it
1298    is resumed (even if the signal is held/blocked); it will NOT
1299    immediately cause another event of interest, and will NOT first
1300    trap back to the debugger.  Returns non-zero for success, zero for
1301    failure.  */
1302
1303 static int
1304 proc_set_current_signal (procinfo *pi, int signo)
1305 {
1306   int win;
1307   struct {
1308     procfs_ctl_t cmd;
1309     /* Use char array to avoid alignment issues.  */
1310     char sinfo[sizeof (siginfo_t)];
1311   } arg;
1312   siginfo_t mysinfo;
1313   ptid_t wait_ptid;
1314   struct target_waitstatus wait_status;
1315
1316   /* We should never have to apply this operation to any procinfo
1317      except the one for the main process.  If that ever changes for
1318      any reason, then take out the following clause and replace it
1319      with one that makes sure the ctl_fd is open.  */
1320
1321   if (pi->tid != 0)
1322     pi = find_procinfo_or_die (pi->pid, 0);
1323
1324   /* The pointer is just a type alias.  */
1325   get_last_target_status (&wait_ptid, &wait_status);
1326   if (wait_ptid == inferior_ptid
1327       && wait_status.kind == TARGET_WAITKIND_STOPPED
1328       && wait_status.value.sig == gdb_signal_from_host (signo)
1329       && proc_get_status (pi)
1330       && pi->prstatus.pr_lwp.pr_info.si_signo == signo
1331       )
1332     /* Use the siginfo associated with the signal being
1333        redelivered.  */
1334     memcpy (arg.sinfo, &pi->prstatus.pr_lwp.pr_info, sizeof (siginfo_t));
1335   else
1336     {
1337       mysinfo.si_signo = signo;
1338       mysinfo.si_code  = 0;
1339       mysinfo.si_pid   = getpid ();       /* ?why? */
1340       mysinfo.si_uid   = getuid ();       /* ?why? */
1341       memcpy (arg.sinfo, &mysinfo, sizeof (siginfo_t));
1342     }
1343
1344   arg.cmd = PCSSIG;
1345   win = (write (pi->ctl_fd, (void *) &arg, sizeof (arg))  == sizeof (arg));
1346
1347   return win;
1348 }
1349
1350 /* The current signal (if any) is cleared, and is not sent to the
1351    process or LWP when it resumes.  Returns non-zero for success, zero
1352    for failure.  */
1353
1354 static int
1355 proc_clear_current_signal (procinfo *pi)
1356 {
1357   int win;
1358
1359   /* We should never have to apply this operation to any procinfo
1360      except the one for the main process.  If that ever changes for
1361      any reason, then take out the following clause and replace it
1362      with one that makes sure the ctl_fd is open.  */
1363
1364   if (pi->tid != 0)
1365     pi = find_procinfo_or_die (pi->pid, 0);
1366
1367   struct {
1368     procfs_ctl_t cmd;
1369     /* Use char array to avoid alignment issues.  */
1370     char sinfo[sizeof (siginfo_t)];
1371   } arg;
1372   siginfo_t mysinfo;
1373
1374   arg.cmd = PCSSIG;
1375   /* The pointer is just a type alias.  */
1376   mysinfo.si_signo = 0;
1377   mysinfo.si_code  = 0;
1378   mysinfo.si_errno = 0;
1379   mysinfo.si_pid   = getpid ();       /* ?why? */
1380   mysinfo.si_uid   = getuid ();       /* ?why? */
1381   memcpy (arg.sinfo, &mysinfo, sizeof (siginfo_t));
1382
1383   win = (write (pi->ctl_fd, (void *) &arg, sizeof (arg)) == sizeof (arg));
1384
1385   return win;
1386 }
1387
1388 /* Return the general-purpose registers for the process or LWP
1389    corresponding to PI.  Upon failure, return NULL.  */
1390
1391 static gdb_gregset_t *
1392 proc_get_gregs (procinfo *pi)
1393 {
1394   if (!pi->status_valid || !pi->gregs_valid)
1395     if (!proc_get_status (pi))
1396       return NULL;
1397
1398   return &pi->prstatus.pr_lwp.pr_reg;
1399 }
1400
1401 /* Return the general-purpose registers for the process or LWP
1402    corresponding to PI.  Upon failure, return NULL.  */
1403
1404 static gdb_fpregset_t *
1405 proc_get_fpregs (procinfo *pi)
1406 {
1407   if (!pi->status_valid || !pi->fpregs_valid)
1408     if (!proc_get_status (pi))
1409       return NULL;
1410
1411   return &pi->prstatus.pr_lwp.pr_fpreg;
1412 }
1413
1414 /* Write the general-purpose registers back to the process or LWP
1415    corresponding to PI.  Return non-zero for success, zero for
1416    failure.  */
1417
1418 static int
1419 proc_set_gregs (procinfo *pi)
1420 {
1421   gdb_gregset_t *gregs;
1422   int win;
1423
1424   gregs = proc_get_gregs (pi);
1425   if (gregs == NULL)
1426     return 0;                   /* proc_get_regs has already warned.  */
1427
1428   if (pi->ctl_fd == 0 && open_procinfo_files (pi, FD_CTL) == 0)
1429     return 0;
1430   else
1431     {
1432       struct {
1433         procfs_ctl_t cmd;
1434         /* Use char array to avoid alignment issues.  */
1435         char gregs[sizeof (gdb_gregset_t)];
1436       } arg;
1437
1438       arg.cmd = PCSREG;
1439       memcpy (&arg.gregs, gregs, sizeof (arg.gregs));
1440       win = (write (pi->ctl_fd, (void *) &arg, sizeof (arg)) == sizeof (arg));
1441     }
1442
1443   /* Policy: writing the registers invalidates our cache.  */
1444   pi->gregs_valid = 0;
1445   return win;
1446 }
1447
1448 /* Write the floating-pointer registers back to the process or LWP
1449    corresponding to PI.  Return non-zero for success, zero for
1450    failure.  */
1451
1452 static int
1453 proc_set_fpregs (procinfo *pi)
1454 {
1455   gdb_fpregset_t *fpregs;
1456   int win;
1457
1458   fpregs = proc_get_fpregs (pi);
1459   if (fpregs == NULL)
1460     return 0;                   /* proc_get_fpregs has already warned.  */
1461
1462   if (pi->ctl_fd == 0 && open_procinfo_files (pi, FD_CTL) == 0)
1463     return 0;
1464   else
1465     {
1466       struct {
1467         procfs_ctl_t cmd;
1468         /* Use char array to avoid alignment issues.  */
1469         char fpregs[sizeof (gdb_fpregset_t)];
1470       } arg;
1471
1472       arg.cmd = PCSFPREG;
1473       memcpy (&arg.fpregs, fpregs, sizeof (arg.fpregs));
1474       win = (write (pi->ctl_fd, (void *) &arg, sizeof (arg)) == sizeof (arg));
1475     }
1476
1477   /* Policy: writing the registers invalidates our cache.  */
1478   pi->fpregs_valid = 0;
1479   return win;
1480 }
1481
1482 /* Send a signal to the proc or lwp with the semantics of "kill()".
1483    Returns non-zero for success, zero for failure.  */
1484
1485 static int
1486 proc_kill (procinfo *pi, int signo)
1487 {
1488   int win;
1489
1490   /* We might conceivably apply this operation to an LWP, and the
1491      LWP's ctl file descriptor might not be open.  */
1492
1493   if (pi->ctl_fd == 0 && open_procinfo_files (pi, FD_CTL) == 0)
1494     return 0;
1495   else
1496     {
1497       procfs_ctl_t cmd[2];
1498
1499       cmd[0] = PCKILL;
1500       cmd[1] = signo;
1501       win = (write (pi->ctl_fd, (char *) &cmd, sizeof (cmd)) == sizeof (cmd));
1502   }
1503
1504   return win;
1505 }
1506
1507 /* Find the pid of the process that started this one.  Returns the
1508    parent process pid, or zero.  */
1509
1510 static int
1511 proc_parent_pid (procinfo *pi)
1512 {
1513   /* We should never have to apply this operation to any procinfo
1514      except the one for the main process.  If that ever changes for
1515      any reason, then take out the following clause and replace it
1516      with one that makes sure the ctl_fd is open.  */
1517
1518   if (pi->tid != 0)
1519     pi = find_procinfo_or_die (pi->pid, 0);
1520
1521   if (!pi->status_valid)
1522     if (!proc_get_status (pi))
1523       return 0;
1524
1525   return pi->prstatus.pr_ppid;
1526 }
1527
1528 /* Convert a target address (a.k.a. CORE_ADDR) into a host address
1529    (a.k.a void pointer)!  */
1530
1531 static void *
1532 procfs_address_to_host_pointer (CORE_ADDR addr)
1533 {
1534   struct type *ptr_type = builtin_type (target_gdbarch ())->builtin_data_ptr;
1535   void *ptr;
1536
1537   gdb_assert (sizeof (ptr) == TYPE_LENGTH (ptr_type));
1538   gdbarch_address_to_pointer (target_gdbarch (), ptr_type,
1539                               (gdb_byte *) &ptr, addr);
1540   return ptr;
1541 }
1542
1543 static int
1544 proc_set_watchpoint (procinfo *pi, CORE_ADDR addr, int len, int wflags)
1545 {
1546   struct {
1547     procfs_ctl_t cmd;
1548     char watch[sizeof (prwatch_t)];
1549   } arg;
1550   prwatch_t pwatch;
1551
1552   /* NOTE: cagney/2003-02-01: Even more horrible hack.  Need to
1553      convert a target address into something that can be stored in a
1554      native data structure.  */
1555   pwatch.pr_vaddr  = (uintptr_t) procfs_address_to_host_pointer (addr);
1556   pwatch.pr_size   = len;
1557   pwatch.pr_wflags = wflags;
1558   arg.cmd = PCWATCH;
1559   memcpy (arg.watch, &pwatch, sizeof (prwatch_t));
1560   return (write (pi->ctl_fd, &arg, sizeof (arg)) == sizeof (arg));
1561 }
1562
1563 #if (defined(__i386__) || defined(__x86_64__)) && defined (sun)
1564
1565 #include <sys/sysi86.h>
1566
1567 /* The KEY is actually the value of the lower 16 bits of the GS
1568    register for the LWP that we're interested in.  Returns the
1569    matching ssh struct (LDT entry).  */
1570
1571 static struct ssd *
1572 proc_get_LDT_entry (procinfo *pi, int key)      /* ARI: editCase function */
1573 {
1574   static struct ssd *ldt_entry = NULL;
1575   char pathname[MAX_PROC_NAME_SIZE];
1576
1577   /* Allocate space for one LDT entry.
1578      This alloc must persist, because we return a pointer to it.  */
1579   if (ldt_entry == NULL)
1580     ldt_entry = XNEW (struct ssd);
1581
1582   /* Open the file descriptor for the LDT table.  */
1583   xsnprintf (pathname, sizeof (pathname), "/proc/%d/ldt", pi->pid);
1584   scoped_fd fd (open_with_retry (pathname, O_RDONLY));
1585   if (fd.get () < 0)
1586     {
1587       proc_warn (pi, "proc_get_LDT_entry (open)", __LINE__);
1588       return NULL;
1589     }
1590
1591   /* Now 'read' thru the table, find a match and return it.  */
1592   while (read (fd.get (), ldt_entry, sizeof (struct ssd))
1593          == sizeof (struct ssd))
1594     {
1595       if (ldt_entry->sel == 0
1596           && ldt_entry->bo  == 0
1597           && ldt_entry->acc1 == 0
1598           && ldt_entry->acc2 == 0)
1599         break;  /* end of table */
1600       /* If key matches, return this entry.  */
1601       if (ldt_entry->sel == key)
1602         return ldt_entry;
1603     }
1604   /* Loop ended, match not found.  */
1605   return NULL;
1606 }
1607
1608 /* Returns the pointer to the LDT entry of PTID.  */
1609
1610 struct ssd *
1611 procfs_find_LDT_entry (ptid_t ptid)     /* ARI: editCase function */
1612 {
1613   gdb_gregset_t *gregs;
1614   int            key;
1615   procinfo      *pi;
1616
1617   /* Find procinfo for the lwp.  */
1618   pi = find_procinfo (ptid.pid (), ptid.lwp ());
1619   if (pi == NULL)
1620     {
1621       warning (_("procfs_find_LDT_entry: could not find procinfo for %d:%ld."),
1622                ptid.pid (), ptid.lwp ());
1623       return NULL;
1624     }
1625   /* get its general registers.  */
1626   gregs = proc_get_gregs (pi);
1627   if (gregs == NULL)
1628     {
1629       warning (_("procfs_find_LDT_entry: could not read gregs for %d:%ld."),
1630                ptid.pid (), ptid.lwp ());
1631       return NULL;
1632     }
1633   /* Now extract the GS register's lower 16 bits.  */
1634   key = (*gregs)[GS] & 0xffff;
1635
1636   /* Find the matching entry and return it.  */
1637   return proc_get_LDT_entry (pi, key);
1638 }
1639
1640 #endif
1641
1642 /* =============== END, non-thread part of /proc  "MODULE" =============== */
1643
1644 /* =================== Thread "MODULE" =================== */
1645
1646 /* NOTE: you'll see more ifdefs and duplication of functions here,
1647    since there is a different way to do threads on every OS.  */
1648
1649 /* Returns the number of threads for the process.  */
1650
1651 static int
1652 proc_get_nthreads (procinfo *pi)
1653 {
1654   if (!pi->status_valid)
1655     if (!proc_get_status (pi))
1656       return 0;
1657
1658   /* Only works for the process procinfo, because the LWP procinfos do not
1659      get prstatus filled in.  */
1660   if (pi->tid != 0)     /* Find the parent process procinfo.  */
1661     pi = find_procinfo_or_die (pi->pid, 0);
1662   return pi->prstatus.pr_nlwp;
1663 }
1664
1665 /* LWP version.
1666
1667    Return the ID of the thread that had an event of interest.
1668    (ie. the one that hit a breakpoint or other traced event).  All
1669    other things being equal, this should be the ID of a thread that is
1670    currently executing.  */
1671
1672 static int
1673 proc_get_current_thread (procinfo *pi)
1674 {
1675   /* Note: this should be applied to the root procinfo for the
1676      process, not to the procinfo for an LWP.  If applied to the
1677      procinfo for an LWP, it will simply return that LWP's ID.  In
1678      that case, find the parent process procinfo.  */
1679
1680   if (pi->tid != 0)
1681     pi = find_procinfo_or_die (pi->pid, 0);
1682
1683   if (!pi->status_valid)
1684     if (!proc_get_status (pi))
1685       return 0;
1686
1687   return pi->prstatus.pr_lwp.pr_lwpid;
1688 }
1689
1690 /* Discover the IDs of all the threads within the process, and create
1691    a procinfo for each of them (chained to the parent).  This
1692    unfortunately requires a different method on every OS.  Returns
1693    non-zero for success, zero for failure.  */
1694
1695 static int
1696 proc_delete_dead_threads (procinfo *parent, procinfo *thread, void *ignore)
1697 {
1698   if (thread && parent) /* sanity */
1699     {
1700       thread->status_valid = 0;
1701       if (!proc_get_status (thread))
1702         destroy_one_procinfo (&parent->thread_list, thread);
1703     }
1704   return 0;     /* keep iterating */
1705 }
1706
1707 static int
1708 proc_update_threads (procinfo *pi)
1709 {
1710   char pathname[MAX_PROC_NAME_SIZE + 16];
1711   struct dirent *direntry;
1712   procinfo *thread;
1713   gdb_dir_up dirp;
1714   int lwpid;
1715
1716   /* We should never have to apply this operation to any procinfo
1717      except the one for the main process.  If that ever changes for
1718      any reason, then take out the following clause and replace it
1719      with one that makes sure the ctl_fd is open.  */
1720
1721   if (pi->tid != 0)
1722     pi = find_procinfo_or_die (pi->pid, 0);
1723
1724   proc_iterate_over_threads (pi, proc_delete_dead_threads, NULL);
1725
1726   /* Note: this brute-force method was originally devised for Unixware
1727      (support removed since), and will also work on Solaris 2.6 and
1728      2.7.  The original comment mentioned the existence of a much
1729      simpler and more elegant way to do this on Solaris, but didn't
1730      point out what that was.  */
1731
1732   strcpy (pathname, pi->pathname);
1733   strcat (pathname, "/lwp");
1734   dirp.reset (opendir (pathname));
1735   if (dirp == NULL)
1736     proc_error (pi, "update_threads, opendir", __LINE__);
1737
1738   while ((direntry = readdir (dirp.get ())) != NULL)
1739     if (direntry->d_name[0] != '.')             /* skip '.' and '..' */
1740       {
1741         lwpid = atoi (&direntry->d_name[0]);
1742         thread = create_procinfo (pi->pid, lwpid);
1743         if (thread == NULL)
1744           proc_error (pi, "update_threads, create_procinfo", __LINE__);
1745       }
1746   pi->threads_valid = 1;
1747   return 1;
1748 }
1749
1750 /* Given a pointer to a function, call that function once for each lwp
1751    in the procinfo list, until the function returns non-zero, in which
1752    event return the value returned by the function.
1753
1754    Note: this function does NOT call update_threads.  If you want to
1755    discover new threads first, you must call that function explicitly.
1756    This function just makes a quick pass over the currently-known
1757    procinfos.
1758
1759    PI is the parent process procinfo.  FUNC is the per-thread
1760    function.  PTR is an opaque parameter for function.  Returns the
1761    first non-zero return value from the callee, or zero.  */
1762
1763 static int
1764 proc_iterate_over_threads (procinfo *pi,
1765                            int (*func) (procinfo *, procinfo *, void *),
1766                            void *ptr)
1767 {
1768   procinfo *thread, *next;
1769   int retval = 0;
1770
1771   /* We should never have to apply this operation to any procinfo
1772      except the one for the main process.  If that ever changes for
1773      any reason, then take out the following clause and replace it
1774      with one that makes sure the ctl_fd is open.  */
1775
1776   if (pi->tid != 0)
1777     pi = find_procinfo_or_die (pi->pid, 0);
1778
1779   for (thread = pi->thread_list; thread != NULL; thread = next)
1780     {
1781       next = thread->next;      /* In case thread is destroyed.  */
1782       retval = (*func) (pi, thread, ptr);
1783       if (retval != 0)
1784         break;
1785     }
1786
1787   return retval;
1788 }
1789
1790 /* =================== END, Thread "MODULE" =================== */
1791
1792 /* =================== END, /proc  "MODULE" =================== */
1793
1794 /* ===================  GDB  "MODULE" =================== */
1795
1796 /* Here are all of the gdb target vector functions and their
1797    friends.  */
1798
1799 static ptid_t do_attach (ptid_t ptid);
1800 static void do_detach ();
1801 static void proc_trace_syscalls_1 (procinfo *pi, int syscallnum,
1802                                    int entry_or_exit, int mode, int from_tty);
1803
1804 /* Sets up the inferior to be debugged.  Registers to trace signals,
1805    hardware faults, and syscalls.  Note: does not set RLC flag: caller
1806    may want to customize that.  Returns zero for success (note!
1807    unlike most functions in this module); on failure, returns the LINE
1808    NUMBER where it failed!  */
1809
1810 static int
1811 procfs_debug_inferior (procinfo *pi)
1812 {
1813   fltset_t traced_faults;
1814   sigset_t traced_signals;
1815   sysset_t *traced_syscall_entries;
1816   sysset_t *traced_syscall_exits;
1817   int status;
1818
1819   /* Register to trace hardware faults in the child.  */
1820   prfillset (&traced_faults);           /* trace all faults...  */
1821   prdelset  (&traced_faults, FLTPAGE);  /* except page fault.  */
1822   if (!proc_set_traced_faults  (pi, &traced_faults))
1823     return __LINE__;
1824
1825   /* Initially, register to trace all signals in the child.  */
1826   prfillset (&traced_signals);
1827   if (!proc_set_traced_signals (pi, &traced_signals))
1828     return __LINE__;
1829
1830
1831   /* Register to trace the 'exit' system call (on entry).  */
1832   traced_syscall_entries = XNEW (sysset_t);
1833   premptyset (traced_syscall_entries);
1834   praddset (traced_syscall_entries, SYS_exit);
1835   praddset (traced_syscall_entries, SYS_lwp_exit);
1836
1837   status = proc_set_traced_sysentry (pi, traced_syscall_entries);
1838   xfree (traced_syscall_entries);
1839   if (!status)
1840     return __LINE__;
1841
1842   /* Method for tracing exec syscalls.  */
1843   /* GW: Rationale...
1844      Not all systems with /proc have all the exec* syscalls with the same
1845      names.  On the SGI, for example, there is no SYS_exec, but there
1846      *is* a SYS_execv.  So, we try to account for that.  */
1847
1848   traced_syscall_exits = XNEW (sysset_t);
1849   premptyset (traced_syscall_exits);
1850 #ifdef SYS_exec
1851   praddset (traced_syscall_exits, SYS_exec);
1852 #endif
1853   praddset (traced_syscall_exits, SYS_execve);
1854   praddset (traced_syscall_exits, SYS_lwp_create);
1855   praddset (traced_syscall_exits, SYS_lwp_exit);
1856
1857   status = proc_set_traced_sysexit (pi, traced_syscall_exits);
1858   xfree (traced_syscall_exits);
1859   if (!status)
1860     return __LINE__;
1861
1862   return 0;
1863 }
1864
1865 void
1866 procfs_target::attach (const char *args, int from_tty)
1867 {
1868   char *exec_file;
1869   int   pid;
1870
1871   pid = parse_pid_to_attach (args);
1872
1873   if (pid == getpid ())
1874     error (_("Attaching GDB to itself is not a good idea..."));
1875
1876   if (from_tty)
1877     {
1878       exec_file = get_exec_file (0);
1879
1880       if (exec_file)
1881         printf_filtered (_("Attaching to program `%s', %s\n"),
1882                          exec_file, target_pid_to_str (ptid_t (pid)));
1883       else
1884         printf_filtered (_("Attaching to %s\n"),
1885                          target_pid_to_str (ptid_t (pid)));
1886
1887       fflush (stdout);
1888     }
1889   inferior_ptid = do_attach (ptid_t (pid));
1890   if (!target_is_pushed (this))
1891     push_target (this);
1892 }
1893
1894 void
1895 procfs_target::detach (inferior *inf, int from_tty)
1896 {
1897   int pid = inferior_ptid.pid ();
1898
1899   if (from_tty)
1900     {
1901       const char *exec_file;
1902
1903       exec_file = get_exec_file (0);
1904       if (exec_file == NULL)
1905         exec_file = "";
1906
1907       printf_filtered (_("Detaching from program: %s, %s\n"), exec_file,
1908                        target_pid_to_str (ptid_t (pid)));
1909       gdb_flush (gdb_stdout);
1910     }
1911
1912   do_detach ();
1913
1914   inferior_ptid = null_ptid;
1915   detach_inferior (inf);
1916   maybe_unpush_target ();
1917 }
1918
1919 static ptid_t
1920 do_attach (ptid_t ptid)
1921 {
1922   procinfo *pi;
1923   struct inferior *inf;
1924   int fail;
1925   int lwpid;
1926
1927   pi = create_procinfo (ptid.pid (), 0);
1928   if (pi == NULL)
1929     perror (_("procfs: out of memory in 'attach'"));
1930
1931   if (!open_procinfo_files (pi, FD_CTL))
1932     {
1933       fprintf_filtered (gdb_stderr, "procfs:%d -- ", __LINE__);
1934       xsnprintf (errmsg, sizeof (errmsg),
1935                  "do_attach: couldn't open /proc file for process %d",
1936                  ptid.pid ());
1937       dead_procinfo (pi, errmsg, NOKILL);
1938     }
1939
1940   /* Stop the process (if it isn't already stopped).  */
1941   if (proc_flags (pi) & (PR_STOPPED | PR_ISTOP))
1942     {
1943       pi->was_stopped = 1;
1944       proc_prettyprint_why (proc_why (pi), proc_what (pi), 1);
1945     }
1946   else
1947     {
1948       pi->was_stopped = 0;
1949       /* Set the process to run again when we close it.  */
1950       if (!proc_set_run_on_last_close (pi))
1951         dead_procinfo (pi, "do_attach: couldn't set RLC.", NOKILL);
1952
1953       /* Now stop the process.  */
1954       if (!proc_stop_process (pi))
1955         dead_procinfo (pi, "do_attach: couldn't stop the process.", NOKILL);
1956       pi->ignore_next_sigstop = 1;
1957     }
1958   /* Save some of the /proc state to be restored if we detach.  */
1959   if (!proc_get_traced_faults   (pi, &pi->saved_fltset))
1960     dead_procinfo (pi, "do_attach: couldn't save traced faults.", NOKILL);
1961   if (!proc_get_traced_signals  (pi, &pi->saved_sigset))
1962     dead_procinfo (pi, "do_attach: couldn't save traced signals.", NOKILL);
1963   if (!proc_get_traced_sysentry (pi, pi->saved_entryset))
1964     dead_procinfo (pi, "do_attach: couldn't save traced syscall entries.",
1965                    NOKILL);
1966   if (!proc_get_traced_sysexit  (pi, pi->saved_exitset))
1967     dead_procinfo (pi, "do_attach: couldn't save traced syscall exits.",
1968                    NOKILL);
1969   if (!proc_get_held_signals    (pi, &pi->saved_sighold))
1970     dead_procinfo (pi, "do_attach: couldn't save held signals.", NOKILL);
1971
1972   fail = procfs_debug_inferior (pi);
1973   if (fail != 0)
1974     dead_procinfo (pi, "do_attach: failed in procfs_debug_inferior", NOKILL);
1975
1976   inf = current_inferior ();
1977   inferior_appeared (inf, pi->pid);
1978   /* Let GDB know that the inferior was attached.  */
1979   inf->attach_flag = 1;
1980
1981   /* Create a procinfo for the current lwp.  */
1982   lwpid = proc_get_current_thread (pi);
1983   create_procinfo (pi->pid, lwpid);
1984
1985   /* Add it to gdb's thread list.  */
1986   ptid = ptid_t (pi->pid, lwpid, 0);
1987   add_thread (ptid);
1988
1989   return ptid;
1990 }
1991
1992 static void
1993 do_detach ()
1994 {
1995   procinfo *pi;
1996
1997   /* Find procinfo for the main process.  */
1998   pi = find_procinfo_or_die (inferior_ptid.pid (),
1999                              0); /* FIXME: threads */
2000
2001   if (!proc_set_traced_signals (pi, &pi->saved_sigset))
2002     proc_warn (pi, "do_detach, set_traced_signal", __LINE__);
2003
2004   if (!proc_set_traced_faults (pi, &pi->saved_fltset))
2005     proc_warn (pi, "do_detach, set_traced_faults", __LINE__);
2006
2007   if (!proc_set_traced_sysentry (pi, pi->saved_entryset))
2008     proc_warn (pi, "do_detach, set_traced_sysentry", __LINE__);
2009
2010   if (!proc_set_traced_sysexit (pi, pi->saved_exitset))
2011     proc_warn (pi, "do_detach, set_traced_sysexit", __LINE__);
2012
2013   if (!proc_set_held_signals (pi, &pi->saved_sighold))
2014     proc_warn (pi, "do_detach, set_held_signals", __LINE__);
2015
2016   if (proc_flags (pi) & (PR_STOPPED | PR_ISTOP))
2017     if (!(pi->was_stopped)
2018         || query (_("Was stopped when attached, make it runnable again? ")))
2019       {
2020         /* Clear any pending signal.  */
2021         if (!proc_clear_current_fault (pi))
2022           proc_warn (pi, "do_detach, clear_current_fault", __LINE__);
2023
2024         if (!proc_clear_current_signal (pi))
2025           proc_warn (pi, "do_detach, clear_current_signal", __LINE__);
2026
2027         if (!proc_set_run_on_last_close (pi))
2028           proc_warn (pi, "do_detach, set_rlc", __LINE__);
2029       }
2030
2031   destroy_procinfo (pi);
2032 }
2033
2034 /* Fetch register REGNUM from the inferior.  If REGNUM is -1, do this
2035    for all registers.
2036
2037    ??? Is the following note still relevant?  We can't get individual
2038    registers with the PT_GETREGS ptrace(2) request either, yet we
2039    don't bother with caching at all in that case.
2040
2041    NOTE: Since the /proc interface cannot give us individual
2042    registers, we pay no attention to REGNUM, and just fetch them all.
2043    This results in the possibility that we will do unnecessarily many
2044    fetches, since we may be called repeatedly for individual
2045    registers.  So we cache the results, and mark the cache invalid
2046    when the process is resumed.  */
2047
2048 void
2049 procfs_target::fetch_registers (struct regcache *regcache, int regnum)
2050 {
2051   gdb_gregset_t *gregs;
2052   procinfo *pi;
2053   ptid_t ptid = regcache->ptid ();
2054   int pid = ptid.pid ();
2055   int tid = ptid.lwp ();
2056   struct gdbarch *gdbarch = regcache->arch ();
2057
2058   pi = find_procinfo_or_die (pid, tid);
2059
2060   if (pi == NULL)
2061     error (_("procfs: fetch_registers failed to find procinfo for %s"),
2062            target_pid_to_str (ptid));
2063
2064   gregs = proc_get_gregs (pi);
2065   if (gregs == NULL)
2066     proc_error (pi, "fetch_registers, get_gregs", __LINE__);
2067
2068   supply_gregset (regcache, (const gdb_gregset_t *) gregs);
2069
2070   if (gdbarch_fp0_regnum (gdbarch) >= 0) /* Do we have an FPU?  */
2071     {
2072       gdb_fpregset_t *fpregs;
2073
2074       if ((regnum >= 0 && regnum < gdbarch_fp0_regnum (gdbarch))
2075           || regnum == gdbarch_pc_regnum (gdbarch)
2076           || regnum == gdbarch_sp_regnum (gdbarch))
2077         return;                 /* Not a floating point register.  */
2078
2079       fpregs = proc_get_fpregs (pi);
2080       if (fpregs == NULL)
2081         proc_error (pi, "fetch_registers, get_fpregs", __LINE__);
2082
2083       supply_fpregset (regcache, (const gdb_fpregset_t *) fpregs);
2084     }
2085 }
2086
2087 /* Store register REGNUM back into the inferior.  If REGNUM is -1, do
2088    this for all registers.
2089
2090    NOTE: Since the /proc interface will not read individual registers,
2091    we will cache these requests until the process is resumed, and only
2092    then write them back to the inferior process.
2093
2094    FIXME: is that a really bad idea?  Have to think about cases where
2095    writing one register might affect the value of others, etc.  */
2096
2097 void
2098 procfs_target::store_registers (struct regcache *regcache, int regnum)
2099 {
2100   gdb_gregset_t *gregs;
2101   procinfo *pi;
2102   ptid_t ptid = regcache->ptid ();
2103   int pid = ptid.pid ();
2104   int tid = ptid.lwp ();
2105   struct gdbarch *gdbarch = regcache->arch ();
2106
2107   pi = find_procinfo_or_die (pid, tid);
2108
2109   if (pi == NULL)
2110     error (_("procfs: store_registers: failed to find procinfo for %s"),
2111            target_pid_to_str (ptid));
2112
2113   gregs = proc_get_gregs (pi);
2114   if (gregs == NULL)
2115     proc_error (pi, "store_registers, get_gregs", __LINE__);
2116
2117   fill_gregset (regcache, gregs, regnum);
2118   if (!proc_set_gregs (pi))
2119     proc_error (pi, "store_registers, set_gregs", __LINE__);
2120
2121   if (gdbarch_fp0_regnum (gdbarch) >= 0) /* Do we have an FPU?  */
2122     {
2123       gdb_fpregset_t *fpregs;
2124
2125       if ((regnum >= 0 && regnum < gdbarch_fp0_regnum (gdbarch))
2126           || regnum == gdbarch_pc_regnum (gdbarch)
2127           || regnum == gdbarch_sp_regnum (gdbarch))
2128         return;                 /* Not a floating point register.  */
2129
2130       fpregs = proc_get_fpregs (pi);
2131       if (fpregs == NULL)
2132         proc_error (pi, "store_registers, get_fpregs", __LINE__);
2133
2134       fill_fpregset (regcache, fpregs, regnum);
2135       if (!proc_set_fpregs (pi))
2136         proc_error (pi, "store_registers, set_fpregs", __LINE__);
2137     }
2138 }
2139
2140 static int
2141 syscall_is_lwp_exit (procinfo *pi, int scall)
2142 {
2143   if (scall == SYS_lwp_exit)
2144     return 1;
2145   return 0;
2146 }
2147
2148 static int
2149 syscall_is_exit (procinfo *pi, int scall)
2150 {
2151   if (scall == SYS_exit)
2152     return 1;
2153   return 0;
2154 }
2155
2156 static int
2157 syscall_is_exec (procinfo *pi, int scall)
2158 {
2159 #ifdef SYS_exec
2160   if (scall == SYS_exec)
2161     return 1;
2162 #endif
2163   if (scall == SYS_execve)
2164     return 1;
2165   return 0;
2166 }
2167
2168 static int
2169 syscall_is_lwp_create (procinfo *pi, int scall)
2170 {
2171   if (scall == SYS_lwp_create)
2172     return 1;
2173   return 0;
2174 }
2175
2176 /* Retrieve the next stop event from the child process.  If child has
2177    not stopped yet, wait for it to stop.  Translate /proc eventcodes
2178    (or possibly wait eventcodes) into gdb internal event codes.
2179    Returns the id of process (and possibly thread) that incurred the
2180    event.  Event codes are returned through a pointer parameter.  */
2181
2182 ptid_t
2183 procfs_target::wait (ptid_t ptid, struct target_waitstatus *status,
2184                      int options)
2185 {
2186   /* First cut: loosely based on original version 2.1.  */
2187   procinfo *pi;
2188   int       wstat;
2189   int       temp_tid;
2190   ptid_t    retval, temp_ptid;
2191   int       why, what, flags;
2192   int       retry = 0;
2193
2194 wait_again:
2195
2196   retry++;
2197   wstat    = 0;
2198   retval   = ptid_t (-1);
2199
2200   /* Find procinfo for main process.  */
2201   pi = find_procinfo_or_die (inferior_ptid.pid (), 0);
2202   if (pi)
2203     {
2204       /* We must assume that the status is stale now...  */
2205       pi->status_valid = 0;
2206       pi->gregs_valid  = 0;
2207       pi->fpregs_valid = 0;
2208
2209 #if 0   /* just try this out...  */
2210       flags = proc_flags (pi);
2211       why   = proc_why (pi);
2212       if ((flags & PR_STOPPED) && (why == PR_REQUESTED))
2213         pi->status_valid = 0;   /* re-read again, IMMEDIATELY...  */
2214 #endif
2215       /* If child is not stopped, wait for it to stop.  */
2216       if (!(proc_flags (pi) & (PR_STOPPED | PR_ISTOP))
2217           && !proc_wait_for_stop (pi))
2218         {
2219           /* wait_for_stop failed: has the child terminated?  */
2220           if (errno == ENOENT)
2221             {
2222               int wait_retval;
2223
2224               /* /proc file not found; presumably child has terminated.  */
2225               wait_retval = ::wait (&wstat); /* "wait" for the child's exit.  */
2226
2227               /* Wrong child?  */
2228               if (wait_retval != inferior_ptid.pid ())
2229                 error (_("procfs: couldn't stop "
2230                          "process %d: wait returned %d."),
2231                        inferior_ptid.pid (), wait_retval);
2232               /* FIXME: might I not just use waitpid?
2233                  Or try find_procinfo to see if I know about this child?  */
2234               retval = ptid_t (wait_retval);
2235             }
2236           else if (errno == EINTR)
2237             goto wait_again;
2238           else
2239             {
2240               /* Unknown error from wait_for_stop.  */
2241               proc_error (pi, "target_wait (wait_for_stop)", __LINE__);
2242             }
2243         }
2244       else
2245         {
2246           /* This long block is reached if either:
2247              a) the child was already stopped, or
2248              b) we successfully waited for the child with wait_for_stop.
2249              This block will analyze the /proc status, and translate it
2250              into a waitstatus for GDB.
2251
2252              If we actually had to call wait because the /proc file
2253              is gone (child terminated), then we skip this block,
2254              because we already have a waitstatus.  */
2255
2256           flags = proc_flags (pi);
2257           why   = proc_why (pi);
2258           what  = proc_what (pi);
2259
2260           if (flags & (PR_STOPPED | PR_ISTOP))
2261             {
2262               /* If it's running async (for single_thread control),
2263                  set it back to normal again.  */
2264               if (flags & PR_ASYNC)
2265                 if (!proc_unset_async (pi))
2266                   proc_error (pi, "target_wait, unset_async", __LINE__);
2267
2268               if (info_verbose)
2269                 proc_prettyprint_why (why, what, 1);
2270
2271               /* The 'pid' we will return to GDB is composed of
2272                  the process ID plus the lwp ID.  */
2273               retval = ptid_t (pi->pid, proc_get_current_thread (pi), 0);
2274
2275               switch (why) {
2276               case PR_SIGNALLED:
2277                 wstat = (what << 8) | 0177;
2278                 break;
2279               case PR_SYSENTRY:
2280                 if (syscall_is_lwp_exit (pi, what))
2281                   {
2282                     if (print_thread_events)
2283                       printf_unfiltered (_("[%s exited]\n"),
2284                                          target_pid_to_str (retval));
2285                     delete_thread (find_thread_ptid (retval));
2286                     status->kind = TARGET_WAITKIND_SPURIOUS;
2287                     return retval;
2288                   }
2289                 else if (syscall_is_exit (pi, what))
2290                   {
2291                     struct inferior *inf;
2292
2293                     /* Handle SYS_exit call only.  */
2294                     /* Stopped at entry to SYS_exit.
2295                        Make it runnable, resume it, then use
2296                        the wait system call to get its exit code.
2297                        Proc_run_process always clears the current
2298                        fault and signal.
2299                        Then return its exit status.  */
2300                     pi->status_valid = 0;
2301                     wstat = 0;
2302                     /* FIXME: what we should do is return
2303                        TARGET_WAITKIND_SPURIOUS.  */
2304                     if (!proc_run_process (pi, 0, 0))
2305                       proc_error (pi, "target_wait, run_process", __LINE__);
2306
2307                     inf = find_inferior_pid (pi->pid);
2308                     if (inf->attach_flag)
2309                       {
2310                         /* Don't call wait: simulate waiting for exit,
2311                            return a "success" exit code.  Bogus: what if
2312                            it returns something else?  */
2313                         wstat = 0;
2314                         retval = inferior_ptid;  /* ? ? ? */
2315                       }
2316                     else
2317                       {
2318                         int temp = ::wait (&wstat);
2319
2320                         /* FIXME: shouldn't I make sure I get the right
2321                            event from the right process?  If (for
2322                            instance) I have killed an earlier inferior
2323                            process but failed to clean up after it
2324                            somehow, I could get its termination event
2325                            here.  */
2326
2327                         /* If wait returns -1, that's what we return
2328                            to GDB.  */
2329                         if (temp < 0)
2330                           retval = ptid_t (temp);
2331                       }
2332                   }
2333                 else
2334                   {
2335                     printf_filtered (_("procfs: trapped on entry to "));
2336                     proc_prettyprint_syscall (proc_what (pi), 0);
2337                     printf_filtered ("\n");
2338
2339                     long i, nsysargs, *sysargs;
2340
2341                     nsysargs = proc_nsysarg (pi);
2342                     sysargs  = proc_sysargs (pi);
2343
2344                     if (nsysargs > 0 && sysargs != NULL)
2345                       {
2346                         printf_filtered (_("%ld syscall arguments:\n"),
2347                                          nsysargs);
2348                         for (i = 0; i < nsysargs; i++)
2349                           printf_filtered ("#%ld: 0x%08lx\n",
2350                                            i, sysargs[i]);
2351                       }
2352
2353                     if (status)
2354                       {
2355                         /* How to exit gracefully, returning "unknown
2356                            event".  */
2357                         status->kind = TARGET_WAITKIND_SPURIOUS;
2358                         return inferior_ptid;
2359                       }
2360                     else
2361                       {
2362                         /* How to keep going without returning to wfi: */
2363                         target_continue_no_signal (ptid);
2364                         goto wait_again;
2365                       }
2366                   }
2367                 break;
2368               case PR_SYSEXIT:
2369                 if (syscall_is_exec (pi, what))
2370                   {
2371                     /* Hopefully this is our own "fork-child" execing
2372                        the real child.  Hoax this event into a trap, and
2373                        GDB will see the child about to execute its start
2374                        address.  */
2375                     wstat = (SIGTRAP << 8) | 0177;
2376                   }
2377                 else if (syscall_is_lwp_create (pi, what))
2378                   {
2379                     /* This syscall is somewhat like fork/exec.  We
2380                        will get the event twice: once for the parent
2381                        LWP, and once for the child.  We should already
2382                        know about the parent LWP, but the child will
2383                        be new to us.  So, whenever we get this event,
2384                        if it represents a new thread, simply add the
2385                        thread to the list.  */
2386
2387                     /* If not in procinfo list, add it.  */
2388                     temp_tid = proc_get_current_thread (pi);
2389                     if (!find_procinfo (pi->pid, temp_tid))
2390                       create_procinfo  (pi->pid, temp_tid);
2391
2392                     temp_ptid = ptid_t (pi->pid, temp_tid, 0);
2393                     /* If not in GDB's thread list, add it.  */
2394                     if (!in_thread_list (temp_ptid))
2395                       add_thread (temp_ptid);
2396
2397                     /* Return to WFI, but tell it to immediately resume.  */
2398                     status->kind = TARGET_WAITKIND_SPURIOUS;
2399                     return inferior_ptid;
2400                   }
2401                 else if (syscall_is_lwp_exit (pi, what))
2402                   {
2403                     if (print_thread_events)
2404                       printf_unfiltered (_("[%s exited]\n"),
2405                                          target_pid_to_str (retval));
2406                     delete_thread (find_thread_ptid (retval));
2407                     status->kind = TARGET_WAITKIND_SPURIOUS;
2408                     return retval;
2409                   }
2410                 else if (0)
2411                   {
2412                     /* FIXME:  Do we need to handle SYS_sproc,
2413                        SYS_fork, or SYS_vfork here?  The old procfs
2414                        seemed to use this event to handle threads on
2415                        older (non-LWP) systems, where I'm assuming
2416                        that threads were actually separate processes.
2417                        Irix, maybe?  Anyway, low priority for now.  */
2418                   }
2419                 else
2420                   {
2421                     printf_filtered (_("procfs: trapped on exit from "));
2422                     proc_prettyprint_syscall (proc_what (pi), 0);
2423                     printf_filtered ("\n");
2424
2425                     long i, nsysargs, *sysargs;
2426
2427                     nsysargs = proc_nsysarg (pi);
2428                     sysargs = proc_sysargs (pi);
2429
2430                     if (nsysargs > 0 && sysargs != NULL)
2431                       {
2432                         printf_filtered (_("%ld syscall arguments:\n"),
2433                                          nsysargs);
2434                         for (i = 0; i < nsysargs; i++)
2435                           printf_filtered ("#%ld: 0x%08lx\n",
2436                                            i, sysargs[i]);
2437                       }
2438
2439                     status->kind = TARGET_WAITKIND_SPURIOUS;
2440                     return inferior_ptid;
2441                   }
2442                 break;
2443               case PR_REQUESTED:
2444 #if 0   /* FIXME */
2445                 wstat = (SIGSTOP << 8) | 0177;
2446                 break;
2447 #else
2448                 if (retry < 5)
2449                   {
2450                     printf_filtered (_("Retry #%d:\n"), retry);
2451                     pi->status_valid = 0;
2452                     goto wait_again;
2453                   }
2454                 else
2455                   {
2456                     /* If not in procinfo list, add it.  */
2457                     temp_tid = proc_get_current_thread (pi);
2458                     if (!find_procinfo (pi->pid, temp_tid))
2459                       create_procinfo  (pi->pid, temp_tid);
2460
2461                     /* If not in GDB's thread list, add it.  */
2462                     temp_ptid = ptid_t (pi->pid, temp_tid, 0);
2463                     if (!in_thread_list (temp_ptid))
2464                       add_thread (temp_ptid);
2465
2466                     status->kind = TARGET_WAITKIND_STOPPED;
2467                     status->value.sig = GDB_SIGNAL_0;
2468                     return retval;
2469                   }
2470 #endif
2471               case PR_JOBCONTROL:
2472                 wstat = (what << 8) | 0177;
2473                 break;
2474               case PR_FAULTED:
2475                 switch (what) {
2476                 case FLTWATCH:
2477                   wstat = (SIGTRAP << 8) | 0177;
2478                   break;
2479                   /* FIXME: use si_signo where possible.  */
2480                 case FLTPRIV:
2481                 case FLTILL:
2482                   wstat = (SIGILL << 8) | 0177;
2483                   break;
2484                 case FLTBPT:
2485                 case FLTTRACE:
2486                   wstat = (SIGTRAP << 8) | 0177;
2487                   break;
2488                 case FLTSTACK:
2489                 case FLTACCESS:
2490                 case FLTBOUNDS:
2491                   wstat = (SIGSEGV << 8) | 0177;
2492                   break;
2493                 case FLTIOVF:
2494                 case FLTIZDIV:
2495                 case FLTFPE:
2496                   wstat = (SIGFPE << 8) | 0177;
2497                   break;
2498                 case FLTPAGE:   /* Recoverable page fault */
2499                 default:        /* FIXME: use si_signo if possible for
2500                                    fault.  */
2501                   retval = ptid_t (-1);
2502                   printf_filtered ("procfs:%d -- ", __LINE__);
2503                   printf_filtered (_("child stopped for unknown reason:\n"));
2504                   proc_prettyprint_why (why, what, 1);
2505                   error (_("... giving up..."));
2506                   break;
2507                 }
2508                 break;  /* case PR_FAULTED: */
2509               default:  /* switch (why) unmatched */
2510                 printf_filtered ("procfs:%d -- ", __LINE__);
2511                 printf_filtered (_("child stopped for unknown reason:\n"));
2512                 proc_prettyprint_why (why, what, 1);
2513                 error (_("... giving up..."));
2514                 break;
2515               }
2516               /* Got this far without error: If retval isn't in the
2517                  threads database, add it.  */
2518               if (retval.pid () > 0
2519                   && retval != inferior_ptid
2520                   && !in_thread_list (retval))
2521                 {
2522                   /* We have a new thread.  We need to add it both to
2523                      GDB's list and to our own.  If we don't create a
2524                      procinfo, resume may be unhappy later.  */
2525                   add_thread (retval);
2526                   if (find_procinfo (retval.pid (),
2527                                      retval.lwp ()) == NULL)
2528                     create_procinfo (retval.pid (),
2529                                      retval.lwp ());
2530                 }
2531             }
2532           else  /* Flags do not indicate STOPPED.  */
2533             {
2534               /* surely this can't happen...  */
2535               printf_filtered ("procfs:%d -- process not stopped.\n",
2536                                __LINE__);
2537               proc_prettyprint_flags (flags, 1);
2538               error (_("procfs: ...giving up..."));
2539             }
2540         }
2541
2542       if (status)
2543         store_waitstatus (status, wstat);
2544     }
2545
2546   return retval;
2547 }
2548
2549 /* Perform a partial transfer to/from the specified object.  For
2550    memory transfers, fall back to the old memory xfer functions.  */
2551
2552 enum target_xfer_status
2553 procfs_target::xfer_partial (enum target_object object,
2554                              const char *annex, gdb_byte *readbuf,
2555                              const gdb_byte *writebuf, ULONGEST offset,
2556                              ULONGEST len, ULONGEST *xfered_len)
2557 {
2558   switch (object)
2559     {
2560     case TARGET_OBJECT_MEMORY:
2561       return procfs_xfer_memory (readbuf, writebuf, offset, len, xfered_len);
2562
2563     case TARGET_OBJECT_AUXV:
2564       return memory_xfer_auxv (this, object, annex, readbuf, writebuf,
2565                                offset, len, xfered_len);
2566
2567     default:
2568       return this->beneath ()->xfer_partial (object, annex,
2569                                              readbuf, writebuf, offset, len,
2570                                              xfered_len);
2571     }
2572 }
2573
2574 /* Helper for procfs_xfer_partial that handles memory transfers.
2575    Arguments are like target_xfer_partial.  */
2576
2577 static enum target_xfer_status
2578 procfs_xfer_memory (gdb_byte *readbuf, const gdb_byte *writebuf,
2579                     ULONGEST memaddr, ULONGEST len, ULONGEST *xfered_len)
2580 {
2581   procinfo *pi;
2582   int nbytes;
2583
2584   /* Find procinfo for main process.  */
2585   pi = find_procinfo_or_die (inferior_ptid.pid (), 0);
2586   if (pi->as_fd == 0 && open_procinfo_files (pi, FD_AS) == 0)
2587     {
2588       proc_warn (pi, "xfer_memory, open_proc_files", __LINE__);
2589       return TARGET_XFER_E_IO;
2590     }
2591
2592   if (lseek (pi->as_fd, (off_t) memaddr, SEEK_SET) != (off_t) memaddr)
2593     return TARGET_XFER_E_IO;
2594
2595   if (writebuf != NULL)
2596     {
2597       PROCFS_NOTE ("write memory:\n");
2598       nbytes = write (pi->as_fd, writebuf, len);
2599     }
2600   else
2601     {
2602       PROCFS_NOTE ("read  memory:\n");
2603       nbytes = read (pi->as_fd, readbuf, len);
2604     }
2605   if (nbytes <= 0)
2606     return TARGET_XFER_E_IO;
2607   *xfered_len = nbytes;
2608   return TARGET_XFER_OK;
2609 }
2610
2611 /* Called by target_resume before making child runnable.  Mark cached
2612    registers and status's invalid.  If there are "dirty" caches that
2613    need to be written back to the child process, do that.
2614
2615    File descriptors are also cached.  As they are a limited resource,
2616    we cannot hold onto them indefinitely.  However, as they are
2617    expensive to open, we don't want to throw them away
2618    indescriminately either.  As a compromise, we will keep the file
2619    descriptors for the parent process, but discard any file
2620    descriptors we may have accumulated for the threads.
2621
2622    As this function is called by iterate_over_threads, it always
2623    returns zero (so that iterate_over_threads will keep
2624    iterating).  */
2625
2626 static int
2627 invalidate_cache (procinfo *parent, procinfo *pi, void *ptr)
2628 {
2629   /* About to run the child; invalidate caches and do any other
2630      cleanup.  */
2631
2632 #if 0
2633   if (pi->gregs_dirty)
2634     if (parent == NULL || proc_get_current_thread (parent) != pi->tid)
2635       if (!proc_set_gregs (pi)) /* flush gregs cache */
2636         proc_warn (pi, "target_resume, set_gregs",
2637                    __LINE__);
2638   if (gdbarch_fp0_regnum (target_gdbarch ()) >= 0)
2639     if (pi->fpregs_dirty)
2640       if (parent == NULL || proc_get_current_thread (parent) != pi->tid)
2641         if (!proc_set_fpregs (pi))      /* flush fpregs cache */
2642           proc_warn (pi, "target_resume, set_fpregs",
2643                      __LINE__);
2644 #endif
2645
2646   if (parent != NULL)
2647     {
2648       /* The presence of a parent indicates that this is an LWP.
2649          Close any file descriptors that it might have open.
2650          We don't do this to the master (parent) procinfo.  */
2651
2652       close_procinfo_files (pi);
2653     }
2654   pi->gregs_valid   = 0;
2655   pi->fpregs_valid  = 0;
2656 #if 0
2657   pi->gregs_dirty   = 0;
2658   pi->fpregs_dirty  = 0;
2659 #endif
2660   pi->status_valid  = 0;
2661   pi->threads_valid = 0;
2662
2663   return 0;
2664 }
2665
2666 #if 0
2667 /* A callback function for iterate_over_threads.  Find the
2668    asynchronous signal thread, and make it runnable.  See if that
2669    helps matters any.  */
2670
2671 static int
2672 make_signal_thread_runnable (procinfo *process, procinfo *pi, void *ptr)
2673 {
2674 #ifdef PR_ASLWP
2675   if (proc_flags (pi) & PR_ASLWP)
2676     {
2677       if (!proc_run_process (pi, 0, -1))
2678         proc_error (pi, "make_signal_thread_runnable", __LINE__);
2679       return 1;
2680     }
2681 #endif
2682   return 0;
2683 }
2684 #endif
2685
2686 /* Make the child process runnable.  Normally we will then call
2687    procfs_wait and wait for it to stop again (unless gdb is async).
2688
2689    If STEP is true, then arrange for the child to stop again after
2690    executing a single instruction.  If SIGNO is zero, then cancel any
2691    pending signal; if non-zero, then arrange for the indicated signal
2692    to be delivered to the child when it runs.  If PID is -1, then
2693    allow any child thread to run; if non-zero, then allow only the
2694    indicated thread to run.  (not implemented yet).  */
2695
2696 void
2697 procfs_target::resume (ptid_t ptid, int step, enum gdb_signal signo)
2698 {
2699   procinfo *pi, *thread;
2700   int native_signo;
2701
2702   /* 2.1:
2703      prrun.prflags |= PRSVADDR;
2704      prrun.pr_vaddr = $PC;         set resume address
2705      prrun.prflags |= PRSTRACE;    trace signals in pr_trace (all)
2706      prrun.prflags |= PRSFAULT;    trace faults in pr_fault (all but PAGE)
2707      prrun.prflags |= PRCFAULT;    clear current fault.
2708
2709      PRSTRACE and PRSFAULT can be done by other means
2710         (proc_trace_signals, proc_trace_faults)
2711      PRSVADDR is unnecessary.
2712      PRCFAULT may be replaced by a PIOCCFAULT call (proc_clear_current_fault)
2713      This basically leaves PRSTEP and PRCSIG.
2714      PRCSIG is like PIOCSSIG (proc_clear_current_signal).
2715      So basically PR_STEP is the sole argument that must be passed
2716      to proc_run_process (for use in the prrun struct by ioctl).  */
2717
2718   /* Find procinfo for main process.  */
2719   pi = find_procinfo_or_die (inferior_ptid.pid (), 0);
2720
2721   /* First cut: ignore pid argument.  */
2722   errno = 0;
2723
2724   /* Convert signal to host numbering.  */
2725   if (signo == 0 || (signo == GDB_SIGNAL_STOP && pi->ignore_next_sigstop))
2726     native_signo = 0;
2727   else
2728     native_signo = gdb_signal_to_host (signo);
2729
2730   pi->ignore_next_sigstop = 0;
2731
2732   /* Running the process voids all cached registers and status.  */
2733   /* Void the threads' caches first.  */
2734   proc_iterate_over_threads (pi, invalidate_cache, NULL);
2735   /* Void the process procinfo's caches.  */
2736   invalidate_cache (NULL, pi, NULL);
2737
2738   if (ptid.pid () != -1)
2739     {
2740       /* Resume a specific thread, presumably suppressing the
2741          others.  */
2742       thread = find_procinfo (ptid.pid (), ptid.lwp ());
2743       if (thread != NULL)
2744         {
2745           if (thread->tid != 0)
2746             {
2747               /* We're to resume a specific thread, and not the
2748                  others.  Set the child process's PR_ASYNC flag.  */
2749               if (!proc_set_async (pi))
2750                 proc_error (pi, "target_resume, set_async", __LINE__);
2751 #if 0
2752               proc_iterate_over_threads (pi,
2753                                          make_signal_thread_runnable,
2754                                          NULL);
2755 #endif
2756               pi = thread;      /* Substitute the thread's procinfo
2757                                    for run.  */
2758             }
2759         }
2760     }
2761
2762   if (!proc_run_process (pi, step, native_signo))
2763     {
2764       if (errno == EBUSY)
2765         warning (_("resume: target already running.  "
2766                    "Pretend to resume, and hope for the best!"));
2767       else
2768         proc_error (pi, "target_resume", __LINE__);
2769     }
2770 }
2771
2772 /* Set up to trace signals in the child process.  */
2773
2774 void
2775 procfs_target::pass_signals (int numsigs, unsigned char *pass_signals)
2776 {
2777   sigset_t signals;
2778   procinfo *pi = find_procinfo_or_die (inferior_ptid.pid (), 0);
2779   int signo;
2780
2781   prfillset (&signals);
2782
2783   for (signo = 0; signo < NSIG; signo++)
2784     {
2785       int target_signo = gdb_signal_from_host (signo);
2786       if (target_signo < numsigs && pass_signals[target_signo])
2787         prdelset (&signals, signo);
2788     }
2789
2790   if (!proc_set_traced_signals (pi, &signals))
2791     proc_error (pi, "pass_signals", __LINE__);
2792 }
2793
2794 /* Print status information about the child process.  */
2795
2796 void
2797 procfs_target::files_info ()
2798 {
2799   struct inferior *inf = current_inferior ();
2800
2801   printf_filtered (_("\tUsing the running image of %s %s via /proc.\n"),
2802                    inf->attach_flag? "attached": "child",
2803                    target_pid_to_str (inferior_ptid));
2804 }
2805
2806 /* Make it die.  Wait for it to die.  Clean up after it.  Note: this
2807    should only be applied to the real process, not to an LWP, because
2808    of the check for parent-process.  If we need this to work for an
2809    LWP, it needs some more logic.  */
2810
2811 static void
2812 unconditionally_kill_inferior (procinfo *pi)
2813 {
2814   int parent_pid;
2815
2816   parent_pid = proc_parent_pid (pi);
2817   if (!proc_kill (pi, SIGKILL))
2818     proc_error (pi, "unconditionally_kill, proc_kill", __LINE__);
2819   destroy_procinfo (pi);
2820
2821   /* If pi is GDB's child, wait for it to die.  */
2822   if (parent_pid == getpid ())
2823     /* FIXME: should we use waitpid to make sure we get the right event?
2824        Should we check the returned event?  */
2825     {
2826 #if 0
2827       int status, ret;
2828
2829       ret = waitpid (pi->pid, &status, 0);
2830 #else
2831       wait (NULL);
2832 #endif
2833     }
2834 }
2835
2836 /* We're done debugging it, and we want it to go away.  Then we want
2837    GDB to forget all about it.  */
2838
2839 void
2840 procfs_target::kill ()
2841 {
2842   if (inferior_ptid != null_ptid) /* ? */
2843     {
2844       /* Find procinfo for main process.  */
2845       procinfo *pi = find_procinfo (inferior_ptid.pid (), 0);
2846
2847       if (pi)
2848         unconditionally_kill_inferior (pi);
2849       target_mourn_inferior (inferior_ptid);
2850     }
2851 }
2852
2853 /* Forget we ever debugged this thing!  */
2854
2855 void
2856 procfs_target::mourn_inferior ()
2857 {
2858   procinfo *pi;
2859
2860   if (inferior_ptid != null_ptid)
2861     {
2862       /* Find procinfo for main process.  */
2863       pi = find_procinfo (inferior_ptid.pid (), 0);
2864       if (pi)
2865         destroy_procinfo (pi);
2866     }
2867
2868   generic_mourn_inferior ();
2869
2870   maybe_unpush_target ();
2871 }
2872
2873 /* When GDB forks to create a runnable inferior process, this function
2874    is called on the parent side of the fork.  It's job is to do
2875    whatever is necessary to make the child ready to be debugged, and
2876    then wait for the child to synchronize.  */
2877
2878 static void
2879 procfs_init_inferior (struct target_ops *ops, int pid)
2880 {
2881   procinfo *pi;
2882   int fail;
2883   int lwpid;
2884
2885   /* This routine called on the parent side (GDB side)
2886      after GDB forks the inferior.  */
2887   if (!target_is_pushed (ops))
2888     push_target (ops);
2889
2890   pi = create_procinfo (pid, 0);
2891   if (pi == NULL)
2892     perror (_("procfs: out of memory in 'init_inferior'"));
2893
2894   if (!open_procinfo_files (pi, FD_CTL))
2895     proc_error (pi, "init_inferior, open_proc_files", __LINE__);
2896
2897   /*
2898     xmalloc                     // done
2899     open_procinfo_files         // done
2900     link list                   // done
2901     prfillset (trace)
2902     procfs_notice_signals
2903     prfillset (fault)
2904     prdelset (FLTPAGE)
2905     PIOCWSTOP
2906     PIOCSFAULT
2907     */
2908
2909   /* If not stopped yet, wait for it to stop.  */
2910   if (!(proc_flags (pi) & PR_STOPPED) && !(proc_wait_for_stop (pi)))
2911     dead_procinfo (pi, "init_inferior: wait_for_stop failed", KILL);
2912
2913   /* Save some of the /proc state to be restored if we detach.  */
2914   /* FIXME: Why?  In case another debugger was debugging it?
2915      We're it's parent, for Ghu's sake!  */
2916   if (!proc_get_traced_signals  (pi, &pi->saved_sigset))
2917     proc_error (pi, "init_inferior, get_traced_signals", __LINE__);
2918   if (!proc_get_held_signals    (pi, &pi->saved_sighold))
2919     proc_error (pi, "init_inferior, get_held_signals", __LINE__);
2920   if (!proc_get_traced_faults   (pi, &pi->saved_fltset))
2921     proc_error (pi, "init_inferior, get_traced_faults", __LINE__);
2922   if (!proc_get_traced_sysentry (pi, pi->saved_entryset))
2923     proc_error (pi, "init_inferior, get_traced_sysentry", __LINE__);
2924   if (!proc_get_traced_sysexit  (pi, pi->saved_exitset))
2925     proc_error (pi, "init_inferior, get_traced_sysexit", __LINE__);
2926
2927   fail = procfs_debug_inferior (pi);
2928   if (fail != 0)
2929     proc_error (pi, "init_inferior (procfs_debug_inferior)", fail);
2930
2931   /* FIXME: logically, we should really be turning OFF run-on-last-close,
2932      and possibly even turning ON kill-on-last-close at this point.  But
2933      I can't make that change without careful testing which I don't have
2934      time to do right now...  */
2935   /* Turn on run-on-last-close flag so that the child
2936      will die if GDB goes away for some reason.  */
2937   if (!proc_set_run_on_last_close (pi))
2938     proc_error (pi, "init_inferior, set_RLC", __LINE__);
2939
2940   /* We now have have access to the lwpid of the main thread/lwp.  */
2941   lwpid = proc_get_current_thread (pi);
2942
2943   /* Create a procinfo for the main lwp.  */
2944   create_procinfo (pid, lwpid);
2945
2946   /* We already have a main thread registered in the thread table at
2947      this point, but it didn't have any lwp info yet.  Notify the core
2948      about it.  This changes inferior_ptid as well.  */
2949   thread_change_ptid (ptid_t (pid),
2950                       ptid_t (pid, lwpid, 0));
2951
2952   gdb_startup_inferior (pid, START_INFERIOR_TRAPS_EXPECTED);
2953 }
2954
2955 /* When GDB forks to create a new process, this function is called on
2956    the child side of the fork before GDB exec's the user program.  Its
2957    job is to make the child minimally debuggable, so that the parent
2958    GDB process can connect to the child and take over.  This function
2959    should do only the minimum to make that possible, and to
2960    synchronize with the parent process.  The parent process should
2961    take care of the details.  */
2962
2963 static void
2964 procfs_set_exec_trap (void)
2965 {
2966   /* This routine called on the child side (inferior side)
2967      after GDB forks the inferior.  It must use only local variables,
2968      because it may be sharing data space with its parent.  */
2969
2970   procinfo *pi;
2971   sysset_t *exitset;
2972
2973   pi = create_procinfo (getpid (), 0);
2974   if (pi == NULL)
2975     perror_with_name (_("procfs: create_procinfo failed in child."));
2976
2977   if (open_procinfo_files (pi, FD_CTL) == 0)
2978     {
2979       proc_warn (pi, "set_exec_trap, open_proc_files", __LINE__);
2980       gdb_flush (gdb_stderr);
2981       /* No need to call "dead_procinfo", because we're going to
2982          exit.  */
2983       _exit (127);
2984     }
2985
2986   /* Method for tracing exec syscalls.  */
2987   /* GW: Rationale...
2988      Not all systems with /proc have all the exec* syscalls with the same
2989      names.  On the SGI, for example, there is no SYS_exec, but there
2990      *is* a SYS_execv.  So, we try to account for that.  */
2991
2992   exitset = XNEW (sysset_t);
2993   premptyset (exitset);
2994 #ifdef SYS_exec
2995   praddset (exitset, SYS_exec);
2996 #endif
2997   praddset (exitset, SYS_execve);
2998
2999   if (!proc_set_traced_sysexit (pi, exitset))
3000     {
3001       proc_warn (pi, "set_exec_trap, set_traced_sysexit", __LINE__);
3002       gdb_flush (gdb_stderr);
3003       _exit (127);
3004     }
3005
3006   /* FIXME: should this be done in the parent instead?  */
3007   /* Turn off inherit on fork flag so that all grand-children
3008      of gdb start with tracing flags cleared.  */
3009   if (!proc_unset_inherit_on_fork (pi))
3010     proc_warn (pi, "set_exec_trap, unset_inherit", __LINE__);
3011
3012   /* Turn off run on last close flag, so that the child process
3013      cannot run away just because we close our handle on it.
3014      We want it to wait for the parent to attach.  */
3015   if (!proc_unset_run_on_last_close (pi))
3016     proc_warn (pi, "set_exec_trap, unset_RLC", __LINE__);
3017
3018   /* FIXME: No need to destroy the procinfo --
3019      we have our own address space, and we're about to do an exec!  */
3020   /*destroy_procinfo (pi);*/
3021 }
3022
3023 /* This function is called BEFORE gdb forks the inferior process.  Its
3024    only real responsibility is to set things up for the fork, and tell
3025    GDB which two functions to call after the fork (one for the parent,
3026    and one for the child).
3027
3028    This function does a complicated search for a unix shell program,
3029    which it then uses to parse arguments and environment variables to
3030    be sent to the child.  I wonder whether this code could not be
3031    abstracted out and shared with other unix targets such as
3032    inf-ptrace?  */
3033
3034 void
3035 procfs_target::create_inferior (const char *exec_file,
3036                                 const std::string &allargs,
3037                                 char **env, int from_tty)
3038 {
3039   const char *shell_file = get_shell ();
3040   char *tryname;
3041   int pid;
3042
3043   if (strchr (shell_file, '/') == NULL)
3044     {
3045
3046       /* We will be looking down the PATH to find shell_file.  If we
3047          just do this the normal way (via execlp, which operates by
3048          attempting an exec for each element of the PATH until it
3049          finds one which succeeds), then there will be an exec for
3050          each failed attempt, each of which will cause a PR_SYSEXIT
3051          stop, and we won't know how to distinguish the PR_SYSEXIT's
3052          for these failed execs with the ones for successful execs
3053          (whether the exec has succeeded is stored at that time in the
3054          carry bit or some such architecture-specific and
3055          non-ABI-specified place).
3056
3057          So I can't think of anything better than to search the PATH
3058          now.  This has several disadvantages: (1) There is a race
3059          condition; if we find a file now and it is deleted before we
3060          exec it, we lose, even if the deletion leaves a valid file
3061          further down in the PATH, (2) there is no way to know exactly
3062          what an executable (in the sense of "capable of being
3063          exec'd") file is.  Using access() loses because it may lose
3064          if the caller is the superuser; failing to use it loses if
3065          there are ACLs or some such.  */
3066
3067       const char *p;
3068       const char *p1;
3069       /* FIXME-maybe: might want "set path" command so user can change what
3070          path is used from within GDB.  */
3071       const char *path = getenv ("PATH");
3072       int len;
3073       struct stat statbuf;
3074
3075       if (path == NULL)
3076         path = "/bin:/usr/bin";
3077
3078       tryname = (char *) alloca (strlen (path) + strlen (shell_file) + 2);
3079       for (p = path; p != NULL; p = p1 ? p1 + 1: NULL)
3080         {
3081           p1 = strchr (p, ':');
3082           if (p1 != NULL)
3083             len = p1 - p;
3084           else
3085             len = strlen (p);
3086           strncpy (tryname, p, len);
3087           tryname[len] = '\0';
3088           strcat (tryname, "/");
3089           strcat (tryname, shell_file);
3090           if (access (tryname, X_OK) < 0)
3091             continue;
3092           if (stat (tryname, &statbuf) < 0)
3093             continue;
3094           if (!S_ISREG (statbuf.st_mode))
3095             /* We certainly need to reject directories.  I'm not quite
3096                as sure about FIFOs, sockets, etc., but I kind of doubt
3097                that people want to exec() these things.  */
3098             continue;
3099           break;
3100         }
3101       if (p == NULL)
3102         /* Not found.  This must be an error rather than merely passing
3103            the file to execlp(), because execlp() would try all the
3104            exec()s, causing GDB to get confused.  */
3105         error (_("procfs:%d -- Can't find shell %s in PATH"),
3106                __LINE__, shell_file);
3107
3108       shell_file = tryname;
3109     }
3110
3111   pid = fork_inferior (exec_file, allargs, env, procfs_set_exec_trap,
3112                        NULL, NULL, shell_file, NULL);
3113
3114   /* We have something that executes now.  We'll be running through
3115      the shell at this point (if startup-with-shell is true), but the
3116      pid shouldn't change.  */
3117   add_thread_silent (ptid_t (pid));
3118
3119   procfs_init_inferior (this, pid);
3120 }
3121
3122 /* An observer for the "inferior_created" event.  */
3123
3124 static void
3125 procfs_inferior_created (struct target_ops *ops, int from_tty)
3126 {
3127 }
3128
3129 /* Callback for update_thread_list.  Calls "add_thread".  */
3130
3131 static int
3132 procfs_notice_thread (procinfo *pi, procinfo *thread, void *ptr)
3133 {
3134   ptid_t gdb_threadid = ptid_t (pi->pid, thread->tid, 0);
3135
3136   if (!in_thread_list (gdb_threadid) || is_exited (gdb_threadid))
3137     add_thread (gdb_threadid);
3138
3139   return 0;
3140 }
3141
3142 /* Query all the threads that the target knows about, and give them
3143    back to GDB to add to its list.  */
3144
3145 void
3146 procfs_target::update_thread_list ()
3147 {
3148   procinfo *pi;
3149
3150   prune_threads ();
3151
3152   /* Find procinfo for main process.  */
3153   pi = find_procinfo_or_die (inferior_ptid.pid (), 0);
3154   proc_update_threads (pi);
3155   proc_iterate_over_threads (pi, procfs_notice_thread, NULL);
3156 }
3157
3158 /* Return true if the thread is still 'alive'.  This guy doesn't
3159    really seem to be doing his job.  Got to investigate how to tell
3160    when a thread is really gone.  */
3161
3162 bool
3163 procfs_target::thread_alive (ptid_t ptid)
3164 {
3165   int proc, thread;
3166   procinfo *pi;
3167
3168   proc    = ptid.pid ();
3169   thread  = ptid.lwp ();
3170   /* If I don't know it, it ain't alive!  */
3171   pi = find_procinfo (proc, thread);
3172   if (pi == NULL)
3173     return false;
3174
3175   /* If I can't get its status, it ain't alive!
3176      What's more, I need to forget about it!  */
3177   if (!proc_get_status (pi))
3178     {
3179       destroy_procinfo (pi);
3180       return false;
3181     }
3182   /* I couldn't have got its status if it weren't alive, so it's
3183      alive.  */
3184   return true;
3185 }
3186
3187 /* Convert PTID to a string.  Returns the string in a static
3188    buffer.  */
3189
3190 const char *
3191 procfs_target::pid_to_str (ptid_t ptid)
3192 {
3193   static char buf[80];
3194
3195   if (ptid.lwp () == 0)
3196     xsnprintf (buf, sizeof (buf), "process %d", ptid.pid ());
3197   else
3198     xsnprintf (buf, sizeof (buf), "LWP %ld", ptid.lwp ());
3199
3200   return buf;
3201 }
3202
3203 /* Accepts an integer PID; Returns a string representing a file that
3204    can be opened to get the symbols for the child process.  */
3205
3206 char *
3207 procfs_target::pid_to_exec_file (int pid)
3208 {
3209   static char buf[PATH_MAX];
3210   char name[PATH_MAX];
3211
3212   /* Solaris 11 introduced /proc/<proc-id>/execname.  */
3213   xsnprintf (name, sizeof (name), "/proc/%d/execname", pid);
3214   scoped_fd fd (gdb_open_cloexec (name, O_RDONLY, 0));
3215   if (fd.get () < 0 || read (fd.get (), buf, PATH_MAX - 1) < 0)
3216     {
3217       /* If that fails, fall back to /proc/<proc-id>/path/a.out introduced in
3218          Solaris 10.  */
3219       ssize_t len;
3220
3221       xsnprintf (name, sizeof (name), "/proc/%d/path/a.out", pid);
3222       len = readlink (name, buf, PATH_MAX - 1);
3223       if (len <= 0)
3224         strcpy (buf, name);
3225       else
3226         buf[len] = '\0';
3227     }
3228
3229   return buf;
3230 }
3231
3232 /* Insert a watchpoint.  */
3233
3234 static int
3235 procfs_set_watchpoint (ptid_t ptid, CORE_ADDR addr, int len, int rwflag,
3236                        int after)
3237 {
3238   int       pflags = 0;
3239   procinfo *pi;
3240
3241   pi = find_procinfo_or_die (ptid.pid () == -1 ?
3242                              inferior_ptid.pid () : ptid.pid (),
3243                              0);
3244
3245   /* Translate from GDB's flags to /proc's.  */
3246   if (len > 0)  /* len == 0 means delete watchpoint.  */
3247     {
3248       switch (rwflag) {         /* FIXME: need an enum!  */
3249       case hw_write:            /* default watchpoint (write) */
3250         pflags = WRITE_WATCHFLAG;
3251         break;
3252       case hw_read:             /* read watchpoint */
3253         pflags = READ_WATCHFLAG;
3254         break;
3255       case hw_access:           /* access watchpoint */
3256         pflags = READ_WATCHFLAG | WRITE_WATCHFLAG;
3257         break;
3258       case hw_execute:          /* execution HW breakpoint */
3259         pflags = EXEC_WATCHFLAG;
3260         break;
3261       default:                  /* Something weird.  Return error.  */
3262         return -1;
3263       }
3264       if (after)                /* Stop after r/w access is completed.  */
3265         pflags |= AFTER_WATCHFLAG;
3266     }
3267
3268   if (!proc_set_watchpoint (pi, addr, len, pflags))
3269     {
3270       if (errno == E2BIG)       /* Typical error for no resources.  */
3271         return -1;              /* fail */
3272       /* GDB may try to remove the same watchpoint twice.
3273          If a remove request returns no match, don't error.  */
3274       if (errno == ESRCH && len == 0)
3275         return 0;               /* ignore */
3276       proc_error (pi, "set_watchpoint", __LINE__);
3277     }
3278   return 0;
3279 }
3280
3281 /* Return non-zero if we can set a hardware watchpoint of type TYPE.  TYPE
3282    is one of bp_hardware_watchpoint, bp_read_watchpoint, bp_write_watchpoint,
3283    or bp_hardware_watchpoint.  CNT is the number of watchpoints used so
3284    far.
3285
3286    Note:  procfs_can_use_hw_breakpoint() is not yet used by all
3287    procfs.c targets due to the fact that some of them still define
3288    target_can_use_hardware_watchpoint.  */
3289
3290 int
3291 procfs_target::can_use_hw_breakpoint (enum bptype type, int cnt, int othertype)
3292 {
3293   /* Due to the way that proc_set_watchpoint() is implemented, host
3294      and target pointers must be of the same size.  If they are not,
3295      we can't use hardware watchpoints.  This limitation is due to the
3296      fact that proc_set_watchpoint() calls
3297      procfs_address_to_host_pointer(); a close inspection of
3298      procfs_address_to_host_pointer will reveal that an internal error
3299      will be generated when the host and target pointer sizes are
3300      different.  */
3301   struct type *ptr_type = builtin_type (target_gdbarch ())->builtin_data_ptr;
3302
3303   if (sizeof (void *) != TYPE_LENGTH (ptr_type))
3304     return 0;
3305
3306   /* Other tests here???  */
3307
3308   return 1;
3309 }
3310
3311 /* Returns non-zero if process is stopped on a hardware watchpoint
3312    fault, else returns zero.  */
3313
3314 bool
3315 procfs_target::stopped_by_watchpoint ()
3316 {
3317   procinfo *pi;
3318
3319   pi = find_procinfo_or_die (inferior_ptid.pid (), 0);
3320
3321   if (proc_flags (pi) & (PR_STOPPED | PR_ISTOP))
3322     if (proc_why (pi) == PR_FAULTED)
3323       if (proc_what (pi) == FLTWATCH)
3324         return true;
3325   return false;
3326 }
3327
3328 /* Returns 1 if the OS knows the position of the triggered watchpoint,
3329    and sets *ADDR to that address.  Returns 0 if OS cannot report that
3330    address.  This function is only called if
3331    procfs_stopped_by_watchpoint returned 1, thus no further checks are
3332    done.  The function also assumes that ADDR is not NULL.  */
3333
3334 bool
3335 procfs_target::stopped_data_address (CORE_ADDR *addr)
3336 {
3337   procinfo *pi;
3338
3339   pi = find_procinfo_or_die (inferior_ptid.pid (), 0);
3340   return proc_watchpoint_address (pi, addr);
3341 }
3342
3343 int
3344 procfs_target::insert_watchpoint (CORE_ADDR addr, int len,
3345                                   enum target_hw_bp_type type,
3346                                   struct expression *cond)
3347 {
3348   if (!target_have_steppable_watchpoint
3349       && !gdbarch_have_nonsteppable_watchpoint (target_gdbarch ()))
3350     /* When a hardware watchpoint fires off the PC will be left at
3351        the instruction following the one which caused the
3352        watchpoint.  It will *NOT* be necessary for GDB to step over
3353        the watchpoint.  */
3354     return procfs_set_watchpoint (inferior_ptid, addr, len, type, 1);
3355   else
3356     /* When a hardware watchpoint fires off the PC will be left at
3357        the instruction which caused the watchpoint.  It will be
3358        necessary for GDB to step over the watchpoint.  */
3359     return procfs_set_watchpoint (inferior_ptid, addr, len, type, 0);
3360 }
3361
3362 int
3363 procfs_target::remove_watchpoint (CORE_ADDR addr, int len,
3364                                   enum target_hw_bp_type type,
3365                                   struct expression *cond)
3366 {
3367   return procfs_set_watchpoint (inferior_ptid, addr, 0, 0, 0);
3368 }
3369
3370 int
3371 procfs_target::region_ok_for_hw_watchpoint (CORE_ADDR addr, int len)
3372 {
3373   /* The man page for proc(4) on Solaris 2.6 and up says that the
3374      system can support "thousands" of hardware watchpoints, but gives
3375      no method for finding out how many; It doesn't say anything about
3376      the allowed size for the watched area either.  So we just tell
3377      GDB 'yes'.  */
3378   return 1;
3379 }
3380
3381 /* Memory Mappings Functions: */
3382
3383 /* Call a callback function once for each mapping, passing it the
3384    mapping, an optional secondary callback function, and some optional
3385    opaque data.  Quit and return the first non-zero value returned
3386    from the callback.
3387
3388    PI is the procinfo struct for the process to be mapped.  FUNC is
3389    the callback function to be called by this iterator.  DATA is the
3390    optional opaque data to be passed to the callback function.
3391    CHILD_FUNC is the optional secondary function pointer to be passed
3392    to the child function.  Returns the first non-zero return value
3393    from the callback function, or zero.  */
3394
3395 static int
3396 iterate_over_mappings (procinfo *pi, find_memory_region_ftype child_func,
3397                        void *data,
3398                        int (*func) (struct prmap *map,
3399                                     find_memory_region_ftype child_func,
3400                                     void *data))
3401 {
3402   char pathname[MAX_PROC_NAME_SIZE];
3403   struct prmap *prmaps;
3404   struct prmap *prmap;
3405   int funcstat;
3406   int nmap;
3407   struct stat sbuf;
3408
3409   /* Get the number of mappings, allocate space,
3410      and read the mappings into prmaps.  */
3411   /* Open map fd.  */
3412   xsnprintf (pathname, sizeof (pathname), "/proc/%d/map", pi->pid);
3413
3414   scoped_fd map_fd (open (pathname, O_RDONLY));
3415   if (map_fd.get () < 0)
3416     proc_error (pi, "iterate_over_mappings (open)", __LINE__);
3417
3418   /* Use stat to determine the file size, and compute
3419      the number of prmap_t objects it contains.  */
3420   if (fstat (map_fd.get (), &sbuf) != 0)
3421     proc_error (pi, "iterate_over_mappings (fstat)", __LINE__);
3422
3423   nmap = sbuf.st_size / sizeof (prmap_t);
3424   prmaps = (struct prmap *) alloca ((nmap + 1) * sizeof (*prmaps));
3425   if (read (map_fd.get (), (char *) prmaps, nmap * sizeof (*prmaps))
3426       != (nmap * sizeof (*prmaps)))
3427     proc_error (pi, "iterate_over_mappings (read)", __LINE__);
3428
3429   for (prmap = prmaps; nmap > 0; prmap++, nmap--)
3430     {
3431       funcstat = (*func) (prmap, child_func, data);
3432       if (funcstat != 0)
3433         return funcstat;
3434     }
3435
3436   return 0;
3437 }
3438
3439 /* Implements the to_find_memory_regions method.  Calls an external
3440    function for each memory region.
3441    Returns the integer value returned by the callback.  */
3442
3443 static int
3444 find_memory_regions_callback (struct prmap *map,
3445                               find_memory_region_ftype func, void *data)
3446 {
3447   return (*func) ((CORE_ADDR) map->pr_vaddr,
3448                   map->pr_size,
3449                   (map->pr_mflags & MA_READ) != 0,
3450                   (map->pr_mflags & MA_WRITE) != 0,
3451                   (map->pr_mflags & MA_EXEC) != 0,
3452                   1, /* MODIFIED is unknown, pass it as true.  */
3453                   data);
3454 }
3455
3456 /* External interface.  Calls a callback function once for each
3457    mapped memory region in the child process, passing as arguments:
3458
3459         CORE_ADDR virtual_address,
3460         unsigned long size,
3461         int read,       TRUE if region is readable by the child
3462         int write,      TRUE if region is writable by the child
3463         int execute     TRUE if region is executable by the child.
3464
3465    Stops iterating and returns the first non-zero value returned by
3466    the callback.  */
3467
3468 int
3469 procfs_target::find_memory_regions (find_memory_region_ftype func, void *data)
3470 {
3471   procinfo *pi = find_procinfo_or_die (inferior_ptid.pid (), 0);
3472
3473   return iterate_over_mappings (pi, func, data,
3474                                 find_memory_regions_callback);
3475 }
3476
3477 /* Returns an ascii representation of a memory mapping's flags.  */
3478
3479 static char *
3480 mappingflags (long flags)
3481 {
3482   static char asciiflags[8];
3483
3484   strcpy (asciiflags, "-------");
3485   if (flags & MA_STACK)
3486     asciiflags[1] = 's';
3487   if (flags & MA_BREAK)
3488     asciiflags[2] = 'b';
3489   if (flags & MA_SHARED)
3490     asciiflags[3] = 's';
3491   if (flags & MA_READ)
3492     asciiflags[4] = 'r';
3493   if (flags & MA_WRITE)
3494     asciiflags[5] = 'w';
3495   if (flags & MA_EXEC)
3496     asciiflags[6] = 'x';
3497   return (asciiflags);
3498 }
3499
3500 /* Callback function, does the actual work for 'info proc
3501    mappings'.  */
3502
3503 static int
3504 info_mappings_callback (struct prmap *map, find_memory_region_ftype ignore,
3505                         void *unused)
3506 {
3507   unsigned int pr_off;
3508
3509   pr_off = (unsigned int) map->pr_offset;
3510
3511   if (gdbarch_addr_bit (target_gdbarch ()) == 32)
3512     printf_filtered ("\t%#10lx %#10lx %#10lx %#10x %7s\n",
3513                      (unsigned long) map->pr_vaddr,
3514                      (unsigned long) map->pr_vaddr + map->pr_size - 1,
3515                      (unsigned long) map->pr_size,
3516                      pr_off,
3517                      mappingflags (map->pr_mflags));
3518   else
3519     printf_filtered ("  %#18lx %#18lx %#10lx %#10x %7s\n",
3520                      (unsigned long) map->pr_vaddr,
3521                      (unsigned long) map->pr_vaddr + map->pr_size - 1,
3522                      (unsigned long) map->pr_size,
3523                      pr_off,
3524                      mappingflags (map->pr_mflags));
3525
3526   return 0;
3527 }
3528
3529 /* Implement the "info proc mappings" subcommand.  */
3530
3531 static void
3532 info_proc_mappings (procinfo *pi, int summary)
3533 {
3534   if (summary)
3535     return;     /* No output for summary mode.  */
3536
3537   printf_filtered (_("Mapped address spaces:\n\n"));
3538   if (gdbarch_ptr_bit (target_gdbarch ()) == 32)
3539     printf_filtered ("\t%10s %10s %10s %10s %7s\n",
3540                      "Start Addr",
3541                      "  End Addr",
3542                      "      Size",
3543                      "    Offset",
3544                      "Flags");
3545   else
3546     printf_filtered ("  %18s %18s %10s %10s %7s\n",
3547                      "Start Addr",
3548                      "  End Addr",
3549                      "      Size",
3550                      "    Offset",
3551                      "Flags");
3552
3553   iterate_over_mappings (pi, NULL, NULL, info_mappings_callback);
3554   printf_filtered ("\n");
3555 }
3556
3557 /* Implement the "info proc" command.  */
3558
3559 bool
3560 procfs_target::info_proc (const char *args, enum info_proc_what what)
3561 {
3562   procinfo *process  = NULL;
3563   procinfo *thread   = NULL;
3564   char     *tmp      = NULL;
3565   int       pid      = 0;
3566   int       tid      = 0;
3567   int       mappings = 0;
3568
3569   switch (what)
3570     {
3571     case IP_MINIMAL:
3572       break;
3573
3574     case IP_MAPPINGS:
3575     case IP_ALL:
3576       mappings = 1;
3577       break;
3578
3579     default:
3580       error (_("Not supported on this target."));
3581     }
3582
3583   gdb_argv built_argv (args);
3584   for (char *arg : built_argv)
3585     {
3586       if (isdigit (arg[0]))
3587         {
3588           pid = strtoul (arg, &tmp, 10);
3589           if (*tmp == '/')
3590             tid = strtoul (++tmp, NULL, 10);
3591         }
3592       else if (arg[0] == '/')
3593         {
3594           tid = strtoul (arg + 1, NULL, 10);
3595         }
3596     }
3597
3598   procinfo_up temporary_procinfo;
3599   if (pid == 0)
3600     pid = inferior_ptid.pid ();
3601   if (pid == 0)
3602     error (_("No current process: you must name one."));
3603   else
3604     {
3605       /* Have pid, will travel.
3606          First see if it's a process we're already debugging.  */
3607       process = find_procinfo (pid, 0);
3608        if (process == NULL)
3609          {
3610            /* No.  So open a procinfo for it, but
3611               remember to close it again when finished.  */
3612            process = create_procinfo (pid, 0);
3613            temporary_procinfo.reset (process);
3614            if (!open_procinfo_files (process, FD_CTL))
3615              proc_error (process, "info proc, open_procinfo_files", __LINE__);
3616          }
3617     }
3618   if (tid != 0)
3619     thread = create_procinfo (pid, tid);
3620
3621   if (process)
3622     {
3623       printf_filtered (_("process %d flags:\n"), process->pid);
3624       proc_prettyprint_flags (proc_flags (process), 1);
3625       if (proc_flags (process) & (PR_STOPPED | PR_ISTOP))
3626         proc_prettyprint_why (proc_why (process), proc_what (process), 1);
3627       if (proc_get_nthreads (process) > 1)
3628         printf_filtered ("Process has %d threads.\n",
3629                          proc_get_nthreads (process));
3630     }
3631   if (thread)
3632     {
3633       printf_filtered (_("thread %d flags:\n"), thread->tid);
3634       proc_prettyprint_flags (proc_flags (thread), 1);
3635       if (proc_flags (thread) & (PR_STOPPED | PR_ISTOP))
3636         proc_prettyprint_why (proc_why (thread), proc_what (thread), 1);
3637     }
3638
3639   if (mappings)
3640     info_proc_mappings (process, 0);
3641
3642   return true;
3643 }
3644
3645 /* Modify the status of the system call identified by SYSCALLNUM in
3646    the set of syscalls that are currently traced/debugged.
3647
3648    If ENTRY_OR_EXIT is set to PR_SYSENTRY, then the entry syscalls set
3649    will be updated.  Otherwise, the exit syscalls set will be updated.
3650
3651    If MODE is FLAG_SET, then traces will be enabled.  Otherwise, they
3652    will be disabled.  */
3653
3654 static void
3655 proc_trace_syscalls_1 (procinfo *pi, int syscallnum, int entry_or_exit,
3656                        int mode, int from_tty)
3657 {
3658   sysset_t *sysset;
3659
3660   if (entry_or_exit == PR_SYSENTRY)
3661     sysset = proc_get_traced_sysentry (pi, NULL);
3662   else
3663     sysset = proc_get_traced_sysexit (pi, NULL);
3664
3665   if (sysset == NULL)
3666     proc_error (pi, "proc-trace, get_traced_sysset", __LINE__);
3667
3668   if (mode == FLAG_SET)
3669     praddset (sysset, syscallnum);
3670   else
3671     prdelset (sysset, syscallnum);
3672
3673   if (entry_or_exit == PR_SYSENTRY)
3674     {
3675       if (!proc_set_traced_sysentry (pi, sysset))
3676         proc_error (pi, "proc-trace, set_traced_sysentry", __LINE__);
3677     }
3678   else
3679     {
3680       if (!proc_set_traced_sysexit (pi, sysset))
3681         proc_error (pi, "proc-trace, set_traced_sysexit", __LINE__);
3682     }
3683 }
3684
3685 static void
3686 proc_trace_syscalls (const char *args, int from_tty, int entry_or_exit, int mode)
3687 {
3688   procinfo *pi;
3689
3690   if (inferior_ptid.pid () <= 0)
3691     error (_("you must be debugging a process to use this command."));
3692
3693   if (args == NULL || args[0] == 0)
3694     error_no_arg (_("system call to trace"));
3695
3696   pi = find_procinfo_or_die (inferior_ptid.pid (), 0);
3697   if (isdigit (args[0]))
3698     {
3699       const int syscallnum = atoi (args);
3700
3701       proc_trace_syscalls_1 (pi, syscallnum, entry_or_exit, mode, from_tty);
3702     }
3703 }
3704
3705 static void
3706 proc_trace_sysentry_cmd (const char *args, int from_tty)
3707 {
3708   proc_trace_syscalls (args, from_tty, PR_SYSENTRY, FLAG_SET);
3709 }
3710
3711 static void
3712 proc_trace_sysexit_cmd (const char *args, int from_tty)
3713 {
3714   proc_trace_syscalls (args, from_tty, PR_SYSEXIT, FLAG_SET);
3715 }
3716
3717 static void
3718 proc_untrace_sysentry_cmd (const char *args, int from_tty)
3719 {
3720   proc_trace_syscalls (args, from_tty, PR_SYSENTRY, FLAG_RESET);
3721 }
3722
3723 static void
3724 proc_untrace_sysexit_cmd (const char *args, int from_tty)
3725 {
3726   proc_trace_syscalls (args, from_tty, PR_SYSEXIT, FLAG_RESET);
3727 }
3728
3729 void
3730 _initialize_procfs (void)
3731 {
3732   gdb::observers::inferior_created.attach (procfs_inferior_created);
3733
3734   add_com ("proc-trace-entry", no_class, proc_trace_sysentry_cmd,
3735            _("Give a trace of entries into the syscall."));
3736   add_com ("proc-trace-exit", no_class, proc_trace_sysexit_cmd,
3737            _("Give a trace of exits from the syscall."));
3738   add_com ("proc-untrace-entry", no_class, proc_untrace_sysentry_cmd,
3739            _("Cancel a trace of entries into the syscall."));
3740   add_com ("proc-untrace-exit", no_class, proc_untrace_sysexit_cmd,
3741            _("Cancel a trace of exits from the syscall."));
3742
3743   add_inf_child_target (&the_procfs_target);
3744 }
3745
3746 /* =================== END, GDB  "MODULE" =================== */
3747
3748
3749
3750 /* miscellaneous stubs: */
3751
3752 /* The following satisfy a few random symbols mostly created by the
3753    solaris threads implementation, which I will chase down later.  */
3754
3755 /* Return a pid for which we guarantee we will be able to find a
3756    'live' procinfo.  */
3757
3758 ptid_t
3759 procfs_first_available (void)
3760 {
3761   return ptid_t (procinfo_list ? procinfo_list->pid : -1);
3762 }
3763
3764 /* ===================  GCORE .NOTE "MODULE" =================== */
3765
3766 static char *
3767 procfs_do_thread_registers (bfd *obfd, ptid_t ptid,
3768                             char *note_data, int *note_size,
3769                             enum gdb_signal stop_signal)
3770 {
3771   struct regcache *regcache = get_thread_regcache (ptid);
3772   gdb_gregset_t gregs;
3773   gdb_fpregset_t fpregs;
3774   unsigned long merged_pid;
3775
3776   merged_pid = ptid.lwp () << 16 | ptid.pid ();
3777
3778   /* This part is the old method for fetching registers.
3779      It should be replaced by the newer one using regsets
3780      once it is implemented in this platform:
3781      gdbarch_iterate_over_regset_sections().  */
3782
3783   scoped_restore save_inferior_ptid = make_scoped_restore (&inferior_ptid);
3784   inferior_ptid = ptid;
3785   target_fetch_registers (regcache, -1);
3786
3787   fill_gregset (regcache, &gregs, -1);
3788   note_data = (char *) elfcore_write_lwpstatus (obfd,
3789                                                 note_data,
3790                                                 note_size,
3791                                                 merged_pid,
3792                                                 stop_signal,
3793                                                 &gregs);
3794   fill_fpregset (regcache, &fpregs, -1);
3795   note_data = (char *) elfcore_write_prfpreg (obfd,
3796                                               note_data,
3797                                               note_size,
3798                                               &fpregs,
3799                                               sizeof (fpregs));
3800
3801   return note_data;
3802 }
3803
3804 struct procfs_corefile_thread_data {
3805   bfd *obfd;
3806   char *note_data;
3807   int *note_size;
3808   enum gdb_signal stop_signal;
3809 };
3810
3811 static int
3812 procfs_corefile_thread_callback (procinfo *pi, procinfo *thread, void *data)
3813 {
3814   struct procfs_corefile_thread_data *args
3815     = (struct procfs_corefile_thread_data *) data;
3816
3817   if (pi != NULL)
3818     {
3819       ptid_t ptid = ptid_t (pi->pid, thread->tid, 0);
3820
3821       args->note_data = procfs_do_thread_registers (args->obfd, ptid,
3822                                                     args->note_data,
3823                                                     args->note_size,
3824                                                     args->stop_signal);
3825     }
3826   return 0;
3827 }
3828
3829 static int
3830 find_signalled_thread (struct thread_info *info, void *data)
3831 {
3832   if (info->suspend.stop_signal != GDB_SIGNAL_0
3833       && info->ptid.pid () == inferior_ptid.pid ())
3834     return 1;
3835
3836   return 0;
3837 }
3838
3839 static enum gdb_signal
3840 find_stop_signal (void)
3841 {
3842   struct thread_info *info =
3843     iterate_over_threads (find_signalled_thread, NULL);
3844
3845   if (info)
3846     return info->suspend.stop_signal;
3847   else
3848     return GDB_SIGNAL_0;
3849 }
3850
3851 char *
3852 procfs_target::make_corefile_notes (bfd *obfd, int *note_size)
3853 {
3854   gdb_gregset_t gregs;
3855   char fname[16] = {'\0'};
3856   char psargs[80] = {'\0'};
3857   procinfo *pi = find_procinfo_or_die (inferior_ptid.pid (), 0);
3858   char *note_data = NULL;
3859   const char *inf_args;
3860   struct procfs_corefile_thread_data thread_args;
3861   enum gdb_signal stop_signal;
3862
3863   if (get_exec_file (0))
3864     {
3865       strncpy (fname, lbasename (get_exec_file (0)), sizeof (fname));
3866       fname[sizeof (fname) - 1] = 0;
3867       strncpy (psargs, get_exec_file (0), sizeof (psargs));
3868       psargs[sizeof (psargs) - 1] = 0;
3869
3870       inf_args = get_inferior_args ();
3871       if (inf_args && *inf_args
3872           && (strlen (inf_args)
3873               < ((int) sizeof (psargs) - (int) strlen (psargs))))
3874         {
3875           strncat (psargs, " ",
3876                    sizeof (psargs) - strlen (psargs));
3877           strncat (psargs, inf_args,
3878                    sizeof (psargs) - strlen (psargs));
3879         }
3880     }
3881
3882   note_data = (char *) elfcore_write_prpsinfo (obfd,
3883                                                note_data,
3884                                                note_size,
3885                                                fname,
3886                                                psargs);
3887
3888   stop_signal = find_stop_signal ();
3889
3890   fill_gregset (get_current_regcache (), &gregs, -1);
3891   note_data = elfcore_write_pstatus (obfd, note_data, note_size,
3892                                      inferior_ptid.pid (),
3893                                      stop_signal, &gregs);
3894
3895   thread_args.obfd = obfd;
3896   thread_args.note_data = note_data;
3897   thread_args.note_size = note_size;
3898   thread_args.stop_signal = stop_signal;
3899   proc_iterate_over_threads (pi, procfs_corefile_thread_callback,
3900                              &thread_args);
3901   note_data = thread_args.note_data;
3902
3903   gdb::optional<gdb::byte_vector> auxv =
3904     target_read_alloc (current_top_target (), TARGET_OBJECT_AUXV, NULL);
3905   if (auxv && !auxv->empty ())
3906     note_data = elfcore_write_note (obfd, note_data, note_size,
3907                                     "CORE", NT_AUXV, auxv->data (),
3908                                     auxv->size ());
3909
3910   return note_data;
3911 }
3912 /* ===================  END GCORE .NOTE "MODULE" =================== */