xref: /titanic_51/usr/src/uts/common/sys/dktp/dadk.h (revision 2df1fe9ca32bb227b9158c67f5c00b54c20b10fd)
17c478bd9Sstevel@tonic-gate /*
27c478bd9Sstevel@tonic-gate  * CDDL HEADER START
37c478bd9Sstevel@tonic-gate  *
47c478bd9Sstevel@tonic-gate  * The contents of this file are subject to the terms of the
54d27faddSmarx  * Common Development and Distribution License (the "License").
64d27faddSmarx  * You may not use this file except in compliance with the License.
77c478bd9Sstevel@tonic-gate  *
87c478bd9Sstevel@tonic-gate  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
97c478bd9Sstevel@tonic-gate  * or http://www.opensolaris.org/os/licensing.
107c478bd9Sstevel@tonic-gate  * See the License for the specific language governing permissions
117c478bd9Sstevel@tonic-gate  * and limitations under the License.
127c478bd9Sstevel@tonic-gate  *
137c478bd9Sstevel@tonic-gate  * When distributing Covered Code, include this CDDL HEADER in each
147c478bd9Sstevel@tonic-gate  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
157c478bd9Sstevel@tonic-gate  * If applicable, add the following below this CDDL HEADER, with the
167c478bd9Sstevel@tonic-gate  * fields enclosed by brackets "[]" replaced with your own identifying
177c478bd9Sstevel@tonic-gate  * information: Portions Copyright [yyyy] [name of copyright owner]
187c478bd9Sstevel@tonic-gate  *
197c478bd9Sstevel@tonic-gate  * CDDL HEADER END
207c478bd9Sstevel@tonic-gate  */
217c478bd9Sstevel@tonic-gate /*
22*2df1fe9cSrandyf  * Copyright 2007 Sun Microsystems, Inc.  All rights reserved.
2343369e13Slclee  * Use is subject to license terms.
247c478bd9Sstevel@tonic-gate  */
257c478bd9Sstevel@tonic-gate 
267c478bd9Sstevel@tonic-gate #ifndef _SYS_DKTP_DADK_H
277c478bd9Sstevel@tonic-gate #define	_SYS_DKTP_DADK_H
287c478bd9Sstevel@tonic-gate 
297c478bd9Sstevel@tonic-gate #pragma ident	"%Z%%M%	%I%	%E% SMI"
307c478bd9Sstevel@tonic-gate 
317c478bd9Sstevel@tonic-gate #ifdef	__cplusplus
327c478bd9Sstevel@tonic-gate extern "C" {
337c478bd9Sstevel@tonic-gate #endif
347c478bd9Sstevel@tonic-gate 
3543369e13Slclee #include <sys/dktp/tgcom.h>
3643369e13Slclee 
377c478bd9Sstevel@tonic-gate struct	dadk {
387c478bd9Sstevel@tonic-gate 	struct tgdk_ext	*dad_extp;	/* back pointer to ext data	*/
397c478bd9Sstevel@tonic-gate 	struct scsi_device *dad_sd;	/* back pointer to SCSI_DEVICE 	*/
407c478bd9Sstevel@tonic-gate 
417c478bd9Sstevel@tonic-gate 	struct  tgdk_geom dad_logg;	/* logical disk geometry 	*/
427c478bd9Sstevel@tonic-gate 	struct  tgdk_geom dad_phyg;	/* physical disk geometry 	*/
437c478bd9Sstevel@tonic-gate 
447c478bd9Sstevel@tonic-gate 	unsigned dad_rmb : 1;		/* removable device		*/
457c478bd9Sstevel@tonic-gate 	unsigned dad_rdonly : 1;	/* read only device		*/
467c478bd9Sstevel@tonic-gate 	unsigned dad_cdrom : 1;		/* cdrom device			*/
47fa9e4066Sahrens 	unsigned dad_noflush : 1;	/* flush cmd unsupported	*/
48fa9e4066Sahrens 	unsigned dad_wce : 1;		/* disk write cache enabled	*/
49fa9e4066Sahrens 	unsigned dad_resv : 3;
507c478bd9Sstevel@tonic-gate 	unsigned char dad_type;		/* device type			*/
517c478bd9Sstevel@tonic-gate 	unsigned char dad_ctype;	/* controller type 		*/
527c478bd9Sstevel@tonic-gate 
537c478bd9Sstevel@tonic-gate 	short	 dad_secshf;
547c478bd9Sstevel@tonic-gate 	short	 dad_blkshf;
557c478bd9Sstevel@tonic-gate 
567c478bd9Sstevel@tonic-gate 	opaque_t dad_bbhobjp;		/* bbh object ptr		*/
577c478bd9Sstevel@tonic-gate 	opaque_t dad_flcobjp;		/* flow control object ptr	*/
587c478bd9Sstevel@tonic-gate 	opaque_t dad_ctlobjp;		/* controller object ptr	*/
597c478bd9Sstevel@tonic-gate 	struct	tgcom_obj dad_com;	/* com object for flowctrl	*/
607c478bd9Sstevel@tonic-gate 	enum dkio_state dad_iostate;	/* ejected/inserted		*/
617c478bd9Sstevel@tonic-gate 	kmutex_t	dad_mutex;	/* protect dad_state		*/
627c478bd9Sstevel@tonic-gate 	kcondvar_t	dad_state_cv;	/* condition variable for state */
637c478bd9Sstevel@tonic-gate 	uchar_t		dad_thread_cnt;	/* reference count on removable	*/
647c478bd9Sstevel@tonic-gate 					/* - disk state watcher thread	*/
654d27faddSmarx 	kstat_t		*dad_errstats;	/* error stats			*/
66*2df1fe9cSrandyf 	kmutex_t	dad_cmd_mutex;
67*2df1fe9cSrandyf 	int		dad_cmd_count;
687c478bd9Sstevel@tonic-gate };
697c478bd9Sstevel@tonic-gate 
707c478bd9Sstevel@tonic-gate #define	DAD_SECSIZ	dad_phyg.g_secsiz
717c478bd9Sstevel@tonic-gate 
727c478bd9Sstevel@tonic-gate /*
737c478bd9Sstevel@tonic-gate  * Local definitions, for clarity of code
747c478bd9Sstevel@tonic-gate  */
757c478bd9Sstevel@tonic-gate 
767c478bd9Sstevel@tonic-gate /*
777c478bd9Sstevel@tonic-gate  * Parameters
787c478bd9Sstevel@tonic-gate  */
797c478bd9Sstevel@tonic-gate #define	DADK_BSY_TIMEOUT	(drv_usectohz(5 * 1000000))
807c478bd9Sstevel@tonic-gate #define	DADK_IO_TIME		35
81fa9e4066Sahrens #define	DADK_FLUSH_CACHE_TIME	60
827c478bd9Sstevel@tonic-gate #define	DADK_RETRY_COUNT	5
837c478bd9Sstevel@tonic-gate #define	DADK_SILENT		1
847c478bd9Sstevel@tonic-gate 
857c478bd9Sstevel@tonic-gate #define	PKT2DADK(pktp)	((struct dadk *)(pktp)->cp_dev_private)
867c478bd9Sstevel@tonic-gate 
877c478bd9Sstevel@tonic-gate /*
887c478bd9Sstevel@tonic-gate  * packet action codes
897c478bd9Sstevel@tonic-gate  */
907c478bd9Sstevel@tonic-gate #define	COMMAND_DONE		0
917c478bd9Sstevel@tonic-gate #define	COMMAND_DONE_ERROR	1
927c478bd9Sstevel@tonic-gate #define	QUE_COMMAND		2
937c478bd9Sstevel@tonic-gate #define	QUE_SENSE		3
947c478bd9Sstevel@tonic-gate #define	JUST_RETURN		4
957c478bd9Sstevel@tonic-gate 
964d27faddSmarx typedef	struct	dadk_errstats {
974d27faddSmarx 	kstat_named_t dadk_softerrs;		/* Collecting Softerrs */
984d27faddSmarx 	kstat_named_t dadk_harderrs;		/* Collecting harderrs */
994d27faddSmarx 	kstat_named_t dadk_transerrs;		/* Collecting Transfer errs */
1004d27faddSmarx 	kstat_named_t dadk_model;		/* model # of the disk */
1014d27faddSmarx 	kstat_named_t dadk_revision;		/* The disk revision */
1024d27faddSmarx 	kstat_named_t dadk_serial;		/* The disk serial number */
1034d27faddSmarx 	kstat_named_t dadk_capacity;		/* Capacity of the disk */
1044d27faddSmarx 	kstat_named_t dadk_rq_media_err;	/* Any media err seen */
1054d27faddSmarx 	kstat_named_t dadk_rq_ntrdy_err;	/* Not ready errs */
1064d27faddSmarx 	kstat_named_t dadk_rq_nodev_err;	/* No device errs */
1074d27faddSmarx 	kstat_named_t dadk_rq_recov_err;	/* Recovered errs */
1084d27faddSmarx 	kstat_named_t dadk_rq_illrq_err;	/* Illegal requests */
1094d27faddSmarx } dadk_errstats_t;
1104d27faddSmarx 
11143369e13Slclee int dadk_init(opaque_t objp, opaque_t devp, opaque_t flcobjp,
11243369e13Slclee     opaque_t queobjp, opaque_t bbhobjp, void *lkarg);
11343369e13Slclee int dadk_free(struct tgdk_obj *dkobjp);
11443369e13Slclee int dadk_probe(opaque_t objp, int kmsflg);
11543369e13Slclee int dadk_attach(opaque_t objp);
11643369e13Slclee int dadk_open(opaque_t objp, int flag);
11743369e13Slclee int dadk_close(opaque_t objp);
11843369e13Slclee int dadk_ioctl(opaque_t objp, dev_t dev, int cmd, intptr_t arg,
11943369e13Slclee     int flag, cred_t *cred_p, int *rval_p);
120fa9e4066Sahrens int dadk_flushdone(struct buf *bp);
12143369e13Slclee int dadk_strategy(opaque_t objp, struct buf *bp);
12243369e13Slclee int dadk_setgeom(opaque_t objp, struct tgdk_geom *dkgeom_p);
12343369e13Slclee int dadk_getgeom(opaque_t objp, struct tgdk_geom *dkgeom_p);
12443369e13Slclee struct tgdk_iob *dadk_iob_alloc(opaque_t objp, daddr_t blkno,
12543369e13Slclee     ssize_t xfer, int kmsflg);
12643369e13Slclee int dadk_iob_free(opaque_t objp, struct tgdk_iob *iobp);
12743369e13Slclee caddr_t dadk_iob_htoc(opaque_t objp, struct tgdk_iob *iobp);
12843369e13Slclee caddr_t dadk_iob_xfer(opaque_t objp, struct tgdk_iob *iobp, int rw);
12943369e13Slclee int dadk_dump(opaque_t objp, struct buf *bp);
13043369e13Slclee int dadk_getphygeom(opaque_t objp, struct tgdk_geom *dkgeom_p);
13143369e13Slclee int dadk_set_bbhobj(opaque_t objp, opaque_t bbhobjp);
13243369e13Slclee int dadk_check_media(opaque_t objp, int *state);
13343369e13Slclee static void dadk_watch_thread(struct dadk *dadkp);
13443369e13Slclee int dadk_inquiry(opaque_t objp, opaque_t *inqpp);
13543369e13Slclee void dadk_cleanup(struct tgdk_obj *dkobjp);
13643369e13Slclee 
137*2df1fe9cSrandyf int dadk_getcmds(opaque_t objp);
138*2df1fe9cSrandyf 
1397c478bd9Sstevel@tonic-gate #ifdef	__cplusplus
1407c478bd9Sstevel@tonic-gate }
1417c478bd9Sstevel@tonic-gate #endif
1427c478bd9Sstevel@tonic-gate 
1437c478bd9Sstevel@tonic-gate #endif	/* _SYS_DKTP_DADK_H */
144