mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 559fb51ba7
			
		
	
	
		559fb51ba7
		
	
	
	
	
		
			
			- Use extern prefix for functions required.
- Removed a lot of wrappers, including t1_read/write_reg_4.
- Removed various macros, using native kernel calls now.
- Enumerated various #defines.
- Removed a lot of shared code which is not currently used in "NIC only" mode.
- Removed dead code.
Documentation/networking/cxgb.txt:
- Updated release notes for version 2.1.1
drivers/net/chelsio/ch_ethtool.h
- removed file, no longer using ETHTOOL namespace.
drivers/net/chelsio/common.h
- moved code from osdep.h to common.h
- added comment to #endif indicating which symbol it closes.
drivers/net/chelsio/cphy.h
- removed dead code.
- added comment to #endif indicating which symbol it closes.
drivers/net/chelsio/cxgb2.c
- use DMA_{32,64}BIT_MASK in include/linux/dma-mapping.h.
- removed unused code.
- use printk message for link info resembling drivers/net/mii.c.
- no longer using the MODULE_xxx namespace.
- no longer using "pci_" namespace.
- no longer using ETHTOOL namespace.
drivers/net/chelsio/cxgb2.h
- removed file, merged into common.h
drivers/net/chelsio/elmer0.h
- removed dead code.
- added various enums.
- added comment to #endif indicating which symbol it closes.
drivers/net/chelsio/espi.c
- removed various macros, using native kernel calls now.
- removed a lot of wrappers, including t1_read/write_reg_4.
drivers/net/chelsio/espi.h
- added comment to #endif indicating which symbol it closes.
drivers/net/chelsio/gmac.h
- added comment to #endif indicating which symbol it closes.
drivers/net/chelsio/mv88x201x.c
- changes to sync with Chelsio TOT.
drivers/net/chelsio/osdep.h
- removed file, consolidation. osdep was used to translate wrapper functions
  since our code supports multiple OSs. removed wrappers.
  drivers/net/chelsio/pm3393.c
  - removed various macros, using native kernel calls now.
  - removed a lot of wrappers, including t1_read/write_reg_4.
  - removed unused code.
  drivers/net/chelsio/regs.h
  - added a few register entries for future and current feature support.
  - added comment to #endif indicating which symbol it closes.
  drivers/net/chelsio/sge.c
  - rewrote large portion of scatter-gather engine to stabilize
  performance.
  - using u8/u16/u32 kernel types instead of __u8/__u16/__u32 compiler
  types.
  drivers/net/chelsio/sge.h
  - rewrote large portion of scatter-gather engine to stabilize
  performance.
  - added comment to #endif indicating which symbol it closes.
  drivers/net/chelsio/subr.c
  - merged tp.c into subr.c
  - removed various macros, using native kernel calls now.
  - removed a lot of wrappers, including t1_read/write_reg_4.
  - removed unused code.
  drivers/net/chelsio/suni1x10gexp_regs.h
  - modified copyright and authorship of file.
  - added comment to #endif indicating which symbol it closes.
  drivers/net/chelsio/tp.c
  - removed file, merged into subr.c.
  drivers/net/chelsio/tp.h
  - removed file.
  include/linux/pci_ids.h
  - patched to include PCI_VENDOR_ID_CHELSIO 0x1425, removed define from
  our code.
		
	
			
		
			
				
	
	
		
			469 lines
		
	
	
		
			15 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			469 lines
		
	
	
		
			15 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*****************************************************************************
 | |
|  *                                                                           *
 | |
|  * File: regs.h                                                              *
 | |
|  * $Revision: 1.8 $                                                          *
 | |
|  * $Date: 2005/06/21 18:29:48 $                                              *
 | |
|  * Description:                                                              *
 | |
|  *  part of the Chelsio 10Gb Ethernet Driver.                                *
 | |
|  *                                                                           *
 | |
|  * This program is free software; you can redistribute it and/or modify      *
 | |
|  * it under the terms of the GNU General Public License, version 2, as       *
 | |
|  * published by the Free Software Foundation.                                *
 | |
|  *                                                                           *
 | |
|  * 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.                 *
 | |
|  *                                                                           *
 | |
|  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR IMPLIED    *
 | |
|  * WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF      *
 | |
|  * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.                     *
 | |
|  *                                                                           *
 | |
|  * http://www.chelsio.com                                                    *
 | |
|  *                                                                           *
 | |
|  * Copyright (c) 2003 - 2005 Chelsio Communications, Inc.                    *
 | |
|  * All rights reserved.                                                      *
 | |
|  *                                                                           *
 | |
|  * Maintainers: maintainers@chelsio.com                                      *
 | |
|  *                                                                           *
 | |
|  * Authors: Dimitrios Michailidis   <dm@chelsio.com>                         *
 | |
|  *          Tina Yang               <tainay@chelsio.com>                     *
 | |
|  *          Felix Marti             <felix@chelsio.com>                      *
 | |
|  *          Scott Bardone           <sbardone@chelsio.com>                   *
 | |
|  *          Kurt Ottaway            <kottaway@chelsio.com>                   *
 | |
|  *          Frank DiMambro          <frank@chelsio.com>                      *
 | |
|  *                                                                           *
 | |
|  * History:                                                                  *
 | |
|  *                                                                           *
 | |
|  ****************************************************************************/
 | |
| 
 | |
| #ifndef _CXGB_REGS_H_
 | |
| #define _CXGB_REGS_H_
 | |
| 
 | |
| /* SGE registers */
 | |
| #define A_SG_CONTROL 0x0
 | |
| 
 | |
| #define S_CMDQ0_ENABLE    0
 | |
| #define V_CMDQ0_ENABLE(x) ((x) << S_CMDQ0_ENABLE)
 | |
| #define F_CMDQ0_ENABLE    V_CMDQ0_ENABLE(1U)
 | |
| 
 | |
| #define S_CMDQ1_ENABLE    1
 | |
| #define V_CMDQ1_ENABLE(x) ((x) << S_CMDQ1_ENABLE)
 | |
| #define F_CMDQ1_ENABLE    V_CMDQ1_ENABLE(1U)
 | |
| 
 | |
| #define S_FL0_ENABLE    2
 | |
| #define V_FL0_ENABLE(x) ((x) << S_FL0_ENABLE)
 | |
| #define F_FL0_ENABLE    V_FL0_ENABLE(1U)
 | |
| 
 | |
| #define S_FL1_ENABLE    3
 | |
| #define V_FL1_ENABLE(x) ((x) << S_FL1_ENABLE)
 | |
| #define F_FL1_ENABLE    V_FL1_ENABLE(1U)
 | |
| 
 | |
| #define S_CPL_ENABLE    4
 | |
| #define V_CPL_ENABLE(x) ((x) << S_CPL_ENABLE)
 | |
| #define F_CPL_ENABLE    V_CPL_ENABLE(1U)
 | |
| 
 | |
| #define S_RESPONSE_QUEUE_ENABLE    5
 | |
| #define V_RESPONSE_QUEUE_ENABLE(x) ((x) << S_RESPONSE_QUEUE_ENABLE)
 | |
| #define F_RESPONSE_QUEUE_ENABLE    V_RESPONSE_QUEUE_ENABLE(1U)
 | |
| 
 | |
| #define S_CMDQ_PRIORITY    6
 | |
| #define M_CMDQ_PRIORITY    0x3
 | |
| #define V_CMDQ_PRIORITY(x) ((x) << S_CMDQ_PRIORITY)
 | |
| #define G_CMDQ_PRIORITY(x) (((x) >> S_CMDQ_PRIORITY) & M_CMDQ_PRIORITY)
 | |
| 
 | |
| #define S_DISABLE_CMDQ1_GTS    9
 | |
| #define V_DISABLE_CMDQ1_GTS(x) ((x) << S_DISABLE_CMDQ1_GTS)
 | |
| #define F_DISABLE_CMDQ1_GTS    V_DISABLE_CMDQ1_GTS(1U)
 | |
| 
 | |
| #define S_DISABLE_FL0_GTS    10
 | |
| #define V_DISABLE_FL0_GTS(x) ((x) << S_DISABLE_FL0_GTS)
 | |
| #define F_DISABLE_FL0_GTS    V_DISABLE_FL0_GTS(1U)
 | |
| 
 | |
| #define S_DISABLE_FL1_GTS    11
 | |
| #define V_DISABLE_FL1_GTS(x) ((x) << S_DISABLE_FL1_GTS)
 | |
| #define F_DISABLE_FL1_GTS    V_DISABLE_FL1_GTS(1U)
 | |
| 
 | |
| #define S_ENABLE_BIG_ENDIAN    12
 | |
| #define V_ENABLE_BIG_ENDIAN(x) ((x) << S_ENABLE_BIG_ENDIAN)
 | |
| #define F_ENABLE_BIG_ENDIAN    V_ENABLE_BIG_ENDIAN(1U)
 | |
| 
 | |
| #define S_ISCSI_COALESCE    14
 | |
| #define V_ISCSI_COALESCE(x) ((x) << S_ISCSI_COALESCE)
 | |
| #define F_ISCSI_COALESCE    V_ISCSI_COALESCE(1U)
 | |
| 
 | |
| #define S_RX_PKT_OFFSET    15
 | |
| #define V_RX_PKT_OFFSET(x) ((x) << S_RX_PKT_OFFSET)
 | |
| 
 | |
| #define S_VLAN_XTRACT    18
 | |
| #define V_VLAN_XTRACT(x) ((x) << S_VLAN_XTRACT)
 | |
| #define F_VLAN_XTRACT    V_VLAN_XTRACT(1U)
 | |
| 
 | |
| #define A_SG_DOORBELL 0x4
 | |
| #define A_SG_CMD0BASELWR 0x8
 | |
| #define A_SG_CMD0BASEUPR 0xc
 | |
| #define A_SG_CMD1BASELWR 0x10
 | |
| #define A_SG_CMD1BASEUPR 0x14
 | |
| #define A_SG_FL0BASELWR 0x18
 | |
| #define A_SG_FL0BASEUPR 0x1c
 | |
| #define A_SG_FL1BASELWR 0x20
 | |
| #define A_SG_FL1BASEUPR 0x24
 | |
| #define A_SG_CMD0SIZE 0x28
 | |
| #define A_SG_FL0SIZE 0x2c
 | |
| #define A_SG_RSPSIZE 0x30
 | |
| #define A_SG_RSPBASELWR 0x34
 | |
| #define A_SG_RSPBASEUPR 0x38
 | |
| #define A_SG_FLTHRESHOLD 0x3c
 | |
| #define A_SG_RSPQUEUECREDIT 0x40
 | |
| #define A_SG_SLEEPING 0x48
 | |
| #define A_SG_INTRTIMER 0x4c
 | |
| #define A_SG_CMD1SIZE 0xb0
 | |
| #define A_SG_FL1SIZE 0xb4
 | |
| #define A_SG_INT_ENABLE 0xb8
 | |
| 
 | |
| #define S_RESPQ_EXHAUSTED    0
 | |
| #define V_RESPQ_EXHAUSTED(x) ((x) << S_RESPQ_EXHAUSTED)
 | |
| #define F_RESPQ_EXHAUSTED    V_RESPQ_EXHAUSTED(1U)
 | |
| 
 | |
| #define S_RESPQ_OVERFLOW    1
 | |
| #define V_RESPQ_OVERFLOW(x) ((x) << S_RESPQ_OVERFLOW)
 | |
| #define F_RESPQ_OVERFLOW    V_RESPQ_OVERFLOW(1U)
 | |
| 
 | |
| #define S_FL_EXHAUSTED    2
 | |
| #define V_FL_EXHAUSTED(x) ((x) << S_FL_EXHAUSTED)
 | |
| #define F_FL_EXHAUSTED    V_FL_EXHAUSTED(1U)
 | |
| 
 | |
| #define S_PACKET_TOO_BIG    3
 | |
| #define V_PACKET_TOO_BIG(x) ((x) << S_PACKET_TOO_BIG)
 | |
| #define F_PACKET_TOO_BIG    V_PACKET_TOO_BIG(1U)
 | |
| 
 | |
| #define S_PACKET_MISMATCH    4
 | |
| #define V_PACKET_MISMATCH(x) ((x) << S_PACKET_MISMATCH)
 | |
| #define F_PACKET_MISMATCH    V_PACKET_MISMATCH(1U)
 | |
| 
 | |
| #define A_SG_INT_CAUSE 0xbc
 | |
| #define A_SG_RESPACCUTIMER 0xc0
 | |
| 
 | |
| /* MC3 registers */
 | |
| 
 | |
| #define S_READY    1
 | |
| #define V_READY(x) ((x) << S_READY)
 | |
| #define F_READY    V_READY(1U)
 | |
| 
 | |
| /* MC4 registers */
 | |
| 
 | |
| #define A_MC4_CFG 0x180
 | |
| #define S_MC4_SLOW    25
 | |
| #define V_MC4_SLOW(x) ((x) << S_MC4_SLOW)
 | |
| #define F_MC4_SLOW    V_MC4_SLOW(1U)
 | |
| 
 | |
| /* TPI registers */
 | |
| 
 | |
| #define A_TPI_ADDR 0x280
 | |
| #define A_TPI_WR_DATA 0x284
 | |
| #define A_TPI_RD_DATA 0x288
 | |
| #define A_TPI_CSR 0x28c
 | |
| 
 | |
| #define S_TPIWR    0
 | |
| #define V_TPIWR(x) ((x) << S_TPIWR)
 | |
| #define F_TPIWR    V_TPIWR(1U)
 | |
| 
 | |
| #define S_TPIRDY    1
 | |
| #define V_TPIRDY(x) ((x) << S_TPIRDY)
 | |
| #define F_TPIRDY    V_TPIRDY(1U)
 | |
| 
 | |
| #define A_TPI_PAR 0x29c
 | |
| 
 | |
| #define S_TPIPAR    0
 | |
| #define M_TPIPAR    0x7f
 | |
| #define V_TPIPAR(x) ((x) << S_TPIPAR)
 | |
| #define G_TPIPAR(x) (((x) >> S_TPIPAR) & M_TPIPAR)
 | |
| 
 | |
| /* TP registers */
 | |
| 
 | |
| #define A_TP_IN_CONFIG 0x300
 | |
| 
 | |
| #define S_TP_IN_CSPI_CPL    3
 | |
| #define V_TP_IN_CSPI_CPL(x) ((x) << S_TP_IN_CSPI_CPL)
 | |
| #define F_TP_IN_CSPI_CPL    V_TP_IN_CSPI_CPL(1U)
 | |
| 
 | |
| #define S_TP_IN_CSPI_CHECK_IP_CSUM    5
 | |
| #define V_TP_IN_CSPI_CHECK_IP_CSUM(x) ((x) << S_TP_IN_CSPI_CHECK_IP_CSUM)
 | |
| #define F_TP_IN_CSPI_CHECK_IP_CSUM    V_TP_IN_CSPI_CHECK_IP_CSUM(1U)
 | |
| 
 | |
| #define S_TP_IN_CSPI_CHECK_TCP_CSUM    6
 | |
| #define V_TP_IN_CSPI_CHECK_TCP_CSUM(x) ((x) << S_TP_IN_CSPI_CHECK_TCP_CSUM)
 | |
| #define F_TP_IN_CSPI_CHECK_TCP_CSUM    V_TP_IN_CSPI_CHECK_TCP_CSUM(1U)
 | |
| 
 | |
| #define S_TP_IN_ESPI_ETHERNET    8
 | |
| #define V_TP_IN_ESPI_ETHERNET(x) ((x) << S_TP_IN_ESPI_ETHERNET)
 | |
| #define F_TP_IN_ESPI_ETHERNET    V_TP_IN_ESPI_ETHERNET(1U)
 | |
| 
 | |
| #define S_TP_IN_ESPI_CHECK_IP_CSUM    12
 | |
| #define V_TP_IN_ESPI_CHECK_IP_CSUM(x) ((x) << S_TP_IN_ESPI_CHECK_IP_CSUM)
 | |
| #define F_TP_IN_ESPI_CHECK_IP_CSUM    V_TP_IN_ESPI_CHECK_IP_CSUM(1U)
 | |
| 
 | |
| #define S_TP_IN_ESPI_CHECK_TCP_CSUM    13
 | |
| #define V_TP_IN_ESPI_CHECK_TCP_CSUM(x) ((x) << S_TP_IN_ESPI_CHECK_TCP_CSUM)
 | |
| #define F_TP_IN_ESPI_CHECK_TCP_CSUM    V_TP_IN_ESPI_CHECK_TCP_CSUM(1U)
 | |
| 
 | |
| #define S_OFFLOAD_DISABLE    14
 | |
| #define V_OFFLOAD_DISABLE(x) ((x) << S_OFFLOAD_DISABLE)
 | |
| #define F_OFFLOAD_DISABLE    V_OFFLOAD_DISABLE(1U)
 | |
| 
 | |
| #define A_TP_OUT_CONFIG 0x304
 | |
| 
 | |
| #define S_TP_OUT_CSPI_CPL    2
 | |
| #define V_TP_OUT_CSPI_CPL(x) ((x) << S_TP_OUT_CSPI_CPL)
 | |
| #define F_TP_OUT_CSPI_CPL    V_TP_OUT_CSPI_CPL(1U)
 | |
| 
 | |
| #define S_TP_OUT_ESPI_ETHERNET    6
 | |
| #define V_TP_OUT_ESPI_ETHERNET(x) ((x) << S_TP_OUT_ESPI_ETHERNET)
 | |
| #define F_TP_OUT_ESPI_ETHERNET    V_TP_OUT_ESPI_ETHERNET(1U)
 | |
| 
 | |
| #define S_TP_OUT_ESPI_GENERATE_IP_CSUM    10
 | |
| #define V_TP_OUT_ESPI_GENERATE_IP_CSUM(x) ((x) << S_TP_OUT_ESPI_GENERATE_IP_CSUM)
 | |
| #define F_TP_OUT_ESPI_GENERATE_IP_CSUM    V_TP_OUT_ESPI_GENERATE_IP_CSUM(1U)
 | |
| 
 | |
| #define S_TP_OUT_ESPI_GENERATE_TCP_CSUM    11
 | |
| #define V_TP_OUT_ESPI_GENERATE_TCP_CSUM(x) ((x) << S_TP_OUT_ESPI_GENERATE_TCP_CSUM)
 | |
| #define F_TP_OUT_ESPI_GENERATE_TCP_CSUM    V_TP_OUT_ESPI_GENERATE_TCP_CSUM(1U)
 | |
| 
 | |
| #define A_TP_GLOBAL_CONFIG 0x308
 | |
| 
 | |
| #define S_IP_TTL    0
 | |
| #define M_IP_TTL    0xff
 | |
| #define V_IP_TTL(x) ((x) << S_IP_TTL)
 | |
| 
 | |
| #define S_TCP_CSUM    11
 | |
| #define V_TCP_CSUM(x) ((x) << S_TCP_CSUM)
 | |
| #define F_TCP_CSUM    V_TCP_CSUM(1U)
 | |
| 
 | |
| #define S_UDP_CSUM    12
 | |
| #define V_UDP_CSUM(x) ((x) << S_UDP_CSUM)
 | |
| #define F_UDP_CSUM    V_UDP_CSUM(1U)
 | |
| 
 | |
| #define S_IP_CSUM    13
 | |
| #define V_IP_CSUM(x) ((x) << S_IP_CSUM)
 | |
| #define F_IP_CSUM    V_IP_CSUM(1U)
 | |
| 
 | |
| #define S_PATH_MTU    15
 | |
| #define V_PATH_MTU(x) ((x) << S_PATH_MTU)
 | |
| #define F_PATH_MTU    V_PATH_MTU(1U)
 | |
| 
 | |
| #define S_5TUPLE_LOOKUP    17
 | |
| #define V_5TUPLE_LOOKUP(x) ((x) << S_5TUPLE_LOOKUP)
 | |
| 
 | |
| #define S_SYN_COOKIE_PARAMETER    26
 | |
| #define V_SYN_COOKIE_PARAMETER(x) ((x) << S_SYN_COOKIE_PARAMETER)
 | |
| 
 | |
| #define A_TP_PC_CONFIG 0x348
 | |
| #define S_DIS_TX_FILL_WIN_PUSH    12
 | |
| #define V_DIS_TX_FILL_WIN_PUSH(x) ((x) << S_DIS_TX_FILL_WIN_PUSH)
 | |
| #define F_DIS_TX_FILL_WIN_PUSH    V_DIS_TX_FILL_WIN_PUSH(1U)
 | |
| 
 | |
| #define S_TP_PC_REV    30
 | |
| #define M_TP_PC_REV    0x3
 | |
| #define G_TP_PC_REV(x) (((x) >> S_TP_PC_REV) & M_TP_PC_REV)
 | |
| #define A_TP_RESET 0x44c
 | |
| #define S_TP_RESET    0
 | |
| #define V_TP_RESET(x) ((x) << S_TP_RESET)
 | |
| #define F_TP_RESET    V_TP_RESET(1U)
 | |
| 
 | |
| #define A_TP_INT_ENABLE 0x470
 | |
| #define A_TP_INT_CAUSE 0x474
 | |
| #define A_TP_TX_DROP_CONFIG 0x4b8
 | |
| 
 | |
| #define S_ENABLE_TX_DROP    31
 | |
| #define V_ENABLE_TX_DROP(x) ((x) << S_ENABLE_TX_DROP)
 | |
| #define F_ENABLE_TX_DROP    V_ENABLE_TX_DROP(1U)
 | |
| 
 | |
| #define S_ENABLE_TX_ERROR    30
 | |
| #define V_ENABLE_TX_ERROR(x) ((x) << S_ENABLE_TX_ERROR)
 | |
| #define F_ENABLE_TX_ERROR    V_ENABLE_TX_ERROR(1U)
 | |
| 
 | |
| #define S_DROP_TICKS_CNT    4
 | |
| #define V_DROP_TICKS_CNT(x) ((x) << S_DROP_TICKS_CNT)
 | |
| 
 | |
| #define S_NUM_PKTS_DROPPED    0
 | |
| #define V_NUM_PKTS_DROPPED(x) ((x) << S_NUM_PKTS_DROPPED)
 | |
| 
 | |
| /* CSPI registers */
 | |
| 
 | |
| #define S_DIP4ERR    0
 | |
| #define V_DIP4ERR(x) ((x) << S_DIP4ERR)
 | |
| #define F_DIP4ERR    V_DIP4ERR(1U)
 | |
| 
 | |
| #define S_RXDROP    1
 | |
| #define V_RXDROP(x) ((x) << S_RXDROP)
 | |
| #define F_RXDROP    V_RXDROP(1U)
 | |
| 
 | |
| #define S_TXDROP    2
 | |
| #define V_TXDROP(x) ((x) << S_TXDROP)
 | |
| #define F_TXDROP    V_TXDROP(1U)
 | |
| 
 | |
| #define S_RXOVERFLOW    3
 | |
| #define V_RXOVERFLOW(x) ((x) << S_RXOVERFLOW)
 | |
| #define F_RXOVERFLOW    V_RXOVERFLOW(1U)
 | |
| 
 | |
| #define S_RAMPARITYERR    4
 | |
| #define V_RAMPARITYERR(x) ((x) << S_RAMPARITYERR)
 | |
| #define F_RAMPARITYERR    V_RAMPARITYERR(1U)
 | |
| 
 | |
| /* ESPI registers */
 | |
| 
 | |
| #define A_ESPI_SCH_TOKEN0 0x880
 | |
| #define A_ESPI_SCH_TOKEN1 0x884
 | |
| #define A_ESPI_SCH_TOKEN2 0x888
 | |
| #define A_ESPI_SCH_TOKEN3 0x88c
 | |
| #define A_ESPI_RX_FIFO_ALMOST_EMPTY_WATERMARK 0x890
 | |
| #define A_ESPI_RX_FIFO_ALMOST_FULL_WATERMARK 0x894
 | |
| #define A_ESPI_CALENDAR_LENGTH 0x898
 | |
| #define A_PORT_CONFIG 0x89c
 | |
| 
 | |
| #define S_RX_NPORTS    0
 | |
| #define V_RX_NPORTS(x) ((x) << S_RX_NPORTS)
 | |
| 
 | |
| #define S_TX_NPORTS    8
 | |
| #define V_TX_NPORTS(x) ((x) << S_TX_NPORTS)
 | |
| 
 | |
| #define A_ESPI_FIFO_STATUS_ENABLE 0x8a0
 | |
| 
 | |
| #define S_RXSTATUSENABLE    0
 | |
| #define V_RXSTATUSENABLE(x) ((x) << S_RXSTATUSENABLE)
 | |
| #define F_RXSTATUSENABLE    V_RXSTATUSENABLE(1U)
 | |
| 
 | |
| #define S_INTEL1010MODE    4
 | |
| #define V_INTEL1010MODE(x) ((x) << S_INTEL1010MODE)
 | |
| #define F_INTEL1010MODE    V_INTEL1010MODE(1U)
 | |
| 
 | |
| #define A_ESPI_MAXBURST1_MAXBURST2 0x8a8
 | |
| #define A_ESPI_TRAIN 0x8ac
 | |
| #define A_ESPI_INTR_STATUS 0x8c8
 | |
| 
 | |
| #define S_DIP2PARITYERR    5
 | |
| #define V_DIP2PARITYERR(x) ((x) << S_DIP2PARITYERR)
 | |
| #define F_DIP2PARITYERR    V_DIP2PARITYERR(1U)
 | |
| 
 | |
| #define A_ESPI_INTR_ENABLE 0x8cc
 | |
| #define A_RX_DROP_THRESHOLD 0x8d0
 | |
| #define A_ESPI_RX_RESET 0x8ec
 | |
| #define A_ESPI_MISC_CONTROL 0x8f0
 | |
| 
 | |
| #define S_OUT_OF_SYNC_COUNT    0
 | |
| #define V_OUT_OF_SYNC_COUNT(x) ((x) << S_OUT_OF_SYNC_COUNT)
 | |
| 
 | |
| #define S_DIP2_PARITY_ERR_THRES    5
 | |
| #define V_DIP2_PARITY_ERR_THRES(x) ((x) << S_DIP2_PARITY_ERR_THRES)
 | |
| 
 | |
| #define S_DIP4_THRES    9
 | |
| #define V_DIP4_THRES(x) ((x) << S_DIP4_THRES)
 | |
| 
 | |
| #define S_MONITORED_PORT_NUM    25
 | |
| #define V_MONITORED_PORT_NUM(x) ((x) << S_MONITORED_PORT_NUM)
 | |
| 
 | |
| #define S_MONITORED_DIRECTION    27
 | |
| #define V_MONITORED_DIRECTION(x) ((x) << S_MONITORED_DIRECTION)
 | |
| #define F_MONITORED_DIRECTION    V_MONITORED_DIRECTION(1U)
 | |
| 
 | |
| #define S_MONITORED_INTERFACE    28
 | |
| #define V_MONITORED_INTERFACE(x) ((x) << S_MONITORED_INTERFACE)
 | |
| #define F_MONITORED_INTERFACE    V_MONITORED_INTERFACE(1U)
 | |
| 
 | |
| #define A_ESPI_DIP2_ERR_COUNT 0x8f4
 | |
| #define A_ESPI_CMD_ADDR 0x8f8
 | |
| 
 | |
| #define S_WRITE_DATA    0
 | |
| #define V_WRITE_DATA(x) ((x) << S_WRITE_DATA)
 | |
| 
 | |
| #define S_REGISTER_OFFSET    8
 | |
| #define V_REGISTER_OFFSET(x) ((x) << S_REGISTER_OFFSET)
 | |
| 
 | |
| #define S_CHANNEL_ADDR    12
 | |
| #define V_CHANNEL_ADDR(x) ((x) << S_CHANNEL_ADDR)
 | |
| 
 | |
| #define S_MODULE_ADDR    16
 | |
| #define V_MODULE_ADDR(x) ((x) << S_MODULE_ADDR)
 | |
| 
 | |
| #define S_BUNDLE_ADDR    20
 | |
| #define V_BUNDLE_ADDR(x) ((x) << S_BUNDLE_ADDR)
 | |
| 
 | |
| #define S_SPI4_COMMAND    24
 | |
| #define V_SPI4_COMMAND(x) ((x) << S_SPI4_COMMAND)
 | |
| 
 | |
| #define A_ESPI_GOSTAT 0x8fc
 | |
| #define S_ESPI_CMD_BUSY    8
 | |
| #define V_ESPI_CMD_BUSY(x) ((x) << S_ESPI_CMD_BUSY)
 | |
| #define F_ESPI_CMD_BUSY    V_ESPI_CMD_BUSY(1U)
 | |
| 
 | |
| /* PL registers */
 | |
| 
 | |
| #define A_PL_ENABLE 0xa00
 | |
| 
 | |
| #define S_PL_INTR_SGE_ERR    0
 | |
| #define V_PL_INTR_SGE_ERR(x) ((x) << S_PL_INTR_SGE_ERR)
 | |
| #define F_PL_INTR_SGE_ERR    V_PL_INTR_SGE_ERR(1U)
 | |
| 
 | |
| #define S_PL_INTR_SGE_DATA    1
 | |
| #define V_PL_INTR_SGE_DATA(x) ((x) << S_PL_INTR_SGE_DATA)
 | |
| #define F_PL_INTR_SGE_DATA    V_PL_INTR_SGE_DATA(1U)
 | |
| 
 | |
| #define S_PL_INTR_TP    6
 | |
| #define V_PL_INTR_TP(x) ((x) << S_PL_INTR_TP)
 | |
| #define F_PL_INTR_TP    V_PL_INTR_TP(1U)
 | |
| 
 | |
| #define S_PL_INTR_ESPI    8
 | |
| #define V_PL_INTR_ESPI(x) ((x) << S_PL_INTR_ESPI)
 | |
| #define F_PL_INTR_ESPI    V_PL_INTR_ESPI(1U)
 | |
| 
 | |
| #define S_PL_INTR_PCIX    10
 | |
| #define V_PL_INTR_PCIX(x) ((x) << S_PL_INTR_PCIX)
 | |
| #define F_PL_INTR_PCIX    V_PL_INTR_PCIX(1U)
 | |
| 
 | |
| #define S_PL_INTR_EXT    11
 | |
| #define V_PL_INTR_EXT(x) ((x) << S_PL_INTR_EXT)
 | |
| #define F_PL_INTR_EXT    V_PL_INTR_EXT(1U)
 | |
| 
 | |
| #define A_PL_CAUSE 0xa04
 | |
| 
 | |
| /* MC5 registers */
 | |
| 
 | |
| #define A_MC5_CONFIG 0xc04
 | |
| 
 | |
| #define S_TCAM_RESET    1
 | |
| #define V_TCAM_RESET(x) ((x) << S_TCAM_RESET)
 | |
| #define F_TCAM_RESET    V_TCAM_RESET(1U)
 | |
| 
 | |
| #define S_M_BUS_ENABLE    5
 | |
| #define V_M_BUS_ENABLE(x) ((x) << S_M_BUS_ENABLE)
 | |
| #define F_M_BUS_ENABLE    V_M_BUS_ENABLE(1U)
 | |
| 
 | |
| /* PCICFG registers */
 | |
| 
 | |
| #define A_PCICFG_PM_CSR 0x44
 | |
| #define A_PCICFG_VPD_ADDR 0x4a
 | |
| 
 | |
| #define S_VPD_OP_FLAG    15
 | |
| #define V_VPD_OP_FLAG(x) ((x) << S_VPD_OP_FLAG)
 | |
| #define F_VPD_OP_FLAG    V_VPD_OP_FLAG(1U)
 | |
| 
 | |
| #define A_PCICFG_VPD_DATA 0x4c
 | |
| 
 | |
| #define A_PCICFG_INTR_ENABLE 0xf4
 | |
| #define A_PCICFG_INTR_CAUSE 0xf8
 | |
| 
 | |
| #define A_PCICFG_MODE 0xfc
 | |
| 
 | |
| #define S_PCI_MODE_64BIT    0
 | |
| #define V_PCI_MODE_64BIT(x) ((x) << S_PCI_MODE_64BIT)
 | |
| #define F_PCI_MODE_64BIT    V_PCI_MODE_64BIT(1U)
 | |
| 
 | |
| #define S_PCI_MODE_PCIX    5
 | |
| #define V_PCI_MODE_PCIX(x) ((x) << S_PCI_MODE_PCIX)
 | |
| #define F_PCI_MODE_PCIX    V_PCI_MODE_PCIX(1U)
 | |
| 
 | |
| #define S_PCI_MODE_CLK    6
 | |
| #define M_PCI_MODE_CLK    0x3
 | |
| #define G_PCI_MODE_CLK(x) (((x) >> S_PCI_MODE_CLK) & M_PCI_MODE_CLK)
 | |
| 
 | |
| #endif /* _CXGB_REGS_H_ */
 |