| /* | 
 |  * This file is subject to the terms and conditions of the GNU General Public | 
 |  * License.  See the file "COPYING" in the main directory of this archive | 
 |  * for more details. | 
 |  * | 
 |  * Copyright (C) 2001 Patton Electronics Company | 
 |  * Copyright (C) 2002 Momentum Computer | 
 |  * | 
 |  * Copyright 2000 MontaVista Software Inc. | 
 |  * Author: MontaVista Software, Inc. | 
 |  *         	stevel@mvista.com or support@mvista.com | 
 |  * | 
 |  *  This program is free software; you can distribute it and/or modify it | 
 |  *  under the terms of the GNU General Public License (Version 2) as | 
 |  *  published by the Free Software Foundation. | 
 |  * | 
 |  *  This program is distributed in the hope 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 this program; if not, write to the Free Software Foundation, Inc., | 
 |  *  59 Temple Place - Suite 330, Boston MA 02111-1307, USA. | 
 |  * | 
 |  * Ethernet driver definitions for the MIPS GT96100 Advanced | 
 |  * Communication Controller. | 
 |  *  | 
 |  * Modified for the Marvellous GT64240 Retarded Communication Controller. | 
 |  */ | 
 | #ifndef _GT64240ETH_H | 
 | #define _GT64240ETH_H | 
 |  | 
 | #include <asm/gt64240.h> | 
 |  | 
 | #define ETHERNET_PORTS_DIFFERENCE_OFFSETS	0x400 | 
 |  | 
 | /* Translate those weanie names from Galileo/VxWorks header files: */ | 
 |  | 
 | #define GT64240_MRR                    MAIN_ROUTING_REGISTER | 
 | #define GT64240_CIU_ARBITER_CONFIG     COMM_UNIT_ARBITER_CONFIGURATION_REGISTER | 
 | #define GT64240_CIU_ARBITER_CONTROL    COMM_UNIT_ARBITER_CONTROL | 
 | #define GT64240_MAIN_LOW_CAUSE         LOW_INTERRUPT_CAUSE_REGISTER | 
 | #define GT64240_MAIN_HIGH_CAUSE        HIGH_INTERRUPT_CAUSE_REGISTER | 
 | #define GT64240_CPU_LOW_MASK           CPU_INTERRUPT_MASK_REGISTER_LOW | 
 | #define GT64240_CPU_HIGH_MASK          CPU_INTERRUPT_MASK_REGISTER_HIGH | 
 | #define GT64240_CPU_SELECT_CAUSE       CPU_SELECT_CAUSE_REGISTER | 
 |  | 
 | #define GT64240_ETH_PHY_ADDR_REG       ETHERNET_PHY_ADDRESS_REGISTER | 
 | #define GT64240_ETH_PORT_CONFIG        ETHERNET0_PORT_CONFIGURATION_REGISTER | 
 | #define GT64240_ETH_PORT_CONFIG_EXT    ETHERNET0_PORT_CONFIGURATION_EXTEND_REGISTER | 
 | #define GT64240_ETH_PORT_COMMAND       ETHERNET0_PORT_COMMAND_REGISTER | 
 | #define GT64240_ETH_PORT_STATUS        ETHERNET0_PORT_STATUS_REGISTER | 
 | #define GT64240_ETH_IO_SIZE            ETHERNET_PORTS_DIFFERENCE_OFFSETS | 
 | #define GT64240_ETH_SMI_REG            ETHERNET_SMI_REGISTER | 
 | #define GT64240_ETH_MIB_COUNT_BASE     ETHERNET0_MIB_COUNTER_BASE | 
 | #define GT64240_ETH_SDMA_CONFIG        ETHERNET0_SDMA_CONFIGURATION_REGISTER | 
 | #define GT64240_ETH_SDMA_COMM          ETHERNET0_SDMA_COMMAND_REGISTER | 
 | #define GT64240_ETH_INT_MASK           ETHERNET0_INTERRUPT_MASK_REGISTER | 
 | #define GT64240_ETH_INT_CAUSE          ETHERNET0_INTERRUPT_CAUSE_REGISTER | 
 | #define GT64240_ETH_CURR_TX_DESC_PTR0  ETHERNET0_CURRENT_TX_DESCRIPTOR_POINTER0 | 
 | #define GT64240_ETH_CURR_TX_DESC_PTR1  ETHERNET0_CURRENT_TX_DESCRIPTOR_POINTER1 | 
 | #define GT64240_ETH_1ST_RX_DESC_PTR0   ETHERNET0_FIRST_RX_DESCRIPTOR_POINTER0 | 
 | #define GT64240_ETH_CURR_RX_DESC_PTR0  ETHERNET0_CURRENT_RX_DESCRIPTOR_POINTER0 | 
 | #define GT64240_ETH_HASH_TBL_PTR       ETHERNET0_HASH_TABLE_POINTER_REGISTER | 
 |  | 
 | /* Turn on NAPI by default */ | 
 |  | 
 | #define	GT64240_NAPI			1 | 
 |  | 
 | /* Some 64240 settings that SHOULD eventually be setup in PROM monitor: */ | 
 | /* (Board-specific to the DSL3224 Rev A board ONLY!)                    */ | 
 | #define D3224_MPP_CTRL0_SETTING		0x66669900 | 
 | #define D3224_MPP_CTRL1_SETTING		0x00000000 | 
 | #define D3224_MPP_CTRL2_SETTING		0x00887700 | 
 | #define D3224_MPP_CTRL3_SETTING		0x00000044 | 
 | #define D3224_GPP_IO_CTRL_SETTING	0x0000e800 | 
 | #define D3224_GPP_LEVEL_CTRL_SETTING	0xf001f703 | 
 | #define D3224_GPP_VALUE_SETTING		0x00000000 | 
 |  | 
 | /* Keep the ring sizes a power of two for efficiency. */ | 
 | //-#define TX_RING_SIZE 16 | 
 | #define TX_RING_SIZE	64	/* TESTING !!! */ | 
 | #define RX_RING_SIZE	32 | 
 | #define PKT_BUF_SZ	1536	/* Size of each temporary Rx buffer. */ | 
 |  | 
 | #define RX_HASH_TABLE_SIZE 16384 | 
 | #define HASH_HOP_NUMBER 12 | 
 |  | 
 | #define NUM_INTERFACES 3 | 
 |  | 
 | #define GT64240ETH_TX_TIMEOUT HZ/4 | 
 |  | 
 | #define MIPS_GT64240_BASE 0xf4000000 | 
 | #define GT64240_ETH0_BASE (MIPS_GT64240_BASE + GT64240_ETH_PORT_CONFIG) | 
 | #define GT64240_ETH1_BASE (GT64240_ETH0_BASE + GT64240_ETH_IO_SIZE) | 
 | #define GT64240_ETH2_BASE (GT64240_ETH1_BASE + GT64240_ETH_IO_SIZE) | 
 |  | 
 | #if defined(CONFIG_MIPS_DSL3224) | 
 | #define GT64240_ETHER0_IRQ 4 | 
 | #define GT64240_ETHER1_IRQ 4 | 
 | #else | 
 | #define GT64240_ETHER0_IRQ -1 | 
 | #define GT64240_ETHER1_IRQ -1 | 
 | #endif | 
 |  | 
 | #define REV_GT64240  0x1 | 
 | #define REV_GT64240A 0x10 | 
 |  | 
 | #define GT64240ETH_READ(gp, offset)					\ | 
 | 	GT_READ((gp)->port_offset + (offset)) | 
 |  | 
 | #define GT64240ETH_WRITE(gp, offset, data)				\ | 
 | 	GT_WRITE((gp)->port_offset + (offset), (data)) | 
 |  | 
 | #define GT64240ETH_SETBIT(gp, offset, bits)				\ | 
 | 	GT64240ETH_WRITE((gp), (offset),				\ | 
 | 	                 GT64240ETH_READ((gp), (offset)) | (bits)) | 
 |  | 
 | #define GT64240ETH_CLRBIT(gp, offset, bits)				\ | 
 | 	GT64240ETH_WRITE((gp), (offset),				\ | 
 | 	                 GT64240ETH_READ((gp), (offset)) & ~(bits)) | 
 |  | 
 | #define GT64240_READ(ofs)		GT_READ(ofs) | 
 | #define GT64240_WRITE(ofs, data)	GT_WRITE((ofs), (data)) | 
 |  | 
 | /* Bit definitions of the SMI Reg */ | 
 | enum { | 
 | 	smirDataMask = 0xffff, | 
 | 	smirPhyAdMask = 0x1f << 16, | 
 | 	smirPhyAdBit = 16, | 
 | 	smirRegAdMask = 0x1f << 21, | 
 | 	smirRegAdBit = 21, | 
 | 	smirOpCode = 1 << 26, | 
 | 	smirReadValid = 1 << 27, | 
 | 	smirBusy = 1 << 28 | 
 | }; | 
 |  | 
 | /* Bit definitions of the Port Config Reg */ | 
 | enum pcr_bits { | 
 | 	pcrPM = 1 << 0, | 
 | 	pcrRBM = 1 << 1, | 
 | 	pcrPBF = 1 << 2, | 
 | 	pcrEN = 1 << 7, | 
 | 	pcrLPBKMask = 0x3 << 8, | 
 | 	pcrLPBKBit = 1 << 8, | 
 | 	pcrFC = 1 << 10, | 
 | 	pcrHS = 1 << 12, | 
 | 	pcrHM = 1 << 13, | 
 | 	pcrHDM = 1 << 14, | 
 | 	pcrHD = 1 << 15, | 
 | 	pcrISLMask = 0x7 << 28, | 
 | 	pcrISLBit = 28, | 
 | 	pcrACCS = 1 << 31 | 
 | }; | 
 |  | 
 | /* Bit definitions of the Port Config Extend Reg */ | 
 | enum pcxr_bits { | 
 | 	pcxrIGMP = 1, | 
 | 	pcxrSPAN = 2, | 
 | 	pcxrPAR = 4, | 
 | 	pcxrPRIOtxMask = 0x7 << 3, | 
 | 	pcxrPRIOtxBit = 3, | 
 | 	pcxrPRIOrxMask = 0x3 << 6, | 
 | 	pcxrPRIOrxBit = 6, | 
 | 	pcxrPRIOrxOverride = 1 << 8, | 
 | 	pcxrDPLXen = 1 << 9, | 
 | 	pcxrFCTLen = 1 << 10, | 
 | 	pcxrFLP = 1 << 11, | 
 | 	pcxrFCTL = 1 << 12, | 
 | 	pcxrMFLMask = 0x3 << 14, | 
 | 	pcxrMFLBit = 14, | 
 | 	pcxrMIBclrMode = 1 << 16, | 
 | 	pcxrSpeed = 1 << 18, | 
 | 	pcxrSpeeden = 1 << 19, | 
 | 	pcxrRMIIen = 1 << 20, | 
 | 	pcxrDSCPen = 1 << 21 | 
 | }; | 
 |  | 
 | /* Bit definitions of the Port Command Reg */ | 
 | enum pcmr_bits { | 
 | 	pcmrFJ = 1 << 15 | 
 | }; | 
 |  | 
 |  | 
 | /* Bit definitions of the Port Status Reg */ | 
 | enum psr_bits { | 
 | 	psrSpeed = 1, | 
 | 	psrDuplex = 2, | 
 | 	psrFctl = 4, | 
 | 	psrLink = 8, | 
 | 	psrPause = 1 << 4, | 
 | 	psrTxLow = 1 << 5, | 
 | 	psrTxHigh = 1 << 6, | 
 | 	psrTxInProg = 1 << 7 | 
 | }; | 
 |  | 
 | /* Bit definitions of the SDMA Config Reg */ | 
 | enum sdcr_bits { | 
 | 	sdcrRCMask = 0xf << 2, | 
 | 	sdcrRCBit = 2, | 
 | 	sdcrBLMR = 1 << 6, | 
 | 	sdcrBLMT = 1 << 7, | 
 | 	sdcrPOVR = 1 << 8, | 
 | 	sdcrRIFB = 1 << 9, | 
 | 	sdcrBSZMask = 0x3 << 12, | 
 | 	sdcrBSZBit = 12 | 
 | }; | 
 |  | 
 | /* Bit definitions of the SDMA Command Reg */ | 
 | enum sdcmr_bits { | 
 | 	sdcmrERD = 1 << 7, | 
 | 	sdcmrAR = 1 << 15, | 
 | 	sdcmrSTDH = 1 << 16, | 
 | 	sdcmrSTDL = 1 << 17, | 
 | 	sdcmrTXDH = 1 << 23, | 
 | 	sdcmrTXDL = 1 << 24, | 
 | 	sdcmrAT = 1 << 31 | 
 | }; | 
 |  | 
 | /* Bit definitions of the Interrupt Cause Reg */ | 
 | enum icr_bits { | 
 | 	icrRxBuffer = 1, | 
 | 	icrTxBufferHigh = 1 << 2, | 
 | 	icrTxBufferLow = 1 << 3, | 
 | 	icrTxEndHigh = 1 << 6, | 
 | 	icrTxEndLow = 1 << 7, | 
 | 	icrRxError = 1 << 8, | 
 | 	icrTxErrorHigh = 1 << 10, | 
 | 	icrTxErrorLow = 1 << 11, | 
 | 	icrRxOVR = 1 << 12, | 
 | 	icrTxUdr = 1 << 13, | 
 | 	icrRxBufferQ0 = 1 << 16, | 
 | 	icrRxBufferQ1 = 1 << 17, | 
 | 	icrRxBufferQ2 = 1 << 18, | 
 | 	icrRxBufferQ3 = 1 << 19, | 
 | 	icrRxErrorQ0 = 1 << 20, | 
 | 	icrRxErrorQ1 = 1 << 21, | 
 | 	icrRxErrorQ2 = 1 << 22, | 
 | 	icrRxErrorQ3 = 1 << 23, | 
 | 	icrMIIPhySTC = 1 << 28, | 
 | 	icrSMIdone = 1 << 29, | 
 | 	icrEtherIntSum = 1 << 31 | 
 | }; | 
 |  | 
 |  | 
 | /* The Rx and Tx descriptor lists. */ | 
 | #ifdef __LITTLE_ENDIAN | 
 | typedef struct { | 
 | 	u32 cmdstat; | 
 | 	u16 reserved;		//-prk21aug01    u32 reserved:16; | 
 | 	u16 byte_cnt;		//-prk21aug01    u32 byte_cnt:16; | 
 | 	u32 buff_ptr; | 
 | 	u32 next; | 
 | } gt64240_td_t; | 
 |  | 
 | typedef struct { | 
 | 	u32 cmdstat; | 
 | 	u16 byte_cnt;		//-prk21aug01    u32 byte_cnt:16; | 
 | 	u16 buff_sz;		//-prk21aug01    u32 buff_sz:16; | 
 | 	u32 buff_ptr; | 
 | 	u32 next; | 
 | } gt64240_rd_t; | 
 | #elif defined(__BIG_ENDIAN) | 
 | typedef struct { | 
 | 	u16 byte_cnt;		//-prk21aug01    u32 byte_cnt:16; | 
 | 	u16 reserved;		//-prk21aug01    u32 reserved:16; | 
 | 	u32 cmdstat; | 
 | 	u32 next; | 
 | 	u32 buff_ptr; | 
 | } gt64240_td_t; | 
 |  | 
 | typedef struct { | 
 | 	u16 buff_sz;		//-prk21aug01    u32 buff_sz:16; | 
 | 	u16 byte_cnt;		//-prk21aug01    u32 byte_cnt:16; | 
 | 	u32 cmdstat; | 
 | 	u32 next; | 
 | 	u32 buff_ptr; | 
 | } gt64240_rd_t; | 
 | #else | 
 | #error Either __BIG_ENDIAN or __LITTLE_ENDIAN must be defined! | 
 | #endif | 
 |  | 
 |  | 
 | /* Values for the Tx command-status descriptor entry. */ | 
 | enum td_cmdstat { | 
 | 	txOwn = 1 << 31, | 
 | 	txAutoMode = 1 << 30, | 
 | 	txEI = 1 << 23, | 
 | 	txGenCRC = 1 << 22, | 
 | 	txPad = 1 << 18, | 
 | 	txFirst = 1 << 17, | 
 | 	txLast = 1 << 16, | 
 | 	txErrorSummary = 1 << 15, | 
 | 	txReTxCntMask = 0x0f << 10, | 
 | 	txReTxCntBit = 10, | 
 | 	txCollision = 1 << 9, | 
 | 	txReTxLimit = 1 << 8, | 
 | 	txUnderrun = 1 << 6, | 
 | 	txLateCollision = 1 << 5 | 
 | }; | 
 |  | 
 |  | 
 | /* Values for the Rx command-status descriptor entry. */ | 
 | enum rd_cmdstat { | 
 | 	rxOwn = 1 << 31, | 
 | 	rxAutoMode = 1 << 30, | 
 | 	rxEI = 1 << 23, | 
 | 	rxFirst = 1 << 17, | 
 | 	rxLast = 1 << 16, | 
 | 	rxErrorSummary = 1 << 15, | 
 | 	rxIGMP = 1 << 14, | 
 | 	rxHashExpired = 1 << 13, | 
 | 	rxMissedFrame = 1 << 12, | 
 | 	rxFrameType = 1 << 11, | 
 | 	rxShortFrame = 1 << 8, | 
 | 	rxMaxFrameLen = 1 << 7, | 
 | 	rxOverrun = 1 << 6, | 
 | 	rxCollision = 1 << 4, | 
 | 	rxCRCError = 1 | 
 | }; | 
 |  | 
 | /* Bit fields of a Hash Table Entry */ | 
 | enum hash_table_entry { | 
 | 	hteValid = 1, | 
 | 	hteSkip = 2, | 
 | 	hteRD = 4 | 
 | }; | 
 |  | 
 | // The MIB counters | 
 | typedef struct { | 
 | 	u32 byteReceived; | 
 | 	u32 byteSent; | 
 | 	u32 framesReceived; | 
 | 	u32 framesSent; | 
 | 	u32 totalByteReceived; | 
 | 	u32 totalFramesReceived; | 
 | 	u32 broadcastFramesReceived; | 
 | 	u32 multicastFramesReceived; | 
 | 	u32 cRCError; | 
 | 	u32 oversizeFrames; | 
 | 	u32 fragments; | 
 | 	u32 jabber; | 
 | 	u32 collision; | 
 | 	u32 lateCollision; | 
 | 	u32 frames64; | 
 | 	u32 frames65_127; | 
 | 	u32 frames128_255; | 
 | 	u32 frames256_511; | 
 | 	u32 frames512_1023; | 
 | 	u32 frames1024_MaxSize; | 
 | 	u32 macRxError; | 
 | 	u32 droppedFrames; | 
 | 	u32 outMulticastFrames; | 
 | 	u32 outBroadcastFrames; | 
 | 	u32 undersizeFrames; | 
 | } mib_counters_t; | 
 |  | 
 |  | 
 | struct gt64240_private { | 
 | 	gt64240_rd_t *rx_ring; | 
 | 	gt64240_td_t *tx_ring; | 
 | 	// The Rx and Tx rings must be 16-byte aligned | 
 | 	dma_addr_t rx_ring_dma; | 
 | 	dma_addr_t tx_ring_dma; | 
 | 	char *hash_table; | 
 | 	// The Hash Table must be 8-byte aligned | 
 | 	dma_addr_t hash_table_dma; | 
 | 	int hash_mode; | 
 |  | 
 | 	// The Rx buffers must be 8-byte aligned | 
 | 	char *rx_buff; | 
 | 	dma_addr_t rx_buff_dma; | 
 | 	// Tx buffers (tx_skbuff[i]->data) with less than 8 bytes | 
 | 	// of payload must be 8-byte aligned | 
 | 	struct sk_buff *tx_skbuff[TX_RING_SIZE]; | 
 | 	int rx_next_out;	/* The next free ring entry to receive */ | 
 | 	int tx_next_in;		/* The next free ring entry to send */ | 
 | 	int tx_next_out;	/* The last ring entry the ISR processed */ | 
 | 	int tx_count;		/* current # of pkts waiting to be sent in Tx ring */ | 
 | 	int intr_work_done;	/* number of Rx and Tx pkts processed in the isr */ | 
 | 	int tx_full;		/* Tx ring is full */ | 
 |  | 
 | 	mib_counters_t mib; | 
 | 	struct net_device_stats stats; | 
 |  | 
 | 	int io_size; | 
 | 	int port_num;		// 0 or 1 | 
 | 	u32 port_offset; | 
 |  | 
 | 	int phy_addr;		// PHY address | 
 | 	u32 last_psr;		// last value of the port status register | 
 |  | 
 | 	int options;		/* User-settable misc. driver options. */ | 
 | 	int drv_flags; | 
 | 	spinlock_t lock;	/* Serialise access to device */ | 
 | 	struct mii_if_info mii_if; | 
 |  | 
 | 	u32 msg_enable; | 
 | }; | 
 |  | 
 | #endif /* _GT64240ETH_H */ |