summaryrefslogtreecommitdiff
path: root/usr/src/uts/common/io/ural/ural_reg.h
blob: 680e8b334fa8400b632be5977c12f3174ab2cdb4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
/*
 * Copyright 2008 Sun Microsystems, Inc.  All rights reserved.
 * Use is subject to license terms.
 */

/*
 * Copyright (c) 2005, 2006
 *	Damien Bergamini <damien.bergamini@free.fr>
 *
 * Permission to use, copy, modify, and distribute this software for any
 * purpose with or without fee is hereby granted, provided that the above
 * copyright notice and this permission notice appear in all copies.
 *
 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
 */
#ifndef _URAL_REG_H
#define	_URAL_REG_H

#pragma ident	"%Z%%M%	%I%	%E% SMI"

#ifdef __cplusplus
extern "C" {
#endif

#define	RAL_RX_DESC_SIZE	(sizeof (struct ural_rx_desc))
#define	RAL_TX_DESC_SIZE	(sizeof (struct ural_tx_desc))

#define	RAL_CONFIG_NO		1
#define	RAL_IFACE_INDEX		0

#define	RAL_VENDOR_REQUEST	0x01
#define	RAL_WRITE_MAC		0x02
#define	RAL_READ_MAC		0x03
#define	RAL_WRITE_MULTI_MAC	0x06
#define	RAL_READ_MULTI_MAC	0x07
#define	RAL_READ_EEPROM		0x09

/*
 * MAC registers.
 */
#define	RAL_MAC_CSR0	0x0400	/* ASIC Version */
#define	RAL_MAC_CSR1	0x0402	/* System control */
#define	RAL_MAC_CSR2	0x0404	/* MAC addr0 */
#define	RAL_MAC_CSR3	0x0406	/* MAC addr1 */
#define	RAL_MAC_CSR4	0x0408	/* MAC addr2 */
#define	RAL_MAC_CSR5	0x040a	/* BSSID0 */
#define	RAL_MAC_CSR6	0x040c	/* BSSID1 */
#define	RAL_MAC_CSR7	0x040e	/* BSSID2 */
#define	RAL_MAC_CSR8	0x0410	/* Max frame length */
#define	RAL_MAC_CSR9	0x0412	/* Timer control */
#define	RAL_MAC_CSR10	0x0414	/* Slot time */
#define	RAL_MAC_CSR11	0x0416	/* IFS */
#define	RAL_MAC_CSR12	0x0418	/* EIFS */
#define	RAL_MAC_CSR13	0x041a	/* Power mode0 */
#define	RAL_MAC_CSR14	0x041c	/* Power mode1 */
#define	RAL_MAC_CSR15	0x041e	/* Power saving transition0 */
#define	RAL_MAC_CSR16	0x0420	/* Power saving transition1 */
#define	RAL_MAC_CSR17	0x0422	/* Power state control */
#define	RAL_MAC_CSR18	0x0424	/* Auto wake-up control */
#define	RAL_MAC_CSR19	0x0426	/* GPIO control */
#define	RAL_MAC_CSR20	0x0428	/* LED control0 */
#define	RAL_MAC_CSR22	0x042c	/* Not documented */

/*
 * Tx/Rx Registers.
 */
#define	RAL_TXRX_CSR0	0x0440	/* Security control */
#define	RAL_TXRX_CSR2	0x0444	/* Rx control */
#define	RAL_TXRX_CSR5	0x044a	/* CCK Tx BBP ID0 */
#define	RAL_TXRX_CSR6	0x044c	/* CCK Tx BBP ID1 */
#define	RAL_TXRX_CSR7	0x044e	/* OFDM Tx BBP ID0 */
#define	RAL_TXRX_CSR8	0x0450	/* OFDM Tx BBP ID1 */
#define	RAL_TXRX_CSR10	0x0454	/* Auto responder control */
#define	RAL_TXRX_CSR11	0x0456	/* Auto responder basic rate */
#define	RAL_TXRX_CSR18	0x0464	/* Beacon interval */
#define	RAL_TXRX_CSR19	0x0466	/* Beacon/sync control */
#define	RAL_TXRX_CSR20	0x0468	/* Beacon alignment */
#define	RAL_TXRX_CSR21	0x046a	/* Not documented */

/*
 * Security registers.
 */
#define	RAL_SEC_CSR0	0x0480	/* Shared key 0, word 0 */

/*
 * PHY registers.
 */
#define	RAL_PHY_CSR2	0x04c4	/* Tx MAC configuration */
#define	RAL_PHY_CSR4	0x04c8	/* Interface configuration */
#define	RAL_PHY_CSR5	0x04ca	/* BBP Pre-Tx CCK */
#define	RAL_PHY_CSR6	0x04cc	/* BBP Pre-Tx OFDM */
#define	RAL_PHY_CSR7	0x04ce	/* BBP serial control */
#define	RAL_PHY_CSR8	0x04d0	/* BBP serial status */
#define	RAL_PHY_CSR9	0x04d2	/* RF serial control0 */
#define	RAL_PHY_CSR10	0x04d4	/* RF serial control1 */

/*
 * Statistics registers.
 */
#define	RAL_STA_CSR0	0x04e0	/* FCS error */


#define	RAL_DISABLE_RX		(1 << 0)
#define	RAL_DROP_CRC		(1 << 1)
#define	RAL_DROP_PHY		(1 << 2)
#define	RAL_DROP_CTL		(1 << 3)
#define	RAL_DROP_NOT_TO_ME	(1 << 4)
#define	RAL_DROP_TODS		(1 << 5)
#define	RAL_DROP_BAD_VERSION	(1 << 6)
#define	RAL_DROP_MULTICAST	(1 << 9)
#define	RAL_DROP_BROADCAST	(1 << 10)

#define	RAL_SHORT_PREAMBLE	(1 << 2)

#define	RAL_RESET_ASIC	(1 << 0)
#define	RAL_RESET_BBP	(1 << 1)
#define	RAL_HOST_READY	(1 << 2)

#define	RAL_ENABLE_TSF			(1 << 0)
#define	RAL_ENABLE_TSF_SYNC(x)		(((x) & 0x3) << 1)
#define	RAL_ENABLE_TBCN			(1 << 3)
#define	RAL_ENABLE_BEACON_GENERATOR	(1 << 4)

#define	RAL_RF_AWAKE	(3 << 7)
#define	RAL_BBP_AWAKE	(3 << 5)

#define	RAL_BBP_WRITE	(1 << 15)
#define	RAL_BBP_BUSY	(1 << 0)

#define	RAL_RF1_AUTOTUNE	0x08000
#define	RAL_RF3_AUTOTUNE	0x00040

#define	RAL_RF_2522	0x00
#define	RAL_RF_2523	0x01
#define	RAL_RF_2524	0x02
#define	RAL_RF_2525	0x03
#define	RAL_RF_2525E	0x04
#define	RAL_RF_2526	0x05
/* dual-band RF */
#define	RAL_RF_5222	0x10

#define	RAL_BBP_VERSION	0
#define	RAL_BBP_TX	2
#define	RAL_BBP_RX	14

#define	RAL_BBP_ANTA		0x00
#define	RAL_BBP_DIVERSITY	0x01
#define	RAL_BBP_ANTB		0x02
#define	RAL_BBP_ANTMASK		0x03
#define	RAL_BBP_FLIPIQ		0x04

#define	RAL_JAPAN_FILTER	0x08

#pragma pack(1)
struct ural_tx_desc {
	uint32_t	flags;
#define	RAL_TX_RETRY(x)		((x) << 4)
#define	RAL_TX_MORE_FRAG	(1 << 8)
#define	RAL_TX_ACK		(1 << 9)
#define	RAL_TX_TIMESTAMP	(1 << 10)
#define	RAL_TX_OFDM		(1 << 11)
#define	RAL_TX_NEWSEQ		(1 << 12)

#define	RAL_TX_IFS_MASK		0x00006000
#define	RAL_TX_IFS_BACKOFF	(0 << 13)
#define	RAL_TX_IFS_SIFS		(1 << 13)
#define	RAL_TX_IFS_NEWBACKOFF	(2 << 13)
#define	RAL_TX_IFS_NONE		(3 << 13)

	uint16_t	wme;
#define	RAL_LOGCWMAX(x)		(((x) & 0xf) << 12)
#define	RAL_LOGCWMIN(x)		(((x) & 0xf) << 8)
#define	RAL_AIFSN(x)		(((x) & 0x3) << 6)
#define	RAL_IVOFFSET(x)		(((x) & 0x3f))

	uint16_t	reserved1;
	uint8_t		plcp_signal;
	uint8_t		plcp_service;
#define	RAL_PLCP_LENGEXT	0x80

	uint8_t		plcp_length_lo;
	uint8_t		plcp_length_hi;
	uint32_t	iv;
	uint32_t	eiv;
};
#pragma pack()

#pragma pack(1)
struct ural_rx_desc {
	uint32_t	flags;
#define	RAL_RX_CRC_ERROR	(1 << 5)
#define	RAL_RX_OFDM		(1 << 6)
#define	RAL_RX_PHY_ERROR	(1 << 7)

	uint8_t		rssi;
	uint8_t		rate;
	uint16_t	reserved;

	uint32_t	iv;
	uint32_t	eiv;
};
#pragma pack()

#define	RAL_RF_LOBUSY	(1 << 15)
#define	RAL_RF_BUSY	((uint32_t)1 << 31)
#define	RAL_RF_20BIT	(20 << 24)

#define	RAL_RF1	0
#define	RAL_RF2	2
#define	RAL_RF3	1
#define	RAL_RF4	3

#define	RAL_EEPROM_ADDRESS	0x0004
#define	RAL_EEPROM_TXPOWER	0x003c
#define	RAL_EEPROM_CONFIG0	0x0016
#define	RAL_EEPROM_BBP_BASE	0x001c

#ifdef __cplusplus
}
#endif

#endif /* _URAL_REG_H */