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