xref: /freebsd-src/sys/geom/geom_disk.h (revision 95ee2897e98f5d444f26ed2334cc7c439f9c16c6)
17c79beb3SPoul-Henning Kamp /*-
23728855aSPedro F. Giffuni  * SPDX-License-Identifier: BSD-3-Clause
33728855aSPedro F. Giffuni  *
47c79beb3SPoul-Henning Kamp  * Copyright (c) 2003 Poul-Henning Kamp
57c79beb3SPoul-Henning Kamp  * All rights reserved.
67c79beb3SPoul-Henning Kamp  *
77c79beb3SPoul-Henning Kamp  * This software was developed for the FreeBSD Project by Poul-Henning Kamp
87c79beb3SPoul-Henning Kamp  * and NAI Labs, the Security Research Division of Network Associates, Inc.
97c79beb3SPoul-Henning Kamp  * under DARPA/SPAWAR contract N66001-01-C-8035 ("CBOSS"), as part of the
107c79beb3SPoul-Henning Kamp  * DARPA CHATS research program.
117c79beb3SPoul-Henning Kamp  *
127c79beb3SPoul-Henning Kamp  * Redistribution and use in source and binary forms, with or without
137c79beb3SPoul-Henning Kamp  * modification, are permitted provided that the following conditions
147c79beb3SPoul-Henning Kamp  * are met:
157c79beb3SPoul-Henning Kamp  * 1. Redistributions of source code must retain the above copyright
167c79beb3SPoul-Henning Kamp  *    notice, this list of conditions and the following disclaimer.
177c79beb3SPoul-Henning Kamp  * 2. Redistributions in binary form must reproduce the above copyright
187c79beb3SPoul-Henning Kamp  *    notice, this list of conditions and the following disclaimer in the
197c79beb3SPoul-Henning Kamp  *    documentation and/or other materials provided with the distribution.
207c79beb3SPoul-Henning Kamp  * 3. The names of the authors may not be used to endorse or promote
217c79beb3SPoul-Henning Kamp  *    products derived from this software without specific prior written
227c79beb3SPoul-Henning Kamp  *    permission.
237c79beb3SPoul-Henning Kamp  *
247c79beb3SPoul-Henning Kamp  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
257c79beb3SPoul-Henning Kamp  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
267c79beb3SPoul-Henning Kamp  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
277c79beb3SPoul-Henning Kamp  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
287c79beb3SPoul-Henning Kamp  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
297c79beb3SPoul-Henning Kamp  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
307c79beb3SPoul-Henning Kamp  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
317c79beb3SPoul-Henning Kamp  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
327c79beb3SPoul-Henning Kamp  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
337c79beb3SPoul-Henning Kamp  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
347c79beb3SPoul-Henning Kamp  * SUCH DAMAGE.
357c79beb3SPoul-Henning Kamp  */
367c79beb3SPoul-Henning Kamp 
377c79beb3SPoul-Henning Kamp #ifndef _GEOM_GEOM_DISK_H_
387c79beb3SPoul-Henning Kamp #define _GEOM_GEOM_DISK_H_
397c79beb3SPoul-Henning Kamp 
4027f0f2ecSAlan Somers #define	DISK_RR_UNKNOWN		0
4127f0f2ecSAlan Somers #define	DISK_RR_NON_ROTATING	1
4227f0f2ecSAlan Somers #define	DISK_RR_MIN		0x0401
4327f0f2ecSAlan Somers #define	DISK_RR_MAX		0xfffe
4427f0f2ecSAlan Somers 
457c79beb3SPoul-Henning Kamp #ifdef _KERNEL
467c79beb3SPoul-Henning Kamp 
477c79beb3SPoul-Henning Kamp #include <sys/queue.h>
48afcbcfaeSPoul-Henning Kamp #include <sys/_lock.h>
49afcbcfaeSPoul-Henning Kamp #include <sys/_mutex.h>
50d0c11f9eSPawel Jakub Dawidek #include <sys/disk.h>
517c79beb3SPoul-Henning Kamp 
52252c094eSIvan Voras #define G_DISK_CLASS_NAME	"DISK"
53252c094eSIvan Voras 
5420b35013SPoul-Henning Kamp struct disk;
5520b35013SPoul-Henning Kamp 
567c79beb3SPoul-Henning Kamp typedef	int	disk_open_t(struct disk *);
577c79beb3SPoul-Henning Kamp typedef	int	disk_close_t(struct disk *);
587c79beb3SPoul-Henning Kamp typedef	void	disk_strategy_t(struct bio *bp);
59416494d7SJustin T. Gibbs typedef	int	disk_getattr_t(struct bio *bp);
60c3fb2891SKenneth D. Merry typedef	void	disk_gone_t(struct disk *);
617c79beb3SPoul-Henning Kamp typedef	int	disk_ioctl_t(struct disk *, u_long cmd, void *data,
627c79beb3SPoul-Henning Kamp 			int fflag, struct thread *td);
637c79beb3SPoul-Henning Kamp 		/* NB: disk_ioctl_t SHALL be cast'able to d_ioctl_t */
647c79beb3SPoul-Henning Kamp 
657c79beb3SPoul-Henning Kamp struct g_geom;
667c79beb3SPoul-Henning Kamp struct devstat;
677c79beb3SPoul-Henning Kamp 
681ff824e7SKenneth D. Merry typedef enum {
691ff824e7SKenneth D. Merry 	DISK_INIT_NONE,
70*90bcc81bSAlexander Motin 	DISK_INIT_CREATE,
711ff824e7SKenneth D. Merry 	DISK_INIT_START,
721ff824e7SKenneth D. Merry 	DISK_INIT_DONE
731ff824e7SKenneth D. Merry } disk_init_level;
741ff824e7SKenneth D. Merry 
75d3517d30SWarner Losh struct disk_alias {
76d3517d30SWarner Losh 	LIST_ENTRY(disk_alias)	da_next;
77d3517d30SWarner Losh 	const char		*da_alias;
78d3517d30SWarner Losh };
79d3517d30SWarner Losh 
807c79beb3SPoul-Henning Kamp struct disk {
817c79beb3SPoul-Henning Kamp 	/* Fields which are private to geom_disk */
827c79beb3SPoul-Henning Kamp 	struct g_geom		*d_geom;
837c79beb3SPoul-Henning Kamp 	struct devstat		*d_devstat;
841ff824e7SKenneth D. Merry 	int			d_goneflag;
850b7ed341SPoul-Henning Kamp 	int			d_destroyed;
861ff824e7SKenneth D. Merry 	disk_init_level		d_init_level;
877c79beb3SPoul-Henning Kamp 
887c79beb3SPoul-Henning Kamp 	/* Shared fields */
897c79beb3SPoul-Henning Kamp 	u_int			d_flags;
907c79beb3SPoul-Henning Kamp 	const char		*d_name;
917c79beb3SPoul-Henning Kamp 	u_int			d_unit;
92afcbcfaeSPoul-Henning Kamp 	struct bio_queue_head	*d_queue;
93afcbcfaeSPoul-Henning Kamp 	struct mtx		*d_lock;
947c79beb3SPoul-Henning Kamp 
957c79beb3SPoul-Henning Kamp 	/* Disk methods  */
967c79beb3SPoul-Henning Kamp 	disk_open_t		*d_open;
977c79beb3SPoul-Henning Kamp 	disk_close_t		*d_close;
987c79beb3SPoul-Henning Kamp 	disk_strategy_t		*d_strategy;
997c79beb3SPoul-Henning Kamp 	disk_ioctl_t		*d_ioctl;
1007c79beb3SPoul-Henning Kamp 	dumper_t		*d_dump;
101416494d7SJustin T. Gibbs 	disk_getattr_t		*d_getattr;
102c3fb2891SKenneth D. Merry 	disk_gone_t		*d_gone;
1037c79beb3SPoul-Henning Kamp 
1047c79beb3SPoul-Henning Kamp 	/* Info fields from driver to geom_disk.c. Valid when open */
1057c79beb3SPoul-Henning Kamp 	u_int			d_sectorsize;
1067c79beb3SPoul-Henning Kamp 	off_t			d_mediasize;
1077c79beb3SPoul-Henning Kamp 	u_int			d_fwsectors;
1087c79beb3SPoul-Henning Kamp 	u_int			d_fwheads;
1097c79beb3SPoul-Henning Kamp 	u_int			d_maxsize;
1109fe9ba5bSSteven Hartland 	off_t			d_delmaxsize;
1116d305ab0SEugene Grosbein 	off_t			d_stripeoffset;
1126d305ab0SEugene Grosbein 	off_t			d_stripesize;
113d0c11f9eSPawel Jakub Dawidek 	char			d_ident[DISK_IDENT_SIZE];
11465cb6238SNathan Whitehorn 	char			d_descr[DISK_IDENT_SIZE];
1158edcf694SAlexander Motin 	uint16_t		d_hba_vendor;
1168edcf694SAlexander Motin 	uint16_t		d_hba_device;
1178edcf694SAlexander Motin 	uint16_t		d_hba_subvendor;
1188edcf694SAlexander Motin 	uint16_t		d_hba_subdevice;
119c28078e9SSteven Hartland 	uint16_t		d_rotation_rate;
120b5961be1SEdward Tomasz Napierala 	char			d_attachment[DISK_IDENT_SIZE];
1217c79beb3SPoul-Henning Kamp 
1227c79beb3SPoul-Henning Kamp 	/* Fields private to the driver */
1237c79beb3SPoul-Henning Kamp 	void			*d_drv1;
124d3517d30SWarner Losh 
125d3517d30SWarner Losh 	/* Fields private to geom_disk, to be moved on next version bump */
126d3517d30SWarner Losh 	LIST_HEAD(,disk_alias)	d_aliases;
127*90bcc81bSAlexander Motin 	struct g_event		*d_cevent;
128*90bcc81bSAlexander Motin 	struct g_event		*d_devent;
1297c79beb3SPoul-Henning Kamp };
1307c79beb3SPoul-Henning Kamp 
1316ce374aaSAndriy Gapon #define	DISKFLAG_RESERVED		0x0001	/* Was NEEDSGIANT */
1326ce374aaSAndriy Gapon #define	DISKFLAG_OPEN			0x0002
1336ce374aaSAndriy Gapon #define	DISKFLAG_CANDELETE		0x0004
1346ce374aaSAndriy Gapon #define	DISKFLAG_CANFLUSHCACHE		0x0008
1356ce374aaSAndriy Gapon #define	DISKFLAG_UNMAPPED_BIO		0x0010
1366ce374aaSAndriy Gapon #define	DISKFLAG_DIRECT_COMPLETION	0x0020
1376ce374aaSAndriy Gapon #define	DISKFLAG_CANZONE		0x0080
1386ce374aaSAndriy Gapon #define	DISKFLAG_WRITE_PROTECT		0x0100
1397c79beb3SPoul-Henning Kamp 
1400b7ed341SPoul-Henning Kamp struct disk *disk_alloc(void);
1410b7ed341SPoul-Henning Kamp void disk_create(struct disk *disk, int version);
1427c79beb3SPoul-Henning Kamp void disk_destroy(struct disk *disk);
143a7e69e8bSJohn Polstra void disk_gone(struct disk *disk);
144416494d7SJustin T. Gibbs void disk_attr_changed(struct disk *dp, const char *attr, int flag);
1453631c638SAlexander Motin void disk_media_changed(struct disk *dp, int flag);
1463631c638SAlexander Motin void disk_media_gone(struct disk *dp, int flag);
1471af2d09bSEdward Tomasz Napierala int disk_resize(struct disk *dp, int flag);
148d3517d30SWarner Losh void disk_add_alias(struct disk *disk, const char *);
1497c79beb3SPoul-Henning Kamp 
1500b7ed341SPoul-Henning Kamp #define DISK_VERSION_00		0x58561059
151d0c11f9eSPawel Jakub Dawidek #define DISK_VERSION_01		0x5856105a
152c3fb2891SKenneth D. Merry #define DISK_VERSION_02		0x5856105b
1538383a92eSSteven Hartland #define DISK_VERSION_03		0x5856105c
154c28078e9SSteven Hartland #define DISK_VERSION_04		0x5856105d
1551ff824e7SKenneth D. Merry #define DISK_VERSION_05		0x5856105e
1566d305ab0SEugene Grosbein #define DISK_VERSION_06		0x5856105f
1576d305ab0SEugene Grosbein #define DISK_VERSION		DISK_VERSION_06
1587c79beb3SPoul-Henning Kamp 
1597c79beb3SPoul-Henning Kamp #endif /* _KERNEL */
1607c79beb3SPoul-Henning Kamp #endif /* _GEOM_GEOM_DISK_H_ */
161