2002-02-08 04:21:55 +03:00
|
|
|
.\" $NetBSD: getrlimit.2,v 1.21 2002/02/08 01:28:18 ross Exp $
|
1995-02-27 15:31:34 +03:00
|
|
|
.\"
|
|
|
|
.\" Copyright (c) 1980, 1991, 1993
|
|
|
|
.\" The Regents of the University of California. All rights reserved.
|
1993-03-21 12:45:37 +03:00
|
|
|
.\"
|
|
|
|
.\" Redistribution and use in source and binary forms, with or without
|
|
|
|
.\" modification, are permitted provided that the following conditions
|
|
|
|
.\" are met:
|
|
|
|
.\" 1. Redistributions of source code must retain the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer.
|
|
|
|
.\" 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer in the
|
|
|
|
.\" documentation and/or other materials provided with the distribution.
|
|
|
|
.\" 3. All advertising materials mentioning features or use of this software
|
|
|
|
.\" must display the following acknowledgement:
|
|
|
|
.\" This product includes software developed by the University of
|
|
|
|
.\" California, Berkeley and its contributors.
|
|
|
|
.\" 4. Neither the name of the University nor the names of its contributors
|
|
|
|
.\" may be used to endorse or promote products derived from this software
|
|
|
|
.\" without specific prior written permission.
|
|
|
|
.\"
|
|
|
|
.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
|
|
|
.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
.\" ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
|
|
|
.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
|
|
.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
|
|
.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
|
|
.\" SUCH DAMAGE.
|
|
|
|
.\"
|
1995-02-27 15:31:34 +03:00
|
|
|
.\" @(#)getrlimit.2 8.1 (Berkeley) 6/4/93
|
1993-03-21 12:45:37 +03:00
|
|
|
.\"
|
2001-11-23 22:50:13 +03:00
|
|
|
.Dd November 23, 2001
|
1993-03-21 12:45:37 +03:00
|
|
|
.Dt GETRLIMIT 2
|
1999-03-22 22:44:33 +03:00
|
|
|
.Os
|
1993-03-21 12:45:37 +03:00
|
|
|
.Sh NAME
|
|
|
|
.Nm getrlimit ,
|
|
|
|
.Nm setrlimit
|
|
|
|
.Nd control maximum system resource consumption
|
1999-12-03 00:42:35 +03:00
|
|
|
.Sh LIBRARY
|
|
|
|
.Lb libc
|
1993-03-21 12:45:37 +03:00
|
|
|
.Sh SYNOPSIS
|
2002-02-08 04:21:55 +03:00
|
|
|
.Fd #include \*[Lt]sys/resource.h\*[Gt]
|
1993-03-21 12:45:37 +03:00
|
|
|
.Ft int
|
|
|
|
.Fn getrlimit "int resource" "struct rlimit *rlp"
|
|
|
|
.Ft int
|
1995-10-12 18:40:27 +03:00
|
|
|
.Fn setrlimit "int resource" "const struct rlimit *rlp"
|
1993-03-21 12:45:37 +03:00
|
|
|
.Sh DESCRIPTION
|
|
|
|
Limits on the consumption of system resources by the current process
|
|
|
|
and each process it creates may be obtained with the
|
|
|
|
.Fn getrlimit
|
|
|
|
call, and set with the
|
|
|
|
.Fn setrlimit
|
1999-09-28 18:52:32 +04:00
|
|
|
call. Resources of an arbitrary process can be obtained/changed using
|
|
|
|
.Xr sysctl 3 .
|
|
|
|
..
|
1993-03-21 12:45:37 +03:00
|
|
|
.Pp
|
|
|
|
The
|
|
|
|
.Fa resource
|
|
|
|
parameter is one of the following:
|
|
|
|
.Bl -tag -width RLIMIT_FSIZEAA
|
1995-02-27 15:31:34 +03:00
|
|
|
.It Li RLIMIT_CORE
|
|
|
|
The largest size (in bytes)
|
1998-04-29 02:28:30 +04:00
|
|
|
.Pa core
|
1995-02-27 15:31:34 +03:00
|
|
|
file that may be created.
|
|
|
|
.It Li RLIMIT_CPU
|
|
|
|
The maximum amount of cpu time (in seconds) to be used by
|
1993-03-21 12:45:37 +03:00
|
|
|
each process.
|
1995-02-27 15:31:34 +03:00
|
|
|
.It Li RLIMIT_DATA
|
|
|
|
The maximum size (in bytes) of the data segment for a process;
|
1993-03-21 12:45:37 +03:00
|
|
|
this defines how far a program may extend its break with the
|
|
|
|
.Xr sbrk 2
|
|
|
|
system call.
|
1995-02-27 15:31:34 +03:00
|
|
|
.It Li RLIMIT_FSIZE
|
|
|
|
The largest size (in bytes) file that may be created.
|
|
|
|
.It Li RLIMIT_MEMLOCK
|
|
|
|
The maximum size (in bytes) which a process may lock into memory
|
|
|
|
using the
|
|
|
|
.Xr mlock 2
|
|
|
|
function.
|
|
|
|
.It Li RLIMIT_NOFILE
|
|
|
|
The maximum number of open files for this process.
|
|
|
|
.It Li RLIMIT_NPROC
|
|
|
|
The maximum number of simultaneous processes for this user id.
|
|
|
|
.It Li RLIMIT_RSS
|
|
|
|
The maximum size (in bytes) to which a process's resident set size may
|
|
|
|
grow.
|
|
|
|
This imposes a limit on the amount of physical memory to be given to
|
|
|
|
a process; if memory is tight, the system will prefer to take memory
|
|
|
|
from processes that are exceeding their declared resident set size.
|
|
|
|
.It Li RLIMIT_STACK
|
|
|
|
The maximum size (in bytes) of the stack segment for a process;
|
1993-03-21 12:45:37 +03:00
|
|
|
this defines how far a program's stack segment may be extended.
|
|
|
|
Stack extension is performed automatically by the system.
|
|
|
|
.El
|
|
|
|
.Pp
|
|
|
|
A resource limit is specified as a soft limit and a hard limit. When a
|
|
|
|
soft limit is exceeded a process may receive a signal (for example, if
|
|
|
|
the cpu time or file size is exceeded), but it will be allowed to
|
|
|
|
continue execution until it reaches the hard limit (or modifies
|
2001-09-16 05:38:59 +04:00
|
|
|
its resource limit). The
|
1993-03-21 12:45:37 +03:00
|
|
|
.Em rlimit
|
|
|
|
structure is used to specify the hard and soft limits on a resource,
|
|
|
|
.Bd -literal -offset indent
|
|
|
|
struct rlimit {
|
1994-12-08 09:49:43 +03:00
|
|
|
rlim_t rlim_cur; /* current (soft) limit */
|
|
|
|
rlim_t rlim_max; /* hard limit */
|
1993-03-21 12:45:37 +03:00
|
|
|
};
|
|
|
|
.Ed
|
|
|
|
.Pp
|
|
|
|
Only the super-user may raise the maximum limits. Other users
|
2001-09-16 05:38:59 +04:00
|
|
|
may only alter
|
1993-03-21 12:45:37 +03:00
|
|
|
.Fa rlim_cur
|
2001-09-16 05:38:59 +04:00
|
|
|
within the range from 0 to
|
1993-03-21 12:45:37 +03:00
|
|
|
.Fa rlim_max
|
|
|
|
or (irreversibly) lower
|
|
|
|
.Fa rlim_max .
|
|
|
|
.Pp
|
|
|
|
An
|
|
|
|
.Dq infinite
|
|
|
|
value for a limit is defined as
|
1995-02-27 15:31:34 +03:00
|
|
|
.Dv RLIM_INFINITY .
|
1993-03-21 12:45:37 +03:00
|
|
|
.Pp
|
|
|
|
Because this information is stored in the per-process information,
|
|
|
|
this system call must be executed directly by the shell if it
|
2001-11-23 22:50:13 +03:00
|
|
|
is to affect all future processes created by the shell.
|
|
|
|
Thus, shells provide built-in commands to change the limits
|
2001-11-23 23:21:49 +03:00
|
|
|
.Ic ( limit
|
2001-11-23 22:50:13 +03:00
|
|
|
for
|
|
|
|
.Xr csh 1 ,
|
|
|
|
or
|
|
|
|
.Ic ulimit
|
|
|
|
for
|
2001-11-23 23:21:49 +03:00
|
|
|
.Xr sh 1 ) .
|
1993-03-21 12:45:37 +03:00
|
|
|
.Pp
|
|
|
|
The system refuses to extend the data or stack space when the limits
|
|
|
|
would be exceeded in the normal way: a
|
1998-04-29 02:28:30 +04:00
|
|
|
.Xr brk 2
|
1993-03-21 12:45:37 +03:00
|
|
|
call fails if the data space limit is reached.
|
|
|
|
When the stack limit is reached, the process receives
|
|
|
|
a segmentation fault
|
|
|
|
.Pq Dv SIGSEGV ;
|
|
|
|
if this signal is not
|
|
|
|
caught by a handler using the signal stack, this signal
|
|
|
|
will kill the process.
|
|
|
|
.Pp
|
|
|
|
A file I/O operation that would create a file larger that the process'
|
|
|
|
soft limit will cause the write to fail and a signal
|
|
|
|
.Dv SIGXFSZ
|
|
|
|
to be
|
|
|
|
generated; this normally terminates the process, but may be caught. When
|
|
|
|
the soft cpu time limit is exceeded, a signal
|
|
|
|
.Dv SIGXCPU
|
|
|
|
is sent to the
|
|
|
|
offending process.
|
|
|
|
.Sh RETURN VALUES
|
|
|
|
A 0 return value indicates that the call succeeded, changing
|
2001-11-23 23:21:49 +03:00
|
|
|
or returning the resource limit. Otherwise, -1 is returned
|
2001-11-23 22:50:13 +03:00
|
|
|
and the global variable
|
|
|
|
.Va errno
|
|
|
|
is set to indicate the error.
|
1993-03-21 12:45:37 +03:00
|
|
|
.Sh ERRORS
|
2001-11-23 22:50:13 +03:00
|
|
|
The
|
1998-08-29 12:32:32 +04:00
|
|
|
.Fn getrlimit
|
1993-03-21 12:45:37 +03:00
|
|
|
and
|
|
|
|
.Fn setrlimit
|
|
|
|
will fail if:
|
|
|
|
.Bl -tag -width Er
|
|
|
|
.It Bq Er EFAULT
|
|
|
|
The address specified for
|
|
|
|
.Fa rlp
|
|
|
|
is invalid.
|
2001-11-23 22:50:13 +03:00
|
|
|
.It Bq Er EINVAL
|
|
|
|
Specified
|
|
|
|
.Fa resource
|
|
|
|
was invalid.
|
|
|
|
.It Bq Er EINVAL
|
|
|
|
In the
|
|
|
|
.Fn setrlimit
|
|
|
|
call, the specified
|
|
|
|
.Fa rlim_cur
|
|
|
|
exceeds the specified
|
|
|
|
.Fa rlim_max .
|
1993-03-21 12:45:37 +03:00
|
|
|
.It Bq Er EPERM
|
|
|
|
The limit specified to
|
|
|
|
.Fn setrlimit
|
|
|
|
would have
|
|
|
|
raised the maximum limit value, and the caller is not the super-user.
|
|
|
|
.El
|
2001-11-23 22:50:13 +03:00
|
|
|
.Pp
|
|
|
|
The
|
|
|
|
.Fn setrlimit
|
|
|
|
function may fail if:
|
|
|
|
.Bl -tag -width Er
|
|
|
|
.It Bq Er EINVAL
|
|
|
|
The limit specified to
|
|
|
|
.Fn setrlimit
|
|
|
|
cannot be lowered, because current usage is already higher than the limit.
|
|
|
|
.El
|
1993-03-21 12:45:37 +03:00
|
|
|
.Sh SEE ALSO
|
|
|
|
.Xr csh 1 ,
|
1996-10-04 20:59:46 +04:00
|
|
|
.Xr sh 1 ,
|
1997-07-16 10:05:58 +04:00
|
|
|
.Xr quotactl 2 ,
|
1994-10-18 02:49:08 +03:00
|
|
|
.Xr sigaction 2 ,
|
1995-02-27 15:31:34 +03:00
|
|
|
.Xr sigaltstack 2 ,
|
|
|
|
.Xr sysctl 3
|
2001-11-24 05:40:05 +03:00
|
|
|
.\" Sh STANDARDS
|
|
|
|
.\" With exception of
|
|
|
|
.\" .Li RLIMIT_AS
|
|
|
|
.\" (which is not currently supported), the
|
|
|
|
.\" .Fn getrlimit
|
|
|
|
.\" and
|
|
|
|
.\" .Fn setrlimit
|
|
|
|
.\" functions conform to
|
|
|
|
.\" .St -susv2 .
|
1993-03-21 12:45:37 +03:00
|
|
|
.Sh HISTORY
|
|
|
|
The
|
1993-11-25 03:38:17 +03:00
|
|
|
.Fn getrlimit
|
1993-03-21 12:45:37 +03:00
|
|
|
function call appeared in
|
|
|
|
.Bx 4.2 .
|