//	Copyright (c) 1984, 1986, 1987, 1988, 1989 AT&T	
//	  All Rights Reserved  	

//	THIS IS UNPUBLISHED PROPRIETARY SOURCE CODE OF AT&T	
//	The copyright notice above does not evidence any   	
//	actual or intended publication of such source code.	

#ifndef _SYS_PROCSET_H
#define	_SYS_PROCSET_H

#pragma ident	"@(#)procset.h	1.13	92/07/14 SMI"	// SVr4.0 1.6

#ifdef	__cplusplus
extern "C" {
#endif

/*
 *	This file defines the data needed to specify a set of
 *	processes.  These types are used by the sigsend, sigsendset,
 *	priocntl, priocntlset, waitid, evexit, and evexitset system
 *	calls.
 */
#define	P_INITPID	1
#define	P_INITUID	0
#define	P_INITPGID	0


/*
 *	The following defines the values for an identifier type.  It
 *	specifies the interpretation of an id value.  An idtype and
 *	id together define a simple set of processes.
 */
typedef enum idtype {
	P_PID,		// A process identifier.		
	P_PPID,		// A parent process identifier.		
	P_PGID,		// A process group (job control group)	
			// identifier.				
	P_SID,		// A session identifier.		
	P_CID,		// A scheduling class identifier.	
	P_UID,		// A user identifier.			
	P_GID,		// A group identifier.			
	P_ALL,		// All processes.			
	P_LWPID		// An LWP identifier.			
} idtype_t;


/*
 *	The following defines the operations which can be performed to
 *	combine two simple sets of processes to form another set of
 *	processes.
 */
typedef enum idop {
	POP_DIFF,	// Set difference.  The processes which	
			// are in the left operand set and not	
			// in the right operand set.		
	POP_AND,	// Set disjunction.  The processes	
			// which are in both the left and right	
			// operand sets.			
	POP_OR,		// Set conjunction.  The processes	
			// which are in either the left or the	
			// right operand sets (or both).	
	POP_XOR		// Set exclusive or.  The processes 	
			// which are in either the left or	
			// right operand sets but not in both.	
} idop_t;


/*
 *	The following structure is used to define a set of processes.
 *	The set is defined in terms of two simple sets of processes
 *	and an operator which operates on these two operand sets.
 */
typedef struct procset {
	idop_t		p_op;	// The operator connection the	
				// following two operands each	
				// of which is a simple set of	
				// processes.			

	idtype_t	p_lidtype;
				// The type of the left operand	
				// simple set.			
	id_t		p_lid;	// The id of the left operand.	

	idtype_t	p_ridtype;
				// The type of the right	
				// operand simple set.		
	id_t		p_rid;	// The id of the right operand.	
} procset_t;


/*
 *	The following macro can be used to initialize a procset_t
 *	structure.
 */
#define	setprocset(psp, op, ltype, lid, rtype, rid) \
			(psp)->p_op		= (op); \
			(psp)->p_lidtype	= (ltype); \
			(psp)->p_lid		= (lid); \
			(psp)->p_ridtype	= (rtype); \
			(psp)->p_rid		= (rid);

#ifdef _KERNEL

/*
 * Public functions.
 */
#if defined(__STDC__)
#include <sys/proc.h>
extern int dotoprocs(procset_t *psp, int (*funcp)(), char *arg);
extern int procinset(proc_t *pp, procset_t *psp);
extern boolean_t cur_inset_only(procset_t *psp);

#else

extern int dotoprocs();
extern int procinset();
extern boolean_t cur_inset_only();

#endif	/* __STDC__ */

#endif	/* _KERNEL */

#ifdef	__cplusplus
}
#endif

#endif	/* _SYS_PROCSET_H */



syntax highlighted by Code2HTML, v. 0.9.1