]> CyberLeo.Net >> Repos - FreeBSD/releng/9.2.git/blob - sys/dev/mii/qsphyreg.h
- Copy stable/9 to releng/9.2 as part of the 9.2-RELEASE cycle.
[FreeBSD/releng/9.2.git] / sys / dev / mii / qsphyreg.h
1 /*      OpenBSD: qsphyreg.h,v 1.2 1999/03/09 00:02:45 jason Exp         */
2 /*      NetBSD: qsphyreg.h,v 1.1 1998/08/11 00:01:03 thorpej Exp        */
3 /*      $FreeBSD$       */
4
5 /*-
6  * Copyright (c) 1998 The NetBSD Foundation, Inc.
7  * All rights reserved.
8  *
9  * This code is derived from software contributed to The NetBSD Foundation
10  * by Jason R. Thorpe of the Numerical Aerospace Simulation Facility,
11  * NASA Ames Research Center.
12  *
13  * Redistribution and use in source and binary forms, with or without
14  * modification, are permitted provided that the following conditions
15  * are met:
16  * 1. Redistributions of source code must retain the above copyright
17  *    notice, this list of conditions and the following disclaimer.
18  * 2. Redistributions in binary form must reproduce the above copyright
19  *    notice, this list of conditions and the following disclaimer in the
20  *    documentation and/or other materials provided with the distribution.
21  *
22  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
23  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
24  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
25  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
26  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
27  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
28  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
29  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
30  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
31  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
32  * POSSIBILITY OF SUCH DAMAGE.
33  */
34
35 #ifndef _DEV_MII_QSPHYREG_H_
36 #define _DEV_MII_QSPHYREG_H_
37
38 /*
39  * Register definitions for the Quality Semiconductor QS6612
40  * Further documentation can be found at:
41  *      http://www.qualitysemi.com/products/network.html
42  */
43
44 #define MII_QSPHY_MCTL          0x11    /* Mode control */
45 #define MCTL_T4PRE              0x1000  /* 100baseT4 interface present */
46 #define MCTL_BTEXT              0x0800  /* reduce 10baseT squelch level */
47 #define MCTL_FACTTEST           0x0100  /* factory test mode */
48 #define MCTL_PHYADDRMASK        0x00f8  /* PHY address */
49 #define MCTL_FACTTEST2          0x0004  /* another factory test mode */
50 #define MCTL_NLPDIS             0x0002  /* disable link pulse tx */
51 #define MCTL_SQEDIS             0x0001  /* disable SQE */
52
53 #define MII_QSPHY_ISRC          0x1d    /* Interrupt source */
54 #define MII_QSPHY_IMASK         0x1e    /* Interrupt mask */
55 #define IMASK_TLINTR            0x8000  /* ThunderLAN interrupt mode */
56 #define IMASK_ANCPL             0x0040  /* autonegotiation complete */
57 #define IMASK_RFD               0x0020  /* remote fault detected */
58 #define IMASK_LD                0x0010  /* link down */
59 #define IMASK_ANLPA             0x0008  /* autonegotiation LP ACK */
60 #define IMASK_PDT               0x0004  /* parallel detection fault */
61 #define IMASK_ANPR              0x0002  /* autonegotiation page received */
62 #define IMASK_REF               0x0001  /* receive error counter full */
63
64 #define MII_QSPHY_PCTL          0x1f    /* PHY control */
65 #define PCTL_RXERDIS            0x2000  /* receive error counter disable */
66 #define PCTL_ANC                0x1000  /* autonegotiation complete */
67 #define PCTL_RLBEN              0x0200  /* remote coopback enable */
68 #define PCTL_DCREN              0x0100  /* DC restoration enable */
69 #define PCTL_4B5BEN             0x0040  /* 4b/5b encoding */
70 #define PCTL_PHYISO             0x0020  /* isolate PHY */
71 #define PCTL_OPMASK             0x001c  /* operation mode mask */
72 #define PCTL_AN                 0x0000  /* autonegotiation in-progress */
73 #define PCTL_10_T               0x0004  /* 10baseT */
74 #define PCTL_100_TX             0x0008  /* 100baseTX */
75 #define PCTL_100_T4             0x0010  /* 100baseT4 */
76 #define PCTL_10_T_FDX           0x0014  /* 10baseT-FDX */
77 #define PCTL_100_TX_FDX         0x0018  /* 100baseTX-FDX */
78 #define PCTL_MLT3DIS            0x0002  /* disable MLT3 */
79 #define PCTL_SRCDIS             0x0001  /* disable scrambling */
80
81 #endif /* _DEV_MII_QSPHYREG_H_ */