xref: /openbsd/sys/dev/vndioctl.h (revision 17df1aa7)
1 /*	$OpenBSD: vndioctl.h,v 1.8 2008/09/03 23:24:25 krw Exp $	*/
2 /*	$NetBSD: vndioctl.h,v 1.5 1995/01/25 04:46:30 cgd Exp $	*/
3 
4 /*
5  * Copyright (c) 1988 University of Utah.
6  * Copyright (c) 1990, 1993
7  *	The Regents of the University of California.  All rights reserved.
8  *
9  * This code is derived from software contributed to Berkeley by
10  * the Systems Programming Group of the University of Utah Computer
11  * Science Department.
12  *
13  * Redistribution and use in source and binary forms, with or without
14  * modification, are permitted provided that the following conditions
15  * are met:
16  * 1. Redistributions of source code must retain the above copyright
17  *    notice, this list of conditions and the following disclaimer.
18  * 2. Redistributions in binary form must reproduce the above copyright
19  *    notice, this list of conditions and the following disclaimer in the
20  *    documentation and/or other materials provided with the distribution.
21  * 3. 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  * from: Utah $Hdr: fdioctl.h 1.1 90/07/09$
38  *
39  *	@(#)vnioctl.h	8.1 (Berkeley) 6/10/93
40  */
41 
42 #ifndef _SYS_VNDIOCTL_H_
43 #define _SYS_VNDIOCTL_H_
44 
45 #define VNDNLEN	90
46 
47 /*
48  * Ioctl definitions for file (vnode) disk pseudo-device.
49  */
50 struct vnd_ioctl {
51 	char	*vnd_file;	/* pathname of file to mount */
52 	size_t	vnd_secsize;	/* sector size in bytes */
53 	size_t	vnd_nsectors;	/* number of sectors in a track */
54 	size_t	vnd_ntracks;	/* number of tracks per cylinder (i.e. heads) */
55 	off_t	vnd_size;	/* (returned) size of disk */
56 	u_char	*vnd_key;
57 	int	vnd_keylen;
58 };
59 
60 /*
61  * A simple structure used by userland to query about a specific vnd.
62  */
63 struct vnd_user {
64 	char	vnu_file[VNDNLEN];	/* vnd file */
65 	int	vnu_unit;		/* vnd unit */
66 	dev_t	vnu_dev;		/* vnd device */
67 	ino_t	vnu_ino;		/* vnd inode */
68 };
69 
70 /*
71  * Before you can use a unit, it must be configured with VNDIOCSET.
72  * The configuration persists across opens and closes of the device;
73  * an VNDIOCCLR must be used to reset a configuration.  An attempt to
74  * VNDIOCSET an already active unit will return EBUSY.
75  */
76 #define VNDIOCSET	_IOWR('F', 0, struct vnd_ioctl)	/* enable disk */
77 #define VNDIOCCLR	_IOW('F', 1, struct vnd_ioctl)	/* disable disk */
78 #define VNDIOCGET	_IOWR('F', 2, struct vnd_user)	/* get disk info */
79 
80 #endif /* !_SYS_VNDIOCTL_H_ */
81