Updated: 2022/Sep/29
Please read Privacy Policy. It's for your privacy.
MINCORE(2) System Calls Manual MINCORE(2) NAME mincore - determine residency of memory pages LIBRARY Standard C Library (libc, -lc) SYNOPSIS #include <sys/mman.h> int mincore(void *addr, size_t len, char *vec); DESCRIPTION The mincore() system call tells whether the pages covering len bytes of data starting at addr are core resident in the process. The status of the memory range is returned in the character-per-page array vec. If the page is resident, the least significant bit of the corresponding character in vec will be set. Other bits are reserved for additional information which future implementations may return. Note that the status of each page may change between the call to mincore() and the return of the page status information. In order to guarantee that pages will remain in core, the address range must be locked with mlock(2). RETURN VALUES The mincore() function returns the value 0 if successful; otherwise the value -1 is returned and the global variable errno is set to indicate the error. ERRORS The mincore() call will fail if: [EFAULT] vec points to an illegal address. [EINVAL] addr is not a multiple of the system page size. [EINVAL] len is equal to 0. [ENOMEM] The address range specified is invalid for the calling process, or one or more of the pages specified in the range are not mapped. SEE ALSO madvise(2), mlock(2), mprotect(2), msync(2), munmap(2), sysconf(3) HISTORY The mincore() function first appeared in 4.4BSD. NetBSD 10.99 June 6, 1999 NetBSD 10.99