Home | History | Annotate | Line # | Download | only in igc
igc_regs.h revision 1.2
      1  1.2  rin /*	$NetBSD: igc_regs.h,v 1.2 2023/10/04 07:35:27 rin Exp $	*/
      2  1.1  rin /*	$OpenBSD: igc_regs.h,v 1.2 2023/08/15 08:27:30 miod Exp $	*/
      3  1.1  rin /*-
      4  1.1  rin  * Copyright 2021 Intel Corp
      5  1.1  rin  * Copyright 2021 Rubicon Communications, LLC (Netgate)
      6  1.1  rin  * SPDX-License-Identifier: BSD-3-Clause
      7  1.1  rin  *
      8  1.1  rin  * $FreeBSD$
      9  1.1  rin  */
     10  1.1  rin 
     11  1.1  rin #ifndef _IGC_REGS_H_
     12  1.1  rin #define _IGC_REGS_H_
     13  1.1  rin 
     14  1.1  rin /* General Register Descriptions */
     15  1.1  rin #define IGC_CTRL		0x00000	/* Device Control - RW */
     16  1.1  rin #define IGC_STATUS		0x00008	/* Device Status - RO */
     17  1.1  rin #define IGC_EECD		0x00010	/* EEPROM/Flash Control - RW */
     18  1.1  rin /* NVM  Register Descriptions */
     19  1.1  rin #define IGC_EERD		0x12014	/* EEprom mode read - RW */
     20  1.1  rin #define IGC_EEWR		0x12018	/* EEprom mode write - RW */
     21  1.1  rin #define IGC_CTRL_EXT		0x00018	/* Extended Device Control - RW */
     22  1.1  rin #define IGC_MDIC		0x00020	/* MDI Control - RW */
     23  1.1  rin #define IGC_MDICNFG		0x00E04	/* MDI Config - RW */
     24  1.1  rin #define IGC_FCAL		0x00028	/* Flow Control Address Low - RW */
     25  1.1  rin #define IGC_FCAH		0x0002C	/* Flow Control Address High -RW */
     26  1.1  rin #define IGC_I225_FLSWCTL	0x12048	/* FLASH control register */
     27  1.1  rin #define IGC_I225_FLSWDATA	0x1204C	/* FLASH data register */
     28  1.1  rin #define IGC_I225_FLSWCNT	0x12050	/* FLASH Access Counter */
     29  1.1  rin #define IGC_I225_FLSECU		0x12114	/* FLASH Security */
     30  1.1  rin #define IGC_FCT			0x00030	/* Flow Control Type - RW */
     31  1.1  rin #define IGC_CONNSW		0x00034	/* Copper/Fiber switch control - RW */
     32  1.1  rin #define IGC_VET			0x00038	/* VLAN Ether Type - RW */
     33  1.1  rin #define IGC_ICR			0x01500	/* Intr Cause Read - RC/W1C */
     34  1.1  rin #define IGC_ITR			0x000C4	/* Interrupt Throttling Rate - RW */
     35  1.1  rin #define IGC_ICS			0x01504	/* Intr Cause Set - WO */
     36  1.1  rin #define IGC_IMS			0x01508	/* Intr Mask Set/Read - RW */
     37  1.1  rin #define IGC_IMC			0x0150C	/* Intr Mask Clear - WO */
     38  1.1  rin #define IGC_IAM			0x01510	/* Intr Ack Auto Mask- RW */
     39  1.1  rin #define IGC_RCTL		0x00100	/* Rx Control - RW */
     40  1.1  rin #define IGC_FCTTV		0x00170	/* Flow Control Transmit Timer Value */
     41  1.1  rin #define IGC_TXCW		0x00178	/* Tx Configuration Word - RW */
     42  1.1  rin #define IGC_RXCW		0x00180	/* Rx Configuration Word - RO */
     43  1.1  rin #define IGC_EICR		0x01580	/* Ext. Interrupt Cause Read - R/clr */
     44  1.1  rin #define IGC_EITR(_n)		(0x01680 + (0x4 * (_n)))
     45  1.1  rin #define IGC_EICS		0x01520	/* Ext. Interrupt Cause Set - W0 */
     46  1.1  rin #define IGC_EIMS		0x01524	/* Ext. Interrupt Mask Set/Read - RW */
     47  1.1  rin #define IGC_EIMC		0x01528	/* Ext. Interrupt Mask Clear - WO */
     48  1.1  rin #define IGC_EIAC		0x0152C	/* Ext. Interrupt Auto Clear - RW */
     49  1.1  rin #define IGC_EIAM		0x01530	/* Ext. Interrupt Ack Auto Clear
     50  1.1  rin 					 * Mask */
     51  1.1  rin #define IGC_GPIE		0x01514	/* General Purpose Interrupt Enable
     52  1.1  rin 					 * - RW */
     53  1.1  rin #define IGC_IVAR0		0x01700	/* Interrupt Vector Allocation (array)
     54  1.1  rin 					 * - RW */
     55  1.1  rin #define IGC_IVAR_MISC		0x01740	/* IVAR for "other" causes - RW */
     56  1.1  rin #define IGC_TCTL		0x00400	/* Tx Control - RW */
     57  1.1  rin #define IGC_TCTL_EXT		0x00404	/* Extended Tx Control - RW */
     58  1.1  rin #define IGC_TIPG		0x00410	/* Tx Inter-packet gap -RW */
     59  1.1  rin #define IGC_AIT			0x00458	/* Adaptive Interframe Spacing
     60  1.1  rin 					 * Throttle - RW */
     61  1.1  rin #define IGC_LEDCTL		0x00E00	/* LED Control - RW */
     62  1.1  rin #define IGC_LEDMUX		0x08130	/* LED MUX Control */
     63  1.1  rin #define IGC_EXTCNF_CTRL		0x00F00	/* Extended Configuration Control */
     64  1.1  rin #define IGC_EXTCNF_SIZE		0x00F08	/* Extended Configuration Size */
     65  1.1  rin #define IGC_PHY_CTRL		0x00F10	/* PHY Control Register in CSR */
     66  1.1  rin #define IGC_PBA			0x01000	/* Packet Buffer Allocation - RW */
     67  1.1  rin #define IGC_PBS			0x01008	/* Packet Buffer Size */
     68  1.1  rin #define IGC_EEMNGCTL		0x01010	/* MNG EEprom Control */
     69  1.1  rin #define IGC_EEMNGCTL_I225	0x01010	/* i225 MNG EEprom Mode Control */
     70  1.1  rin #define IGC_EEARBC_I225		0x12024	/* EEPROM Auto Read Bus Control */
     71  1.1  rin #define IGC_FLOP		0x0103C	/* FLASH Opcode Register */
     72  1.1  rin #define IGC_WDSTP		0x01040	/* Watchdog Setup - RW */
     73  1.1  rin #define IGC_SWDSTS		0x01044	/* SW Device Status - RW */
     74  1.1  rin #define IGC_FRTIMER		0x01048	/* Free Running Timer - RW */
     75  1.1  rin #define IGC_TCPTIMER		0x0104C	/* TCP Timer - RW */
     76  1.1  rin #define IGC_ERT			0x02008	/* Early Rx Threshold - RW */
     77  1.1  rin #define IGC_FCRTL		0x02160	/* Flow Control Receive Threshold Low
     78  1.1  rin 					 * - RW */
     79  1.1  rin #define IGC_FCRTH		0x02168	/* Flow Control Receive Threshold High
     80  1.1  rin 					 * - RW */
     81  1.1  rin #define IGC_PSRCTL		0x02170	/* Packet Split Receive Control - RW */
     82  1.1  rin #define IGC_RDFH		0x02410	/* Rx Data FIFO Head - RW */
     83  1.1  rin #define IGC_RDFT		0x02418	/* Rx Data FIFO Tail - RW */
     84  1.1  rin #define IGC_RDFHS		0x02420	/* Rx Data FIFO Head Saved - RW */
     85  1.1  rin #define IGC_RDFTS		0x02428	/* Rx Data FIFO Tail Saved - RW */
     86  1.1  rin #define IGC_RDFPC		0x02430	/* Rx Data FIFO Packet Count - RW */
     87  1.1  rin #define IGC_PBRTH		0x02458	/* PB Rx Arbitration Threshold - RW */
     88  1.1  rin #define IGC_FCRTV		0x02460	/* Flow Control Refresh Timer Value
     89  1.1  rin 					 * - RW */
     90  1.1  rin /* Split and Replication Rx Control - RW */
     91  1.1  rin #define IGC_RXPBS		0x02404	/* Rx Packet Buffer Size - RW */
     92  1.1  rin #define IGC_RDTR		0x02820	/* Rx Delay Timer - RW */
     93  1.1  rin #define IGC_RADV		0x0282C	/* Rx Interrupt Absolute Delay Timer
     94  1.1  rin 					 * - RW */
     95  1.1  rin /* Shadow Ram Write Register - RW */
     96  1.1  rin #define IGC_SRWR		0x12018
     97  1.1  rin #define IGC_EEC_REG		0x12010
     98  1.1  rin 
     99  1.1  rin 
    100  1.1  rin #define IGC_SHADOWINF		0x12068
    101  1.1  rin #define IGC_FLFWUPDATE		0x12108
    102  1.1  rin 
    103  1.1  rin #define IGC_INVM_DATA_REG(_n)	(0x12120 + 4*(_n))
    104  1.1  rin #define IGC_INVM_SIZE		64	/* Number of INVM Data Registers */
    105  1.1  rin 
    106  1.1  rin #define IGC_MMDAC		13	/* MMD Access Control */
    107  1.1  rin #define IGC_MMDAAD		14	/* MMD Access Address/Data */
    108  1.1  rin /* Convenience macros
    109  1.1  rin  *
    110  1.1  rin  * Note: "_n" is the queue number of the register to be written to.
    111  1.1  rin  *
    112  1.1  rin  * Example usage:
    113  1.1  rin  * IGC_RDBAL_REG(current_rx_queue)
    114  1.1  rin  */
    115  1.1  rin #define IGC_RDBAL(_n)	((_n) < 4 ? (0x02800 + ((_n) * 0x100)) : \
    116  1.1  rin 			(0x0C000 + ((_n) * 0x40)))
    117  1.1  rin #define IGC_RDBAH(_n)	((_n) < 4 ? (0x02804 + ((_n) * 0x100)) : \
    118  1.1  rin 			(0x0C004 + ((_n) * 0x40)))
    119  1.1  rin #define IGC_RDLEN(_n)	((_n) < 4 ? (0x02808 + ((_n) * 0x100)) : \
    120  1.1  rin 			(0x0C008 + ((_n) * 0x40)))
    121  1.1  rin #define IGC_SRRCTL(_n)	((_n) < 4 ? (0x0280C + ((_n) * 0x100)) : \
    122  1.1  rin 			(0x0C00C + ((_n) * 0x40)))
    123  1.1  rin #define IGC_RDH(_n)	((_n) < 4 ? (0x02810 + ((_n) * 0x100)) : \
    124  1.1  rin 			(0x0C010 + ((_n) * 0x40)))
    125  1.1  rin #define IGC_RDT(_n)	((_n) < 4 ? (0x02818 + ((_n) * 0x100)) : \
    126  1.1  rin 			(0x0C018 + ((_n) * 0x40)))
    127  1.1  rin #define IGC_RXDCTL(_n)	((_n) < 4 ? (0x02828 + ((_n) * 0x100)) : \
    128  1.1  rin 			(0x0C028 + ((_n) * 0x40)))
    129  1.1  rin #define IGC_RQDPC(_n)	((_n) < 4 ? (0x02830 + ((_n) * 0x100)) : \
    130  1.1  rin 			(0x0C030 + ((_n) * 0x40)))
    131  1.1  rin #define IGC_TDBAL(_n)	((_n) < 4 ? (0x03800 + ((_n) * 0x100)) : \
    132  1.1  rin 			(0x0E000 + ((_n) * 0x40)))
    133  1.1  rin #define IGC_TDBAH(_n)	((_n) < 4 ? (0x03804 + ((_n) * 0x100)) : \
    134  1.1  rin 			(0x0E004 + ((_n) * 0x40)))
    135  1.1  rin #define IGC_TDLEN(_n)	((_n) < 4 ? (0x03808 + ((_n) * 0x100)) : \
    136  1.1  rin 			(0x0E008 + ((_n) * 0x40)))
    137  1.1  rin #define IGC_TDH(_n)	((_n) < 4 ? (0x03810 + ((_n) * 0x100)) : \
    138  1.1  rin 			(0x0E010 + ((_n) * 0x40)))
    139  1.1  rin #define IGC_TDT(_n)	((_n) < 4 ? (0x03818 + ((_n) * 0x100)) : \
    140  1.1  rin 			(0x0E018 + ((_n) * 0x40)))
    141  1.1  rin #define IGC_TXDCTL(_n)	((_n) < 4 ? (0x03828 + ((_n) * 0x100)) : \
    142  1.1  rin 			(0x0E028 + ((_n) * 0x40)))
    143  1.1  rin #define IGC_TARC(_n)		(0x03840 + ((_n) * 0x100))
    144  1.1  rin #define IGC_RSRPD		0x02C00	/* Rx Small Packet Detect - RW */
    145  1.1  rin #define IGC_RAID		0x02C08	/* Receive Ack Interrupt Delay - RW */
    146  1.1  rin #define IGC_KABGTXD		0x03004	/* AFE Band Gap Transmit Ref Data */
    147  1.1  rin #define IGC_PSRTYPE(_i)		(0x05480 + ((_i) * 4))
    148  1.1  rin #define IGC_RAL(_i)		(((_i) <= 15) ? (0x05400 + ((_i) * 8)) : \
    149  1.1  rin 				(0x054E0 + ((_i - 16) * 8)))
    150  1.1  rin #define IGC_RAH(_i)		(((_i) <= 15) ? (0x05404 + ((_i) * 8)) : \
    151  1.1  rin 				(0x054E4 + ((_i - 16) * 8)))
    152  1.1  rin #define IGC_VLANPQF		0x055B0	/* VLAN Priority Queue Filter VLAPQF */
    153  1.1  rin 
    154  1.1  rin #define IGC_SHRAL(_i)		(0x05438 + ((_i) * 8))
    155  1.1  rin #define IGC_SHRAH(_i)		(0x0543C + ((_i) * 8))
    156  1.1  rin #define IGC_IP4AT_REG(_i)	(0x05840 + ((_i) * 8))
    157  1.1  rin #define IGC_IP6AT_REG(_i)	(0x05880 + ((_i) * 4))
    158  1.1  rin #define IGC_WUPM_REG(_i)	(0x05A00 + ((_i) * 4))
    159  1.1  rin #define IGC_FFMT_REG(_i)	(0x09000 + ((_i) * 8))
    160  1.1  rin #define IGC_FFVT_REG(_i)	(0x09800 + ((_i) * 8))
    161  1.1  rin #define IGC_FFLT_REG(_i)	(0x05F00 + ((_i) * 8))
    162  1.1  rin #define IGC_TXPBS		0x03404  /* Tx Packet Buffer Size - RW */
    163  1.1  rin #define IGC_TIDV		0x03820  /* Tx Interrupt Delay Value - RW */
    164  1.1  rin #define IGC_TADV		0x0382C  /* Tx Interrupt Absolute Delay Val - RW */
    165  1.1  rin /* Statistics Register Descriptions */
    166  1.1  rin #define IGC_CRCERRS		0x04000  /* CRC Error Count - R/clr */
    167  1.1  rin #define IGC_ALGNERRC		0x04004  /* Alignment Error Count - R/clr */
    168  1.1  rin #define IGC_MPC			0x04010  /* Missed Packet Count - R/clr */
    169  1.1  rin #define IGC_SCC			0x04014  /* Single Collision Count - R/clr */
    170  1.1  rin #define IGC_ECOL		0x04018  /* Excessive Collision Count - R/clr */
    171  1.1  rin #define IGC_MCC			0x0401C  /* Multiple Collision Count - R/clr */
    172  1.1  rin #define IGC_LATECOL		0x04020  /* Late Collision Count - R/clr */
    173  1.1  rin #define IGC_COLC		0x04028  /* Collision Count - R/clr */
    174  1.1  rin #define IGC_RERC		0x0402C  /* Receive Error Count - R/clr */
    175  1.1  rin #define IGC_DC			0x04030  /* Defer Count - R/clr */
    176  1.1  rin #define IGC_TNCRS		0x04034  /* Tx-No CRS - R/clr */
    177  1.1  rin #define IGC_HTDPMC		0x0403C  /* Host Transmit Discarded by MAC - R/clr */
    178  1.1  rin #define IGC_RLEC		0x04040  /* Receive Length Error Count - R/clr */
    179  1.1  rin #define IGC_XONRXC		0x04048  /* XON Rx Count - R/clr */
    180  1.1  rin #define IGC_XONTXC		0x0404C  /* XON Tx Count - R/clr */
    181  1.1  rin #define IGC_XOFFRXC		0x04050  /* XOFF Rx Count - R/clr */
    182  1.1  rin #define IGC_XOFFTXC		0x04054  /* XOFF Tx Count - R/clr */
    183  1.1  rin #define IGC_FCRUC		0x04058  /* Flow Control Rx Unsupported Count- R/clr */
    184  1.1  rin #define IGC_PRC64		0x0405C  /* Packets Rx (64 bytes) - R/clr */
    185  1.1  rin #define IGC_PRC127		0x04060  /* Packets Rx (65-127 bytes) - R/clr */
    186  1.1  rin #define IGC_PRC255		0x04064  /* Packets Rx (128-255 bytes) - R/clr */
    187  1.2  rin #define IGC_PRC511		0x04068  /* Packets Rx (256-511 bytes) - R/clr */
    188  1.1  rin #define IGC_PRC1023		0x0406C  /* Packets Rx (512-1023 bytes) - R/clr */
    189  1.1  rin #define IGC_PRC1522		0x04070  /* Packets Rx (1024-1522 bytes) - R/clr */
    190  1.1  rin #define IGC_GPRC		0x04074  /* Good Packets Rx Count - R/clr */
    191  1.1  rin #define IGC_BPRC		0x04078  /* Broadcast Packets Rx Count - R/clr */
    192  1.1  rin #define IGC_MPRC		0x0407C  /* Multicast Packets Rx Count - R/clr */
    193  1.1  rin #define IGC_GPTC		0x04080  /* Good Packets Tx Count - R/clr */
    194  1.1  rin #define IGC_GORCL		0x04088  /* Good Octets Rx Count Low - R/clr */
    195  1.1  rin #define IGC_GORCH		0x0408C  /* Good Octets Rx Count High - R/clr */
    196  1.1  rin #define IGC_GOTCL		0x04090  /* Good Octets Tx Count Low - R/clr */
    197  1.1  rin #define IGC_GOTCH		0x04094  /* Good Octets Tx Count High - R/clr */
    198  1.1  rin #define IGC_RNBC		0x040A0  /* Rx No Buffers Count - R/clr */
    199  1.1  rin #define IGC_RUC			0x040A4  /* Rx Undersize Count - R/clr */
    200  1.1  rin #define IGC_RFC			0x040A8  /* Rx Fragment Count - R/clr */
    201  1.1  rin #define IGC_ROC			0x040AC  /* Rx Oversize Count - R/clr */
    202  1.1  rin #define IGC_RJC			0x040B0  /* Rx Jabber Count - R/clr */
    203  1.1  rin #define IGC_MGTPRC		0x040B4  /* Management Packets Rx Count - R/clr */
    204  1.1  rin #define IGC_MGTPDC		0x040B8  /* Management Packets Dropped Count - R/clr */
    205  1.1  rin #define IGC_MGTPTC		0x040BC  /* Management Packets Tx Count - R/clr */
    206  1.1  rin #define IGC_TORL		0x040C0  /* Total Octets Rx Low - R/clr */
    207  1.1  rin #define IGC_TORH		0x040C4  /* Total Octets Rx High - R/clr */
    208  1.1  rin #define IGC_TOTL		0x040C8  /* Total Octets Tx Low - R/clr */
    209  1.1  rin #define IGC_TOTH		0x040CC  /* Total Octets Tx High - R/clr */
    210  1.1  rin #define IGC_TPR			0x040D0  /* Total Packets Rx - R/clr */
    211  1.1  rin #define IGC_TPT			0x040D4  /* Total Packets Tx - R/clr */
    212  1.1  rin #define IGC_PTC64		0x040D8  /* Packets Tx (64 bytes) - R/clr */
    213  1.1  rin #define IGC_PTC127		0x040DC  /* Packets Tx (65-127 bytes) - R/clr */
    214  1.1  rin #define IGC_PTC255		0x040E0  /* Packets Tx (128-255 bytes) - R/clr */
    215  1.1  rin #define IGC_PTC511		0x040E4  /* Packets Tx (256-511 bytes) - R/clr */
    216  1.1  rin #define IGC_PTC1023		0x040E8  /* Packets Tx (512-1023 bytes) - R/clr */
    217  1.2  rin #define IGC_PTC1522		0x040EC  /* Packets Tx (1024-1522 bytes) - R/clr */
    218  1.1  rin #define IGC_MPTC		0x040F0  /* Multicast Packets Tx Count - R/clr */
    219  1.1  rin #define IGC_BPTC		0x040F4  /* Broadcast Packets Tx Count - R/clr */
    220  1.1  rin #define IGC_TSCTC		0x040F8  /* TCP Segmentation Context Tx - R/clr */
    221  1.1  rin #define IGC_IAC			0x04100  /* Interrupt Assertion Count */
    222  1.1  rin #define IGC_RXDMTC		0x04120  /* Rx Descriptor Minimum Threshold Count */
    223  1.1  rin 
    224  1.1  rin #define IGC_VFGPRC		0x00F10
    225  1.1  rin #define IGC_VFGORC		0x00F18
    226  1.1  rin #define IGC_VFMPRC		0x00F3C
    227  1.1  rin #define IGC_VFGPTC		0x00F14
    228  1.1  rin #define IGC_VFGOTC		0x00F34
    229  1.1  rin #define IGC_VFGOTLBC		0x00F50
    230  1.1  rin #define IGC_VFGPTLBC		0x00F44
    231  1.1  rin #define IGC_VFGORLBC		0x00F48
    232  1.1  rin #define IGC_VFGPRLBC		0x00F40
    233  1.1  rin #define IGC_HGORCL		0x04128  /* Host Good Octets Received Count Low */
    234  1.1  rin #define IGC_HGORCH		0x0412C  /* Host Good Octets Received Count High */
    235  1.1  rin #define IGC_HGOTCL		0x04130  /* Host Good Octets Transmit Count Low */
    236  1.1  rin #define IGC_HGOTCH		0x04134  /* Host Good Octets Transmit Count High */
    237  1.1  rin #define IGC_LENERRS		0x04138  /* Length Errors Count */
    238  1.1  rin #define IGC_PCS_ANADV		0x04218  /* AN advertisement - RW */
    239  1.1  rin #define IGC_PCS_LPAB		0x0421C  /* Link Partner Ability - RW */
    240  1.1  rin #define IGC_RXCSUM		0x05000  /* Rx Checksum Control - RW */
    241  1.1  rin #define IGC_RLPML		0x05004  /* Rx Long Packet Max Length */
    242  1.1  rin #define IGC_RFCTL		0x05008  /* Receive Filter Control*/
    243  1.1  rin #define IGC_MTA			0x05200  /* Multicast Table Array - RW Array */
    244  1.1  rin #define IGC_RA			0x05400  /* Receive Address - RW Array */
    245  1.1  rin #define IGC_VFTA		0x05600  /* VLAN Filter Table Array - RW Array */
    246  1.1  rin #define IGC_WUC			0x05800  /* Wakeup Control - RW */
    247  1.1  rin #define IGC_WUFC		0x05808  /* Wakeup Filter Control - RW */
    248  1.1  rin #define IGC_WUS			0x05810  /* Wakeup Status - RO */
    249  1.1  rin /* Management registers */
    250  1.1  rin #define IGC_MANC		0x05820  /* Management Control - RW */
    251  1.1  rin #define IGC_IPAV		0x05838  /* IP Address Valid - RW */
    252  1.1  rin #define IGC_IP4AT		0x05840  /* IPv4 Address Table - RW Array */
    253  1.1  rin #define IGC_IP6AT		0x05880  /* IPv6 Address Table - RW Array */
    254  1.1  rin #define IGC_WUPL		0x05900  /* Wakeup Packet Length - RW */
    255  1.1  rin #define IGC_WUPM		0x05A00  /* Wakeup Packet Memory - RO A */
    256  1.1  rin #define IGC_WUPM_EXT		0x0B800  /* Wakeup Packet Memory Extended - RO Array */
    257  1.1  rin #define IGC_WUFC_EXT		0x0580C  /* Wakeup Filter Control Extended - RW */
    258  1.1  rin #define IGC_WUS_EXT		0x05814  /* Wakeup Status Extended - RW1C */
    259  1.1  rin #define IGC_FHFTSL		0x05804  /* Flex Filter Indirect Table Select - RW */
    260  1.1  rin #define IGC_PROXYFCEX		0x05590  /* Proxy Filter Control Extended - RW1C */
    261  1.1  rin #define IGC_PROXYEXS		0x05594  /* Proxy Extended Status - RO */
    262  1.1  rin #define IGC_WFUTPF		0x05500  /* Wake Flex UDP TCP Port Filter - RW Array */
    263  1.1  rin #define IGC_RFUTPF		0x05580  /* Range Flex UDP TCP Port Filter - RW */
    264  1.1  rin #define IGC_RWPFC		0x05584  /* Range Wake Port Filter Control - RW */
    265  1.1  rin #define IGC_WFUTPS		0x05588  /* Wake Filter UDP TCP Status - RW1C */
    266  1.1  rin #define IGC_WCS			0x0558C  /* Wake Control Status - RW1C */
    267  1.1  rin /* MSI-X Table Register Descriptions */
    268  1.1  rin #define IGC_PBACL		0x05B68  /* MSIx PBA Clear - Read/Write 1's to clear */
    269  1.1  rin #define IGC_FFLT		0x05F00  /* Flexible Filter Length Table - RW Array */
    270  1.1  rin #define IGC_HOST_IF		0x08800  /* Host Interface */
    271  1.1  rin /* Flexible Host Filter Table */
    272  1.1  rin #define IGC_FHFT(_n)		(0x09000 + ((_n) * 0x100))
    273  1.1  rin /* Ext Flexible Host Filter Table */
    274  1.1  rin #define IGC_FHFT_EXT(_n)	(0x09A00 + ((_n) * 0x100))
    275  1.1  rin 
    276  1.1  rin 
    277  1.1  rin #define IGC_KMRNCTRLSTA		0x00034 /* MAC-PHY interface - RW */
    278  1.1  rin #define IGC_MANC2H		0x05860 /* Management Control To Host - RW */
    279  1.1  rin /* Management Decision Filters */
    280  1.1  rin #define IGC_MDEF(_n)		(0x05890 + (4 * (_n)))
    281  1.1  rin /* Semaphore registers */
    282  1.1  rin #define IGC_SW_FW_SYNC		0x05B5C /* SW-FW Synchronization - RW */
    283  1.1  rin /* Function Active and Power State to MNG */
    284  1.1  rin #define IGC_FACTPS		0x05B30
    285  1.1  rin #define IGC_SWSM		0x05B50 /* SW Semaphore */
    286  1.1  rin #define IGC_FWSM		0x05B54 /* FW Semaphore */
    287  1.1  rin /* Driver-only SW semaphore (not used by BOOT agents) */
    288  1.1  rin #define IGC_SWSM2		0x05B58
    289  1.1  rin #define IGC_FFLT_DBG		0x05F04 /* Debug Register */
    290  1.1  rin #define IGC_HICR		0x08F00 /* Host Interface Control */
    291  1.1  rin #define IGC_FWSTS		0x08F0C /* FW Status */
    292  1.1  rin 
    293  1.1  rin /* RSS registers */
    294  1.1  rin #define IGC_MRQC	0x05818 /* Multiple Receive Control - RW */
    295  1.1  rin #define IGC_IMIR(_i)	(0x05A80 + ((_i) * 4))  /* Immediate Interrupt */
    296  1.1  rin #define IGC_IMIREXT(_i)	(0x05AA0 + ((_i) * 4)) /* Immediate INTR Ext*/
    297  1.1  rin #define IGC_IMIRVP	0x05AC0 /* Immediate INT Rx VLAN Priority -RW */
    298  1.1  rin #define IGC_MSIXBM(_i)	(0x01600 + ((_i) * 4)) /* MSI-X Alloc Reg -RW */
    299  1.1  rin /* Redirection Table - RW Array */
    300  1.1  rin #define IGC_RETA(_i)	(0x05C00 + ((_i) * 4))
    301  1.1  rin /* RSS Random Key - RW Array */
    302  1.1  rin #define IGC_RSSRK(_i)	(0x05C80 + ((_i) * 4))
    303  1.1  rin #define IGC_RSSIM	0x05864 /* RSS Interrupt Mask */
    304  1.1  rin #define IGC_RSSIR	0x05868 /* RSS Interrupt Request */
    305  1.1  rin #define IGC_UTA		0x0A000 /* Unicast Table Array - RW */
    306  1.1  rin #define IGC_TSYNCRXCTL	0x0B620 /* Rx Time Sync Control register - RW */
    307  1.1  rin #define IGC_TSYNCTXCTL	0x0B614 /* Tx Time Sync Control register - RW */
    308  1.1  rin #define IGC_TSYNCRXCFG	0x05F50 /* Time Sync Rx Configuration - RW */
    309  1.1  rin #define IGC_RXSTMPL	0x0B624 /* Rx timestamp Low - RO */
    310  1.1  rin #define IGC_RXSTMPH	0x0B628 /* Rx timestamp High - RO */
    311  1.1  rin #define IGC_RXSATRL	0x0B62C /* Rx timestamp attribute low - RO */
    312  1.1  rin #define IGC_RXSATRH	0x0B630 /* Rx timestamp attribute high - RO */
    313  1.1  rin #define IGC_TXSTMPL	0x0B618 /* Tx timestamp value Low - RO */
    314  1.1  rin #define IGC_TXSTMPH	0x0B61C /* Tx timestamp value High - RO */
    315  1.1  rin #define IGC_SYSTIML	0x0B600 /* System time register Low - RO */
    316  1.1  rin #define IGC_SYSTIMH	0x0B604 /* System time register High - RO */
    317  1.1  rin #define IGC_TIMINCA	0x0B608 /* Increment attributes register - RW */
    318  1.1  rin #define IGC_TIMADJL	0x0B60C /* Time sync time adjustment offset Low - RW */
    319  1.1  rin #define IGC_TIMADJH	0x0B610 /* Time sync time adjustment offset High - RW */
    320  1.1  rin #define IGC_TSAUXC	0x0B640 /* Timesync Auxiliary Control register */
    321  1.1  rin #define IGC_SYSTIMR	0x0B6F8 /* System time register Residue */
    322  1.1  rin #define IGC_TSICR	0x0B66C /* Interrupt Cause Register */
    323  1.1  rin #define IGC_TSIM	0x0B674 /* Interrupt Mask Register */
    324  1.1  rin 
    325  1.1  rin /* Filtering Registers */
    326  1.1  rin #define IGC_SAQF(_n)	(0x05980 + (4 * (_n))) /* Source Address Queue Fltr */
    327  1.1  rin #define IGC_DAQF(_n)	(0x059A0 + (4 * (_n))) /* Dest Address Queue Fltr */
    328  1.1  rin #define IGC_SPQF(_n)	(0x059C0 + (4 * (_n))) /* Source Port Queue Fltr */
    329  1.1  rin #define IGC_FTQF(_n)	(0x059E0 + (4 * (_n))) /* 5-tuple Queue Fltr */
    330  1.1  rin #define IGC_TTQF(_n)	(0x059E0 + (4 * (_n))) /* 2-tuple Queue Fltr */
    331  1.1  rin #define IGC_SYNQF(_n)	(0x055FC + (4 * (_n))) /* SYN Packet Queue Fltr */
    332  1.1  rin #define IGC_ETQF(_n)	(0x05CB0 + (4 * (_n))) /* EType Queue Fltr */
    333  1.1  rin 
    334  1.1  rin /* ETQF register bit definitions */
    335  1.1  rin #define IGC_ETQF_FILTER_ENABLE	(1 << 26)
    336  1.1  rin #define IGC_ETQF_IMM_INT	(1 << 29)
    337  1.1  rin #define IGC_ETQF_QUEUE_ENABLE	(1U << 31)
    338  1.1  rin #define IGC_ETQF_QUEUE_SHIFT	16
    339  1.1  rin #define IGC_ETQF_QUEUE_MASK	0x00070000
    340  1.1  rin #define IGC_ETQF_ETYPE_MASK	0x0000FFFF
    341  1.1  rin 
    342  1.1  rin #define IGC_RTTDCS		0x3600 /* Reedtown Tx Desc plane control and status */
    343  1.1  rin #define IGC_RTTPCS		0x3474 /* Reedtown Tx Packet Plane control and status */
    344  1.1  rin #define IGC_RTRPCS		0x2474 /* Rx packet plane control and status */
    345  1.1  rin #define IGC_RTRUP2TC		0x05AC4 /* Rx User Priority to Traffic Class */
    346  1.1  rin #define IGC_RTTUP2TC		0x0418 /* Transmit User Priority to Traffic Class */
    347  1.1  rin /* Tx Desc plane TC Rate-scheduler config */
    348  1.1  rin #define IGC_RTTDTCRC(_n)	(0x3610 + ((_n) * 4))
    349  1.1  rin /* Tx Packet plane TC Rate-Scheduler Config */
    350  1.1  rin #define IGC_RTTPTCRC(_n)	(0x3480 + ((_n) * 4))
    351  1.1  rin /* Rx Packet plane TC Rate-Scheduler Config */
    352  1.1  rin #define IGC_RTRPTCRC(_n)	(0x2480 + ((_n) * 4))
    353  1.1  rin /* Tx Desc Plane TC Rate-Scheduler Status */
    354  1.1  rin #define IGC_RTTDTCRS(_n)	(0x3630 + ((_n) * 4))
    355  1.1  rin /* Tx Desc Plane TC Rate-Scheduler MMW */
    356  1.1  rin #define IGC_RTTDTCRM(_n)	(0x3650 + ((_n) * 4))
    357  1.1  rin /* Tx Packet plane TC Rate-Scheduler Status */
    358  1.1  rin #define IGC_RTTPTCRS(_n)	(0x34A0 + ((_n) * 4))
    359  1.1  rin /* Tx Packet plane TC Rate-scheduler MMW */
    360  1.1  rin #define IGC_RTTPTCRM(_n)	(0x34C0 + ((_n) * 4))
    361  1.1  rin /* Rx Packet plane TC Rate-Scheduler Status */
    362  1.1  rin #define IGC_RTRPTCRS(_n)	(0x24A0 + ((_n) * 4))
    363  1.1  rin /* Rx Packet plane TC Rate-Scheduler MMW */
    364  1.1  rin #define IGC_RTRPTCRM(_n)	(0x24C0 + ((_n) * 4))
    365  1.1  rin /* Tx Desc plane VM Rate-Scheduler MMW*/
    366  1.1  rin #define IGC_RTTDVMRM(_n)	(0x3670 + ((_n) * 4))
    367  1.1  rin /* Tx BCN Rate-Scheduler MMW */
    368  1.1  rin #define IGC_RTTBCNRM(_n)	(0x3690 + ((_n) * 4))
    369  1.1  rin #define IGC_RTTDQSEL		0x3604  /* Tx Desc Plane Queue Select */
    370  1.1  rin #define IGC_RTTDVMRC		0x3608  /* Tx Desc Plane VM Rate-Scheduler Config */
    371  1.1  rin #define IGC_RTTDVMRS		0x360C  /* Tx Desc Plane VM Rate-Scheduler Status */
    372  1.1  rin #define IGC_RTTBCNRC		0x36B0  /* Tx BCN Rate-Scheduler Config */
    373  1.1  rin #define IGC_RTTBCNRS		0x36B4  /* Tx BCN Rate-Scheduler Status */
    374  1.1  rin #define IGC_RTTBCNCR		0xB200  /* Tx BCN Control Register */
    375  1.1  rin #define IGC_RTTBCNTG		0x35A4  /* Tx BCN Tagging */
    376  1.1  rin #define IGC_RTTBCNCP		0xB208  /* Tx BCN Congestion point */
    377  1.1  rin #define IGC_RTRBCNCR		0xB20C  /* Rx BCN Control Register */
    378  1.1  rin #define IGC_RTTBCNRD		0x36B8  /* Tx BCN Rate Drift */
    379  1.1  rin #define IGC_PFCTOP		0x1080  /* Priority Flow Control Type and Opcode */
    380  1.1  rin #define IGC_RTTBCNIDX		0xB204  /* Tx BCN Congestion Point */
    381  1.1  rin #define IGC_RTTBCNACH		0x0B214 /* Tx BCN Control High */
    382  1.1  rin #define IGC_RTTBCNACL		0x0B210 /* Tx BCN Control Low */
    383  1.1  rin 
    384  1.1  rin /* DMA Coalescing registers */
    385  1.1  rin #define IGC_DMACR		0x02508 /* Control Register */
    386  1.1  rin #define IGC_DMCTXTH		0x03550 /* Transmit Threshold */
    387  1.1  rin #define IGC_DMCTLX		0x02514 /* Time to Lx Request */
    388  1.1  rin #define IGC_DMCRTRH		0x05DD0 /* Receive Packet Rate Threshold */
    389  1.1  rin #define IGC_DMCCNT		0x05DD4 /* Current Rx Count */
    390  1.1  rin #define IGC_FCRTC		0x02170 /* Flow Control Rx high watermark */
    391  1.1  rin #define IGC_PCIEMISC		0x05BB8 /* PCIE misc config register */
    392  1.1  rin 
    393  1.1  rin /* PCIe Parity Status Register */
    394  1.1  rin #define IGC_PCIEERRSTS		0x05BA8
    395  1.1  rin 
    396  1.1  rin #define IGC_PROXYS		0x5F64 /* Proxying Status */
    397  1.1  rin #define IGC_PROXYFC		0x5F60 /* Proxying Filter Control */
    398  1.1  rin /* Thermal sensor configuration and status registers */
    399  1.1  rin #define IGC_THMJT		0x08100 /* Junction Temperature */
    400  1.1  rin #define IGC_THLOWTC		0x08104 /* Low Threshold Control */
    401  1.1  rin #define IGC_THMIDTC		0x08108 /* Mid Threshold Control */
    402  1.1  rin #define IGC_THHIGHTC		0x0810C /* High Threshold Control */
    403  1.1  rin #define IGC_THSTAT		0x08110 /* Thermal Sensor Status */
    404  1.1  rin 
    405  1.1  rin /* Energy Efficient Ethernet "EEE" registers */
    406  1.1  rin #define IGC_IPCNFG		0x0E38 /* Internal PHY Configuration */
    407  1.1  rin #define IGC_LTRC		0x01A0 /* Latency Tolerance Reporting Control */
    408  1.1  rin #define IGC_EEER		0x0E30 /* Energy Efficient Ethernet "EEE"*/
    409  1.1  rin #define IGC_EEE_SU		0x0E34 /* EEE Setup */
    410  1.1  rin #define IGC_EEE_SU_2P5		0x0E3C /* EEE 2.5G Setup */
    411  1.1  rin #define IGC_TLPIC		0x4148 /* EEE Tx LPI Count - TLPIC */
    412  1.1  rin #define IGC_RLPIC		0x414C /* EEE Rx LPI Count - RLPIC */
    413  1.1  rin 
    414  1.1  rin /* OS2BMC Registers */
    415  1.1  rin #define IGC_B2OSPC		0x08FE0 /* BMC2OS packets sent by BMC */
    416  1.1  rin #define IGC_B2OGPRC		0x04158 /* BMC2OS packets received by host */
    417  1.1  rin #define IGC_O2BGPTC		0x08FE4 /* OS2BMC packets received by BMC */
    418  1.1  rin #define IGC_O2BSPC		0x0415C /* OS2BMC packets transmitted by host */
    419  1.1  rin 
    420  1.1  rin #define IGC_LTRMINV		0x5BB0 /* LTR Minimum Value */
    421  1.1  rin #define IGC_LTRMAXV		0x5BB4 /* LTR Maximum Value */
    422  1.1  rin 
    423  1.1  rin 
    424  1.1  rin /* IEEE 1588 TIMESYNCH */
    425  1.1  rin #define IGC_TRGTTIML0		0x0B644 /* Target Time Register 0 Low  - RW */
    426  1.1  rin #define IGC_TRGTTIMH0		0x0B648 /* Target Time Register 0 High - RW */
    427  1.1  rin #define IGC_TRGTTIML1		0x0B64C /* Target Time Register 1 Low  - RW */
    428  1.1  rin #define IGC_TRGTTIMH1		0x0B650 /* Target Time Register 1 High - RW */
    429  1.1  rin #define IGC_FREQOUT0		0x0B654 /* Frequency Out 0 Control Register - RW */
    430  1.1  rin #define IGC_FREQOUT1		0x0B658 /* Frequency Out 1 Control Register - RW */
    431  1.1  rin #define IGC_TSSDP		0x0003C  /* Time Sync SDP Configuration Register - RW */
    432  1.1  rin 
    433  1.1  rin 
    434  1.1  rin #endif	/* _IGC_REGS_H_ */
    435