edvar.h revision 1.1 1 /* $NetBSD: edvar.h,v 1.1 2001/04/19 07:30:24 jdolecek Exp $ */
2
3 /*
4 * Copyright (c) 2001 The NetBSD Foundation, Inc.
5 *
6 * This code is derived from software contributed to The NetBSD Foundation
7 * by Jaromir Dolecek.
8 *
9 * Redistribution and use in source and binary forms, with or without
10 * modification, are permitted provided that the following conditions
11 * are met:
12 * 1. Redistributions of source code must retain the above copyright
13 * notice, this list of conditions and the following disclaimer.
14 * 2. Redistributions in binary form must reproduce the above copyright
15 * notice, this list of conditions and the following disclaimer in the
16 * documentation and/or other materials provided with the distribution.
17 * 3. All advertising materials mentioning features or use of this software
18 * must display the following acknowledgement:
19 * This product includes software developed by the NetBSD
20 * Foundation, Inc. and its contributors.
21 * 4. The name of the author may not be used to endorse or promote products
22 * derived from this software without specific prior written permission.
23 *
24 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
25 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
26 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
27 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
28 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
29 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
30 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
31 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
32 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
33 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
34 */
35
36 struct dasd_mca_softc;
37 #define DASD_MAX_CMD_RES_LEN 8
38
39 struct ed_softc {
40 struct device sc_dev;
41
42 /* General disk infos */
43 struct disk sc_dk;
44 struct buf_queue sc_q;
45 struct simplelock sc_q_lock;
46 struct callout sc_edstart;
47
48 struct buf *sc_bp; /* buf being transfered */
49 struct dasd_mca_softc *dasd_softc; /* pointer to our parent */
50
51 int sc_flags;
52 #define WDF_LOCKED 0x001
53 #define WDF_WANTED 0x002
54 #define WDF_WLABEL 0x004 /* label is writable */
55 #define WDF_LABELLING 0x008 /* writing label */
56 #define WDF_LOADED 0x010 /* parameters loaded */
57 #define WDF_WAIT 0x020 /* waiting for resources */
58 #define WDF_KLABEL 0x080 /* retain label after 'full' close */
59 #define EDF_BOUNCEBUF 0x100 /* use bounce buffer */
60 #define EDF_DMAMAP_LOADED 0x200 /* dmamap_xfer loaded */
61 #define EDF_PROCESS_QUEUE 0x400
62 int sc_capacity;
63
64 /* actual drive parameters */
65 int sc_devno; /* DASD device number */
66 u_int16_t cyl;
67 u_int8_t heads;
68 u_int8_t sectors;
69 u_int8_t spares; /* spares per cylinder */
70 u_int32_t rba;
71 u_int8_t drv_flags;
72
73 u_int16_t sc_status_block[DASD_MAX_CMD_RES_LEN]; /* CMD status block */
74
75 int retries; /* number of xfer retry */
76 int sc_dk_busy;
77 daddr_t sc_badsect[127]; /* 126 plus trailing -1 marker */
78
79 /* Info needed for DMA */
80 bus_dma_tag_t sc_dmat; /* DMA tag as passed by parent */
81 bus_dmamap_t dmamap_xfer; /* transfer dma map */
82 #define ED_NSEGS 1
83 bus_dma_segment_t sc_dmaseg[ED_NSEGS]; /* DMA segment array */
84 bus_dma_segment_t sc_dmam[1]; /* Allocated DMA-safe memory */
85 vsize_t sc_dmam_sz; /* Size of allocated DMA memory */
86 caddr_t sc_dmamkva; /* Mapped kva of the memory */
87
88 void *sc_sdhook; /* our shutdown hook */
89
90 #if NRND > 0
91 rndsource_element_t rnd_source;
92 #endif
93
94 struct proc *sc_worker; /* Worker thread */
95 int sc_error;
96 };
97