2 * Copyright (c) 2003,2004 The DragonFly Project. All rights reserved.
4 * This code is derived from software contributed to The DragonFly Project
5 * by Matthew Dillon <dillon@backplane.com>
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions
11 * 1. Redistributions of source code must retain the above copyright
12 * notice, this list of conditions and the following disclaimer.
13 * 2. Redistributions in binary form must reproduce the above copyright
14 * notice, this list of conditions and the following disclaimer in
15 * the documentation and/or other materials provided with the
17 * 3. Neither the name of The DragonFly Project nor the names of its
18 * contributors may be used to endorse or promote products derived
19 * from this software without specific, prior written permission.
21 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22 * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
24 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
25 * COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
26 * INCIDENTAL, SPECIAL, EXEMPLARY OR CONSEQUENTIAL DAMAGES (INCLUDING,
27 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
28 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
29 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
30 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
31 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
34 * ----------------------------------------------------------------------------
35 * "THE BEER-WARE LICENSE" (Revision 42):
36 * <phk@FreeBSD.ORG> wrote this file. As long as you retain this notice you
37 * can do whatever you want with this stuff. If we meet some day, and you think
38 * this stuff is worth it, you can buy me a beer in return. Poul-Henning Kamp
39 * ----------------------------------------------------------------------------
41 * $FreeBSD: src/sys/sys/disk.h,v 1.16.2.3 2001/06/20 16:11:01 scottl Exp $
47 #if !defined(_KERNEL) && !defined(_KERNEL_STRUCTURES)
48 #error "This file should not be included by userland programs."
51 #ifndef _SYS_DISKSLICE_H_
52 #include <sys/diskslice.h>
55 #include <sys/queue.h>
57 #ifndef _SYS_MSGPORT_H_
58 #include <sys/msgport.h>
65 * Media information structure - filled in by the media driver.
67 * NOTE: d_serialno is copied on the call to setdiskinfo and need
68 * not be valid after that.
72 * These fields are required. Most drivers will load a disk_info
73 * structure in the device open function with the media parameters
74 * and call disk_setdiskinfo().
76 * Note that only one of d_media_size or d_media_blocks should be
79 * d_media_size media size in bytes
80 * d_media_blocks media size in blocks (e.g. total sectors)
81 * d_media_blksize media block size / sector size
82 * d_dsflags disklabel management flags
84 u_int64_t d_media_size
;
85 u_int64_t d_media_blocks
;
90 * Optional fields, leave 0 if not known
92 u_int d_type
; /* DTYPE_xxx */
102 * d_dsflags, also used for dsopen() - control disklabel processing
104 * COMPATPARTA - used by scsi devices to allow CDs to boot from cd0a.
105 * cd's don't have disklabels and the default compat label
106 * does not implement an 'a' partition.
108 * COMPATMBR - used by the vn device to request that one sector be
109 * reserved as if an MBR were present even when one isn't.
111 * MBRQUIET - silently ignore MBR probe if unable to read sector 0.
114 * DEVICEMAPPER - used by the device mapper (dm). Adds a '.' between the
115 * device name and the slice/part stuff (i.e. foo.s0).
117 * RAWPSIZE - use the dev_psize of the underlying raw device if the top
120 #define DSO_NOLABELS 0x0001
121 #define DSO_ONESLICE 0x0002
122 #define DSO_COMPATLABEL 0x0004
123 #define DSO_COMPATPARTA 0x0008
124 #define DSO_COMPATMBR 0x0010
125 #define DSO_RAWEXTENSIONS 0x0020
126 #define DSO_MBRQUIET 0x0040
127 #define DSO_DEVICEMAPPER 0x0080
128 #define DSO_RAWPSIZE 0x0100
130 #if defined(_KERNEL) || defined(_KERNEL_STRUCTURES)
133 * Disk management structure - automated disklabel support.
136 struct dev_ops
*d_dev_ops
; /* our device switch */
137 struct dev_ops
*d_raw_ops
; /* the raw device switch */
139 int d_opencount
; /* The current open count */
140 cdev_t d_rawdev
; /* backing raw device */
141 cdev_t d_cdev
; /* special whole-disk part */
142 struct diskslices
*d_slice
;
143 struct disk_info d_info
; /* info structure for media */
147 const char *d_disktype
; /* Disk type information */
148 LIST_ENTRY(disk
) d_list
;
149 kdmsg_iocom_t d_iocom
; /* cluster import/export */
150 int d_refs
; /* interlock destruction */
158 #define DISKFLAG_LOCK 0x0001
159 #define DISKFLAG_WANTED 0x0002
160 #define DISKFLAG_MARKER 0x0004
163 cdev_t
disk_create (int unit
, struct disk
*disk
, struct dev_ops
*raw_ops
);
164 cdev_t
disk_create_clone (int unit
, struct disk
*disk
, struct dev_ops
*raw_ops
);
165 cdev_t
disk_create_named(const char *name
, int unit
, struct disk
*dp
, struct dev_ops
*raw_ops
);
166 cdev_t
disk_create_named_clone(const char *name
, int unit
, struct disk
*dp
, struct dev_ops
*raw_ops
);
167 cdev_t
disk_locate (const char *devname
);
168 void disk_destroy (struct disk
*disk
);
169 void disk_setdiskinfo (struct disk
*disk
, struct disk_info
*info
);
170 int disk_setdisktype(struct disk
*disk
, const char *type
);
171 int disk_getopencount(struct disk
*disk
);
172 void disk_setdiskinfo_sync(struct disk
*disk
, struct disk_info
*info
);
173 int disk_dumpcheck (cdev_t dev
, u_int64_t
*count
, u_int64_t
*blkno
, u_int
*secsize
);
174 int disk_dumpconf(cdev_t dev
, u_int onoff
);
175 struct disk
*disk_enumerate (struct disk
*marker
, struct disk
*dp
);
176 void disk_enumerate_stop (struct disk
*marker
, struct disk
*dp
);
177 void disk_invalidate (struct disk
*disk
);
178 void disk_unprobe(struct disk
*disk
);
180 void disk_msg_send(uint32_t cmd
, void *load
, void *load2
);
181 void disk_msg_send_sync(uint32_t cmd
, void *load
, void *load2
);
182 void disk_config(void *);
184 int bounds_check_with_mediasize(struct bio
*bio
, int secsize
, uint64_t mediasize
);
186 void disk_iocom_init(struct disk
*dp
);
187 void disk_iocom_update(struct disk
*dp
);
188 void disk_iocom_uninit(struct disk
*dp
);
189 int disk_iocom_ioctl(struct disk
*dp
, u_long cmd
, void *data
);
190 void disk_clusterctl_wakeup(kdmsg_iocom_t
*iocom
);
192 typedef struct disk_msg
{
198 #define DISK_DISK_PROBE 0x01
199 #define DISK_DISK_DESTROY 0x02
200 #define DISK_SLICE_REPROBE 0x03
201 #define DISK_DISK_REPROBE 0x04
202 #define DISK_UNPROBE 0x05
203 #define DISK_SYNC 0x99
208 #endif /* _SYS_DISK_H_ */