if_gmreg.h revision 1.1 1 1.1 tsubai /* $NetBSD: if_gmreg.h,v 1.1 2000/02/27 18:00:55 tsubai Exp $ */
2 1.1 tsubai
3 1.1 tsubai /*-
4 1.1 tsubai * Copyright (c) 2000 Tsubai Masanari. All rights reserved.
5 1.1 tsubai *
6 1.1 tsubai * Redistribution and use in source and binary forms, with or without
7 1.1 tsubai * modification, are permitted provided that the following conditions
8 1.1 tsubai * are met:
9 1.1 tsubai * 1. Redistributions of source code must retain the above copyright
10 1.1 tsubai * notice, this list of conditions and the following disclaimer.
11 1.1 tsubai * 2. Redistributions in binary form must reproduce the above copyright
12 1.1 tsubai * notice, this list of conditions and the following disclaimer in the
13 1.1 tsubai * documentation and/or other materials provided with the distribution.
14 1.1 tsubai * 3. The name of the author may not be used to endorse or promote products
15 1.1 tsubai * derived from this software without specific prior written permission.
16 1.1 tsubai *
17 1.1 tsubai * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18 1.1 tsubai * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19 1.1 tsubai * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20 1.1 tsubai * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21 1.1 tsubai * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22 1.1 tsubai * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 1.1 tsubai * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 1.1 tsubai * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 1.1 tsubai * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
26 1.1 tsubai * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 1.1 tsubai */
28 1.1 tsubai
29 1.1 tsubai struct gmac_dma {
30 1.1 tsubai u_int32_t cmd;
31 1.1 tsubai u_int32_t cmd_hi;
32 1.1 tsubai u_int32_t address;
33 1.1 tsubai u_int32_t address_hi;
34 1.1 tsubai };
35 1.1 tsubai
36 1.1 tsubai #define GMAC_OWN 0x80000000
37 1.1 tsubai #define GMAC_SOP 0x40000000 /* start of packet? */
38 1.1 tsubai #define GMAC_LEN_MASK 0x00003fff
39 1.1 tsubai
40 1.1 tsubai #define GMAC_INT_TXDONE 0x04
41 1.1 tsubai #define GMAC_INT_RXDONE 0x10
42 1.1 tsubai
43 1.1 tsubai #define GMAC_RXMAC_PR 0x08
44 1.1 tsubai
45 1.1 tsubai /*
46 1.1 tsubai * register offset
47 1.1 tsubai */
48 1.1 tsubai #define GMAC_STATUS 0x000c
49 1.1 tsubai #define GMAC_INTMASK 0x0010
50 1.1 tsubai #define GMAC_SOFTWARERESET 0x1010
51 1.1 tsubai
52 1.1 tsubai #define GMAC_TXDMAKICK 0x2000
53 1.1 tsubai #define GMAC_TXDMACONFIG 0x2004
54 1.1 tsubai #define GMAC_TXDMADESCBASELO 0x2008
55 1.1 tsubai #define GMAC_TXDMADESCBASEHI 0x200c
56 1.1 tsubai #define GMAC_TXDMACOMPLETE 0x2100
57 1.1 tsubai
58 1.1 tsubai #define GMAC_RXDMACONFIG 0x4000
59 1.1 tsubai #define GMAC_RXDMADESCBASELO 0x4004
60 1.1 tsubai #define GMAC_RXDMADESCBASEHI 0x4008
61 1.1 tsubai #define GMAC_RXDMAKICK 0x4100
62 1.1 tsubai
63 1.1 tsubai #define GMAC_MACPAUSE 0x6008
64 1.1 tsubai #define GMAC_MACPAUSE 0x6008
65 1.1 tsubai #define GMAC_TXMACSTATUS 0x6010
66 1.1 tsubai #define GMAC_TXMACCONFIG 0x6030
67 1.1 tsubai #define GMAC_RXMACCONFIG 0x6034
68 1.1 tsubai #define GMAC_MACCTRLCONFIG 0x6038
69 1.1 tsubai #define GMAC_XIFCONFIG 0x603c
70 1.1 tsubai #define GMAC_INTERPACKETGAP0 0x6040
71 1.1 tsubai #define GMAC_INTERPACKETGAP1 0x6044
72 1.1 tsubai #define GMAC_INTERPACKETGAP2 0x6048
73 1.1 tsubai #define GMAC_SLOTTIME 0x604c
74 1.1 tsubai #define GMAC_MINFRAMESIZE 0x6050
75 1.1 tsubai #define GMAC_MAXFRAMESIZE 0x6054
76 1.1 tsubai #define GMAC_PASIZE 0x6058
77 1.1 tsubai #define GMAC_JAMSIZE 0x605c
78 1.1 tsubai #define GMAC_ATTEMPTLIMIT 0x6060 /* atemptlimit */
79 1.1 tsubai #define GMAC_MACCNTLTYPE 0x6064
80 1.1 tsubai #define GMAC_MACADDRESS0 0x6080
81 1.1 tsubai #define GMAC_MACADDRESS1 0x6084
82 1.1 tsubai #define GMAC_MACADDRESS2 0x6088
83 1.1 tsubai #define GMAC_MACADDRESS3 0x608c
84 1.1 tsubai #define GMAC_MACADDRESS4 0x6090
85 1.1 tsubai #define GMAC_MACADDRESS5 0x6094
86 1.1 tsubai #define GMAC_MACADDRESS6 0x6098
87 1.1 tsubai #define GMAC_MACADDRESS7 0x609c
88 1.1 tsubai #define GMAC_MACADDRESS8 0x60a0
89 1.1 tsubai #define GMAC_MACADDRFILT0 0x60a4
90 1.1 tsubai #define GMAC_MACADDRFILT1 0x60a8
91 1.1 tsubai #define GMAC_MACADDRFILT2 0x60ac
92 1.1 tsubai #define GMAC_MACADDRFILT2_1MASK 0x60b0 /* macaddressfilter2&1mask */
93 1.1 tsubai #define GMAC_MACADDRFILT0MASK 0x60b4 /* macaddressfilter0mask */
94 1.1 tsubai #define GMAC_HASHTABLE0 0x60c0
95 1.1 tsubai
96 1.1 tsubai #define GMAC_RANDOMSEED 0x6130
97 1.1 tsubai #define GMAC_MIFFRAMEOUTPUT 0x620c
98 1.1 tsubai #define GMAC_DATAPATHMODE 0x9050
99