tqphyreg.h revision 1.3 1 1.3 perry /* $NetBSD: tqphyreg.h,v 1.3 2005/02/27 00:27:32 perry Exp $ */
2 1.1 soren
3 1.1 soren /*
4 1.1 soren * Copyright (c) 1999 Soren S. Jorvang.
5 1.1 soren * All rights reserved.
6 1.1 soren *
7 1.1 soren * Redistribution and use in source and binary forms, with or without
8 1.1 soren * modification, are permitted provided that the following conditions
9 1.1 soren * are met:
10 1.1 soren * 1. Redistributions of source code must retain the above copyright
11 1.1 soren * notice, this list of conditions, and the following disclaimer.
12 1.1 soren * 2. Redistributions in binary form must reproduce the above copyright
13 1.1 soren * notice, this list of conditions and the following disclaimer in the
14 1.1 soren * documentation and/or other materials provided with the distribution.
15 1.1 soren *
16 1.1 soren * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
17 1.1 soren * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18 1.1 soren * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19 1.1 soren * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
20 1.1 soren * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21 1.1 soren * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
22 1.1 soren * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
23 1.1 soren * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
24 1.1 soren * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
25 1.1 soren * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26 1.1 soren * SUCH DAMAGE.
27 1.1 soren */
28 1.1 soren
29 1.1 soren #ifndef _DEV_MII_TQPHYREG_H_
30 1.1 soren #define _DEV_MII_TQPHYREG_H_
31 1.1 soren
32 1.1 soren /*
33 1.1 soren * TDK TSC78Q2120 PHY registers
34 1.1 soren *
35 1.1 soren * Documentation available at http://www.tsc.tdk.com/lan/78Q2120.pdf .
36 1.1 soren */
37 1.1 soren
38 1.1 soren /*
39 1.1 soren * http://cesdis.gsfc.nasa.gov/linux/misc/100mbps.html has this to say:
40 1.1 soren *
41 1.1 soren * TDK Semiconductor (formerly Silicon Systems) 78Q2120 (10/100) and 78Q2121
42 1.1 soren * (100Mbps only) MII transceivers. The first PHY available which worked at
43 1.1 soren * both 5.0 and 3.3V. Used on the 3Com 3c574 and Ositech products. The OUI
44 1.1 soren * is 00:c0:39, models 20 and 21. Warning: The older revision 3 part has
45 1.1 soren * several bugs. It always responds to MDIO address 0, and has clear-only
46 1.1 soren * semantics for the capability-advertise registers. The current (3/99)
47 1.3 perry * revision 11 part, shipping since 8/98, has reportedly fixed these problems.
48 1.1 soren */
49 1.1 soren
50 1.1 soren #define MII_TQPHY_VENDOR 0x10 /* Vendor specific register */
51 1.1 soren #define VENDOR_RPTR 0x8000 /* Repeater mode */
52 1.1 soren #define VENDOR_INTLEVEL 0x4000 /* INTR pin level */
53 1.1 soren #define VENDOR_RSVD1 0x2000 /* Reserved */
54 1.1 soren #define VENDOR_TXHIM 0x1000 /* Transmit high impedance */
55 1.1 soren #define VENDOR_SEQTESTINHIBIT 0x0800 /* Disables 10baseT SQE testing */
56 1.1 soren #define VENDOR_10BT_LOOPBACK 0x0400 /* 10baseT natural loopback */
57 1.1 soren #define VENDOR_GPIO1_DAT 0x0200 /* General purpose I/O 1 data */
58 1.1 soren #define VENDOR_GPIO1_DIR 0x0100 /* General purpose I/O 1 direction */
59 1.1 soren #define VENDOR_GPIO0_DAT 0x0080 /* General purpose I/O 0 data */
60 1.1 soren #define VENDOR_GPIO0_DIR 0x0040 /* General purpose I/O 0 direction */
61 1.1 soren #define VENDOR_APOL 0x0020 /* Auto polarity */
62 1.1 soren #define VENDOR_RVSPOL 0x0010 /* Reverse polarity */
63 1.1 soren #define VENDOR_RSVD2 0x0008 /* Reserved (must be zero) */
64 1.1 soren #define VENDOR_RSVD3 0x0004 /* Reserved (must be zero) */
65 1.1 soren #define VENDOR_PCSBP 0x0002 /* PCS bypass */
66 1.1 soren #define VENDOR_RXCC 0x0001 /* Receive clock control */
67 1.1 soren
68 1.1 soren #define MII_TQPHY_INTR 0x11 /* Interrupt control/status register */
69 1.1 soren #define INTR_JABBER_IE 0x8000 /* Jabber interrupt enable */
70 1.1 soren #define INTR_RXER_IE 0x4000 /* Receive error enable */
71 1.1 soren #define INTR_PRX_IE 0x2000 /* Page received enable */
72 1.1 soren #define INTR_PFD_IE 0x1000 /* Parallel detect fault enable */
73 1.1 soren #define INTR_LPACK_IE 0x0800 /* Link partner ack. enable */
74 1.1 soren #define INTR_LSCHG_IE 0x0400 /* Link status change enable */
75 1.1 soren #define INTR_RFAULT_IE 0x0200 /* Remote fault enable */
76 1.1 soren #define INTR_ANEGCOMP_IE 0x0100 /* Autonegotiation complete enable */
77 1.1 soren #define INTR_JABBER_INT 0x0080 /* Jabber interrupt */
78 1.1 soren #define INTR_RXER_INT 0x0040 /* Receive error interrupt */
79 1.1 soren #define INTR_PRX_INT 0x0020 /* Page receive interrupt */
80 1.1 soren #define INTR_PDF_INT 0x0010 /* Parallel detect fault interrupt */
81 1.1 soren #define INTR_LPACK_INT 0x0008 /* Link partner ack. interrupt */
82 1.1 soren #define INTR_LSCHG_INT 0x0004 /* Link status change interrupt */
83 1.1 soren #define INTR_RFAULT_INT 0x0002 /* Remote fault interrupt */
84 1.1 soren #define INTR_ANEGCOMP_INT 0x0001 /* Autonegotiation complete interrupt */
85 1.1 soren
86 1.1 soren #define MII_TQPHY_DIAG 0x12 /* Diagnostic register */
87 1.1 soren #define DIAG_ANEGF 0x1000 /* Autonegotiation fail */
88 1.1 soren #define DIAG_DPLX 0x0800 /* Duplex (half/full) */
89 1.1 soren #define DIAG_RATE 0x0400 /* Rate (10/100) */
90 1.1 soren #define DIAG_RXPASS 0x0200 /* Receive pass */
91 1.1 soren #define DIAG_RXLOCK 0x0100 /* Receive lock */
92 1.1 soren
93 1.1 soren #endif /* _DEV_MII_TQPHYREG_H_ */
94