]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - share/man/man9/vslock.9
Remove $FreeBSD$: two-line nroff pattern
[FreeBSD/FreeBSD.git] / share / man / man9 / vslock.9
1 .\"     $NetBSD: vslock.9,v 1.1 1996/06/15 20:47:29 pk Exp $
2 .\"
3 .\" Copyright (c) 1996 The NetBSD Foundation, Inc.
4 .\" All rights reserved.
5 .\"
6 .\" This code is derived from software contributed to The NetBSD Foundation
7 .\" by Paul Kranenburg.
8 .\"
9 .\" Redistribution and use in source and binary forms, with or without
10 .\" modification, are permitted provided that the following conditions
11 .\" are met:
12 .\" 1. Redistributions of source code must retain the above copyright
13 .\"    notice, this list of conditions and the following disclaimer.
14 .\" 2. Redistributions in binary form must reproduce the above copyright
15 .\"    notice, this list of conditions and the following disclaimer in the
16 .\"    documentation and/or other materials provided with the distribution.
17 .\"
18 .\" THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
19 .\" ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
20 .\" TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
21 .\" PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE
22 .\" LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
23 .\" CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
24 .\" SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
25 .\" INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
26 .\" CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
27 .\" ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
28 .\" POSSIBILITY OF SUCH DAMAGE.
29 .\"
30 .Dd August 29, 2012
31 .Dt VSLOCK 9
32 .Os
33 .Sh NAME
34 .Nm vslock ,
35 .Nm vsunlock
36 .Nd lock/unlock user space addresses in memory
37 .Sh SYNOPSIS
38 .In sys/param.h
39 .In sys/proc.h
40 .In vm/vm.h
41 .In vm/vm_extern.h
42 .Ft int
43 .Fn vslock "void *addr" "size_t len"
44 .Ft void
45 .Fn vsunlock "void *addr" "size_t len"
46 .Sh DESCRIPTION
47 The
48 .Fn vslock
49 and
50 .Fn vsunlock
51 functions respectively lock and unlock a range of
52 addresses belonging to the currently running process into memory.
53 The actual amount of memory locked is a multiple of the machine's page size.
54 The starting page number is computed by truncating
55 .Fa addr
56 to the nearest preceding page boundary, and by rounding up
57 .Fa addr +
58 .Fa len
59 to the next page boundary.
60 The process context to use for this operation is taken from the
61 global variable
62 .Va curproc .
63 .Sh RETURN VALUES
64 The
65 .Fn vslock
66 function will return 0 on success, otherwise it will return
67 one of the errors listed below.
68 .Sh ERRORS
69 The
70 .Fn vslock
71 function will fail if:
72 .Bl -tag -width Er
73 .It Bq Er EINVAL
74 The
75 .Fa addr
76 and
77 .Fa len
78 parameters specify a memory range that wraps around the end of the
79 machine address space.
80 .It Bq Er ENOMEM
81 The size of the specified address range exceeds the system
82 limit on locked memory.
83 .It Bq Er EFAULT
84 Some portion of the indicated address range is not allocated.
85 There was an error faulting/mapping a page.
86 .El