xref: /openbsd/sys/dev/usb/if_axereg.h (revision 34eef271)
1*34eef271Smbalmer /*	$OpenBSD: if_axereg.h,v 1.18 2007/06/10 10:15:35 mbalmer Exp $	*/
248f0b646Sjsg 
3f63446eaSderaadt /*
4f63446eaSderaadt  * Copyright (c) 1997, 1998, 1999, 2000-2003
5f63446eaSderaadt  *	Bill Paul <wpaul@windriver.com>.  All rights reserved.
6f63446eaSderaadt  *
7f63446eaSderaadt  * Redistribution and use in source and binary forms, with or without
8f63446eaSderaadt  * modification, are permitted provided that the following conditions
9f63446eaSderaadt  * are met:
10f63446eaSderaadt  * 1. Redistributions of source code must retain the above copyright
11f63446eaSderaadt  *    notice, this list of conditions and the following disclaimer.
12f63446eaSderaadt  * 2. Redistributions in binary form must reproduce the above copyright
13f63446eaSderaadt  *    notice, this list of conditions and the following disclaimer in the
14f63446eaSderaadt  *    documentation and/or other materials provided with the distribution.
15f63446eaSderaadt  * 3. All advertising materials mentioning features or use of this software
16f63446eaSderaadt  *    must display the following acknowledgement:
17f63446eaSderaadt  *	This product includes software developed by Bill Paul.
18f63446eaSderaadt  * 4. Neither the name of the author nor the names of any co-contributors
19f63446eaSderaadt  *    may be used to endorse or promote products derived from this software
20f63446eaSderaadt  *    without specific prior written permission.
21f63446eaSderaadt  *
22f63446eaSderaadt  * THIS SOFTWARE IS PROVIDED BY Bill Paul AND CONTRIBUTORS ``AS IS'' AND
23f63446eaSderaadt  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
24f63446eaSderaadt  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
25f63446eaSderaadt  * ARE DISCLAIMED.  IN NO EVENT SHALL Bill Paul OR THE VOICES IN HIS HEAD
26f63446eaSderaadt  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
27f63446eaSderaadt  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
28f63446eaSderaadt  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
29f63446eaSderaadt  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
30f63446eaSderaadt  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
31f63446eaSderaadt  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
32f63446eaSderaadt  * THE POSSIBILITY OF SUCH DAMAGE.
33f63446eaSderaadt  *
34f63446eaSderaadt  * $FreeBSD: src/sys/dev/usb/if_axereg.h,v 1.2 2003/06/15 21:45:43 wpaul Exp $
35f63446eaSderaadt  */
36f63446eaSderaadt 
37f63446eaSderaadt /*
38f63446eaSderaadt  * Definitions for the ASIX Electronics AX88172 to ethernet controller.
39f63446eaSderaadt  */
40f63446eaSderaadt 
41f63446eaSderaadt 
42f63446eaSderaadt /*
43f63446eaSderaadt  * Vendor specific commands
44f63446eaSderaadt  * ASIX conveniently doesn't document the 'set NODEID' command in their
45f63446eaSderaadt  * datasheet (thanks a lot guys).
46f63446eaSderaadt  * To make handling these commands easier, I added some extra data
47f63446eaSderaadt  * which is decided by the axe_cmd() routine. Commands are encoded
48f63446eaSderaadt  * in 16 bites, with the format: LDCC. L and D are both nibbles in
49f63446eaSderaadt  * the high byte. L represents the data length (0 to 15) and D
50f63446eaSderaadt  * represents the direction (0 for vendor read, 1 for vendor write).
51f63446eaSderaadt  * CC is the command byte, as specified in the manual.
52f63446eaSderaadt  */
53f63446eaSderaadt 
54f63446eaSderaadt #define AXE_CMD_LEN(x)	(((x) & 0xF000) >> 12)
555054db1dSpascoe #define AXE_CMD_DIR(x)	(((x) & 0x0F00) >> 8)
56f63446eaSderaadt #define AXE_CMD_CMD(x)	 ((x) & 0x00FF)
57f63446eaSderaadt 
5858ed394fSjsg #define AXE_172_CMD_READ_RXTX_SRAM		0x2002
5958ed394fSjsg #define AXE_182_CMD_READ_RXTX_SRAM		0x8002
6058ed394fSjsg #define AXE_172_CMD_WRITE_RX_SRAM		0x0103
6158ed394fSjsg #define AXE_172_CMD_WRITE_TX_SRAM		0x0104
6258ed394fSjsg #define AXE_182_CMD_WRITE_RXTX_SRAM		0x8103
63f63446eaSderaadt #define AXE_CMD_MII_OPMODE_SW			0x0106
64f63446eaSderaadt #define AXE_CMD_MII_READ_REG			0x2007
65f63446eaSderaadt #define AXE_CMD_MII_WRITE_REG			0x2108
66f63446eaSderaadt #define AXE_CMD_MII_READ_OPMODE			0x1009
67f63446eaSderaadt #define AXE_CMD_MII_OPMODE_HW			0x010A
68f63446eaSderaadt #define AXE_CMD_SROM_READ			0x200B
69f63446eaSderaadt #define AXE_CMD_SROM_WRITE			0x010C
70f63446eaSderaadt #define AXE_CMD_SROM_WR_ENABLE			0x010D
71f63446eaSderaadt #define AXE_CMD_SROM_WR_DISABLE			0x010E
72f63446eaSderaadt #define AXE_CMD_RXCTL_READ			0x200F
73f63446eaSderaadt #define AXE_CMD_RXCTL_WRITE			0x0110
74f63446eaSderaadt #define AXE_CMD_READ_IPG012			0x3011
7558ed394fSjsg #define AXE_172_CMD_WRITE_IPG0			0x0112
7658ed394fSjsg #define AXE_172_CMD_WRITE_IPG1			0x0113
7758ed394fSjsg #define AXE_172_CMD_WRITE_IPG2			0x0114
7858ed394fSjsg #define AXE_178_CMD_WRITE_IPG012		0x0112
79f63446eaSderaadt #define AXE_CMD_READ_MCAST			0x8015
80f63446eaSderaadt #define AXE_CMD_WRITE_MCAST			0x8116
8158ed394fSjsg #define AXE_172_CMD_READ_NODEID			0x6017
8258ed394fSjsg #define AXE_172_CMD_WRITE_NODEID		0x6118
8358ed394fSjsg #define AXE_178_CMD_READ_NODEID			0x6013
842c184f77Sjsg #define AXE_178_CMD_WRITE_NODEID		0x6114
85f63446eaSderaadt #define AXE_CMD_READ_PHYID			0x2019
8658ed394fSjsg #define AXE_172_CMD_READ_MEDIA			0x101A
8758ed394fSjsg #define AXE_178_CMD_READ_MEDIA			0x201A
88f63446eaSderaadt #define AXE_CMD_WRITE_MEDIA			0x011B
89f63446eaSderaadt #define AXE_CMD_READ_MONITOR_MODE		0x101C
90f63446eaSderaadt #define AXE_CMD_WRITE_MONITOR_MODE		0x011D
91f63446eaSderaadt #define AXE_CMD_READ_GPIO			0x101E
92f63446eaSderaadt #define AXE_CMD_WRITE_GPIO			0x011F
9358ed394fSjsg #define AXE_CMD_SW_RESET_REG			0x0120
9458ed394fSjsg #define AXE_CMD_SW_PHY_STATUS			0x0021
9558ed394fSjsg #define AXE_CMD_SW_PHY_SELECT			0x0122
96f63446eaSderaadt 
97838fd592Sjsg #define AXE_SW_RESET_CLEAR			0x00
98838fd592Sjsg #define AXE_SW_RESET_RR				0x01
99838fd592Sjsg #define AXE_SW_RESET_RT				0x02
100838fd592Sjsg #define AXE_SW_RESET_PRTE			0x04
101838fd592Sjsg #define AXE_SW_RESET_PRL			0x08
102838fd592Sjsg #define AXE_SW_RESET_BZ				0x10
103838fd592Sjsg #define AXE_SW_RESET_IPRL			0x20
104838fd592Sjsg #define AXE_SW_RESET_IPPD			0x40
105838fd592Sjsg 
10658ed394fSjsg /* AX88178 documentation says to always write this bit... */
10758ed394fSjsg #define AXE_178_RESET_MAGIC			0x40
10858ed394fSjsg 
10958ed394fSjsg #define AXE_178_MEDIA_GMII			0x0001
11058ed394fSjsg #define AXE_MEDIA_FULL_DUPLEX			0x0002
11158ed394fSjsg #define AXE_172_MEDIA_TX_ABORT_ALLOW		0x0004
11258ed394fSjsg /* AX88178 documentation says to always write 1 to reserved bit... */
11358ed394fSjsg #define AXE_178_MEDIA_MAGIC			0x0004
11458ed394fSjsg #define AXE_178_MEDIA_ENCK			0x0008
11558ed394fSjsg #define AXE_172_MEDIA_FLOW_CONTROL_EN		0x0010
11658ed394fSjsg #define AXE_178_MEDIA_RXFLOW_CONTROL_EN		0x0010
11758ed394fSjsg #define AXE_178_MEDIA_TXFLOW_CONTROL_EN		0x0020
11858ed394fSjsg #define AXE_178_MEDIA_JUMBO_EN			0x0040
11958ed394fSjsg #define AXE_178_MEDIA_LTPF_ONLY			0x0080
12058ed394fSjsg #define AXE_178_MEDIA_RX_EN			0x0100
121ef8190e3Sjsg #define AXE_178_MEDIA_100TX			0x0200
12258ed394fSjsg #define AXE_178_MEDIA_SBP			0x0800
12358ed394fSjsg #define AXE_178_MEDIA_SUPERMAC			0x1000
124810313afSdlg 
125f63446eaSderaadt #define AXE_RXCMD_PROMISC			0x0001
126f63446eaSderaadt #define AXE_RXCMD_ALLMULTI			0x0002
12758ed394fSjsg #define AXE_172_RXCMD_UNICAST			0x0004
12858ed394fSjsg #define AXE_178_RXCMD_KEEP_INVALID_CRC		0x0004
129f63446eaSderaadt #define AXE_RXCMD_BROADCAST			0x0008
130f63446eaSderaadt #define AXE_RXCMD_MULTICAST			0x0010
131f63446eaSderaadt #define AXE_RXCMD_ENABLE			0x0080
132bca247aaSjsg #define AXE_178_RXCMD_MFB			0x0300
133f63446eaSderaadt 
134f63446eaSderaadt #define AXE_NOPHY				0xE0
135838fd592Sjsg #define AXE_INTPHY				0x10
136f63446eaSderaadt 
137f63446eaSderaadt #define AXE_TIMEOUT		1000
138e500abf8Sjsg #define AXE_172_BUFSZ		1536
139e500abf8Sjsg #define AXE_178_MIN_BUFSZ	2048
140e500abf8Sjsg #define AXE_178_MAX_BUFSZ	16384
141f63446eaSderaadt 
142f63446eaSderaadt #define AXE_RX_LIST_CNT		1
143f63446eaSderaadt #define AXE_TX_LIST_CNT		1
144f63446eaSderaadt 
145f63446eaSderaadt #define AXE_CTL_READ		0x01
146f63446eaSderaadt #define AXE_CTL_WRITE		0x02
147f63446eaSderaadt 
148f63446eaSderaadt #define AXE_CONFIG_NO		1
149f63446eaSderaadt #define AXE_IFACE_IDX		0
150f63446eaSderaadt 
151f63446eaSderaadt /*
152f63446eaSderaadt  * The interrupt endpoint is currently unused
153f63446eaSderaadt  * by the ASIX part.
154f63446eaSderaadt  */
155f63446eaSderaadt #define AXE_ENDPT_RX		0x0
156f63446eaSderaadt #define AXE_ENDPT_TX		0x1
157f63446eaSderaadt #define AXE_ENDPT_INTR		0x2
158f63446eaSderaadt #define AXE_ENDPT_MAX		0x3
159f63446eaSderaadt 
160f63446eaSderaadt struct axe_type {
161f63446eaSderaadt 	struct usb_devno	axe_dev;
162f63446eaSderaadt 	u_int16_t		axe_flags;
16358ed394fSjsg #define AX178	0x0001		/* AX88178 */
1649b39d331Sjsg #define AX772	0x0002		/* AX88772 */
165f63446eaSderaadt };
166f63446eaSderaadt 
167f63446eaSderaadt struct axe_softc;
168f63446eaSderaadt 
169f63446eaSderaadt struct axe_chain {
170f63446eaSderaadt 	struct axe_softc	*axe_sc;
171f63446eaSderaadt 	usbd_xfer_handle	axe_xfer;
172f63446eaSderaadt 	char			*axe_buf;
173f63446eaSderaadt 	struct mbuf		*axe_mbuf;
174f63446eaSderaadt 	int			axe_accum;
175f63446eaSderaadt 	int			axe_idx;
176f63446eaSderaadt };
177f63446eaSderaadt 
178f63446eaSderaadt struct axe_cdata {
179f63446eaSderaadt 	struct axe_chain	axe_tx_chain[AXE_TX_LIST_CNT];
180f63446eaSderaadt 	struct axe_chain	axe_rx_chain[AXE_RX_LIST_CNT];
181f63446eaSderaadt 	int			axe_tx_prod;
182f63446eaSderaadt 	int			axe_tx_cons;
183f63446eaSderaadt 	int			axe_tx_cnt;
184f63446eaSderaadt 	int			axe_rx_prod;
185f63446eaSderaadt };
186f63446eaSderaadt 
18721ca1aebSjsg struct axe_sframe_hdr {
18821ca1aebSjsg 	u_int16_t		len;
18921ca1aebSjsg 	u_int16_t		ilen;
19021ca1aebSjsg } __packed;
19121ca1aebSjsg 
192f63446eaSderaadt struct axe_softc {
1938c5d01eeSmk 	struct device		axe_dev;
194f63446eaSderaadt #define GET_MII(sc) (&(sc)->axe_mii)
195f63446eaSderaadt 	struct arpcom		arpcom;
196f63446eaSderaadt #define GET_IFP(sc) (&(sc)->arpcom.ac_if)
197f63446eaSderaadt 	struct mii_data		axe_mii;
198f63446eaSderaadt 	usbd_device_handle	axe_udev;
199f63446eaSderaadt 	usbd_interface_handle	axe_iface;
200f63446eaSderaadt 
201f63446eaSderaadt 	u_int16_t		axe_vendor;
202f63446eaSderaadt 	u_int16_t		axe_product;
203f63446eaSderaadt 
20458ed394fSjsg 	u_int16_t		axe_flags;
20558ed394fSjsg 
206f63446eaSderaadt 	int			axe_ed[AXE_ENDPT_MAX];
207f63446eaSderaadt 	usbd_pipe_handle	axe_ep[AXE_ENDPT_MAX];
208f63446eaSderaadt 	int			axe_unit;
209f63446eaSderaadt 	int			axe_if_flags;
210f63446eaSderaadt 	struct axe_cdata	axe_cdata;
211*34eef271Smbalmer 	struct timeout		axe_stat_ch;
212f63446eaSderaadt 
213f63446eaSderaadt 	int			axe_refcnt;
214f63446eaSderaadt 	char			axe_dying;
215f63446eaSderaadt 	char			axe_attached;
216f63446eaSderaadt 
217f63446eaSderaadt 	struct usb_task		axe_tick_task;
218f63446eaSderaadt 	struct usb_task		axe_stop_task;
219f63446eaSderaadt 
2201af31be2Sjsg 	struct rwlock		axe_mii_lock;
221f63446eaSderaadt 
222f63446eaSderaadt 	int			axe_link;
223f63446eaSderaadt 	unsigned char		axe_ipgs[3];
224f63446eaSderaadt 	unsigned char 		axe_phyaddrs[2];
225f63446eaSderaadt 	struct timeval		axe_rx_notice;
226e500abf8Sjsg 	u_int			axe_bufsz;
227f63446eaSderaadt };
228