1 1.3 tsubai /* $NetBSD: if_gmreg.h,v 1.3 2000/06/15 19:09:15 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.2 tsubai #define GMAC_INT_TXEMPTY 0x02 /* TX ring empty */ 41 1.2 tsubai #define GMAC_INT_TXDONE 0x04 42 1.2 tsubai #define GMAC_INT_RXDONE 0x10 43 1.1 tsubai 44 1.3 tsubai #define GMAC_RXMAC_PR 0x08 /* enable promiscuous mode */ 45 1.3 tsubai #define GMAC_RXMAC_HEN 0x10 /* enable the hash filter */ 46 1.1 tsubai 47 1.1 tsubai /* 48 1.1 tsubai * register offset 49 1.1 tsubai */ 50 1.1 tsubai #define GMAC_STATUS 0x000c 51 1.1 tsubai #define GMAC_INTMASK 0x0010 52 1.1 tsubai #define GMAC_SOFTWARERESET 0x1010 53 1.1 tsubai 54 1.1 tsubai #define GMAC_TXDMAKICK 0x2000 55 1.1 tsubai #define GMAC_TXDMACONFIG 0x2004 56 1.1 tsubai #define GMAC_TXDMADESCBASELO 0x2008 57 1.1 tsubai #define GMAC_TXDMADESCBASEHI 0x200c 58 1.1 tsubai #define GMAC_TXDMACOMPLETE 0x2100 59 1.1 tsubai 60 1.1 tsubai #define GMAC_RXDMACONFIG 0x4000 61 1.1 tsubai #define GMAC_RXDMADESCBASELO 0x4004 62 1.1 tsubai #define GMAC_RXDMADESCBASEHI 0x4008 63 1.1 tsubai #define GMAC_RXDMAKICK 0x4100 64 1.1 tsubai 65 1.1 tsubai #define GMAC_MACPAUSE 0x6008 66 1.1 tsubai #define GMAC_MACPAUSE 0x6008 67 1.1 tsubai #define GMAC_TXMACSTATUS 0x6010 68 1.1 tsubai #define GMAC_TXMACCONFIG 0x6030 69 1.1 tsubai #define GMAC_RXMACCONFIG 0x6034 70 1.1 tsubai #define GMAC_MACCTRLCONFIG 0x6038 71 1.1 tsubai #define GMAC_XIFCONFIG 0x603c 72 1.1 tsubai #define GMAC_INTERPACKETGAP0 0x6040 73 1.1 tsubai #define GMAC_INTERPACKETGAP1 0x6044 74 1.1 tsubai #define GMAC_INTERPACKETGAP2 0x6048 75 1.1 tsubai #define GMAC_SLOTTIME 0x604c 76 1.1 tsubai #define GMAC_MINFRAMESIZE 0x6050 77 1.1 tsubai #define GMAC_MAXFRAMESIZE 0x6054 78 1.1 tsubai #define GMAC_PASIZE 0x6058 79 1.1 tsubai #define GMAC_JAMSIZE 0x605c 80 1.1 tsubai #define GMAC_ATTEMPTLIMIT 0x6060 /* atemptlimit */ 81 1.1 tsubai #define GMAC_MACCNTLTYPE 0x6064 82 1.1 tsubai #define GMAC_MACADDRESS0 0x6080 83 1.1 tsubai #define GMAC_MACADDRESS1 0x6084 84 1.1 tsubai #define GMAC_MACADDRESS2 0x6088 85 1.1 tsubai #define GMAC_MACADDRESS3 0x608c 86 1.1 tsubai #define GMAC_MACADDRESS4 0x6090 87 1.1 tsubai #define GMAC_MACADDRESS5 0x6094 88 1.1 tsubai #define GMAC_MACADDRESS6 0x6098 89 1.1 tsubai #define GMAC_MACADDRESS7 0x609c 90 1.1 tsubai #define GMAC_MACADDRESS8 0x60a0 91 1.1 tsubai #define GMAC_MACADDRFILT0 0x60a4 92 1.1 tsubai #define GMAC_MACADDRFILT1 0x60a8 93 1.1 tsubai #define GMAC_MACADDRFILT2 0x60ac 94 1.1 tsubai #define GMAC_MACADDRFILT2_1MASK 0x60b0 /* macaddressfilter2&1mask */ 95 1.1 tsubai #define GMAC_MACADDRFILT0MASK 0x60b4 /* macaddressfilter0mask */ 96 1.1 tsubai #define GMAC_HASHTABLE0 0x60c0 97 1.1 tsubai 98 1.1 tsubai #define GMAC_RANDOMSEED 0x6130 99 1.1 tsubai #define GMAC_MIFFRAMEOUTPUT 0x620c 100 1.1 tsubai #define GMAC_DATAPATHMODE 0x9050 101