10Sstevel@tonic-gate /* 20Sstevel@tonic-gate * CDDL HEADER START 30Sstevel@tonic-gate * 40Sstevel@tonic-gate * The contents of this file are subject to the terms of the 52799Smarx * Common Development and Distribution License (the "License"). 62799Smarx * You may not use this file except in compliance with the License. 70Sstevel@tonic-gate * 80Sstevel@tonic-gate * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 90Sstevel@tonic-gate * or http://www.opensolaris.org/os/licensing. 100Sstevel@tonic-gate * See the License for the specific language governing permissions 110Sstevel@tonic-gate * and limitations under the License. 120Sstevel@tonic-gate * 130Sstevel@tonic-gate * When distributing Covered Code, include this CDDL HEADER in each 140Sstevel@tonic-gate * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 150Sstevel@tonic-gate * If applicable, add the following below this CDDL HEADER, with the 160Sstevel@tonic-gate * fields enclosed by brackets "[]" replaced with your own identifying 170Sstevel@tonic-gate * information: Portions Copyright [yyyy] [name of copyright owner] 180Sstevel@tonic-gate * 190Sstevel@tonic-gate * CDDL HEADER END 200Sstevel@tonic-gate */ 210Sstevel@tonic-gate /* 22*5295Srandyf * Copyright 2007 Sun Microsystems, Inc. All rights reserved. 23753Slclee * Use is subject to license terms. 240Sstevel@tonic-gate */ 250Sstevel@tonic-gate 260Sstevel@tonic-gate #ifndef _SYS_DKTP_DADK_H 270Sstevel@tonic-gate #define _SYS_DKTP_DADK_H 280Sstevel@tonic-gate 290Sstevel@tonic-gate #pragma ident "%Z%%M% %I% %E% SMI" 300Sstevel@tonic-gate 310Sstevel@tonic-gate #ifdef __cplusplus 320Sstevel@tonic-gate extern "C" { 330Sstevel@tonic-gate #endif 340Sstevel@tonic-gate 35753Slclee #include <sys/dktp/tgcom.h> 36753Slclee 370Sstevel@tonic-gate struct dadk { 380Sstevel@tonic-gate struct tgdk_ext *dad_extp; /* back pointer to ext data */ 390Sstevel@tonic-gate struct scsi_device *dad_sd; /* back pointer to SCSI_DEVICE */ 400Sstevel@tonic-gate 410Sstevel@tonic-gate struct tgdk_geom dad_logg; /* logical disk geometry */ 420Sstevel@tonic-gate struct tgdk_geom dad_phyg; /* physical disk geometry */ 430Sstevel@tonic-gate 440Sstevel@tonic-gate unsigned dad_rmb : 1; /* removable device */ 450Sstevel@tonic-gate unsigned dad_rdonly : 1; /* read only device */ 460Sstevel@tonic-gate unsigned dad_cdrom : 1; /* cdrom device */ 47789Sahrens unsigned dad_noflush : 1; /* flush cmd unsupported */ 48789Sahrens unsigned dad_wce : 1; /* disk write cache enabled */ 49789Sahrens unsigned dad_resv : 3; 500Sstevel@tonic-gate unsigned char dad_type; /* device type */ 510Sstevel@tonic-gate unsigned char dad_ctype; /* controller type */ 520Sstevel@tonic-gate 530Sstevel@tonic-gate short dad_secshf; 540Sstevel@tonic-gate short dad_blkshf; 550Sstevel@tonic-gate 560Sstevel@tonic-gate opaque_t dad_bbhobjp; /* bbh object ptr */ 570Sstevel@tonic-gate opaque_t dad_flcobjp; /* flow control object ptr */ 580Sstevel@tonic-gate opaque_t dad_ctlobjp; /* controller object ptr */ 590Sstevel@tonic-gate struct tgcom_obj dad_com; /* com object for flowctrl */ 600Sstevel@tonic-gate enum dkio_state dad_iostate; /* ejected/inserted */ 610Sstevel@tonic-gate kmutex_t dad_mutex; /* protect dad_state */ 620Sstevel@tonic-gate kcondvar_t dad_state_cv; /* condition variable for state */ 630Sstevel@tonic-gate uchar_t dad_thread_cnt; /* reference count on removable */ 640Sstevel@tonic-gate /* - disk state watcher thread */ 652799Smarx kstat_t *dad_errstats; /* error stats */ 66*5295Srandyf kmutex_t dad_cmd_mutex; 67*5295Srandyf int dad_cmd_count; 680Sstevel@tonic-gate }; 690Sstevel@tonic-gate 700Sstevel@tonic-gate #define DAD_SECSIZ dad_phyg.g_secsiz 710Sstevel@tonic-gate 720Sstevel@tonic-gate /* 730Sstevel@tonic-gate * Local definitions, for clarity of code 740Sstevel@tonic-gate */ 750Sstevel@tonic-gate 760Sstevel@tonic-gate /* 770Sstevel@tonic-gate * Parameters 780Sstevel@tonic-gate */ 790Sstevel@tonic-gate #define DADK_BSY_TIMEOUT (drv_usectohz(5 * 1000000)) 800Sstevel@tonic-gate #define DADK_IO_TIME 35 81789Sahrens #define DADK_FLUSH_CACHE_TIME 60 820Sstevel@tonic-gate #define DADK_RETRY_COUNT 5 830Sstevel@tonic-gate #define DADK_SILENT 1 840Sstevel@tonic-gate 850Sstevel@tonic-gate #define PKT2DADK(pktp) ((struct dadk *)(pktp)->cp_dev_private) 860Sstevel@tonic-gate 870Sstevel@tonic-gate /* 880Sstevel@tonic-gate * packet action codes 890Sstevel@tonic-gate */ 900Sstevel@tonic-gate #define COMMAND_DONE 0 910Sstevel@tonic-gate #define COMMAND_DONE_ERROR 1 920Sstevel@tonic-gate #define QUE_COMMAND 2 930Sstevel@tonic-gate #define QUE_SENSE 3 940Sstevel@tonic-gate #define JUST_RETURN 4 950Sstevel@tonic-gate 962799Smarx typedef struct dadk_errstats { 972799Smarx kstat_named_t dadk_softerrs; /* Collecting Softerrs */ 982799Smarx kstat_named_t dadk_harderrs; /* Collecting harderrs */ 992799Smarx kstat_named_t dadk_transerrs; /* Collecting Transfer errs */ 1002799Smarx kstat_named_t dadk_model; /* model # of the disk */ 1012799Smarx kstat_named_t dadk_revision; /* The disk revision */ 1022799Smarx kstat_named_t dadk_serial; /* The disk serial number */ 1032799Smarx kstat_named_t dadk_capacity; /* Capacity of the disk */ 1042799Smarx kstat_named_t dadk_rq_media_err; /* Any media err seen */ 1052799Smarx kstat_named_t dadk_rq_ntrdy_err; /* Not ready errs */ 1062799Smarx kstat_named_t dadk_rq_nodev_err; /* No device errs */ 1072799Smarx kstat_named_t dadk_rq_recov_err; /* Recovered errs */ 1082799Smarx kstat_named_t dadk_rq_illrq_err; /* Illegal requests */ 1092799Smarx } dadk_errstats_t; 1102799Smarx 111753Slclee int dadk_init(opaque_t objp, opaque_t devp, opaque_t flcobjp, 112753Slclee opaque_t queobjp, opaque_t bbhobjp, void *lkarg); 113753Slclee int dadk_free(struct tgdk_obj *dkobjp); 114753Slclee int dadk_probe(opaque_t objp, int kmsflg); 115753Slclee int dadk_attach(opaque_t objp); 116753Slclee int dadk_open(opaque_t objp, int flag); 117753Slclee int dadk_close(opaque_t objp); 118753Slclee int dadk_ioctl(opaque_t objp, dev_t dev, int cmd, intptr_t arg, 119753Slclee int flag, cred_t *cred_p, int *rval_p); 120789Sahrens int dadk_flushdone(struct buf *bp); 121753Slclee int dadk_strategy(opaque_t objp, struct buf *bp); 122753Slclee int dadk_setgeom(opaque_t objp, struct tgdk_geom *dkgeom_p); 123753Slclee int dadk_getgeom(opaque_t objp, struct tgdk_geom *dkgeom_p); 124753Slclee struct tgdk_iob *dadk_iob_alloc(opaque_t objp, daddr_t blkno, 125753Slclee ssize_t xfer, int kmsflg); 126753Slclee int dadk_iob_free(opaque_t objp, struct tgdk_iob *iobp); 127753Slclee caddr_t dadk_iob_htoc(opaque_t objp, struct tgdk_iob *iobp); 128753Slclee caddr_t dadk_iob_xfer(opaque_t objp, struct tgdk_iob *iobp, int rw); 129753Slclee int dadk_dump(opaque_t objp, struct buf *bp); 130753Slclee int dadk_getphygeom(opaque_t objp, struct tgdk_geom *dkgeom_p); 131753Slclee int dadk_set_bbhobj(opaque_t objp, opaque_t bbhobjp); 132753Slclee int dadk_check_media(opaque_t objp, int *state); 133753Slclee static void dadk_watch_thread(struct dadk *dadkp); 134753Slclee int dadk_inquiry(opaque_t objp, opaque_t *inqpp); 135753Slclee void dadk_cleanup(struct tgdk_obj *dkobjp); 136753Slclee 137*5295Srandyf int dadk_getcmds(opaque_t objp); 138*5295Srandyf 1390Sstevel@tonic-gate #ifdef __cplusplus 1400Sstevel@tonic-gate } 1410Sstevel@tonic-gate #endif 1420Sstevel@tonic-gate 1430Sstevel@tonic-gate #endif /* _SYS_DKTP_DADK_H */ 144