URL
https://opencores.org/ocsvn/openrisc/openrisc/trunk
Subversion Repositories openrisc
[/] [openrisc/] [trunk/] [rtos/] [ecos-2.0/] [packages/] [devs/] [eth/] [mips/] [atlas/] [v2_0/] [src/] [saa9730.h] - Rev 420
Go to most recent revision | Compare with Previous | Blame | View Log
#ifndef CYGONCE_DEVS_ETH_MIPS_ATLAS_SAA9730_H #define CYGONCE_DEVS_ETH_MIPS_ATLAS_SAA9730_H /*========================================================================== // // saa9730.h // Philips SAA9730 IO Chip Ethernet Interface // // //========================================================================== //####ECOSGPLCOPYRIGHTBEGIN#### // ------------------------------------------- // This file is part of eCos, the Embedded Configurable Operating System. // Copyright (C) 1998, 1999, 2000, 2001, 2002 Red Hat, Inc. // Copyright (C) 2003 Nick Garnett <nickg@calivar.com> // // eCos is free software; you can redistribute it and/or modify it under // the terms of the GNU General Public License as published by the Free // Software Foundation; either version 2 or (at your option) any later version. // // eCos is distributed in the hope that it will be useful, but WITHOUT ANY // WARRANTY; without even the implied warranty of MERCHANTABILITY or // FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License // for more details. // // You should have received a copy of the GNU General Public License along // with eCos; if not, write to the Free Software Foundation, Inc., // 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. // // As a special exception, if other files instantiate templates or use macros // or inline functions from this file, or you compile this file and link it // with other works to produce a work based on this file, this file does not // by itself cause the resulting work to be covered by the GNU General Public // License. However the source code for this file must still be made available // in accordance with section (3) of the GNU General Public License. // // This exception does not invalidate any other reasons why a work based on // this file might be covered by the GNU General Public License. // // Alternative licenses for eCos may be arranged by contacting the copyright // holders. // ------------------------------------------- //####ECOSGPLCOPYRIGHTEND#### //========================================================================== //#####DESCRIPTIONBEGIN#### // // Author(s): msalter // Contributors: msalter, nickg // Date: 2000-12-09 // Description: Definitions for Philips SAA9730 Ethernet module. // //####DESCRIPTIONEND#### */ // QS6612 PHY definitions #define PHY_CONTROL 0 #define PHY_STATUS 1 #define PHY_REG31 31 #define PHY_CONTROL_RESET (1 << 15) #define PHY_CONTROL_AUTO_NEG (1 << 12) #define PHY_CONTROL_RESTART_AUTO_NEG (1 << 9) #define PHY_STATUS_LINK_UP (1 << 2) #define PHY_REG31_OPMODE_SHIFT 2 #define PHY_REG31_OPMODE_MSK (7 << PHY_REG31_OPMODE_SHIFT) #define OPMODE_AUTONEGOTIATE 0 #define OPMODE_10BASET_HALFDUPLEX 1 #define OPMODE_100BASEX_HALFDUPLEX 2 #define OPMODE_REPEATER_MODE 3 #define OPMODE_UNDEFINED 4 #define OPMODE_10BASET_FULLDUPLEX 5 #define OPMODE_100BASEX_FULLDUPLEX 6 #define OPMODE_ISOLATE 7 #define QS6612_PHY_ADDRESS 0 #define PHY_ADDRESS QS6612_PHY_ADDRESS // Number of 6-byte entries in the CAM #define SAA9730_CAM_ENTRIES 10 // TX and RX packet size fixed at 2k bytes by hw #define SAA9730_PACKET_SIZE 2048 // Number of TX buffers = number of RX buffers = 2, // which is fixed according to HW requirements #define SAA9730_BUFFERS 2 // Number of RX packets per RX buffer #define SAA9730_RXPKTS_PER_BUFFER 2 // Number of TX packets per TX buffer #define SAA9730_TXPKTS_PER_BUFFER 1 // Minimum packet size #define SAA9730_MIN_PACKET_SIZE 60 // owner ship bit #define SAA9730_BLOCK_OWNED_BY_SYSTEM 0 #define SAA9730_BLOCK_OWNED_BY_HARDWARE 1 // Default Rcv interrupt count #define SAA9730_DEFAULT_RCV_INTERRUPT_CNT 4 // Default maxium transmit retry #define SAA9730_DEFAULT_MAX_TXM_RETRY 16 // Default time out value #define SAA9730_DEFAULT_TIME_OUT_CNT 200 // MAX map registers #define SAA9730__MAX_MAP_REGISTERS 64 // Defines used by Interrupt code #define SAA9730_DMA_PACKET_SIZE 2048 #define SAA9730_VALID_PACKET 0xC0000000 #define SAA9730_FRAME_TYPELEN_OFFSET 12 #define SAA9730_ETH_MIN_FRAME_SIZE 60 #define SAA9730_DEST_ADDR_SIZE 6 #define SAA9730_SRC_ADDR_SIZE 6 #define SAA9730_TYPE_LEN_SIZE 2 // MAC receive error #define SAA9730_MAC_GOOD_RX (0x00004000) << 11 #define SAA9730_MAC_RCV_ALIGN_ERROR (0x00000100) << 11 #define SAA9730_MAC_RCV_CRC_ERROR (0x00000200) << 11 #define SAA9730_MAC_RCV_OVERFLOW (0x00000400) << 11 // This number is arbitrary and can be increased if needed #define SAA9730_MAX_MULTICAST_ADDRESSES 20 // SAA9730 Event Manager Registers #define SAA9730_EVM_ISR *((volatile unsigned *)(__base + 0x02000)) #define SAA9730_EVM_IER *((volatile unsigned *)(__base + 0x02004)) #define SAA9730_EVM_IMR *((volatile unsigned *)(__base + 0x02008)) #define SAA9730_EVM_IER_SW *((volatile unsigned *)(__base + 0x0202c)) #define SAA9730_EVM_LAN_INT (1<<16) // LAN interrupt bit #define SAA9730_EVM_MASTER (1<<0) // Master interrupt bit // SAA9730 LAN Registers #define SAA9730_TXBUFA *((volatile unsigned *)(__base + 0x20400)) // TX buffer A #define SAA9730_TXBUFB *((volatile unsigned *)(__base + 0x20404)) // TX buffer B #define SAA9730_RXBUFA *((volatile unsigned *)(__base + 0x20408)) // RX buffer A #define SAA9730_RXBUFB *((volatile unsigned *)(__base + 0x2040C)) // RX buffer B #define SAA9730_PKTCNT *((volatile unsigned *)(__base + 0x20410)) // Packet count #define SAA9730_OK2USE *((volatile unsigned *)(__base + 0x20414)) // OK-to-use # define SAA9730_OK2USE_TXA 8 # define SAA9730_OK2USE_TXB 4 # define SAA9730_OK2USE_RXA 2 # define SAA9730_OK2USE_RXB 1 #define SAA9730_DMACTL *((volatile unsigned *)(__base + 0x20418)) // DMA control # define SAA9730_DMACTL_BLKINT (1 << 31) # define SAA9730_DMACTL_MAXXFER_ANY (0 << 18) # define SAA9730_DMACTL_MAXXFER_8 (1 << 18) # define SAA9730_DMACTL_MAXXFER_32 (2 << 18) # define SAA9730_DMACTL_MAXXFER_64 (3 << 18) # define SAA9730_DMACTL_ENDIAN_LITTLE (0 << 16) # define SAA9730_DMACTL_ENDIAN_2143 (1 << 16) # define SAA9730_DMACTL_ENDIAN_4321 (2 << 16) # define SAA9730_DMACTL_RXINTCNT_SHIFT 8 # define SAA9730_DMACTL_RXINTCNT_MSK (0xff << SAA9730_DMACTL_RXINTCNT_SHIFT) # define SAA9730_DMACTL_ENTX (1 << 7) # define SAA9730_DMACTL_ENRX (1 << 6) # define SAA9730_DMACTL_RXFULL (1 << 5) # define SAA9730_DMACTL_RXTOINT (1 << 4) # define SAA9730_DMACTL_RXINT (1 << 3) # define SAA9730_DMACTL_TXINT (1 << 2) # define SAA9730_DMACTL_MACTXINT (1 << 1) # define SAA9730_DMACTL_MACRXINT (1 << 0) #define SAA9730_TIMOUT *((volatile unsigned *)(__base + 0x2041C)) // Time out #define SAA9730_DMASTA *((volatile unsigned *)(__base + 0x20420)) // DMA status # define SAA9730_DMASTA_TXABADR_MSK (1 << 19) # define SAA9730_DMASTA_TXBBADR_MSK (1 << 18) # define SAA9730_DMASTA_RXABADR_MSK (1 << 17) # define SAA9730_DMASTA_RXBBADR_MSK (1 << 16) # define SAA9730_DMASTA_RXBBADR_SHIFT 8 # define SAA9730_DMASTA_RXPCKCNT_MASK (0xff << SAA9730_DMASTA_RXPCKCNT_SHIFT) # define SAA9730_DMASTA_TXMACBUSY_MSK (1 << 7) # define SAA9730_DMASTA_RXAFULL_MSK (1 << 6) # define SAA9730_DMASTA_RXBFULL_MSK (1 << 5) # define SAA9730_DMASTA_RXTOINT_MSK (1 << 4) # define SAA9730_DMASTA_RXINT_MSK (1 << 3) # define SAA9730_DMASTA_TXINT_MSK (1 << 2) # define SAA9730_DMASTA_MACTXINT_MSK (1 << 1) # define SAA9730_DMASTA_MACRXINT_MSK (1 << 0) #define SAA9730_DMATST *((volatile unsigned *)(__base + 0x20424)) // DMA loop back # define SAA9730_DMATST_LPBACK (1 << 24) # define SAA9730_DMATST_RESET 1 #define SAA9730_PAUSE *((volatile unsigned *)(__base + 0x20430)) // Pause count #define SAA9730_REMPAUSE *((volatile unsigned *)(__base + 0x20434)) // Remote Pause count #define SAA9730_MACCTL *((volatile unsigned *)(__base + 0x20440)) // MAC control # define SAA9730_MACCTL_MISSRINT (1 << 13) # define SAA9730_MACCTL_MISSROLL (1 << 10) # define SAA9730_MACCTL_LOOP10 (1 << 7) # define SAA9730_MACCTL_CONMODE_AUTOMATIC (0 << 5) # define SAA9730_MACCTL_CONMODE_FORCE_10MB (1 << 5) # define SAA9730_MACCTL_CONMODE_FORCE_MII (2 << 5) # define SAA9730_MACCTL_LPBACK (1 << 4) # define SAA9730_MACCTL_FULLDUP (1 << 3) # define SAA9730_MACCTL_RESET (1 << 2) # define SAA9730_MACCTL_HALTNOW (1 << 1) # define SAA9730_MACCTL_HALTREQ (1 << 0) #define SAA9730_CAMCTL *((volatile unsigned *)(__base + 0x20444)) // CAM control # define SAA9730_CAMCTL_COMPARE (1 << 4) # define SAA9730_CAMCTL_NEGATE (1 << 3) # define SAA9730_CAMCTL_BROADCAST (1 << 2) # define SAA9730_CAMCTL_MULTICAST (1 << 1) # define SAA9730_CAMCTL_UNICAST (1 << 0) #define SAA9730_TXCTL *((volatile unsigned *)(__base + 0x20448)) // TX control # define SAA9730_TXCTL_COMPLINT (1 << 14) # define SAA9730_TXCTL_TXPARINT (1 << 13) # define SAA9730_TXCTL_LATECOLLINT (1 << 12) # define SAA9730_TXCTL_EXCOLLINT (1 << 11) # define SAA9730_TXCTL_CARRIERINT (1 << 10) # define SAA9730_TXCTL_DEFERINT (1 << 9) # define SAA9730_TXCTL_UNDERINT (1 << 8) # define SAA9730_TXCTL_MII10 (1 << 7) # define SAA9730_TXCTL_SDPAUSE (1 << 6) # define SAA9730_TXCTL_NOEXDEF (1 << 5) # define SAA9730_TXCTL_FBACK (1 << 4) # define SAA9730_TXCTL_NOCRC (1 << 3) # define SAA9730_TXCTL_NOPAD (1 << 2) # define SAA9730_TXCTL_TXHALT (1 << 1) # define SAA9730_TXCTL_ENTX (1 << 0) #define SAA9730_TXSTA *((volatile unsigned *)(__base + 0x2044C)) // TX status # define SAA9730_TXSTA_SQERR (1 << 16) # define SAA9730_TXSTA_TXHALTED (1 << 15) # define SAA9730_TXSTA_COMPLETION (1 << 14) # define SAA9730_TXSTA_PARITYERR (1 << 13) # define SAA9730_TXSTA_LATECOLLERR (1 << 12) # define SAA9730_TXSTA_WAS10MB (1 << 11) # define SAA9730_TXSTA_LOSTCARRIER (1 << 10) # define SAA9730_TXSTA_EXDEFER (1 << 9) # define SAA9730_TXSTA_UNDERRUN (1 << 8) # define SAA9730_TXSTA_INTERRUPT (1 << 7) # define SAA9730_TXSTA_PAUSED (1 << 6) # define SAA9730_TXSTA_DEFERRED (1 << 5) # define SAA9730_TXSTA_EXCOLL (1 << 4) # define SAA9730_TXSTA_COLLISIONS_MASK 0xf #define SAA9730_RXCTL *((volatile unsigned *)(__base + 0x20450)) // RX control # define SAA9730_RXCTL_ENGOOD (1 << 14) # define SAA9730_RXCTL_ENPARITY (1 << 13) # define SAA9730_RXCTL_ENLONGERR (1 << 11) # define SAA9730_RXCTL_ENOVER (1 << 10) # define SAA9730_RXCTL_ENCRCERR (1 << 9) # define SAA9730_RXCTL_ENALIGN (1 << 8) # define SAA9730_RXCTL_IGNORECRC (1 << 6) # define SAA9730_RXCTL_PASSCTL (1 << 5) # define SAA9730_RXCTL_STRIPCRC (1 << 4) # define SAA9730_RXCTL_SHORTEN (1 << 3) # define SAA9730_RXCTL_LONGEN (1 << 2) # define SAA9730_RXCTL_RXHALT (1 << 1) # define SAA9730_RXCTL_ENRX (1 << 0) #define SAA9730_RXSTA *((volatile unsigned *)(__base + 0x20454)) // RX status # define SAA9730_RXSTA_HALTED (1 << 15) # define SAA9730_RXSTA_GOOD (1 << 14) # define SAA9730_RXSTA_PARITY (1 << 13) # define SAA9730_RXSTA_LONGERR (1 << 11) # define SAA9730_RXSTA_OVERFLOW (1 << 10) # define SAA9730_RXSTA_CRCERR (1 << 9) # define SAA9730_RXSTA_ALIGNERR (1 << 8) # define SAA9730_RXSTA_WAS10MB (1 << 7) # define SAA9730_RXSTA_INTERRUPT (1 << 6) # define SAA9730_RXSTA_CONTROLRCV (1 << 5) #define SAA9730_MDDATA *((volatile unsigned *)(__base + 0x20458)) // PHY mgmt data # define SAA9730_MDDATA_DATA_MASK (0xffff << SAA9730_MDDATA_DATA_SHIFT) #define SAA9730_MDCTL *((volatile unsigned *)(__base + 0x2045C)) // PHY mgmt control # define SAA9730_MDCTL_PRESUP (1 << 12) # define SAA9730_MDCTL_BUSY (1 << 11) # define SAA9730_MDCTL_WRITE (1 << 10) # define SAA9730_MDCTL_PHY_SHIFT 5 # define SAA9730_MDCTL_PHY_MASK (0x1f << SAA9730_MDCTL_PHY_SHIFT) # define SAA9730_MDCTL_ADDR_MASK 0x1f #define SAA9730_CAMADR *((volatile unsigned *)(__base + 0x20460)) // CAM address # define SAA9730_CAMADR_ADDRESS_MASK (0x1ff << SAA9730_CAMADR_ADDRESS_SHIFT) #define SAA9730_CAMDAT *((volatile unsigned *)(__base + 0x20464)) // CAM data #define SAA9730_CAMENA *((volatile unsigned *)(__base + 0x20468)) // CAM enable # define SAA9730_CAMENA_ENABLE_MASK (0x3fffff << SAA9730_CAMENA_ENABLE_SHIFT) #define SAA9730_DBGRXS *((volatile unsigned *)(__base + 0x20508)) // DEBUG # define SAA9730_DBGRXS_RXPI_MASK (0x3ff << 16) # define SAA9730_DBGRXS_RXPI_ERROR (0x001 << 16) # define SAA9730_DBGRXS_RXDII_MASK 0x1ff # define SAA9730_DBGRXS_RXDII_ERROR 8 #define SAA9730_DBGRXFIFO *((volatile unsigned *)(__base + 0x20510)) // DEBUG #define SAA9730_DBGLANSTA *((volatile unsigned *)(__base + 0x20514)) // DEBUG // ******** Packet control/status ********** #define TXPACKET_CTL_FLAG_MASK (0x3 << 30) # define TX_EMPTY (0 << 30) # define TX_READY (2 << 30) # define TX_HWDONE (3 << 30) # define TXPACKET_CTL_IRQ_MASK (1 << 29) # define TXPACKET_CTL_NOCRC_MASK (1 << 28) # define TXPACKET_CTL_NOPAD_MASK (1 << 27) # define TXPACKET_CTL_SIZE_MASK 0x7ff #define TXPACKET_STATUS_FLAG_MASK (0x3 << 30) # define TXPACKET_STATUS_SQERR (1 << 27) # define TXPACKET_STATUS_TXHALTED (1 << 26) # define TXPACKET_STATUS_COMPLETION (1 << 25) # define TXPACKET_STATUS_PARITYERR (1 << 24) # define TXPACKET_STATUS_LATECOLLERR (1 << 23) # define TXPACKET_STATUS_WAS10MB (1 << 22) # define TXPACKET_STATUS_LOSTCARRIER (1 << 21) # define TXPACKET_STATUS_EXDEFER (1 << 20) # define TXPACKET_STATUS_UNDERRUN (1 << 19) # define TXPACKET_STATUS_COLLISIONS_SHIFT 11 # define TXPACKET_STATUS_COLLISIONS_MASK (0x1f << TXPACKET_STATUS_COLLISIONS_SHIFT) # define TXPACKET_STATUS_SIZE_MASK 0x7ff # define TXPACKET_STATUS_ERROR (TXPACKET_STATUS_EXDEFER | \ TXPACKET_STATUS_LATECOLLERR | \ TXPACKET_STATUS_LOSTCARRIER | \ TXPACKET_STATUS_UNDERRUN | \ TXPACKET_STATUS_SQERR) # define RXPACKET_STATUS_FLAG_MASK (0x3 << 30) # define RX_NDIS (0 << 30) # define RX_INVALID_STAT (1 << 30) # define RX_READY (2 << 30) # define RX_HWDONE (3 << 30) # define RXPACKET_STATUS_GOOD (1 << 25) # define RXPACKET_STATUS_PARITY (1 << 24) # define RXPACKET_STATUS_LONGERR (1 << 22) # define RXPACKET_STATUS_OVERFLOW (1 << 21) # define RXPACKET_STATUS_CRCERR (1 << 20) # define RXPACKET_STATUS_ALIGNERR (1 << 19) # define RXPACKET_STATUS_WAS10MB (1 << 18) # define RXPACKET_STATUS_SIZE_MASK 0x7ff #endif // CYGONCE_DEVS_ETH_MIPS_ATLAS_SAA9730_H
Go to most recent revision | Compare with Previous | Blame | View Log