USG_PG3/usr/source/head/user.h
/*
* The user structure.
* One allocated per process.
* Contains all per process data
* that doesn't need to be referenced
* while the process is swapped.
* The user block is USIZE*64 bytes
* long; resides at virtual kernel
* loc 140000; contains the system
* stack per user; is cross referenced
* with the proc structure for the
* same process.
*/
struct user
{
int u_rsav[2]; /* save r5,r6 when exchanging stacks */
int u_fsav[25]; /* save fp registers */
/* rsav and fsav must be first in structure */
char u_segflg; /* IO flag: 0:user D; 1:system; 2:user I */
char u_error; /* return error code */
char u_uid; /* effective user id */
char u_gid; /* effective group id */
char u_ruid; /* real user id */
char u_rgid; /* real group id */
int u_procp; /* pointer to proc structure */
char *u_base; /* base address for IO */
char *u_count; /* bytes remaining for IO */
char *u_offset[2]; /* offset in file for IO */
int *u_cdir; /* pointer to inode of current directory */
char u_dbuf[DIRSIZ]; /* current pathname component */
char *u_dirp; /* current pointer to inode */
struct { /* current directory entry */
int u_ino;
char u_name[DIRSIZ];
} u_dent;
int *u_pdir; /* inode of parent directory of dirp */
int u_uisa[16]; /* prototype of segmentation addresses */
int u_uisd[16]; /* prototype of segmentation descriptors */
int u_ofile[NOFILE]; /* pointers to file structures of open files */
int u_arg[5]; /* arguments to current system call */
int u_tsize; /* text size (*64) */
int u_dsize; /* data size (*64) */
int u_ssize; /* stack size (*64) */
int u_sep; /* flag for I and D separation */
int u_qsav[2]; /* label variable for quits and interrupts */
int u_ssav[2]; /* label variable for swapping */
int u_signal[NSIG]; /* disposition of signals */
long u_utime; /* this process user time */
long u_stime; /* this process system time */
long u_cutime; /* sum of childs' utimes */
long u_cstime; /* sum of childs' stimes */
int *u_ar0; /* address of users saved R0 */
int u_prof[4]; /* profile arguments */
char u_intflg; /* catch intr from sys */
int u_ttyp; /* controlling tty pointer */
int u_ttyd; /* controlling tty dev */
struct { /* header of executable file */
int ux_mag; /* magic number */
int ux_tsize; /* text size */
int ux_dsize; /* data size */
int ux_bsize; /* bss size */
int ux_ssize; /* symbol table size */
int ux_entloc; /* entry location */
} u_exdata;
int *u_semi4[NOLOCK]; /* semaphore control ptrs */
int *u_msgqhdr; /* ptr to message q header */
char u_comm[DIRSIZ];
long u_start;
char u_acflag;
int u_call;
int u_narg;
int u_nargc;
int u_loc;
int u_dev;
int u_inode;
int *u_rdir; /* root for this process */
/* kernel stack per user
* extends from u + USIZE*64
* backward not to reach here
*/
};
/* u_error codes */
#define EPERM 1
#define ENOENT 2
#define ESRCH 3
#define EINTR 4
#define EIO 5
#define ENXIO 6
#define E2BIG 7
#define ENOEXEC 8
#define EBADF 9
#define ECHILD 10
#define EAGAIN 11
#define ENOMEM 12
#define EACCES 13
#define EFAULT 14
#define ENOTBLK 15
#define EBUSY 16
#define EEXIST 17
#define EXDEV 18
#define ENODEV 19
#define ENOTDIR 20
#define EISDIR 21
#define EINVAL 22
#define ENFILE 23
#define EMFILE 24
#define ENOTTY 25
#define ETXTBSY 26
#define EFBIG 27
#define ENOSPC 28
#define ESPIPE 29
#define EROFS 30
#define EMLINK 31
#define EPIPE 32
#define ETABLE 33 /*no table entries left*/
#define EFUNC 34 /*invalid operation requested*/
#define ENOMSG 35 /* no message on queue */
#define ENOALOC 36 /*resource not allocated or for proper purpose*/
#define EBIOCTL 37 /* invalid ioctl operation */