1700 Add SCSI UNMAP support
[unleashed.git] / usr / src / uts / common / sys / dktp / dadk.h
blobf5c990e7c0241261c5e264d4f532eb7c1661132f
1 /*
2 * CDDL HEADER START
4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License (the "License").
6 * You may not use this file except in compliance with the License.
8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 * or http://www.opensolaris.org/os/licensing.
10 * See the License for the specific language governing permissions
11 * and limitations under the License.
13 * When distributing Covered Code, include this CDDL HEADER in each
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 * If applicable, add the following below this CDDL HEADER, with the
16 * fields enclosed by brackets "[]" replaced with your own identifying
17 * information: Portions Copyright [yyyy] [name of copyright owner]
19 * CDDL HEADER END
22 * Copyright 2007 Sun Microsystems, Inc. All rights reserved.
23 * Use is subject to license terms.
26 #ifndef _SYS_DKTP_DADK_H
27 #define _SYS_DKTP_DADK_H
29 #pragma ident "%Z%%M% %I% %E% SMI"
31 #ifdef __cplusplus
32 extern "C" {
33 #endif
35 #include <sys/dktp/tgcom.h>
37 struct dadk {
38 struct tgdk_ext *dad_extp; /* back pointer to ext data */
39 struct scsi_device *dad_sd; /* back pointer to SCSI_DEVICE */
41 struct tgdk_geom dad_logg; /* logical disk geometry */
42 struct tgdk_geom dad_phyg; /* physical disk geometry */
44 unsigned dad_rmb : 1; /* removable device */
45 unsigned dad_rdonly : 1; /* read only device */
46 unsigned dad_cdrom : 1; /* cdrom device */
47 unsigned dad_noflush : 1; /* flush cmd unsupported */
48 unsigned dad_wce : 1; /* disk write cache enabled */
49 unsigned dad_resv : 3;
50 unsigned char dad_type; /* device type */
51 unsigned char dad_ctype; /* controller type */
53 short dad_secshf;
54 short dad_blkshf;
56 opaque_t dad_bbhobjp; /* bbh object ptr */
57 opaque_t dad_flcobjp; /* flow control object ptr */
58 opaque_t dad_ctlobjp; /* controller object ptr */
59 struct tgcom_obj dad_com; /* com object for flowctrl */
60 enum dkio_state dad_iostate; /* ejected/inserted */
61 kmutex_t dad_mutex; /* protect dad_state */
62 kcondvar_t dad_state_cv; /* condition variable for state */
63 uchar_t dad_thread_cnt; /* reference count on removable */
64 /* - disk state watcher thread */
65 kstat_t *dad_errstats; /* error stats */
66 kmutex_t dad_cmd_mutex;
67 int dad_cmd_count;
70 #define DAD_SECSIZ dad_phyg.g_secsiz
73 * Local definitions, for clarity of code
77 * Parameters
79 #define DADK_BSY_TIMEOUT (drv_usectohz(5 * 1000000))
80 #define DADK_IO_TIME 35
81 #define DADK_FLUSH_CACHE_TIME 60
82 #define DADK_RETRY_COUNT 5
83 #define DADK_SILENT 1
85 #define PKT2DADK(pktp) ((struct dadk *)(pktp)->cp_dev_private)
88 * packet action codes
90 #define COMMAND_DONE 0
91 #define COMMAND_DONE_ERROR 1
92 #define QUE_COMMAND 2
93 #define QUE_SENSE 3
94 #define JUST_RETURN 4
96 typedef struct dadk_errstats {
97 kstat_named_t dadk_softerrs; /* Collecting Softerrs */
98 kstat_named_t dadk_harderrs; /* Collecting harderrs */
99 kstat_named_t dadk_transerrs; /* Collecting Transfer errs */
100 kstat_named_t dadk_model; /* model # of the disk */
101 kstat_named_t dadk_revision; /* The disk revision */
102 kstat_named_t dadk_serial; /* The disk serial number */
103 kstat_named_t dadk_capacity; /* Capacity of the disk */
104 kstat_named_t dadk_rq_media_err; /* Any media err seen */
105 kstat_named_t dadk_rq_ntrdy_err; /* Not ready errs */
106 kstat_named_t dadk_rq_nodev_err; /* No device errs */
107 kstat_named_t dadk_rq_recov_err; /* Recovered errs */
108 kstat_named_t dadk_rq_illrq_err; /* Illegal requests */
109 } dadk_errstats_t;
111 int dadk_init(opaque_t objp, opaque_t devp, opaque_t flcobjp,
112 opaque_t queobjp, opaque_t bbhobjp, void *lkarg);
113 int dadk_free(struct tgdk_obj *dkobjp);
114 int dadk_probe(opaque_t objp, int kmsflg);
115 int dadk_attach(opaque_t objp);
116 int dadk_open(opaque_t objp, int flag);
117 int dadk_close(opaque_t objp);
118 int dadk_ioctl(opaque_t objp, dev_t dev, int cmd, intptr_t arg,
119 int flag, cred_t *cred_p, int *rval_p);
120 int dadk_flushdone(struct buf *bp);
121 int dadk_strategy(opaque_t objp, struct buf *bp);
122 int dadk_setgeom(opaque_t objp, struct tgdk_geom *dkgeom_p);
123 int dadk_getgeom(opaque_t objp, struct tgdk_geom *dkgeom_p);
124 struct tgdk_iob *dadk_iob_alloc(opaque_t objp, daddr_t blkno,
125 ssize_t xfer, int kmsflg);
126 int dadk_iob_free(opaque_t objp, struct tgdk_iob *iobp);
127 caddr_t dadk_iob_htoc(opaque_t objp, struct tgdk_iob *iobp);
128 caddr_t dadk_iob_xfer(opaque_t objp, struct tgdk_iob *iobp, int rw);
129 int dadk_dump(opaque_t objp, struct buf *bp);
130 int dadk_getphygeom(opaque_t objp, struct tgdk_geom *dkgeom_p);
131 int dadk_set_bbhobj(opaque_t objp, opaque_t bbhobjp);
132 int dadk_check_media(opaque_t objp, int *state);
133 static void dadk_watch_thread(struct dadk *dadkp);
134 int dadk_inquiry(opaque_t objp, opaque_t *inqpp);
135 void dadk_cleanup(struct tgdk_obj *dkobjp);
137 int dadk_getcmds(opaque_t objp);
139 #ifdef __cplusplus
141 #endif
143 #endif /* _SYS_DKTP_DADK_H */