source: branches/libc-0.6/src/emx/include/sys/resource.h

Last change on this file was 2060, checked in by bird, 20 years ago

Updated sys/stat.h, sys/resource.h and sys/_types.h to FreeBSD 5.3 level.

  • Property cvs2svn:cvs-rev set to 1.4
  • Property svn:eol-style set to native
  • Property svn:executable set to *
File size: 5.0 KB
Line 
1/*
2 * Copyright (c) 1982, 1986, 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 * 4. Neither the name of the University nor the names of its contributors
14 * may be used to endorse or promote products derived from this software
15 * without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
18 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
21 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
22 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
23 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
24 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
25 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
26 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
27 * SUCH DAMAGE.
28 *
29 * @(#)resource.h 8.4 (Berkeley) 1/9/95
30 * $FreeBSD: src/sys/sys/resource.h,v 1.23 2004/06/13 22:07:58 das Exp $
31 */
32
33/** @file
34 * FreeBSD 5.3
35 * @changed bird: get/setpriority takes id_t not int according to SuS.
36 */
37
38#ifndef _SYS_RESOURCE_H_
39#define _SYS_RESOURCE_H_
40
41#include <sys/cdefs.h>
42#include <sys/_timeval.h>
43#include <sys/_types.h>
44
45/*
46 * Process priority specifications to get/setpriority.
47 */
48#define PRIO_MIN -20
49#define PRIO_MAX 20
50
51#define PRIO_PROCESS 0
52#define PRIO_PGRP 1
53#define PRIO_USER 2
54
55/*
56 * Resource utilization information.
57 */
58
59#define RUSAGE_SELF 0
60#define RUSAGE_CHILDREN -1
61
62struct rusage {
63 struct timeval ru_utime; /* user time used */
64 struct timeval ru_stime; /* system time used */
65 long ru_maxrss; /* max resident set size */
66#define ru_first ru_ixrss
67 long ru_ixrss; /* integral shared memory size */
68 long ru_idrss; /* integral unshared data " */
69 long ru_isrss; /* integral unshared stack " */
70 long ru_minflt; /* page reclaims */
71 long ru_majflt; /* page faults */
72 long ru_nswap; /* swaps */
73 long ru_inblock; /* block input operations */
74 long ru_oublock; /* block output operations */
75 long ru_msgsnd; /* messages sent */
76 long ru_msgrcv; /* messages received */
77 long ru_nsignals; /* signals received */
78 long ru_nvcsw; /* voluntary context switches */
79 long ru_nivcsw; /* involuntary " */
80#define ru_last ru_nivcsw
81};
82
83/*
84 * Resource limits
85 */
86#define RLIMIT_CPU 0 /* cpu time in milliseconds */
87#define RLIMIT_FSIZE 1 /* maximum file size */
88#define RLIMIT_DATA 2 /* data size */
89#define RLIMIT_STACK 3 /* stack size */
90#define RLIMIT_CORE 4 /* core file size */
91#define RLIMIT_RSS 5 /* resident set size */
92#define RLIMIT_MEMLOCK 6 /* locked-in-memory address space */
93#define RLIMIT_NPROC 7 /* number of processes */
94#define RLIMIT_NOFILE 8 /* number of open files */
95#define RLIMIT_SBSIZE 9 /* maximum size of all socket buffers */
96#define RLIMIT_VMEM 10 /* virtual process size (inclusive of mmap) */
97#define RLIMIT_AS RLIMIT_VMEM /* standard name for RLIMIT_VMEM */
98
99#define RLIM_NLIMITS 11 /* number of resource limits */
100
101#define RLIM_INFINITY ((rlim_t)(((u_quad_t)1 << 63) - 1))
102/* XXX Missing: RLIM_SAVED_MAX, RLIM_SAVED_CUR */
103
104
105/*
106 * Resource limit string identifiers
107 */
108
109#ifdef _RLIMIT_IDENT
110static char *rlimit_ident[] = {
111 "cpu",
112 "fsize",
113 "data",
114 "stack",
115 "core",
116 "rss",
117 "memlock",
118 "nproc",
119 "nofile",
120 "sbsize",
121 "vmem",
122};
123#endif
124
125#ifndef _RLIM_T_DECLARED
126typedef __rlim_t rlim_t;
127#define _RLIM_T_DECLARED
128#endif
129
130struct rlimit {
131 rlim_t rlim_cur; /* current (soft) limit */
132 rlim_t rlim_max; /* maximum value for rlim_cur */
133};
134
135#if __BSD_VISIBLE
136
137struct orlimit {
138 __int32_t rlim_cur; /* current (soft) limit */
139 __int32_t rlim_max; /* maximum value for rlim_cur */
140};
141
142struct loadavg {
143 __fixpt_t ldavg[3];
144 long fscale;
145};
146
147#define CP_USER 0
148#define CP_NICE 1
149#define CP_SYS 2
150#define CP_INTR 3
151#define CP_IDLE 4
152#define CPUSTATES 5
153
154#endif /* __BSD_VISIBLE */
155
156#ifdef _KERNEL
157extern struct loadavg averunnable;
158extern long cp_time[CPUSTATES];
159
160int kern_setrlimit(struct thread *, u_int, struct rlimit *);
161
162#else
163
164__BEGIN_DECLS
165/* XXX 2nd arg to [gs]etpriority() should be an id_t */
166int getpriority(int, /*int*/ id_t); /* bird: SuS uses id_t */
167int getrlimit(int, struct rlimit *);
168int getrusage(int, struct rusage *);
169int setpriority(int, /*int*/ id_t, int); /* bird: SuS uses id_t */
170int setrlimit(int, const struct rlimit *);
171__END_DECLS
172
173#endif /* _KERNEL */
174#endif /* !_SYS_RESOURCE_H_ */
Note: See TracBrowser for help on using the repository browser.