xref: /minix3/lib/libc/sys/mincore.2 (revision 2fe8fb192fe7e8720e3e7a77f928da545e872a6a)
1*2fe8fb19SBen Gras.\"	$NetBSD: mincore.2,v 1.19 2004/05/13 10:20:58 wiz Exp $
2*2fe8fb19SBen Gras.\"
3*2fe8fb19SBen Gras.\" Copyright (c) 1991, 1993
4*2fe8fb19SBen Gras.\"	The Regents of the University of California.  All rights reserved.
5*2fe8fb19SBen Gras.\"
6*2fe8fb19SBen Gras.\" Redistribution and use in source and binary forms, with or without
7*2fe8fb19SBen Gras.\" modification, are permitted provided that the following conditions
8*2fe8fb19SBen Gras.\" are met:
9*2fe8fb19SBen Gras.\" 1. Redistributions of source code must retain the above copyright
10*2fe8fb19SBen Gras.\"    notice, this list of conditions and the following disclaimer.
11*2fe8fb19SBen Gras.\" 2. Redistributions in binary form must reproduce the above copyright
12*2fe8fb19SBen Gras.\"    notice, this list of conditions and the following disclaimer in the
13*2fe8fb19SBen Gras.\"    documentation and/or other materials provided with the distribution.
14*2fe8fb19SBen Gras.\" 3. Neither the name of the University nor the names of its contributors
15*2fe8fb19SBen Gras.\"    may be used to endorse or promote products derived from this software
16*2fe8fb19SBen Gras.\"    without specific prior written permission.
17*2fe8fb19SBen Gras.\"
18*2fe8fb19SBen Gras.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
19*2fe8fb19SBen Gras.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
20*2fe8fb19SBen Gras.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
21*2fe8fb19SBen Gras.\" ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
22*2fe8fb19SBen Gras.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
23*2fe8fb19SBen Gras.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
24*2fe8fb19SBen Gras.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
25*2fe8fb19SBen Gras.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
26*2fe8fb19SBen Gras.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
27*2fe8fb19SBen Gras.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
28*2fe8fb19SBen Gras.\" SUCH DAMAGE.
29*2fe8fb19SBen Gras.\"
30*2fe8fb19SBen Gras.\"	@(#)mincore.2	8.1 (Berkeley) 6/9/93
31*2fe8fb19SBen Gras.\"
32*2fe8fb19SBen Gras.Dd June 6, 1999
33*2fe8fb19SBen Gras.Dt MINCORE 2
34*2fe8fb19SBen Gras.Os
35*2fe8fb19SBen Gras.Sh NAME
36*2fe8fb19SBen Gras.Nm mincore
37*2fe8fb19SBen Gras.Nd determine residency of memory pages
38*2fe8fb19SBen Gras.Sh LIBRARY
39*2fe8fb19SBen Gras.Lb libc
40*2fe8fb19SBen Gras.Sh SYNOPSIS
41*2fe8fb19SBen Gras.In sys/mman.h
42*2fe8fb19SBen Gras.Ft int
43*2fe8fb19SBen Gras.Fn mincore "void *addr" "size_t len" "char *vec"
44*2fe8fb19SBen Gras.Sh DESCRIPTION
45*2fe8fb19SBen GrasThe
46*2fe8fb19SBen Gras.Fn mincore
47*2fe8fb19SBen Grassystem call
48*2fe8fb19SBen Grasallows a process to obtain information about whether pages are
49*2fe8fb19SBen Grascore resident.
50*2fe8fb19SBen GrasThe status of the memory range is returned in the character-per-page array
51*2fe8fb19SBen Gras.Ar vec .
52*2fe8fb19SBen GrasIf the page is resident, the least significant bit of the corresponding
53*2fe8fb19SBen Grascharacter in
54*2fe8fb19SBen Gras.Ar vec
55*2fe8fb19SBen Graswill be set.
56*2fe8fb19SBen GrasOther bits are reserved for additional information
57*2fe8fb19SBen Graswhich future implementations may return.
58*2fe8fb19SBen Gras.Pp
59*2fe8fb19SBen GrasNote that the status of each page may change between the call to
60*2fe8fb19SBen Gras.Fn mincore
61*2fe8fb19SBen Grasand the return of the page status information.
62*2fe8fb19SBen GrasIn order to guarantee
63*2fe8fb19SBen Grasthat pages will remain in core, the address range must be locked with
64*2fe8fb19SBen Gras.Xr mlock 2 .
65*2fe8fb19SBen Gras.Sh RETURN VALUES
66*2fe8fb19SBen Gras.Fn mincore
67*2fe8fb19SBen Grasreturns 0 on success, or \-1 on failure and sets the variable
68*2fe8fb19SBen Gras.Va errno
69*2fe8fb19SBen Grasto indicate the error.
70*2fe8fb19SBen Gras.Sh ERRORS
71*2fe8fb19SBen GrasThe
72*2fe8fb19SBen Gras.Fn mincore
73*2fe8fb19SBen Grascall will fail if:
74*2fe8fb19SBen Gras.Bl -tag -width Er
75*2fe8fb19SBen Gras.It Bq Er EFAULT
76*2fe8fb19SBen Gras.Ar vec
77*2fe8fb19SBen Graspoints to an illegal address.
78*2fe8fb19SBen Gras.It Bq Er EINVAL
79*2fe8fb19SBen Gras.Ar addr
80*2fe8fb19SBen Grasis not a multiple of the system page size.
81*2fe8fb19SBen Gras.It Bq Er EINVAL
82*2fe8fb19SBen Gras.Ar len
83*2fe8fb19SBen Grasis equal to 0.
84*2fe8fb19SBen Gras.It Bq Er ENOMEM
85*2fe8fb19SBen GrasThe address range specified is invalid for the calling process,
86*2fe8fb19SBen Grasor one or more of the pages specified in the range are not mapped.
87*2fe8fb19SBen Gras.El
88*2fe8fb19SBen Gras.Sh SEE ALSO
89*2fe8fb19SBen Gras.Xr madvise 2 ,
90*2fe8fb19SBen Gras.Xr mlock 2 ,
91*2fe8fb19SBen Gras.Xr mprotect 2 ,
92*2fe8fb19SBen Gras.Xr msync 2 ,
93*2fe8fb19SBen Gras.Xr munmap 2 ,
94*2fe8fb19SBen Gras.Xr sysconf 3
95*2fe8fb19SBen Gras.Sh HISTORY
96*2fe8fb19SBen GrasThe
97*2fe8fb19SBen Gras.Fn mincore
98*2fe8fb19SBen Grasfunction first appeared in
99*2fe8fb19SBen Gras.Bx 4.4 .
100