gt64240eth.h

来自「Linux Kernel 2.6.9 for OMAP1710」· C头文件 代码 · 共 403 行

H
403
字号
/* * 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_ENDIANtypedef 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 counterstypedef 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 */

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?