| 
        mlock,  munlock  -  Locks or unlocks a specified region in
       memory (P1003.1b)
       #include <sys/mman.h>
       int mlock ( const void *addr, size_t len);
       int munlock ( const void *addr, size_t len);
       Realtime Library (librt.so, librt.a)
        A pointer to the starting address of the region to lock or
       unlock.  The  addr argument must be a multiple of the page
       size returned by the sysconf system call.  The size of the
       memory  region  to  lock  or  unlock.  The value of len is
       rounded up to a multiple of the page  size  before  decrementing
 by 1.
       The  mlock  and  munlock  functions  lock and unlock whole
       pages containing any part of  the  process  address  space
       starting at addr and continuing for len bytes.
       The  mlock  function  guarantees all whole pages mapped by
       the range addr to addr+len-1 (inclusive) to be memory resident.
  (The  area locked is the same  as if the len argument
 were rounded up to a multiple of the page size before
       decrementing by 1.)
       The  locked area remains locked until unlocked with a call
       to the munlock function, until the process calls the  exec
       function,  until an address space associated with the lock
       is unmapped, or until the process terminates.  A  lock  is
       not inherited across a fork or an exec.
       The  mlock  function unlocks whole pages previously mapped
       by the range addr to addr+len-1 (inclusive), regardless of
       how  many  times the mlock function was called by the process
 for any pages within the specified range.
       A call to the munlock function does not affect pages  that
       may  be  mapped  into  another  process's address space or
       locked by another process.
       You must have superuser privileges to call  the  mlock  or
       munlock  functions.
       On  a  successful call to the mlock function, a value of 0
       (zero) is returned and the region becomes locked and  memory
  resident.   On an unsuccessful call, a value of -1 is
       returned, no changes are made to any locks in the  process
       address  space, and errno is set to indicate that an error
       occurred.
       On a successful call to the munlock function, a value of 0
       (zero) is returned and the memory is unlocked with respect
       to the process's address space. On an unsuccessful call, a
       value  of  -1 is returned, none of the memory is unlocked,
       and errno is set to indicate that an error occurred.
       The mlock and munlock functions fail under  the  following
       conditions:  The  addr  argument  is not a multiple of the
       page size returned by sysconf.  Some or all of the address
       range  specified  by  the  addr and len arguments does not
       correspond to valid mapped pages in the process's  address
       space. For the mlock function, locking the pages mapped by
       the specified range would exceed an implementation-defined
       limit on the amount of memory that the process may lock.
       If  any of the following conditions occur, the mlock function
 fails: Some or all of the memory  identified  by  the
       operation could not be locked when the call was made.  The
       calling process does not have the  appropriate  privileges
       to perform the requested operation.
       Functions:    exec(2),   _exit(2),   fork(2),   munmap(2),
       sysconf(3)
       Guide to Realtime Programming
                                                         mlock(3)
[ Back ] |