2 * Copyright 2005 Sun Microsystems, Inc. All rights reserved.
3 * Use is subject to license terms.
6 /* Copyright (c) 1983, 1984, 1985, 1986, 1987, 1988, 1989 AT&T */
7 /* All Rights Reserved */
10 * Copyright (c) 1980 Regents of the University of California.
11 * All rights reserved. The Berkeley Software License Agreement
12 * specifies the terms and conditions for redistribution.
15 #pragma ident "%Z%%M% %I% %E% SMI"
18 * C shell - process structure declarations
22 * Structure for each process the shell knows about:
23 * allocated and filled by pcreate.
24 * flushed by pflush; freeing always happens at top level
25 * so the interrupt level has less to worry about.
26 * processes are related to "friends" when in a pipeline;
27 * p_friends links makes a circular list of such jobs
30 struct process
*p_next
; /* next in global "proclist" */
31 struct process
*p_friends
; /* next in job list (or self) */
32 struct directory
*p_cwd
; /* cwd of the job (only in head) */
33 short unsigned p_flags
; /* various job status flags */
34 tchar p_reason
; /* reason for entering this state */
35 tchar p_index
; /* shorthand job index */
37 int p_jobid
; /* pid of job leader */
38 /* if a job is stopped/background p_jobid gives its pgrp */
39 struct timeval p_btime
; /* begin time */
40 struct timeval p_etime
; /* end time */
41 struct rusage p_rusage
;
42 tchar
*p_command
; /* first PMAXLEN chars of command */
45 /* added for status */
48 /* flag values for p_flags */
49 #define PRUNNING (1<<0) /* running */
50 #define PSTOPPED (1<<1) /* stopped */
51 #define PNEXITED (1<<2) /* normally exited */
52 #define PAEXITED (1<<3) /* abnormally exited */
53 #define PSIGNALED (1<<4) /* terminated by a signal != SIGINT */
55 #define PALLSTATES (PRUNNING|PSTOPPED|PNEXITED|PAEXITED|PSIGNALED|PINTERRUPTED)
56 #define PNOTIFY (1<<5) /* notify async when done */
57 #define PTIME (1<<6) /* job times should be printed */
58 #define PAWAITED (1<<7) /* top level is waiting for it */
59 #define PFOREGND (1<<8) /* started in shells pgrp */
60 #define PDUMPED (1<<9) /* process dumped core */
61 #define PDIAG (1<<10) /* diagnostic output also piped out */
62 #define PPOU (1<<11) /* piped output */
63 #define PREPORTED (1<<12) /* status has been reported */
64 #define PINTERRUPTED (1<<13) /* job stopped via interrupt signal */
65 #define PPTIME (1<<14) /* time individual process */
66 #define PNEEDNOTE (1<<15) /* notify as soon as practical */
68 #define PNULL (struct process *)0
71 /* defines for arguments to pprint */
77 #define SHELLDIR 040 /* print shell's dir if not the same */
78 #define JOBDIR 0100 /* print job's dir if not the same */
81 struct process proclist
; /* list head of all processes */
82 bool pnoprocesses
; /* pchild found nothing to wait for */
84 struct process
*pholdjob
; /* one level stack of current jobs */
86 struct process
*pcurrjob
; /* current job */
87 struct process
*pcurrent
; /* current job in table */
88 struct process
*pprevious
; /* previous job in table */
90 short pmaxindex
; /* current maximum job index */