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