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 65The 66.Nm 67command configures, enables and lists vnode pseudo disk devices. 68The first form of the command will associate the special file 69.Ar special_file 70with the regular file 71.Ar regular_file 72allowing the latter to be accessed as though it were a disk. 73Hence a regular file within the filesystem can be used for swapping 74or can contain a filesystem that is mounted in the name space. If you 75want to use swap backing store for your device instead of a file, you 76can leave 77.Ar regular_file 78out and specify the size of the block device 79with the 80.Fl S 81option. 82.Pp 83Options indicate an action to be performed: 84.Bl -tag -width indent 85.It Fl a 86Read a command file and performs the 87specified actions for each device/file pair. 88.It Fl c 89Configure the device. 90If successful, references to 91.Ar special_file 92will access the contents of 93.Ar regular_file . 94.It Fl d 95Disable (if possible) the specified feature. 96.It Fl e 97Configure the device and enables any 98.Ar feature 99that was specified. 100If no feature was specified, 101.Fl e 102is the same as 103.Fl c . 104.It Fl f Ar config_file 105Use 106.Ar config_file 107as an alternate config file. 108.It Fl g 109Fiddle global options. 110.It Fl l Ar special_file Ar ... 111List the VN devices and indicate which ones are in use. 112If a 113.Ar special_file 114list is given, only those devices will be described. 115.It Fl r Ar options 116Reset 117.Ar options , 118which is a comma separated string of options. 119The list of allowed options and their meanings are: 120.Bl -tag -width "follow" 121.It Ar labels 122use disk/slice labels. 123.It Ar reserve 124Pre-reserve the blocks underlying the file or swap backing store. Currently only 125works for swap backing store. This option also disables on-the-fly freeing of 126the underlying backing store (for example, when you remove a large file). 127Use this option if you wish to avoid long-term fragmentation of the backing 128store. Also note that when this option is used, the initial contents of the 129backing store may contain garbage rather than zeros. It may even be possible to 130recover the prior contents of a swap-backed VN across a reboot if the VN device 131is configured before any swap is allocated by the system. 132.It Ar follow 133debug flow in the 134.Xr vn 4 135driver. 136.It Ar debug 137debug data in the 138.Xr vn 4 139driver. 140.It Ar io 141debug I/O in the 142.Xr vn 4 143driver. 144.It Ar all 145turn on all options. 146.It Ar none 147turn off all options. 148.El 149.It Fl s Ar options 150Set 151.Ar options , 152which is a comma separated string of options. 153The list of allowed options and their meanings are the same as for the 154.Fl r 155option. 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 163If no regular file is specified, VN will use swap for backing store. 164This option specifies the size of the device. For example, 165.Sq 23m 166for 16723 megabytes. 168In the absence of a size modifier, 169.Cm m 170is implied. 171The VN device will round the size up to a machine page boundary. 172Filesystems up to 7.9 terabytes are supported. When specified along with 173a regular file, this option overrides the regular file's size insofar as 174VN is concerned. 175.It Fl T 176When a regular file is specified, VN will 177.Fn ftruncate 178the file to length 0 first. 179Normally you should also specify the 180.Fl S 181option to set the size of the file. 182This option also creates the file if it did not previously exist. 183This option is only meaningful if the 184.Fl S 185option has been specified. 186.It Fl Z 187When a regular file is specified, VN will zero the contents of the file to 188ensure that all blocks have been allocated by the filesystem. This option is 189only meaningful if the 190.Fl S 191option has been specified. 192.It Fl u 193Disable and ``unconfigure'' the device. 194.It Fl v 195Print messages to stdout describing actions taken. 196.El 197.Pp 198If no action option is given, 199.Fl c 200is assumed. 201.Pp 202The 203.Ar feature 204argument specifies a feature that can be enabled via the 205.Fl e 206option: 207.Bl -tag -width indent 208.It Dv swap 209Swapping is enabled on the special file. 210See 211.Xr swapon 2 . 212.It Dv mountro Ns = Ns Pa mount_point 213The special file is mounted read-only on 214.Ar mount_point . 215See 216.Xr mount 2 . 217.It Dv mountrw Ns = Ns Pa mount_point 218The special file is mounted read-write on 219.Ar mount_point . 220See 221.Xr mount 2 . 222.It Dv mount Ns = Ns Pa mount_point 223Same as ``mountrw=''. 224.El 225.Pp 226A 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 231where fields are separated by white space. 232The previously described action options serve to configure, enable, 233disable or unconfigure all devices in the configuration file. 234.Sh FILES 235.Bl -tag -width /etc/vntab -compact 236.It Pa /etc/vntab 237default configuration file for 238.Fl a 239option 240.El 241.Sh EXAMPLES 242.Dl vnconfig vn0 /tmp/diskimage 243.Pp 244Configures the vnode disk 245.Pa vn0 . 246.Pp 247.Dl vnconfig -e vn0 /var/swapfile swap 248.Pp 249Configures 250.Pa vn0 251and 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 256Mount an ISO9660 CD image file. 257.Pp 258.Dl umount /mnt 259.Dl vnconfig -u vn0 260.Pp 261Unmount the CD image file. 262.Pp 263.Dl vnconfig -d vn0 myfilesystem mount=/mnt 264.Pp 265Unmounts (disables) 266.Pa vn0 . 267.Pp 268.Dl vnconfig -ae 269.Pp 270Configures 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 277Is an example of how to configure a file-backed VN disk with a disk label 278and to initialize and then edit the label. Once you create the label, you 279can partition your VN disk and, for example, create a filesystem on one of 280the partitions. If you are using a file as backing store, it may be possible 281to recover your VN disk after a crash by vnconfig'ing the same file again 282and using the VN configuration already stored in the file rather than 283relabeling and recreating the filesystem. It is even possible to fsck the 284VN 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 291Is an example of a swap-backed VN disk configuration. This example assumes 292that you have at least 400 megabytes of swap free (and hopefully much more). 293The swap space is pre-reserved in order to maintain maximum performance. 294We then label the disk, newfs it, and mount it as 295.Pa /usr/obj . 296Swap-backed VN 297devices 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 299vnconfig's would have to be run in your rc.local. In general, though, you 300only use swap-backed VN devices to hold information you don't mind losing 301on every reboot. 302.Sh SEE ALSO 303.Xr mount 2 , 304.Xr swapon 2 , 305.Xr unmount 2 , 306.Xr vn 4 307