2.9BSD/usr/include/sys/proc.h

Compare this file to the similar file:
Show the results in this format:

/*
 * One structure allocated per active
 * process. It contains all data needed
 * about the process while the
 * process may be swapped out.
 * Other per process data (user.h)
 * is swapped with the process.
 */
struct	proc {
	char	p_stat;
	char	p_pri;		/* priority, negative is high */
#ifndef	MENLO_JCL
	char	p_flag;
#else
	short	p_flag;
#endif
	char	p_time;		/* resident time for scheduling */
	char	p_cpu;		/* cpu usage for scheduling */
	char	p_nice;		/* nice for cpu usage */
#ifdef	UCB_METER
	char	p_slptime;	/* secs sleeping */
				/* there is room for a char here */
#endif
#ifdef	MENLO_JCL
	char	p_cursig;
	long	p_sig;		/* signals pending to this process */
	long	p_siga0;	/* low bit of 2 bit signal action */
	long	p_siga1;	/* high bit of 2 bit signal action */
#define	p_ignsig	p_siga0	/* ignored signal mask */
#else
	short	p_sig;		/* signals pending to this process */
#endif
#if	defined(MENLO_JCL) || defined(VIRUS_VFORK)
	struct	proc	*p_pptr;/* pointer to parent's process structure */
#endif
	short	p_uid;		/* user id, used to direct tty signals */
	short	p_pgrp;		/* name of process group leader */
	short	p_pid;		/* unique process id */
	short	p_ppid;		/* process id of parent */
		/*
		 * union (supercedes xproc)
		 * to replace part with times
		 * to be passed to parent process
		 * in ZOMBIE state.
		 */
	union {
	    struct {
#ifdef	VIRUS_VFORK
		memaddr	P_addr;		/* address of u. area */
		memaddr	P_daddr;	/* address of data area */
		memaddr	P_saddr;	/* address of stack area */
		size_t	P_dsize;	/* size of data area (clicks) */
		size_t	P_ssize;	/* size of stack segment (clicks) */
#else
		memaddr	P_addr;		/* address of swappable image */
		size_t	P_size;		/* size of swappable image (clicks) */
#endif
		caddr_t	P_wchan;	/* event process is awaiting */
		struct	text	*P_textp;/* pointer to text structure */
		struct	proc	*P_link;/* linked list of running processes */
		short	P_clktim;	/* time to alarm clock signal */
	    } p_p;
#define	p_addr		p_un.p_p.P_addr
#ifdef	VIRUS_VFORK
#define	p_daddr		p_un.p_p.P_daddr
#define	p_saddr		p_un.p_p.P_saddr
#define	p_dsize		p_un.p_p.P_dsize
#define	p_ssize		p_un.p_p.P_ssize
#else
#define	p_size		p_un.p_p.P_size
#endif
#define	p_wchan 	p_un.p_p.P_wchan
#define	p_textp		p_un.p_p.P_textp
#define	p_link		p_un.p_p.P_link
#define	p_clktim 	p_un.p_p.P_clktim
	    struct {
		short	Xp_xstat;	/* Exit status for wait */
		time_t	Xp_utime;	/* user time, this proc */
		time_t	Xp_stime;	/* system time, this proc */
#ifdef	UCB_LOGIN
		short	Xp_login;	/* login flag */
#endif
	    } p_xp;
#define	xp_xstat	p_xp.Xp_xstat
#define	xp_utime	p_xp.Xp_utime
#define	xp_stime	p_xp.Xp_stime
#ifdef	UCB_LOGIN
#define	xp_login	p_xp.Xp_login
#endif
	} p_un;
};

#ifdef	KERNEL
extern struct proc proc[];	/* the proc table itself */
#endif

/* stat codes */
#define	SSLEEP	1		/* awaiting an event */
#define	SWAIT	2		/* (abandoned state) */
#define	SRUN	3		/* running */
#define	SIDL	4		/* intermediate state in process creation */
#define	SZOMB	5		/* intermediate state in process termination */
#define	SSTOP	6		/* process being traced */

/* flag codes */
#define	SLOAD	01		/* in core */
#define	SSYS	02		/* scheduling process */
#define	SLOCK	04		/* process cannot be swapped */
#define	SSWAP	010		/* process is being swapped out */
#define	STRC	020		/* process is being traced */
#define	SWTED	040		/* another tracing flag */
#define	SULOCK	0100		/* user settable lock in core */
#ifdef	MENLO_JCL
#define	SDETACH	0200		/* detached inherited by init */
#define	SNUSIG	0400		/* using new signal mechanism */
#endif
#ifdef	VIRUS_VFORK
#define	SVFORK	01000		/* child in vfork, using parent's data */
#define	SVFPARENT 02000		/* parent in vfork, waiting for child */
#define	SVFDONE	04000		/* parent has relesed child in vfork */
#endif
#ifdef	UCB_NET
#define	SSEL	010000		/* selecting, cleared if rescan needed */
#define	STIMO	020000		/* timing out during sleep */
#endif

#ifdef	VIRUS_VFORK
/* arguments to expand() to expand specified segment */
#define	S_DATA	0
#define	S_STACK	1
#endif