diff options
author | Kenneth R Westerback <krw@cvs.openbsd.org> | 2005-07-02 04:24:55 +0000 |
---|---|---|
committer | Kenneth R Westerback <krw@cvs.openbsd.org> | 2005-07-02 04:24:55 +0000 |
commit | 2e49fd52ed22155d5d657dd5ce96914d13b6f5d8 (patch) | |
tree | e6f8240333286388f2208d431fcac448fb6414e8 /sys/scsi | |
parent | 6d094a535ab6bae839f381222773c7e82b38b42c (diff) |
Unused files.
Diffstat (limited to 'sys/scsi')
-rw-r--r-- | sys/scsi/atapi_disk.h | 70 | ||||
-rw-r--r-- | sys/scsi/sd_atapi.c | 153 | ||||
-rw-r--r-- | sys/scsi/sd_scsi.c | 216 |
3 files changed, 0 insertions, 439 deletions
diff --git a/sys/scsi/atapi_disk.h b/sys/scsi/atapi_disk.h deleted file mode 100644 index 5f7606effad..00000000000 --- a/sys/scsi/atapi_disk.h +++ /dev/null @@ -1,70 +0,0 @@ -/* $OpenBSD: atapi_disk.h,v 1.4 2005/06/19 20:41:28 krw Exp $ */ -/* $NetBSD: atapi_disk.h,v 1.3 1998/02/13 08:28:21 enami Exp $ */ - -/* - * Copyright 1998 - * Digital Equipment Corporation. All rights reserved. - * - * This software is furnished under license and may be used and - * copied only in accordance with the following terms and conditions. - * Subject to these conditions, you may download, copy, install, - * use, modify and distribute this software in source and/or binary - * form. No title or ownership is transferred hereby. - * - * 1) Any source code used, modified or distributed must reproduce - * and retain this copyright notice and list of conditions as - * they appear in the source file. - * - * 2) No right is granted to use any trade name, trademark, or logo of - * Digital Equipment Corporation. Neither the "Digital Equipment - * Corporation" name nor any trademark or logo of Digital Equipment - * Corporation may be used to endorse or promote products derived - * from this software without the prior written permission of - * Digital Equipment Corporation. - * - * 3) This software is provided "AS-IS" and any express or implied - * warranties, including but not limited to, any implied warranties - * of merchantability, fitness for a particular purpose, or - * non-infringement are disclaimed. In no event shall DIGITAL be - * liable for any damages whatsoever, and in particular, DIGITAL - * shall not be liable for special, indirect, consequential, or - * incidental damages or damages for lost profits, loss of - * revenue or loss of use, whether such damages arise in contract, - * negligence, tort, under statute, in equity, at law or otherwise, - * even if advised of the possibility of such damage. - */ - -/* - * Definitions of commands and structures specific to ATAPI disks. - * - * Chris Demetriou, January 10, 1998. - */ - -#define ATAPI_READ_FORMAT_CAPACITIES 0x23 -struct atapi_read_format_capacities { - u_int8_t opcode; - u_int8_t byte2; - u_int8_t reserved1[5]; - u_int8_t length[2]; - u_int8_t reserved2[3]; -}; - -struct atapi_capacity_list_header { - u_int8_t reserved[3]; - u_int8_t length; -}; - -/* codes only valid in the current/maximum capacity descriptor */ -#define ATAPI_CAP_DESC_CODE_MASK 0x3 -/* reserved 0x0 */ -#define ATAPI_CAP_DESC_CODE_UNFORMATTED 0x1 -#define ATAPI_CAP_DESC_CODE_FORMATTED 0x2 -#define ATAPI_CAP_DESC_CODE_NONE 0x3 - -#define ATAPI_CAP_DESC_SIZE(n) \ - (sizeof(struct atapi_capacity_list_header) + \ - (n) * sizeof(struct scsi_direct_blk_desc)) -#define ATAPI_CAP_DESC_OFFSET_HEADER 0 -#define ATAPI_CAP_DESC_OFFSET_DESC(n) ATAPI_CAP_DESC_SIZE(n) - -#define ATAPI_FLEX_GEOMETRY_PAGE 0x05 diff --git a/sys/scsi/sd_atapi.c b/sys/scsi/sd_atapi.c deleted file mode 100644 index ff8726a7463..00000000000 --- a/sys/scsi/sd_atapi.c +++ /dev/null @@ -1,153 +0,0 @@ -/* $OpenBSD: sd_atapi.c,v 1.10 2005/06/19 20:41:28 krw Exp $ */ -/* $NetBSD: sd_atapi.c,v 1.3 1998/08/31 22:28:07 cgd Exp $ */ - -/* - * Copyright 1998 - * Digital Equipment Corporation. All rights reserved. - * - * This software is furnished under license and may be used and - * copied only in accordance with the following terms and conditions. - * Subject to these conditions, you may download, copy, install, - * use, modify and distribute this software in source and/or binary - * form. No title or ownership is transferred hereby. - * - * 1) Any source code used, modified or distributed must reproduce - * and retain this copyright notice and list of conditions as - * they appear in the source file. - * - * 2) No right is granted to use any trade name, trademark, or logo of - * Digital Equipment Corporation. Neither the "Digital Equipment - * Corporation" name nor any trademark or logo of Digital Equipment - * Corporation may be used to endorse or promote products derived - * from this software without the prior written permission of - * Digital Equipment Corporation. - * - * 3) This software is provided "AS-IS" and any express or implied - * warranties, including but not limited to, any implied warranties - * of merchantability, fitness for a particular purpose, or - * non-infringement are disclaimed. In no event shall DIGITAL be - * liable for any damages whatsoever, and in particular, DIGITAL - * shall not be liable for special, indirect, consequential, or - * incidental damages or damages for lost profits, loss of - * revenue or loss of use, whether such damages arise in contract, - * negligence, tort, under statute, in equity, at law or otherwise, - * even if advised of the possibility of such damage. - */ - -/* - * ATAPI disk attachment for the 'sd' driver. - * - * Chris Demetriou, January 10, 1998. - */ - -#include <sys/types.h> -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/kernel.h> -#include <sys/buf.h> -#include <sys/malloc.h> -#include <sys/errno.h> -#include <sys/device.h> -#include <sys/disk.h> -#include <sys/conf.h> - -#include <scsi/scsi_all.h> -#include <scsi/scsi_disk.h> -#include <scsi/scsiconf.h> -#include <scsi/atapi_disk.h> -#include <scsi/sdvar.h> - -static int sd_atapibus_get_parms(struct sd_softc *, - struct disk_parms *, int); - -const struct sd_ops sd_atapibus_ops = { - sd_atapibus_get_parms, -}; - -static int -sd_atapibus_get_parms(sd, dp, flags) - struct sd_softc *sd; - struct disk_parms *dp; - int flags; -{ - struct atapi_read_format_capacities scsi_cmd; - struct scsi_direct_blk_desc *descp; - struct scsi_mode_sense_buf sense_data; - union scsi_disk_pages *sense_pages = NULL; - char capacity_data[ATAPI_CAP_DESC_SIZE(1)]; - u_int16_t rpm; - int error; - - bzero(&scsi_cmd, sizeof scsi_cmd); - scsi_cmd.opcode = ATAPI_READ_FORMAT_CAPACITIES; - _lto2b(ATAPI_CAP_DESC_SIZE(1), scsi_cmd.length); - - error = scsi_scsi_cmd(sd->sc_link, - (struct scsi_generic *)&scsi_cmd, sizeof(scsi_cmd), - (void *)capacity_data, ATAPI_CAP_DESC_SIZE(1), SDRETRIES, 20000, - NULL, flags | SCSI_DATA_IN); - SC_DEBUG(sd->sc_link, SDEV_DB2, - ("sd_atapibus_get_parms: read format capacities error=%d\n", - error)); - if (error != 0) - return (SDGP_RESULT_OFFLINE); - - descp = (struct scsi_direct_blk_desc *) - &capacity_data[ATAPI_CAP_DESC_OFFSET_DESC(0)]; - - switch (descp->density & ATAPI_CAP_DESC_CODE_MASK) { - case ATAPI_CAP_DESC_CODE_UNFORMATTED: - return SDGP_RESULT_UNFORMATTED; - - case ATAPI_CAP_DESC_CODE_FORMATTED: - break; - - case ATAPI_CAP_DESC_CODE_NONE: - return SDGP_RESULT_OFFLINE; - - default: -#ifdef DIAGNOSTIC - printf("%s: strange capacity descriptor density 0x%x\n", - sd->sc_dev.dv_xname, (u_int)descp->density); -#endif - break; - } - - dp->disksize = _4btol(descp->nblocks); - if (dp->disksize == 0) - return (SDGP_RESULT_OFFLINE); - - dp->blksize = _3btol(descp->blklen); - - error = scsi_do_mode_sense(sd->sc_link, ATAPI_FLEX_GEOMETRY_PAGE, - &sense_data, (void **)&sense_pages, NULL, NULL, NULL, - sizeof(sense_pages->flex_geometry), flags | SCSI_SILENT, NULL); - if (error == 0 && sense_pages) { - dp->heads = sense_pages->flex_geometry.nheads; - dp->sectors = sense_pages->flex_geometry.ph_sec_tr; - dp->cyls = _2btol(sense_pages->flex_geometry.ncyl); - if (dp->blksize == 0) - dp->blksize = - _2btol(sense_pages->flex_geometry.bytes_s); - rpm = _2btol(sense_pages->flex_geometry.rpm); - if (rpm) - dp->rot_rate = rpm; - } - - /* - * Use standard fake values if MODE SENSE did not provide better ones. - */ - if (dp->rot_rate == 0) - dp->rot_rate = 3600; - if (dp->blksize == 0) - dp->blksize = 512; - - if (dp->heads == 0) - dp->heads = 64; - if (dp->sectors == 0) - dp->sectors = 32; - if (dp->cyls == 0) - dp->cyls = dp->disksize / (dp->heads * dp->sectors); - - return (SDGP_RESULT_OK); -} diff --git a/sys/scsi/sd_scsi.c b/sys/scsi/sd_scsi.c deleted file mode 100644 index 98a6dc3b416..00000000000 --- a/sys/scsi/sd_scsi.c +++ /dev/null @@ -1,216 +0,0 @@ -/* $OpenBSD: sd_scsi.c,v 1.22 2005/06/27 23:50:43 krw Exp $ */ -/* $NetBSD: sd_scsi.c,v 1.8 1998/10/08 20:21:13 thorpej Exp $ */ - -/*- - * Copyright (c) 1998 The NetBSD Foundation, Inc. - * All rights reserved. - * - * This code is derived from software contributed to The NetBSD Foundation - * by Charles M. Hannum. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by the NetBSD - * Foundation, Inc. and its contributors. - * 4. Neither the name of The NetBSD Foundation nor the names of its - * contributors may be used to endorse or promote products derived - * from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS - * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED - * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR - * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS - * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR - * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF - * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS - * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN - * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) - * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE - * POSSIBILITY OF SUCH DAMAGE. - */ - -/* - * Originally written by Julian Elischer (julian@dialix.oz.au) - * for TRW Financial Systems for use under the MACH(2.5) operating system. - * - * TRW Financial Systems, in accordance with their agreement with Carnegie - * Mellon University, makes this software available to CMU to distribute - * or use in any manner that they see fit as long as this message is kept with - * the software. For this reason TFS also grants any other persons or - * organisations permission to use or modify this software. - * - * TFS supplies this software to be publicly redistributed - * on the understanding that TFS is not responsible for the correct - * functioning of this software in any circumstances. - * - * Ported to run under 386BSD by Julian Elischer (julian@dialix.oz.au) Sept 1992 - */ - -#include <sys/types.h> -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/kernel.h> -#include <sys/buf.h> -#include <sys/malloc.h> -#include <sys/errno.h> -#include <sys/device.h> -#include <sys/disk.h> -#include <sys/conf.h> - -#include <scsi/scsi_all.h> -#include <scsi/scsi_disk.h> -#include <scsi/scsiconf.h> -#include <scsi/sdvar.h> - -int sd_scsibus_get_parms(struct sd_softc *, - struct disk_parms *, int); -void sd_scsibus_flush(struct sd_softc *, int); - -const struct sd_ops sd_scsibus_ops = { - sd_scsibus_get_parms, - sd_scsibus_flush, -}; - -/* - * Fill out the disk parameter structure. Return SDGP_RESULT_OK if the - * structure is correctly filled in, SDGP_RESULT_OFFLINE otherwise. The caller - * is responsible for clearing the SDEV_MEDIA_LOADED flag if the structure - * cannot be completed. - */ -int -sd_scsibus_get_parms(sd, dp, flags) - struct sd_softc *sd; - struct disk_parms *dp; - int flags; -{ - struct scsi_mode_sense_buf buf; - union scsi_disk_pages *sense_pages = NULL; - u_int32_t heads = 0, sectors = 0, cyls = 0, blksize; - u_int16_t rpm = 0; - - dp->disksize = scsi_size(sd->sc_link, flags, &blksize); - - switch (sd->type) { - case T_OPTICAL: - /* No more information needed or available. */ - break; - - case T_RDIRECT: - /* T_RDIRECT only supports RBC Device Parameter Page (6). */ - scsi_do_mode_sense(sd->sc_link, 6, &buf, (void **)&sense_pages, - NULL, NULL, &blksize, sizeof(sense_pages->reduced_geometry), - flags | SCSI_SILENT, NULL); - if (sense_pages) { - if (dp->disksize == 0) - dp->disksize = _5btol(sense_pages-> - reduced_geometry.sectors); - if (blksize == 0) - blksize = _2btol(sense_pages-> - reduced_geometry.bytes_s); - } - break; - - default: - /* - * For other devices try mode sense page 4 (RIGID GEOMETRY) and - * if that doesn't work try page 5 (FLEX GEOMETRY). - */ - scsi_do_mode_sense(sd->sc_link, 4, &buf, (void **)&sense_pages, - NULL, NULL, &blksize, sizeof(sense_pages->rigid_geometry), - flags | SCSI_SILENT, NULL); - if (sense_pages) { - heads = sense_pages->rigid_geometry.nheads; - cyls = _3btol(sense_pages->rigid_geometry.ncyl); - rpm = _2btol(sense_pages->rigid_geometry.rpm); - if (heads * cyls > 0) - sectors = dp->disksize / (heads * cyls); - } else { - scsi_do_mode_sense(sd->sc_link, 5, &buf, - (void **)&sense_pages, NULL, NULL, &blksize, - sizeof(sense_pages->flex_geometry), - flags | SCSI_SILENT, NULL); - if (sense_pages) { - sectors = sense_pages->flex_geometry.ph_sec_tr; - heads = sense_pages->flex_geometry.nheads; - cyls = _2btol(sense_pages->flex_geometry.ncyl); - rpm = _2btol(sense_pages->flex_geometry.rpm); - if (blksize == 0) - blksize = _2btol(sense_pages-> - flex_geometry.bytes_s); - if (dp->disksize == 0) - dp->disksize = heads * cyls * sectors; - } - } - break; - } - - if (dp->disksize == 0) - return (SDGP_RESULT_OFFLINE); - - /* - * Use Adaptec standard geometry values for anything we still don't - * know. - */ - - dp->heads = (heads == 0) ? 64 : heads; - dp->blksize = (blksize == 0) ? 512 : blksize; - dp->sectors = (sectors == 0) ? 32 : sectors; - dp->rot_rate = (rpm == 0) ? 3600 : rpm; - - /* - * XXX THINK ABOUT THIS!! Using values such that sectors * heads * - * cyls is <= disk_size can lead to wasted space. We need a more - * careful calculation/validation to make everything work out - * optimally. - */ - dp->cyls = (cyls == 0) ? dp->disksize / (dp->heads * dp->sectors) : - cyls; - - return (SDGP_RESULT_OK); -} - -void -sd_scsibus_flush(sd, flags) - struct sd_softc *sd; - int flags; -{ - struct scsi_link *sc_link = sd->sc_link; - struct scsi_synchronize_cache sync_cmd; - - /* - * If the device is SCSI-2, issue a SYNCHRONIZE CACHE. - * We issue with address 0 length 0, which should be - * interpreted by the device as "all remaining blocks - * starting at address 0". We ignore ILLEGAL REQUEST - * in the event that the command is not supported by - * the device, and poll for completion so that we know - * that the cache has actually been flushed. - * - * Unless, that is, the device can't handle the SYNCHRONIZE CACHE - * command, as indicated by our quirks flags. - * - * XXX What about older devices? - */ - if ((sc_link->scsi_version & SID_ANSII) >= 2 && - (sc_link->quirks & SDEV_NOSYNCCACHE) == 0) { - bzero(&sync_cmd, sizeof(sync_cmd)); - sync_cmd.opcode = SYNCHRONIZE_CACHE; - - if (scsi_scsi_cmd(sc_link, - (struct scsi_generic *)&sync_cmd, sizeof(sync_cmd), - NULL, 0, SDRETRIES, 100000, NULL, - flags|SCSI_IGNORE_ILLEGAL_REQUEST)) - printf("%s: WARNING: cache synchronization failed\n", - sd->sc_dev.dv_xname); - else - sd->flags |= SDF_FLUSHING; - } -} |