Merge branch 'vendor/BINUTILS220' into bu220
[dragonfly.git] / sys / dev / disk / ic_layer / wd33c93reg.h
1 /* $FreeBSD: src/sys/dev/ic/wd33c93reg.h,v 1.1.2.1 2001/07/26 02:32:18 nyan Exp $ */
2 /* $DragonFly: src/sys/dev/disk/ic_layer/wd33c93reg.h,v 1.2 2003/06/17 04:28:27 dillon Exp $ */
3 /*      $NecBSD: wd33c93reg.h,v 1.21.24.1 2001/06/13 05:52:05 honda Exp $       */
4 /*      $NetBSD$        */
5 /*
6  * [NetBSD for NEC PC-98 series]
7  *  Copyright (c) 1996, 1997, 1998
8  *      NetBSD/pc98 porting staff. All rights reserved.
9  *  Copyright (c) 1996, 1997, 1998
10  *      Naofumi Honda. All rights reserved.
11  * 
12  *  Redistribution and use in source and binary forms, with or without
13  *  modification, are permitted provided that the following conditions
14  *  are met:
15  *  1. Redistributions of source code must retain the above copyright
16  *     notice, this list of conditions and the following disclaimer.
17  *  2. Redistributions in binary form must reproduce the above copyright
18  *     notice, this list of conditions and the following disclaimer in the
19  *     documentation and/or other materials provided with the distribution.
20  *  3. The name of the author may not be used to endorse or promote products
21  *     derived from this software without specific prior written permission.
22  * 
23  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
24  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
25  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
26  * DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT,
27  * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
28  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
29  * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
30  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
31  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
32  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
33  * POSSIBILITY OF SUCH DAMAGE.
34  */
35
36 #ifndef _WD33C93REG_H_
37 #define _WD33C93REG_H_
38
39 /* wd33c93 register */
40 #define wd3s_oid                0x00
41 #define IDR_FS_16_20            0x80
42 #define IDR_FS_12_15            0x40
43 #define IDR_FS_8_10             0x00
44 #define IDR_RAF                 0x20
45 #define IDR_EHP                 0x10
46 #define IDR_EAF                 0x08
47 #define IDR_IDM                 0x07
48
49 #define wd3s_ctrl               0x01
50 #define CR_DMA                  0x80
51 #define CR_DMAD                 0x40
52 #define CR_HLT_HOST_PARITY      0x10
53 #define CR_DIS_INT              0x08
54 #define CR_IDIS_INT             0x04
55 #define CR_HLT_ATN              0x02
56 #define CR_HLT_BUS_PARITY       0x01
57 #define CR_DEFAULT              (CR_DIS_INT | CR_IDIS_INT)
58 #define CR_DEFAULT_HP           (CR_DEFAULT | CR_HLT_BUS_PARITY)
59
60 #define wd3s_tout               0x02
61 #define wd3s_cdb                0x03
62 #define wd3s_lun                0x0f
63 #define wd3s_cph                0x10
64 #define wd3s_synch              0x11
65 #define wd3s_cnt                0x12
66 #define wd3s_did                0x15
67 #define DIDR_SCC                0x80
68 #define DIDR_DPD                0x40
69
70 #define wd3s_sid                0x16
71 #define SIDR_RESEL              0x80
72 #define SIDR_SEL                0x40
73 #define SIDR_VALID              0x08
74 #define SIDR_IDM                0x07
75
76 #define wd3s_stat               0x17
77
78 #define BSR_CM                  0xf0
79 #define BSR_CMDCPL              0x10
80 #define BSR_CMDABT              0x20
81 #define BSR_CMDERR              0x40
82 #define BSR_CMDREQ              0x80
83
84 #define BSR_SM                  0x0f
85 #define BSR_PM                  0x07
86 #define BSR_PHVALID             0x08
87 #define BSR_IOR                 0x01
88 #define BSR_DATAOUT             0x00
89 #define BSR_DATAIN              0x01
90 #define BSR_CMDOUT              0x02
91 #define BSR_STATIN              0x03
92 #define BSR_UNSPINFO0           0x04
93 #define BSR_UNSPINFO1           0x05
94 #define BSR_MSGOUT              0x06
95 #define BSR_MSGIN               0x07
96
97 #define BSR_RESET               0x00
98 #define BSR_AFM_RESET           0x01
99 #define BSR_SELECTED            0x11
100 #define BSR_SATFIN              0x16
101 #define BSR_ACKREQ              0x20
102 #define BSR_SATSDP              0x21
103 #define BSR_RESEL               0x80
104 #define BSR_AFM_RESEL           0x81
105 #define BSR_DISC                0x85
106
107 #define wd3s_cmd                0x18
108 #define wd3s_data               0x19
109 #define wd3s_qtag               0x1a
110
111 #define wd3s_mbank              0x30
112 #define MBR_RST                 0x02
113 #define MBR_IEN                 0x04
114
115 #define wd3s_mwin               0x31
116 #define wd3s_auxc               0x33
117 #define AUXCR_HIDM              0x07
118 #define AUXCR_INTM              0x38
119 #define AUXCR_RRST              0x80
120
121 /* status port */
122 #define STR_INT                 0x80
123 #define STR_LCI                 0x40
124 #define STR_BSY                 0x20
125 #define STR_CIP                 0x10
126 #define STR_PE                  0x02
127 #define STR_DBR                 0x01
128 #define STR_BUSY                0xf0
129
130 /* cmd port */
131 #define CMDP_DMES               0x01
132 #define CMDP_DMER               0x02
133 #define CMDP_TCMS               0x04
134 #define CMDP_TCMR               0x08
135 #define CMDP_TCIR               0x10
136
137 /* wd33c93 chip cmds */
138 #define WD3S_SBT                0x80
139 #define WD3S_RESET              0x00
140 #define WD3S_ABORT              0x01
141 #define WD3S_ASSERT_ATN         0x02
142 #define WD3S_NEGATE_ACK         0x03
143 #define WD3S_DISCONNECT         0x04
144 #define WD3S_RESELECT           0x05
145 #define WD3S_SELECT_ATN         0x06
146 #define WD3S_SELECT_NO_ATN      0x07
147 #define WD3S_SELECT_ATN_TFR     0x08
148 #define WD3S_SELECT_NO_ATN_TFR  0x09
149 #define WD3S_RESELECT_RCV_DATA  0x0a
150 #define WD3S_RESELECT_SEND_DATA 0x0b
151 #define WD3S_WAIT_SELECT_RCV    0x0c
152 #define WD3S_CMD_COMPSEQ        0x0d
153 #define WD3S_SEND_DISC_MSG      0x0e
154 #define WD3S_SET_IDI            0x0f
155 #define WD3S_RCV_CMD            0x10
156 #define WD3S_RCV_DATA           0x11
157 #define WD3S_RCV_MSG_OUT        0x12
158 #define WD3S_RCV_UNSP_INFO_OUT  0x13
159 #define WD3S_SEND_STATUS        0x14
160 #define WD3S_SEND_DATA          0x15
161 #define WD3S_SEND_MSG_IN        0x16
162 #define WD3S_SEND_UNSP_INFO_IN  0x17
163 #define WD3S_TRANSLATE_ADDRESS  0x18
164 #define WD3S_TFR_INFO           0x20
165
166 #endif  /* !_WD33C93REG_H_ */