xref: /freebsd/sys/dev/usb/net/if_axgereg.h (revision a42c5d9fa7ed20e0aba8f42d67ce562ddcd1dd78)
1da089c14SMark Johnston /*-
2d32048bbSKevin Lo  * Copyright (c) 2013-2014 Kevin Lo
3da089c14SMark Johnston  * All rights reserved.
4da089c14SMark Johnston  *
5da089c14SMark Johnston  * Redistribution and use in source and binary forms, with or without
6da089c14SMark Johnston  * modification, are permitted provided that the following conditions
7da089c14SMark Johnston  * are met:
8da089c14SMark Johnston  * 1. Redistributions of source code must retain the above copyright
9da089c14SMark Johnston  *    notice, this list of conditions and the following disclaimer.
10da089c14SMark Johnston  * 2. Redistributions in binary form must reproduce the above copyright
11da089c14SMark Johnston  *    notice, this list of conditions and the following disclaimer in the
12da089c14SMark Johnston  *    documentation and/or other materials provided with the distribution.
13da089c14SMark Johnston  *
1477c66464SKevin Lo  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
15da089c14SMark Johnston  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
16da089c14SMark Johnston  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
175dc8bea6SKevin Lo  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
185dc8bea6SKevin Lo  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
195dc8bea6SKevin Lo  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
205dc8bea6SKevin Lo  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
215dc8bea6SKevin Lo  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
225dc8bea6SKevin Lo  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
235dc8bea6SKevin Lo  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
245dc8bea6SKevin Lo  * SUCH DAMAGE.
25da089c14SMark Johnston  *
26da089c14SMark Johnston  * $FreeBSD$
27da089c14SMark Johnston  */
28da089c14SMark Johnston 
29da089c14SMark Johnston #define	AXGE_ACCESS_MAC			0x01
30da089c14SMark Johnston #define	AXGE_ACCESS_PHY			0x02
31da089c14SMark Johnston #define	AXGE_ACCESS_WAKEUP		0x03
32da089c14SMark Johnston #define	AXGE_ACCESS_EEPROM		0x04
33da089c14SMark Johnston #define	AXGE_ACCESS_EFUSE		0x05
34da089c14SMark Johnston #define	AXGE_RELOAD_EEPROM_EFUSE	0x06
35da089c14SMark Johnston #define	AXGE_WRITE_EFUSE_EN		0x09
36da089c14SMark Johnston #define	AXGE_WRITE_EFUSE_DIS		0x0A
37da089c14SMark Johnston #define	AXGE_ACCESS_MFAB		0x10
38da089c14SMark Johnston 
39d32048bbSKevin Lo /* Physical link status register */
40d32048bbSKevin Lo #define	AXGE_PLSR			0x02
41d32048bbSKevin Lo #define	PLSR_USB_FS			0x01
42d32048bbSKevin Lo #define	PLSR_USB_HS			0x02
43d32048bbSKevin Lo #define	PLSR_USB_SS			0x04
44da089c14SMark Johnston 
45d32048bbSKevin Lo /* EEPROM address register */
46d32048bbSKevin Lo #define	AXGE_EAR			0x07
47da089c14SMark Johnston 
48d32048bbSKevin Lo /* EEPROM data low register */
49d32048bbSKevin Lo #define	AXGE_EDLR			0x08
50da089c14SMark Johnston 
51d32048bbSKevin Lo /* EEPROM data high register */
52d32048bbSKevin Lo #define	AXGE_EDHR			0x09
53da089c14SMark Johnston 
54d32048bbSKevin Lo /* EEPROM command register */
55d32048bbSKevin Lo #define	AXGE_ECR			0x0a
56da089c14SMark Johnston 
57d32048bbSKevin Lo /* Rx control register */
58d32048bbSKevin Lo #define	AXGE_RCR			0x0b
59d32048bbSKevin Lo #define	RCR_STOP			0x0000
60d32048bbSKevin Lo #define	RCR_PRO				0x0001
61d32048bbSKevin Lo #define	RCR_AMALL			0x0002
62d32048bbSKevin Lo #define	RCR_AB				0x0008
63d32048bbSKevin Lo #define	RCR_AM				0x0010
64d32048bbSKevin Lo #define	RCR_AP				0x0020
65d32048bbSKevin Lo #define	RCR_SO				0x0080
66d32048bbSKevin Lo #define	RCR_DROP_CRCE			0x0100
67d32048bbSKevin Lo #define	RCR_IPE				0x0200
68d32048bbSKevin Lo #define	RCR_TX_CRC_PAD			0x0400
69da089c14SMark Johnston 
70d32048bbSKevin Lo /* Node id register */
71d32048bbSKevin Lo #define	AXGE_NIDR			0x10
72da089c14SMark Johnston 
73d32048bbSKevin Lo /* Multicast filter array */
74d32048bbSKevin Lo #define	AXGE_MFA			0x16
75d32048bbSKevin Lo 
76d32048bbSKevin Lo /* Medium status register */
77d32048bbSKevin Lo #define	AXGE_MSR			0x22
78d32048bbSKevin Lo #define	MSR_GM				0x0001
79d32048bbSKevin Lo #define	MSR_FD				0x0002
80d32048bbSKevin Lo #define	MSR_EN_125MHZ			0x0008
81d32048bbSKevin Lo #define	MSR_RFC				0x0010
82d32048bbSKevin Lo #define	MSR_TFC				0x0020
83d32048bbSKevin Lo #define	MSR_RE				0x0100
84d32048bbSKevin Lo #define	MSR_PS				0x0200
85d32048bbSKevin Lo 
86d32048bbSKevin Lo /* Monitor mode status register */
87d32048bbSKevin Lo #define	AXGE_MMSR			0x24
88d32048bbSKevin Lo #define	MMSR_RWLC			0x02
89d32048bbSKevin Lo #define	MMSR_RWMP			0x04
90d32048bbSKevin Lo #define	MMSR_RWWF			0x08
91d32048bbSKevin Lo #define	MMSR_RW_FLAG			0x10
92d32048bbSKevin Lo #define	MMSR_PME_POL			0x20
93d32048bbSKevin Lo #define	MMSR_PME_TYPE			0x40
94d32048bbSKevin Lo #define	MMSR_PME_IND			0x80
95d32048bbSKevin Lo 
96d32048bbSKevin Lo /* GPIO control/status register */
97d32048bbSKevin Lo #define	AXGE_GPIOCR			0x25
98d32048bbSKevin Lo 
99d32048bbSKevin Lo /* Ethernet PHY power & reset control register */
100d32048bbSKevin Lo #define	AXGE_EPPRCR			0x26
101d32048bbSKevin Lo #define	EPPRCR_BZ			0x0010
102d32048bbSKevin Lo #define	EPPRCR_IPRL			0x0020
103d32048bbSKevin Lo #define	EPPRCR_AUTODETACH		0x1000
104da089c14SMark Johnston 
105da089c14SMark Johnston #define	AXGE_RX_BULKIN_QCTRL		0x2e
106da089c14SMark Johnston 
107da089c14SMark Johnston #define	AXGE_CLK_SELECT			0x33
108da089c14SMark Johnston #define	AXGE_CLK_SELECT_BCS		0x01
109da089c14SMark Johnston #define	AXGE_CLK_SELECT_ACS		0x02
110da089c14SMark Johnston #define	AXGE_CLK_SELECT_ACSREQ		0x10
111da089c14SMark Johnston #define	AXGE_CLK_SELECT_ULR		0x08
112da089c14SMark Johnston 
113d32048bbSKevin Lo /* COE Rx control register */
114d32048bbSKevin Lo #define	AXGE_CRCR			0x34
115d32048bbSKevin Lo #define	CRCR_IP				0x01
116d32048bbSKevin Lo #define	CRCR_TCP			0x02
117d32048bbSKevin Lo #define	CRCR_UDP			0x04
118d32048bbSKevin Lo #define	CRCR_ICMP			0x08
119d32048bbSKevin Lo #define	CRCR_IGMP			0x10
120d32048bbSKevin Lo #define	CRCR_TCPV6			0x20
121d32048bbSKevin Lo #define	CRCR_UDPV6			0x40
122d32048bbSKevin Lo #define	CRCR_ICMPV6			0x80
123da089c14SMark Johnston 
124d32048bbSKevin Lo /* COE Tx control register */
125d32048bbSKevin Lo #define	AXGE_CTCR			0x35
126d32048bbSKevin Lo #define	CTCR_IP				0x01
127d32048bbSKevin Lo #define	CTCR_TCP			0x02
128d32048bbSKevin Lo #define	CTCR_UDP			0x04
129d32048bbSKevin Lo #define	CTCR_ICMP			0x08
130d32048bbSKevin Lo #define	CTCR_IGMP			0x10
131d32048bbSKevin Lo #define	CTCR_TCPV6			0x20
132d32048bbSKevin Lo #define	CTCR_UDPV6			0x40
133d32048bbSKevin Lo #define	CTCR_ICMPV6			0x80
134da089c14SMark Johnston 
135d32048bbSKevin Lo /* Pause water level high register */
136d32048bbSKevin Lo #define	AXGE_PWLHR			0x54
137da089c14SMark Johnston 
138d32048bbSKevin Lo /* Pause water level low register */
139d32048bbSKevin Lo #define	AXGE_PWLLR			0x55
140da089c14SMark Johnston 
141da089c14SMark Johnston #define	AXGE_CONFIG_IDX			0	/* config number 1 */
142da089c14SMark Johnston #define	AXGE_IFACE_IDX			0
143da089c14SMark Johnston 
144da089c14SMark Johnston #define	AXGE_RXHDR_L4_TYPE_MASK		0x1c
145d32048bbSKevin Lo #define	AXGE_RXHDR_L4CSUM_ERR		1
146d32048bbSKevin Lo #define	AXGE_RXHDR_L3CSUM_ERR		2
147da089c14SMark Johnston #define	AXGE_RXHDR_L4_TYPE_UDP		4
148da089c14SMark Johnston #define	AXGE_RXHDR_L4_TYPE_TCP		16
149d32048bbSKevin Lo #define	AXGE_RXHDR_CRC_ERR		0x20000000
150d32048bbSKevin Lo #define	AXGE_RXHDR_DROP_ERR		0x80000000
151da089c14SMark Johnston 
152da089c14SMark Johnston #define	GET_MII(sc)		uether_getmii(&(sc)->sc_ue)
153da089c14SMark Johnston 
154da089c14SMark Johnston /* The interrupt endpoint is currently unused by the ASIX part. */
155da089c14SMark Johnston enum {
156da089c14SMark Johnston 	AXGE_BULK_DT_WR,
157da089c14SMark Johnston 	AXGE_BULK_DT_RD,
158da089c14SMark Johnston 	AXGE_N_TRANSFER,
159da089c14SMark Johnston };
160da089c14SMark Johnston 
161*a42c5d9fSPyun YongHyeon #define	AXGE_PHY_ADDR		3
162*a42c5d9fSPyun YongHyeon 
163da089c14SMark Johnston struct axge_softc {
164da089c14SMark Johnston 	struct usb_ether	sc_ue;
165da089c14SMark Johnston 	struct mtx		sc_mtx;
166da089c14SMark Johnston 	struct usb_xfer		*sc_xfer[AXGE_N_TRANSFER];
167da089c14SMark Johnston 
168da089c14SMark Johnston 	int			sc_flags;
169da089c14SMark Johnston #define	AXGE_FLAG_LINK		0x0001	/* got a link */
170da089c14SMark Johnston };
171da089c14SMark Johnston 
172da089c14SMark Johnston #define	AXGE_LOCK(_sc)			mtx_lock(&(_sc)->sc_mtx)
173da089c14SMark Johnston #define	AXGE_UNLOCK(_sc)		mtx_unlock(&(_sc)->sc_mtx)
174da089c14SMark Johnston #define	AXGE_LOCK_ASSERT(_sc, t)	mtx_assert(&(_sc)->sc_mtx, t)
175