1 /* 2 * Copyright (c) 1982, 1986, 1989, 1991, 1993 3 * The Regents of the University of California. All rights reserved. 4 * 5 * Redistribution and use in source and binary forms, with or without 6 * modification, are permitted provided that the following conditions 7 * are met: 8 * 1. Redistributions of source code must retain the above copyright 9 * notice, this list of conditions and the following disclaimer. 10 * 2. Redistributions in binary form must reproduce the above copyright 11 * notice, this list of conditions and the following disclaimer in the 12 * documentation and/or other materials provided with the distribution. 13 * 3. All advertising materials mentioning features or use of this software 14 * must display the following acknowledgement: 15 * This product includes software developed by the University of 16 * California, Berkeley and its contributors. 17 * 4. Neither the name of the University nor the names of its contributors 18 * may be used to endorse or promote products derived from this software 19 * without specific prior written permission. 20 * 21 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 22 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 23 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 24 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 25 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 26 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 27 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 28 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 29 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 30 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 31 * SUCH DAMAGE. 32 * 33 * @(#)user.h 8.2 (Berkeley) 9/23/93 34 * $Id: user.h,v 1.13 1997/03/03 08:34:08 ache Exp $ 35 */ 36 37 #ifndef _SYS_USER_H_ 38 #define _SYS_USER_H_ 39 40 #include <machine/pcb.h> 41 #ifndef KERNEL 42 /* stuff that *used* to be included by user.h, or is now needed */ 43 #include <sys/errno.h> 44 #include <sys/time.h> 45 #include <sys/resource.h> 46 #include <sys/ucred.h> 47 #include <sys/uio.h> 48 #include <sys/proc.h> 49 #include <vm/vm.h> /* XXX */ 50 #include <vm/vm_param.h> /* XXX */ 51 #include <vm/pmap.h> /* XXX */ 52 #include <sys/lock.h> /* XXX */ 53 #include <vm/vm_map.h> /* XXX */ 54 #else 55 #include <vm/vm.h> /* XXX */ 56 #endif /* !KERNEL */ 57 #include <sys/resourcevar.h> 58 #include <sys/signalvar.h> 59 60 /* 61 * KERN_PROC subtype ops return arrays of augmented proc structures: 62 */ 63 struct kinfo_proc { 64 struct proc kp_proc; /* proc structure */ 65 struct eproc { 66 struct proc *e_paddr; /* address of proc */ 67 struct session *e_sess; /* session pointer */ 68 struct pcred e_pcred; /* process credentials */ 69 struct ucred e_ucred; /* current credentials */ 70 struct vmspace e_vm; /* address space */ 71 pid_t e_ppid; /* parent process id */ 72 pid_t e_pgid; /* process group id */ 73 short e_jobc; /* job control counter */ 74 dev_t e_tdev; /* controlling tty dev */ 75 pid_t e_tpgid; /* tty process group id */ 76 struct session *e_tsess; /* tty session pointer */ 77 #define WMESGLEN 7 78 char e_wmesg[WMESGLEN+1]; /* wchan message */ 79 segsz_t e_xsize; /* text size */ 80 short e_xrssize; /* text rss */ 81 short e_xccount; /* text references */ 82 short e_xswrss; 83 long e_flag; 84 #define EPROC_CTTY 0x01 /* controlling tty vnode active */ 85 #define EPROC_SLEADER 0x02 /* session leader */ 86 char e_login[roundup(MAXLOGNAME, sizeof(long))]; /* setlogin() name */ 87 long e_spare[2]; 88 } kp_eproc; 89 }; 90 void fill_eproc __P((struct proc *, struct eproc *)); 91 92 93 /* 94 * Per process structure containing data that isn't needed in core 95 * when the process isn't running (esp. when swapped out). 96 * This structure may or may not be at the same kernel address 97 * in all processes. 98 */ 99 100 struct user { 101 struct pcb u_pcb; 102 103 struct sigacts u_sigacts; /* p_sigacts points here (use it!) */ 104 struct pstats u_stats; /* p_stats points here (use it!) */ 105 106 /* 107 * Remaining fields only for core dump and/or ptrace-- 108 * not valid at other times! 109 */ 110 struct kinfo_proc u_kproc; /* proc + eproc */ 111 struct md_coredump u_md; /* machine dependent glop */ 112 }; 113 114 /* 115 * Redefinitions to make the debuggers happy for now... This subterfuge 116 * brought to you by coredump() and trace_req(). These fields are *only* 117 * valid at those times! 118 */ 119 #define U_ar0 u_kproc.kp_proc.p_md.md_regs /* copy of curproc->p_md.md_regs */ 120 #define U_tsize u_kproc.kp_eproc.e_vm.vm_tsize 121 #define U_dsize u_kproc.kp_eproc.e_vm.vm_dsize 122 #define U_ssize u_kproc.kp_eproc.e_vm.vm_ssize 123 #define U_sig u_sigacts.ps_sig 124 #define U_code u_sigacts.ps_code 125 126 #ifndef KERNEL 127 #define u_ar0 U_ar0 128 #define u_tsize U_tsize 129 #define u_dsize U_dsize 130 #define u_ssize U_ssize 131 #define u_sig U_sig 132 #define u_code U_code 133 #endif /* KERNEL */ 134 135 #endif 136