Merge branch 'vendor/OPENSSH' (early part)
[dragonfly.git] / usr.sbin / vnconfig / vnconfig.8
1 .\" Copyright (c) 1993 University of Utah.
2 .\" Copyright (c) 1980, 1989, 1991, 1993
3 .\"     The Regents of the University of California.  All rights reserved.
4 .\"
5 .\" This code is derived from software contributed to Berkeley by
6 .\" the Systems Programming Group of the University of Utah Computer
7 .\" Science Department.
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 .\" 3. All advertising materials mentioning features or use of this software
18 .\"    must display the following acknowledgement:
19 .\"     This product includes software developed by the University of
20 .\"     California, Berkeley and its contributors.
21 .\" 4. Neither the name of the University nor the names of its contributors
22 .\"    may be used to endorse or promote products derived from this software
23 .\"    without specific prior written permission.
24 .\"
25 .\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
26 .\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
27 .\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
28 .\" ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
29 .\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
30 .\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
31 .\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
32 .\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
33 .\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
34 .\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
35 .\" SUCH DAMAGE.
36 .\"
37 .\"     @(#)vnconfig.8  8.1 (Berkeley) 6/5/93
38 .\" $FreeBSD: src/usr.sbin/vnconfig/vnconfig.8,v 1.14.2.8 2003/01/04 22:35:53 keramida Exp $
39 .\" $DragonFly: src/usr.sbin/vnconfig/vnconfig.8,v 1.10 2008/07/27 22:36:01 thomas Exp $
40 .\"
41 .Dd January 30, 2008
42 .Dt VNCONFIG 8
43 .Os
44 .Sh NAME
45 .Nm vnconfig
46 .Nd configure and enable vnode disks
47 .Sh SYNOPSIS
48 .Nm
49 .Op Fl cdeguvTZ
50 .Op Fl s Ar options
51 .Op Fl r Ar options
52 .Op Fl S Ar value
53 .Ar special_file Op Ar regular_file
54 .Op Ar feature
55 .Nm
56 .Fl a
57 .Op Fl cdeguv
58 .Op Fl s Ar options
59 .Op Fl r Ar options
60 .Op Fl f Ar config_file
61 .Nm
62 .Fl l
63 .Op Ar special_file Ar ...
64 .Sh DESCRIPTION
65 The
66 .Nm
67 command configures, enables and lists vnode pseudo disk devices.
68 The first form of the command will associate the special file
69 .Ar special_file
70 with the regular file
71 .Ar regular_file
72 allowing the latter to be accessed as though it were a disk.
73 Hence a regular file within the filesystem can be used for swapping
74 or can contain a filesystem that is mounted in the name space.  If you
75 want to use swap backing store for your device instead of a file, you
76 can leave
77 .Ar regular_file
78 out and specify the size of the block device
79 with the
80 .Fl S
81 option.
82 .Pp
83 Options indicate an action to be performed:
84 .Bl -tag -width indent
85 .It Fl a
86 Read a command file and performs the
87 specified actions for each device/file pair.
88 .It Fl c
89 Configure the device.
90 If successful, references to
91 .Ar special_file
92 will access the contents of
93 .Ar regular_file .
94 .It Fl d
95 Disable (if possible) the specified feature.
96 .It Fl e
97 Configure the device and enables any
98 .Ar feature
99 that was specified.
100 If no feature was specified,
101 .Fl e
102 is the same as
103 .Fl c .
104 .It Fl f Ar config_file
105 Use
106 .Ar config_file
107 as an alternate config file.
108 .It Fl g
109 Fiddle global options.
110 .It Fl l Ar special_file Ar ...
111 List the VN devices and indicate which ones are in use.
112 If a
113 .Ar special_file
114 list is given, only those devices will be described.
115 .It Fl r Ar options
116 Reset
117 .Ar options ,
118 which is a comma separated string of options.
119 The list of allowed options and their meanings are:
120 .Bl -tag -width "follow"
121 .It Ar labels
122 use disk/slice labels.
123 .It Ar reserve
124 Pre-reserve the blocks underlying the file or swap backing store.  Currently only
125 works for swap backing store.  This option also disables on-the-fly freeing of
126 the underlying backing store (for example, when you remove a large file).
127 Use this option if you wish to avoid long-term fragmentation of the backing
128 store.  Also note that when this option is used, the initial contents of the
129 backing store may contain garbage rather than zeros.  It may even be possible to
130 recover the prior contents of a swap-backed VN across a reboot if the VN device
131 is configured before any swap is allocated by the system.
132 .It Ar follow
133 debug flow in the
134 .Xr vn 4
135 driver.
136 .It Ar debug
137 debug data in the
138 .Xr vn 4
139 driver.
140 .It Ar io
141 debug I/O in the
142 .Xr vn 4
143 driver.
144 .It Ar all
145 turn on all options.
146 .It Ar none
147 turn off all options.
148 .El
149 .It Fl s Ar options
150 Set
151 .Ar options ,
152 which is a comma separated string of options.
153 The list of allowed options and their meanings are the same as for the
154 .Fl r
155 option.
156 .It Fl S Xo
157 .Sm off
158 .Ar value
159 .Es \&{ \&}
160 .En Cm k , m , g , t
161 .Sm on
162 .Xc
163 If no regular file is specified, VN will use swap for backing store.
164 This option specifies the size of the device.  For example,
165 .Sq 23m
166 for
167 23 megabytes.
168 In the absence of a size modifier,
169 .Cm m
170 is implied.
171 The VN device will round the size up to a machine page boundary.
172 Filesystems up to 7.9 terabytes are supported.  When specified along with
173 a regular file, this option overrides the regular file's size insofar as
174 VN is concerned.
175 .It Fl T
176 When a regular file is specified, VN will
177 .Fn ftruncate
178 the file to length 0 first.
179 Normally you should also specify the
180 .Fl S
181 option to set the size of the file.
182 This option also creates the file if it did not previously exist.
183 This option is only meaningful if the
184 .Fl S
185 option has been specified.
186 .It Fl Z
187 When a regular file is specified, VN will zero the contents of the file to
188 ensure that all blocks have been allocated by the filesystem.  This option is
189 only meaningful if the
190 .Fl S
191 option has been specified.
192 .It Fl u
193 Disable and ``unconfigure'' the device.
194 .It Fl v
195 Print messages to stdout describing actions taken.
196 .El
197 .Pp
198 If no action option is given,
199 .Fl c
200 is assumed.
201 .Pp
202 The
203 .Ar feature
204 argument specifies a feature that can be enabled via the
205 .Fl e
206 option:
207 .Bl -tag -width indent
208 .It Dv swap
209 Swapping is enabled on the special file.
210 See
211 .Xr swapon 2 .
212 .It Dv mountro Ns = Ns Pa mount_point
213 The special file is mounted read-only on
214 .Ar mount_point .
215 See
216 .Xr mount 2 .
217 .It Dv mountrw Ns = Ns Pa mount_point
218 The special file is mounted read-write on
219 .Ar mount_point .
220 See
221 .Xr mount 2 .
222 .It Dv mount Ns = Ns Pa mount_point
223 Same as ``mountrw=''.
224 .El
225 .Pp
226 A configuration file contains one line per device/file pair in the form:
227 .Bd -literal
228         special_file    regular_file    [ feature ]
229 .Ed
230 .Pp
231 where fields are separated by white space.
232 The previously described action options serve to configure, enable,
233 disable or unconfigure all devices in the configuration file.
234 .Sh FILES
235 .Bl -tag -width /etc/vntab -compact
236 .It Pa /etc/vntab
237 default configuration file for
238 .Fl a
239 option
240 .El
241 .Sh EXAMPLES
242 .Dl vnconfig vn0 /tmp/diskimage
243 .Pp
244 Configures the vnode disk
245 .Pa vn0 .
246 .Pp
247 .Dl vnconfig -e vn0 /var/swapfile swap
248 .Pp
249 Configures
250 .Pa vn0
251 and enables swapping on it.
252 .Pp
253 .Dl vnconfig -c -v /dev/vn0 cdimage.iso
254 .Dl mount -t cd9660 -o ro /dev/vn0 /mnt
255 .Pp
256 Mount an ISO9660 CD image file.
257 .Pp
258 .Dl umount /mnt
259 .Dl vnconfig -u vn0
260 .Pp
261 Unmount the CD image file.
262 .Pp
263 .Dl vnconfig -d vn0 myfilesystem mount=/mnt
264 .Pp
265 Unmounts (disables)
266 .Pa vn0 .
267 .Pp
268 .Dl vnconfig -ae
269 .Pp
270 Configures and enables all devices specified in
271 .Pa /etc/vntab .
272 .Pp
273 .Dl vnconfig -s labels -c vn0 somebackingfile
274 .Dl disklabel -r -w vn0s0 auto
275 .Dl disklabel -e vn0s0
276 .Pp
277 Is an example of how to configure a file-backed VN disk with a disk label
278 and to initialize and then edit the label.  Once you create the label, you
279 can partition your VN disk and, for example, create a filesystem on one of
280 the partitions.  If you are using a file as backing store, it may be possible
281 to recover your VN disk after a crash by vnconfig'ing the same file again
282 and using the VN configuration already stored in the file rather than
283 relabeling and recreating the filesystem.  It is even possible to fsck the
284 VN partitions that previously contained filesystems.
285 .Pp
286 .Dl vnconfig -e -s labels,reserve -S 400m vn1
287 .Dl disklabel -r -w vn1s0 auto
288 .Dl newfs /dev/vn1s0
289 .Dl mount /dev/vn1s0 /usr/obj
290 .Pp
291 Is an example of a swap-backed VN disk configuration.  This example assumes
292 that you have at least 400 megabytes of swap free (and hopefully much more).
293 The swap space is pre-reserved in order to maintain maximum performance.
294 We then label the disk, newfs it, and mount it as
295 .Pa /usr/obj .
296 Swap-backed VN
297 devices are recoverable after a crash if you (A) use the reserve option, and if
298 (B) the same swap is reserved as was the last time, meaning that such
299 vnconfig's would have to be run in your rc.local.  In general, though, you
300 only use swap-backed VN devices to hold information you don't mind losing
301 on every reboot.
302 .Sh SEE ALSO
303 .Xr mount 2 ,
304 .Xr swapon 2 ,
305 .Xr unmount 2 ,
306 .Xr vn 4