mirror of https://github.com/F-Stack/f-stack.git
1810 lines
56 KiB
C
1810 lines
56 KiB
C
|
/*-
|
|||
|
*******************************************************************************
|
|||
|
Copyright (C) 2015 Annapurna Labs Ltd.
|
|||
|
|
|||
|
This file may be licensed under the terms of the Annapurna Labs Commercial
|
|||
|
License Agreement.
|
|||
|
|
|||
|
Alternatively, this file can be distributed under the terms of the GNU General
|
|||
|
Public License V2 as published by the Free Software Foundation and can be
|
|||
|
found at http://www.gnu.org/licenses/gpl-2.0.html
|
|||
|
|
|||
|
Alternatively, redistribution and use in source and binary forms, with or
|
|||
|
without modification, are permitted provided that the following conditions are
|
|||
|
met:
|
|||
|
|
|||
|
* Redistributions of source code must retain the above copyright notice,
|
|||
|
this list of conditions and the following disclaimer.
|
|||
|
|
|||
|
* Redistributions in binary form must reproduce the above copyright
|
|||
|
notice, this list of conditions and the following disclaimer in
|
|||
|
the documentation and/or other materials provided with the
|
|||
|
distribution.
|
|||
|
|
|||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
|||
|
ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
|||
|
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|||
|
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
|
|||
|
ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
|||
|
(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
|||
|
LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
|||
|
ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|||
|
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
|||
|
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|||
|
|
|||
|
*******************************************************************************/
|
|||
|
|
|||
|
/**
|
|||
|
* @{
|
|||
|
* @file al_hal_eth_mac_regs.h
|
|||
|
*
|
|||
|
* @brief Ethernet MAC registers
|
|||
|
*
|
|||
|
*/
|
|||
|
|
|||
|
#ifndef __AL_HAL_ETH_MAC_REGS_H__
|
|||
|
#define __AL_HAL_ETH_MAC_REGS_H__
|
|||
|
|
|||
|
#include "al_hal_plat_types.h"
|
|||
|
|
|||
|
#ifdef __cplusplus
|
|||
|
extern "C" {
|
|||
|
#endif
|
|||
|
/*
|
|||
|
* Unit Registers
|
|||
|
*/
|
|||
|
|
|||
|
struct al_eth_mac_1g {
|
|||
|
/* [0x0] */
|
|||
|
uint32_t rev;
|
|||
|
uint32_t scratch;
|
|||
|
uint32_t cmd_cfg;
|
|||
|
uint32_t mac_0;
|
|||
|
/* [0x10] */
|
|||
|
uint32_t mac_1;
|
|||
|
uint32_t frm_len;
|
|||
|
uint32_t pause_quant;
|
|||
|
uint32_t rx_section_empty;
|
|||
|
/* [0x20] */
|
|||
|
uint32_t rx_section_full;
|
|||
|
uint32_t tx_section_empty;
|
|||
|
uint32_t tx_section_full;
|
|||
|
uint32_t rx_almost_empty;
|
|||
|
/* [0x30] */
|
|||
|
uint32_t rx_almost_full;
|
|||
|
uint32_t tx_almost_empty;
|
|||
|
uint32_t tx_almost_full;
|
|||
|
uint32_t mdio_addr0;
|
|||
|
/* [0x40] */
|
|||
|
uint32_t mdio_addr1;
|
|||
|
uint32_t Reserved[5];
|
|||
|
/* [0x58] */
|
|||
|
uint32_t reg_stat;
|
|||
|
uint32_t tx_ipg_len;
|
|||
|
/* [0x60] */
|
|||
|
uint32_t Reserved1[104];
|
|||
|
/* [0x200] */
|
|||
|
uint32_t phy_regs_base;
|
|||
|
uint32_t Reserved2[127];
|
|||
|
};
|
|||
|
|
|||
|
struct al_eth_mac_10g {
|
|||
|
/* [0x0] */
|
|||
|
uint32_t rev;
|
|||
|
uint32_t scratch;
|
|||
|
uint32_t cmd_cfg;
|
|||
|
uint32_t mac_0;
|
|||
|
/* [0x10] */
|
|||
|
uint32_t mac_1;
|
|||
|
uint32_t frm_len;
|
|||
|
uint32_t Reserved;
|
|||
|
uint32_t rx_fifo_sections;
|
|||
|
/* [0x20] */
|
|||
|
uint32_t tx_fifo_sections;
|
|||
|
uint32_t rx_fifo_almost_f_e;
|
|||
|
uint32_t tx_fifo_almost_f_e;
|
|||
|
uint32_t hashtable_load;
|
|||
|
/* [0x30] */
|
|||
|
uint32_t mdio_cfg_status;
|
|||
|
uint16_t mdio_cmd;
|
|||
|
uint16_t reserved1;
|
|||
|
uint16_t mdio_data;
|
|||
|
uint16_t reserved2;
|
|||
|
uint16_t mdio_regaddr;
|
|||
|
uint16_t reserved3;
|
|||
|
/* [0x40] */
|
|||
|
uint32_t status;
|
|||
|
uint32_t tx_ipg_len;
|
|||
|
uint32_t Reserved1[3];
|
|||
|
/* [0x54] */
|
|||
|
uint32_t cl01_pause_quanta;
|
|||
|
uint32_t cl23_pause_quanta;
|
|||
|
uint32_t cl45_pause_quanta;
|
|||
|
/* [0x60] */
|
|||
|
uint32_t cl67_pause_quanta;
|
|||
|
uint32_t cl01_quanta_thresh;
|
|||
|
uint32_t cl23_quanta_thresh;
|
|||
|
uint32_t cl45_quanta_thresh;
|
|||
|
/* [0x70] */
|
|||
|
uint32_t cl67_quanta_thresh;
|
|||
|
uint32_t rx_pause_status;
|
|||
|
uint32_t Reserved2;
|
|||
|
uint32_t ts_timestamp;
|
|||
|
/* [0x80] */
|
|||
|
|
|||
|
uint32_t Reserved3[160];
|
|||
|
|
|||
|
/* [0x300] */
|
|||
|
uint32_t control;
|
|||
|
uint32_t status_reg;
|
|||
|
uint32_t phy_id[2];
|
|||
|
/* [0x310] */
|
|||
|
uint32_t dev_ability;
|
|||
|
uint32_t partner_ability;
|
|||
|
uint32_t an_expansion;
|
|||
|
uint32_t device_np;
|
|||
|
/* [0x320] */
|
|||
|
uint32_t partner_np;
|
|||
|
uint32_t Reserved4[9];
|
|||
|
|
|||
|
/* [0x348] */
|
|||
|
uint32_t link_timer_lo;
|
|||
|
uint32_t link_timer_hi;
|
|||
|
/* [0x350] */
|
|||
|
uint32_t if_mode;
|
|||
|
|
|||
|
uint32_t Reserved5[43];
|
|||
|
};
|
|||
|
|
|||
|
struct al_eth_mac_gen {
|
|||
|
/* [0x0] Ethernet Controller Version */
|
|||
|
uint32_t version;
|
|||
|
uint32_t rsrvd_0[2];
|
|||
|
/* [0xc] MAC selection configuration */
|
|||
|
uint32_t cfg;
|
|||
|
/* [0x10] 10/100/1000 MAC external configuration */
|
|||
|
uint32_t mac_1g_cfg;
|
|||
|
/* [0x14] 10/100/1000 MAC status */
|
|||
|
uint32_t mac_1g_stat;
|
|||
|
/* [0x18] RGMII external configuration */
|
|||
|
uint32_t rgmii_cfg;
|
|||
|
/* [0x1c] RGMII status */
|
|||
|
uint32_t rgmii_stat;
|
|||
|
/* [0x20] 1/2.5/10G MAC external configuration */
|
|||
|
uint32_t mac_10g_cfg;
|
|||
|
/* [0x24] 1/2.5/10G MAC status */
|
|||
|
uint32_t mac_10g_stat;
|
|||
|
/* [0x28] XAUI PCS configuration */
|
|||
|
uint32_t xaui_cfg;
|
|||
|
/* [0x2c] XAUI PCS status */
|
|||
|
uint32_t xaui_stat;
|
|||
|
/* [0x30] RXAUI PCS configuration */
|
|||
|
uint32_t rxaui_cfg;
|
|||
|
/* [0x34] RXAUI PCS status */
|
|||
|
uint32_t rxaui_stat;
|
|||
|
/* [0x38] Signal detect configuration */
|
|||
|
uint32_t sd_cfg;
|
|||
|
/* [0x3c] MDIO control register for MDIO interface 1 */
|
|||
|
uint32_t mdio_ctrl_1;
|
|||
|
/* [0x40] MDIO information register for MDIO interface 1 */
|
|||
|
uint32_t mdio_1;
|
|||
|
/* [0x44] MDIO control register for MDIO interface 2 */
|
|||
|
uint32_t mdio_ctrl_2;
|
|||
|
/* [0x48] MDIO information register for MDIO interface 2 */
|
|||
|
uint32_t mdio_2;
|
|||
|
/* [0x4c] XGMII 32 to 64 data FIFO control */
|
|||
|
uint32_t xgmii_dfifo_32_64;
|
|||
|
/* [0x50] Reserved 1 out */
|
|||
|
uint32_t mac_res_1_out;
|
|||
|
/* [0x54] XGMII 64 to 32 data FIFO control */
|
|||
|
uint32_t xgmii_dfifo_64_32;
|
|||
|
/* [0x58] Reserved 1 in */
|
|||
|
uint32_t mac_res_1_in;
|
|||
|
/* [0x5c] SerDes TX FIFO control */
|
|||
|
uint32_t sd_fifo_ctrl;
|
|||
|
/* [0x60] SerDes TX FIFO status */
|
|||
|
uint32_t sd_fifo_stat;
|
|||
|
/* [0x64] SerDes in/out selection */
|
|||
|
uint32_t mux_sel;
|
|||
|
/* [0x68] Clock configuration */
|
|||
|
uint32_t clk_cfg;
|
|||
|
uint32_t rsrvd_1;
|
|||
|
/* [0x70] LOS and SD selection */
|
|||
|
uint32_t los_sel;
|
|||
|
/* [0x74] RGMII selection configuration */
|
|||
|
uint32_t rgmii_sel;
|
|||
|
/* [0x78] Ethernet LED configuration */
|
|||
|
uint32_t led_cfg;
|
|||
|
uint32_t rsrvd[33];
|
|||
|
};
|
|||
|
struct al_eth_mac_kr {
|
|||
|
/* [0x0] PCS register file address */
|
|||
|
uint32_t pcs_addr;
|
|||
|
/* [0x4] PCS register file data */
|
|||
|
uint32_t pcs_data;
|
|||
|
/* [0x8] AN register file address */
|
|||
|
uint32_t an_addr;
|
|||
|
/* [0xc] AN register file data */
|
|||
|
uint32_t an_data;
|
|||
|
/* [0x10] PMA register file address */
|
|||
|
uint32_t pma_addr;
|
|||
|
/* [0x14] PMA register file data */
|
|||
|
uint32_t pma_data;
|
|||
|
/* [0x18] MTIP register file address */
|
|||
|
uint32_t mtip_addr;
|
|||
|
/* [0x1c] MTIP register file data */
|
|||
|
uint32_t mtip_data;
|
|||
|
/* [0x20] KR PCS config */
|
|||
|
uint32_t pcs_cfg;
|
|||
|
/* [0x24] KR PCS status */
|
|||
|
uint32_t pcs_stat;
|
|||
|
uint32_t rsrvd[54];
|
|||
|
};
|
|||
|
struct al_eth_mac_sgmii {
|
|||
|
/* [0x0] PCS register file address */
|
|||
|
uint32_t reg_addr;
|
|||
|
/* [0x4] PCS register file data */
|
|||
|
uint32_t reg_data;
|
|||
|
/* [0x8] PCS clock divider configuration */
|
|||
|
uint32_t clk_div;
|
|||
|
/* [0xc] PCS Status */
|
|||
|
uint32_t link_stat;
|
|||
|
uint32_t rsrvd[60];
|
|||
|
};
|
|||
|
struct al_eth_mac_stat {
|
|||
|
/* [0x0] Receive rate matching error */
|
|||
|
uint32_t match_fault;
|
|||
|
/* [0x4] EEE, number of times the MAC went into low power mode */
|
|||
|
uint32_t eee_in;
|
|||
|
/* [0x8] EEE, number of times the MAC went out of low power mode */
|
|||
|
uint32_t eee_out;
|
|||
|
/*
|
|||
|
* [0xc] 40G PCS,
|
|||
|
* FEC corrected error indication
|
|||
|
*/
|
|||
|
uint32_t v3_pcs_40g_ll_cerr_0;
|
|||
|
/*
|
|||
|
* [0x10] 40G PCS,
|
|||
|
* FEC corrected error indication
|
|||
|
*/
|
|||
|
uint32_t v3_pcs_40g_ll_cerr_1;
|
|||
|
/*
|
|||
|
* [0x14] 40G PCS,
|
|||
|
* FEC corrected error indication
|
|||
|
*/
|
|||
|
uint32_t v3_pcs_40g_ll_cerr_2;
|
|||
|
/*
|
|||
|
* [0x18] 40G PCS,
|
|||
|
* FEC corrected error indication
|
|||
|
*/
|
|||
|
uint32_t v3_pcs_40g_ll_cerr_3;
|
|||
|
/*
|
|||
|
* [0x1c] 40G PCS,
|
|||
|
* FEC uncorrectable error indication
|
|||
|
*/
|
|||
|
uint32_t v3_pcs_40g_ll_ncerr_0;
|
|||
|
/*
|
|||
|
* [0x20] 40G PCS,
|
|||
|
* FEC uncorrectable error indication
|
|||
|
*/
|
|||
|
uint32_t v3_pcs_40g_ll_ncerr_1;
|
|||
|
/*
|
|||
|
* [0x24] 40G PCS,
|
|||
|
* FEC uncorrectable error indication
|
|||
|
*/
|
|||
|
uint32_t v3_pcs_40g_ll_ncerr_2;
|
|||
|
/*
|
|||
|
* [0x28] 40G PCS,
|
|||
|
* FEC uncorrectable error indication
|
|||
|
*/
|
|||
|
uint32_t v3_pcs_40g_ll_ncerr_3;
|
|||
|
/*
|
|||
|
* [0x2c] 10G_LL PCS,
|
|||
|
* FEC corrected error indication
|
|||
|
*/
|
|||
|
uint32_t v3_pcs_10g_ll_cerr;
|
|||
|
/*
|
|||
|
* [0x30] 10G_LL PCS,
|
|||
|
* FEC uncorrectable error indication
|
|||
|
*/
|
|||
|
uint32_t v3_pcs_10g_ll_ncerr;
|
|||
|
uint32_t rsrvd[51];
|
|||
|
};
|
|||
|
struct al_eth_mac_stat_lane {
|
|||
|
/* [0x0] Character error */
|
|||
|
uint32_t char_err;
|
|||
|
/* [0x4] Disparity error */
|
|||
|
uint32_t disp_err;
|
|||
|
/* [0x8] Comma detection */
|
|||
|
uint32_t pat;
|
|||
|
uint32_t rsrvd[13];
|
|||
|
};
|
|||
|
struct al_eth_mac_gen_v3 {
|
|||
|
/* [0x0] ASYNC FIFOs control */
|
|||
|
uint32_t afifo_ctrl;
|
|||
|
/* [0x4] TX ASYNC FIFO configuration */
|
|||
|
uint32_t tx_afifo_cfg_1;
|
|||
|
/* [0x8] TX ASYNC FIFO configuration */
|
|||
|
uint32_t tx_afifo_cfg_2;
|
|||
|
/* [0xc] TX ASYNC FIFO configuration */
|
|||
|
uint32_t tx_afifo_cfg_3;
|
|||
|
/* [0x10] TX ASYNC FIFO configuration */
|
|||
|
uint32_t tx_afifo_cfg_4;
|
|||
|
/* [0x14] TX ASYNC FIFO configuration */
|
|||
|
uint32_t tx_afifo_cfg_5;
|
|||
|
/* [0x18] RX ASYNC FIFO configuration */
|
|||
|
uint32_t rx_afifo_cfg_1;
|
|||
|
/* [0x1c] RX ASYNC FIFO configuration */
|
|||
|
uint32_t rx_afifo_cfg_2;
|
|||
|
/* [0x20] RX ASYNC FIFO configuration */
|
|||
|
uint32_t rx_afifo_cfg_3;
|
|||
|
/* [0x24] RX ASYNC FIFO configuration */
|
|||
|
uint32_t rx_afifo_cfg_4;
|
|||
|
/* [0x28] RX ASYNC FIFO configuration */
|
|||
|
uint32_t rx_afifo_cfg_5;
|
|||
|
/* [0x2c] MAC selection configuration */
|
|||
|
uint32_t mac_sel;
|
|||
|
/* [0x30] 10G LL MAC configuration */
|
|||
|
uint32_t mac_10g_ll_cfg;
|
|||
|
/* [0x34] 10G LL MAC control */
|
|||
|
uint32_t mac_10g_ll_ctrl;
|
|||
|
/* [0x38] 10G LL PCS configuration */
|
|||
|
uint32_t pcs_10g_ll_cfg;
|
|||
|
/* [0x3c] 10G LL PCS status */
|
|||
|
uint32_t pcs_10g_ll_status;
|
|||
|
/* [0x40] 40G LL PCS configuration */
|
|||
|
uint32_t pcs_40g_ll_cfg;
|
|||
|
/* [0x44] 40G LL PCS status */
|
|||
|
uint32_t pcs_40g_ll_status;
|
|||
|
/* [0x48] PCS 40G register file address */
|
|||
|
uint32_t pcs_40g_ll_addr;
|
|||
|
/* [0x4c] PCS 40G register file data */
|
|||
|
uint32_t pcs_40g_ll_data;
|
|||
|
/* [0x50] 40G LL MAC configuration */
|
|||
|
uint32_t mac_40g_ll_cfg;
|
|||
|
/* [0x54] 40G LL MAC status */
|
|||
|
uint32_t mac_40g_ll_status;
|
|||
|
/* [0x58] Preamble configuration (high [55:32]) */
|
|||
|
uint32_t preamble_cfg_high;
|
|||
|
/* [0x5c] Preamble configuration (low [31:0]) */
|
|||
|
uint32_t preamble_cfg_low;
|
|||
|
/* [0x60] MAC 40G register file address */
|
|||
|
uint32_t mac_40g_ll_addr;
|
|||
|
/* [0x64] MAC 40G register file data */
|
|||
|
uint32_t mac_40g_ll_data;
|
|||
|
/* [0x68] 40G LL MAC control */
|
|||
|
uint32_t mac_40g_ll_ctrl;
|
|||
|
/* [0x6c] PCS 40G register file address */
|
|||
|
uint32_t pcs_40g_fec_91_ll_addr;
|
|||
|
/* [0x70] PCS 40G register file data */
|
|||
|
uint32_t pcs_40g_fec_91_ll_data;
|
|||
|
/* [0x74] 40G LL PCS EEE configuration */
|
|||
|
uint32_t pcs_40g_ll_eee_cfg;
|
|||
|
/* [0x78] 40G LL PCS EEE status */
|
|||
|
uint32_t pcs_40g_ll_eee_status;
|
|||
|
/*
|
|||
|
* [0x7c] SERDES 32-bit interface shift configuration (when swap is
|
|||
|
* enabled)
|
|||
|
*/
|
|||
|
uint32_t serdes_32_tx_shift;
|
|||
|
/*
|
|||
|
* [0x80] SERDES 32-bit interface shift configuration (when swap is
|
|||
|
* enabled)
|
|||
|
*/
|
|||
|
uint32_t serdes_32_rx_shift;
|
|||
|
/*
|
|||
|
* [0x84] SERDES 32-bit interface bit selection
|
|||
|
*/
|
|||
|
uint32_t serdes_32_tx_sel;
|
|||
|
/*
|
|||
|
* [0x88] SERDES 32-bit interface bit selection
|
|||
|
*/
|
|||
|
uint32_t serdes_32_rx_sel;
|
|||
|
/* [0x8c] AN/LT wrapper control */
|
|||
|
uint32_t an_lt_ctrl;
|
|||
|
/* [0x90] AN/LT wrapper register file address */
|
|||
|
uint32_t an_lt_0_addr;
|
|||
|
/* [0x94] AN/LT wrapper register file data */
|
|||
|
uint32_t an_lt_0_data;
|
|||
|
/* [0x98] AN/LT wrapper register file address */
|
|||
|
uint32_t an_lt_1_addr;
|
|||
|
/* [0x9c] AN/LT wrapper register file data */
|
|||
|
uint32_t an_lt_1_data;
|
|||
|
/* [0xa0] AN/LT wrapper register file address */
|
|||
|
uint32_t an_lt_2_addr;
|
|||
|
/* [0xa4] AN/LT wrapper register file data */
|
|||
|
uint32_t an_lt_2_data;
|
|||
|
/* [0xa8] AN/LT wrapper register file address */
|
|||
|
uint32_t an_lt_3_addr;
|
|||
|
/* [0xac] AN/LT wrapper register file data */
|
|||
|
uint32_t an_lt_3_data;
|
|||
|
/* [0xb0] External SERDES control */
|
|||
|
uint32_t ext_serdes_ctrl;
|
|||
|
/* [0xb4] spare bits */
|
|||
|
uint32_t spare;
|
|||
|
uint32_t rsrvd[18];
|
|||
|
};
|
|||
|
|
|||
|
struct al_eth_mac_regs {
|
|||
|
struct al_eth_mac_1g mac_1g; /* [0x000] */
|
|||
|
struct al_eth_mac_10g mac_10g; /* [0x400] */
|
|||
|
uint32_t rsrvd_0[64]; /* [0x800] */
|
|||
|
struct al_eth_mac_gen gen; /* [0x900] */
|
|||
|
struct al_eth_mac_kr kr; /* [0xa00] */
|
|||
|
struct al_eth_mac_sgmii sgmii; /* [0xb00] */
|
|||
|
struct al_eth_mac_stat stat; /* [0xc00] */
|
|||
|
struct al_eth_mac_stat_lane stat_lane[4]; /* [0xd00] */
|
|||
|
struct al_eth_mac_gen_v3 gen_v3; /* [0xe00] */
|
|||
|
};
|
|||
|
|
|||
|
|
|||
|
/*
|
|||
|
* Registers Fields
|
|||
|
*/
|
|||
|
|
|||
|
/**** control register (1G mac) ****/
|
|||
|
/* enable Half Duplex */
|
|||
|
#define AL_ETH_1G_MAC_CTRL_HD_EN (1 << 10)
|
|||
|
/* enable 1G speed */
|
|||
|
#define AL_ETH_1G_MAC_CTRL_1G_SPD (1 << 3)
|
|||
|
/* enable 10M speed */
|
|||
|
#define AL_ETH_1G_MAC_CTRL_10M_SPD (1 << 25)
|
|||
|
|
|||
|
|
|||
|
/**** 10G MAC register ****/
|
|||
|
/* mdio_cfg_status */
|
|||
|
#define ETH_10G_MAC_MDIO_CFG_HOLD_TIME_MASK 0x0000001c
|
|||
|
#define ETH_10G_MAC_MDIO_CFG_HOLD_TIME_SHIFT 2
|
|||
|
|
|||
|
#define ETH_10G_MAC_MDIO_CFG_HOLD_TIME_1_CLK 0
|
|||
|
#define ETH_10G_MAC_MDIO_CFG_HOLD_TIME_3_CLK 1
|
|||
|
#define ETH_10G_MAC_MDIO_CFG_HOLD_TIME_5_CLK 2
|
|||
|
#define ETH_10G_MAC_MDIO_CFG_HOLD_TIME_7_CLK 3
|
|||
|
#define ETH_10G_MAC_MDIO_CFG_HOLD_TIME_9_CLK 4
|
|||
|
#define ETH_10G_MAC_MDIO_CFG_HOLD_TIME_11_CLK 5
|
|||
|
#define ETH_10G_MAC_MDIO_CFG_HOLD_TIME_13_CLK 6
|
|||
|
#define ETH_10G_MAC_MDIO_CFG_HOLD_TIME_15_CLK 7
|
|||
|
|
|||
|
/**** version register ****/
|
|||
|
/* Revision number (Minor) */
|
|||
|
#define ETH_MAC_GEN_VERSION_RELEASE_NUM_MINOR_MASK 0x000000FF
|
|||
|
#define ETH_MAC_GEN_VERSION_RELEASE_NUM_MINOR_SHIFT 0
|
|||
|
/* Revision number (Major) */
|
|||
|
#define ETH_MAC_GEN_VERSION_RELEASE_NUM_MAJOR_MASK 0x0000FF00
|
|||
|
#define ETH_MAC_GEN_VERSION_RELEASE_NUM_MAJOR_SHIFT 8
|
|||
|
/* Date of release */
|
|||
|
#define ETH_MAC_GEN_VERSION_DATE_DAY_MASK 0x001F0000
|
|||
|
#define ETH_MAC_GEN_VERSION_DATE_DAY_SHIFT 16
|
|||
|
/* Month of release */
|
|||
|
#define ETH_MAC_GEN_VERSION_DATA_MONTH_MASK 0x01E00000
|
|||
|
#define ETH_MAC_GEN_VERSION_DATA_MONTH_SHIFT 21
|
|||
|
/* Year of release (starting from 2000) */
|
|||
|
#define ETH_MAC_GEN_VERSION_DATE_YEAR_MASK 0x3E000000
|
|||
|
#define ETH_MAC_GEN_VERSION_DATE_YEAR_SHIFT 25
|
|||
|
/* Reserved */
|
|||
|
#define ETH_MAC_GEN_VERSION_RESERVED_MASK 0xC0000000
|
|||
|
#define ETH_MAC_GEN_VERSION_RESERVED_SHIFT 30
|
|||
|
|
|||
|
/**** cfg register ****/
|
|||
|
/*
|
|||
|
* Selects between the 10/100/1000 MAC and the 1/2.5/10G MAC:
|
|||
|
* 0 - 10/100/1000
|
|||
|
* 1 - 1/2.5/10G
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_CFG_MAC_1_10 (1 << 0)
|
|||
|
/*
|
|||
|
* Selects the operation mode of the 1/2.5/10G MAC:
|
|||
|
* 00 - 1/2.5G SGMII
|
|||
|
* 01 - 10G XAUI/RXAUI
|
|||
|
* 10 – 10G KR
|
|||
|
* 11 – Reserved
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_CFG_XGMII_SGMII_MASK 0x00000006
|
|||
|
#define ETH_MAC_GEN_CFG_XGMII_SGMII_SHIFT 1
|
|||
|
/*
|
|||
|
* Selects the operation mode of the PCS:
|
|||
|
* 0 - XAUI
|
|||
|
* 1 - RXAUI
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_CFG_XAUI_RXAUI (1 << 3)
|
|||
|
/* Swap bits of TBI (SGMII mode) interface */
|
|||
|
#define ETH_MAC_GEN_CFG_SWAP_TBI_RX (1 << 4)
|
|||
|
/*
|
|||
|
* Determines the offset of the TBI bus on the SerDes interface:
|
|||
|
* 0 - LSB
|
|||
|
* 1 - MSB
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_CFG_TBI_MSB_RX (1 << 5)
|
|||
|
/*
|
|||
|
* Selects the SGMII PCS/MAC:
|
|||
|
* 0 – 10G MAC with SGMII
|
|||
|
* 1 – 1G MAC with SGMII
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_CFG_SGMII_SEL (1 << 6)
|
|||
|
/*
|
|||
|
* Selects between RGMII and SGMII for the 1G MAC:
|
|||
|
* 0 – RGMII
|
|||
|
* 1 – SGMII
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_CFG_RGMII_SGMII_SEL (1 << 7)
|
|||
|
/* Swap bits of TBI (SGMII mode) interface */
|
|||
|
#define ETH_MAC_GEN_CFG_SWAP_TBI_TX (1 << 8)
|
|||
|
/*
|
|||
|
* Determines the offset of the TBI bus on the SerDes interface:
|
|||
|
* 0 - LSB
|
|||
|
* 1 - MSB
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_CFG_TBI_MSB_TX (1 << 9)
|
|||
|
/*
|
|||
|
* Selection between the MDIO from 10/100/1000 MAC or the 1/2.5/10G MAC
|
|||
|
* 0 - 10/100/1000
|
|||
|
* 1 - 1/2.5/10G
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_CFG_MDIO_1_10 (1 << 10)
|
|||
|
/*
|
|||
|
* Swap MDC output
|
|||
|
* 0 – Normal
|
|||
|
* 1 – Flipped
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_CFG_MDIO_POL (1 << 11)
|
|||
|
/* Swap bits on SerDes interface */
|
|||
|
#define ETH_MAC_GEN_CFG_SWAP_SERDES_RX_MASK 0x000F0000
|
|||
|
#define ETH_MAC_GEN_CFG_SWAP_SERDES_RX_SHIFT 16
|
|||
|
/* Swap bits on SerDes interface */
|
|||
|
#define ETH_MAC_GEN_CFG_SWAP_SERDES_TX_MASK 0x0F000000
|
|||
|
#define ETH_MAC_GEN_CFG_SWAP_SERDES_TX_SHIFT 24
|
|||
|
|
|||
|
/**** mac_1g_cfg register ****/
|
|||
|
/*
|
|||
|
* Selection of the input for the "set_1000" input of the Ethernet 10/100/1000
|
|||
|
* MAC:
|
|||
|
* 0 - From RGMII converter (automatic speed selection)
|
|||
|
* 1 - From register set_1000_def
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_MAC_1G_CFG_SET_1000_SEL (1 << 0)
|
|||
|
/* Default value for the 10/100/1000 MAC "set_1000" input */
|
|||
|
#define ETH_MAC_GEN_MAC_1G_CFG_SET_1000_DEF (1 << 1)
|
|||
|
/*
|
|||
|
* Selection of the input for the "set_10" input of the Ethernet 10/100/1000
|
|||
|
* MAC:
|
|||
|
* 0 - From RGMII converter (automatic speed selection)
|
|||
|
* 1 - From register set_10_def
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_MAC_1G_CFG_SET_10_SEL (1 << 4)
|
|||
|
/* Default value for the 10/100/1000 MAC "set_10" input */
|
|||
|
#define ETH_MAC_GEN_MAC_1G_CFG_SET_10_DEF (1 << 5)
|
|||
|
/* Transmit low power enable */
|
|||
|
#define ETH_MAC_GEN_MAC_1G_CFG_LOWP_ENA (1 << 8)
|
|||
|
/*
|
|||
|
* Enable magic packet mode:
|
|||
|
* 0 - Sleep mode
|
|||
|
* 1 - Normal operation
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_MAC_1G_CFG_SLEEPN (1 << 9)
|
|||
|
/* Swap ff_tx_crc input */
|
|||
|
#define ETH_MAC_GEN_MAC_1G_CFG_SWAP_FF_TX_CRC (1 << 12)
|
|||
|
|
|||
|
/**** mac_1g_stat register ****/
|
|||
|
/* Status of the en_10 output form the 10/100/1000 MAC */
|
|||
|
#define ETH_MAC_GEN_MAC_1G_STAT_EN_10 (1 << 0)
|
|||
|
/* Status of the eth_mode output from th 10/100/1000 MAC */
|
|||
|
#define ETH_MAC_GEN_MAC_1G_STAT_ETH_MODE (1 << 1)
|
|||
|
/* Status of the lowp output from the 10/100/1000 MAC */
|
|||
|
#define ETH_MAC_GEN_MAC_1G_STAT_LOWP (1 << 4)
|
|||
|
/* Status of the wakeup output from the 10/100/1000 MAC */
|
|||
|
#define ETH_MAC_GEN_MAC_1G_STAT_WAKEUP (1 << 5)
|
|||
|
|
|||
|
/**** rgmii_cfg register ****/
|
|||
|
/*
|
|||
|
* Selection of the input for the "set_1000" input of the RGMII converter
|
|||
|
* 0 - From MAC
|
|||
|
* 1 - From register set_1000_def (automatic speed selection)
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_RGMII_CFG_SET_1000_SEL (1 << 0)
|
|||
|
/* Default value for the RGMII converter "set_1000" input */
|
|||
|
#define ETH_MAC_GEN_RGMII_CFG_SET_1000_DEF (1 << 1)
|
|||
|
/*
|
|||
|
* Selection of the input for the "set_10" input of the RGMII converter:
|
|||
|
* 0 - From MAC
|
|||
|
* 1 - From register set_10_def (automatic speed selection)
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_RGMII_CFG_SET_10_SEL (1 << 4)
|
|||
|
/* Default value for the 10/100/1000 MAC "set_10" input */
|
|||
|
#define ETH_MAC_GEN_RGMII_CFG_SET_10_DEF (1 << 5)
|
|||
|
/* Enable automatic speed selection (based on PHY in-band status information) */
|
|||
|
#define ETH_MAC_GEN_RGMII_CFG_ENA_AUTO (1 << 8)
|
|||
|
/* Force full duplex, only valid when ena_auto is '1'. */
|
|||
|
#define ETH_MAC_GEN_RGMII_CFG_SET_FD (1 << 9)
|
|||
|
|
|||
|
/**** rgmii_stat register ****/
|
|||
|
/*
|
|||
|
* Status of the speed output form the RGMII converter
|
|||
|
* 00 - 10 Mbps
|
|||
|
* 01 - 100 Mbps
|
|||
|
* 10 - 1000 Mbps
|
|||
|
* 11 - Reserved
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_RGMII_STAT_SPEED_MASK 0x00000003
|
|||
|
#define ETH_MAC_GEN_RGMII_STAT_SPEED_SHIFT 0
|
|||
|
/*
|
|||
|
* Link indication from the RGMII converter (valid only if the external PHY
|
|||
|
* supports in-band status signaling)
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_RGMII_STAT_LINK (1 << 4)
|
|||
|
/*
|
|||
|
* Full duplex indication from the RGMII converter (valid only if the external
|
|||
|
* PHY supports in-band status signaling)
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_RGMII_STAT_DUP (1 << 5)
|
|||
|
|
|||
|
/**** mac_10g_cfg register ****/
|
|||
|
/* Instruct the XGMII to transmit local fault. */
|
|||
|
#define ETH_MAC_GEN_MAC_10G_CFG_TX_LOC_FAULT (1 << 0)
|
|||
|
/* Instruct the XGMII to transmit remote fault. */
|
|||
|
#define ETH_MAC_GEN_MAC_10G_CFG_TX_REM_FAULT (1 << 1)
|
|||
|
/* Instruct the XGMII to transmit link fault. */
|
|||
|
#define ETH_MAC_GEN_MAC_10G_CFG_TX_LI_FAULT (1 << 2)
|
|||
|
/*
|
|||
|
* Synchronous reset for the PCS layer. Can be used after SerDes lock assertion
|
|||
|
* to reset the PCS state machine.
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_MAC_10G_CFG_SG_SRESET (1 << 3)
|
|||
|
/*
|
|||
|
* PHY LOS indication selection
|
|||
|
* 00 - Select register value from phy_los_def
|
|||
|
* 01 - Select input from the SerDes
|
|||
|
* 10 - Select input from GPIO
|
|||
|
* 11 - Select inverted input from GPIO
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_MAC_10G_CFG_PHY_LOS_SEL_MASK 0x00000030
|
|||
|
#define ETH_MAC_GEN_MAC_10G_CFG_PHY_LOS_SEL_SHIFT 4
|
|||
|
/*
|
|||
|
* Default value for PHY LOS indication. Reflects the LOS indication from the
|
|||
|
* SerDes. ('0' if not used)
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_MAC_10G_CFG_PHY_LOS_DEF (1 << 6)
|
|||
|
/* Reverse polarity of the LOS signal from the SerDes */
|
|||
|
#define ETH_MAC_GEN_MAC_10G_CFG_PHY_LOS_POL (1 << 7)
|
|||
|
/* Transmit low power enable */
|
|||
|
#define ETH_MAC_GEN_MAC_10G_CFG_LOWP_ENA (1 << 8)
|
|||
|
/* Swap ff_tx_crc input */
|
|||
|
#define ETH_MAC_GEN_MAC_10G_CFG_SWAP_FF_TX_CRC (1 << 12)
|
|||
|
|
|||
|
/**** mac_10g_stat register ****/
|
|||
|
/* XGMII RS detects local fault */
|
|||
|
#define ETH_MAC_GEN_MAC_10G_STAT_LOC_FAULT (1 << 0)
|
|||
|
/* XGMII RS detects remote fault */
|
|||
|
#define ETH_MAC_GEN_MAC_10G_STAT_REM_FAULT (1 << 1)
|
|||
|
/* XGMII RS detects link fault */
|
|||
|
#define ETH_MAC_GEN_MAC_10G_STAT_LI_FAULT (1 << 2)
|
|||
|
/* PFC mode */
|
|||
|
#define ETH_MAC_GEN_MAC_10G_STAT_PFC_MODE (1 << 3)
|
|||
|
|
|||
|
#define ETH_MAC_GEN_MAC_10G_STAT_SG_ENA (1 << 4)
|
|||
|
|
|||
|
#define ETH_MAC_GEN_MAC_10G_STAT_SG_ANDONE (1 << 5)
|
|||
|
|
|||
|
#define ETH_MAC_GEN_MAC_10G_STAT_SG_SYNC (1 << 6)
|
|||
|
|
|||
|
#define ETH_MAC_GEN_MAC_10G_STAT_SG_SPEED_MASK 0x00000180
|
|||
|
#define ETH_MAC_GEN_MAC_10G_STAT_SG_SPEED_SHIFT 7
|
|||
|
/* Status of the lowp output form the 1/2.5/10G MAC */
|
|||
|
#define ETH_MAC_GEN_MAC_10G_STAT_LOWP (1 << 9)
|
|||
|
/* Status of the ts_avail output from th 1/2.5/10G MAC */
|
|||
|
#define ETH_MAC_GEN_MAC_10G_STAT_TS_AVAIL (1 << 10)
|
|||
|
/* Transmit pause indication */
|
|||
|
#define ETH_MAC_GEN_MAC_10G_STAT_PAUSE_ON_MASK 0xFF000000
|
|||
|
#define ETH_MAC_GEN_MAC_10G_STAT_PAUSE_ON_SHIFT 24
|
|||
|
|
|||
|
/**** xaui_cfg register ****/
|
|||
|
/* Increase rate matching FIFO threshold */
|
|||
|
#define ETH_MAC_GEN_XAUI_CFG_JUMBO_EN (1 << 0)
|
|||
|
|
|||
|
/**** xaui_stat register ****/
|
|||
|
/* Lane alignment status */
|
|||
|
#define ETH_MAC_GEN_XAUI_STAT_ALIGN_DONE (1 << 0)
|
|||
|
/* Lane synchronization */
|
|||
|
#define ETH_MAC_GEN_XAUI_STAT_SYNC_MASK 0x000000F0
|
|||
|
#define ETH_MAC_GEN_XAUI_STAT_SYNC_SHIFT 4
|
|||
|
/* Code group alignment indication */
|
|||
|
#define ETH_MAC_GEN_XAUI_STAT_CG_ALIGN_MASK 0x00000F00
|
|||
|
#define ETH_MAC_GEN_XAUI_STAT_CG_ALIGN_SHIFT 8
|
|||
|
|
|||
|
/**** rxaui_cfg register ****/
|
|||
|
/* Increase rate matching FIFO threshold */
|
|||
|
#define ETH_MAC_GEN_RXAUI_CFG_JUMBO_EN (1 << 0)
|
|||
|
/* Scrambler enable */
|
|||
|
#define ETH_MAC_GEN_RXAUI_CFG_SRBL_EN (1 << 1)
|
|||
|
/* Disparity calculation across lanes enabled */
|
|||
|
#define ETH_MAC_GEN_RXAUI_CFG_DISP_ACROSS_LANE (1 << 2)
|
|||
|
|
|||
|
/**** rxaui_stat register ****/
|
|||
|
/* Lane alignment status */
|
|||
|
#define ETH_MAC_GEN_RXAUI_STAT_ALIGN_DONE (1 << 0)
|
|||
|
/* Lane synchronization */
|
|||
|
#define ETH_MAC_GEN_RXAUI_STAT_SYNC_MASK 0x000000F0
|
|||
|
#define ETH_MAC_GEN_RXAUI_STAT_SYNC_SHIFT 4
|
|||
|
/* Code group alignment indication */
|
|||
|
#define ETH_MAC_GEN_RXAUI_STAT_CG_ALIGN_MASK 0x00000F00
|
|||
|
#define ETH_MAC_GEN_RXAUI_STAT_CG_ALIGN_SHIFT 8
|
|||
|
|
|||
|
/**** sd_cfg register ****/
|
|||
|
/*
|
|||
|
* Signal detect selection
|
|||
|
* 0 - from register
|
|||
|
* 1 - from SerDes
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_SD_CFG_SEL_MASK 0x0000000F
|
|||
|
#define ETH_MAC_GEN_SD_CFG_SEL_SHIFT 0
|
|||
|
/* Signal detect value */
|
|||
|
#define ETH_MAC_GEN_SD_CFG_VAL_MASK 0x000000F0
|
|||
|
#define ETH_MAC_GEN_SD_CFG_VAL_SHIFT 4
|
|||
|
/* Signal detect revers polarity (reverse polarity of signal from the SerDes */
|
|||
|
#define ETH_MAC_GEN_SD_CFG_POL_MASK 0x00000F00
|
|||
|
#define ETH_MAC_GEN_SD_CFG_POL_SHIFT 8
|
|||
|
|
|||
|
/**** mdio_ctrl_1 register ****/
|
|||
|
/*
|
|||
|
* Available indication
|
|||
|
* 0 - The port was available and it is captured by this Ethernet controller.
|
|||
|
* 1 - The port is used by another Ethernet controller.
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_MDIO_CTRL_1_AVAIL (1 << 0)
|
|||
|
|
|||
|
/**** mdio_1 register ****/
|
|||
|
/* Current Ethernet interface number that controls the MDIO port */
|
|||
|
#define ETH_MAC_GEN_MDIO_1_INFO_MASK 0x000000FF
|
|||
|
#define ETH_MAC_GEN_MDIO_1_INFO_SHIFT 0
|
|||
|
|
|||
|
/**** mdio_ctrl_2 register ****/
|
|||
|
/*
|
|||
|
* Available indication
|
|||
|
* 0 - The port was available and it is captured by this Ethernet controller.
|
|||
|
* 1 - The port is used by another Ethernet controller.
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_MDIO_CTRL_2_AVAIL (1 << 0)
|
|||
|
|
|||
|
/**** mdio_2 register ****/
|
|||
|
/* Current Ethernet interface number that controls the MDIO port */
|
|||
|
#define ETH_MAC_GEN_MDIO_2_INFO_MASK 0x000000FF
|
|||
|
#define ETH_MAC_GEN_MDIO_2_INFO_SHIFT 0
|
|||
|
|
|||
|
/**** xgmii_dfifo_32_64 register ****/
|
|||
|
/* FIFO enable */
|
|||
|
#define ETH_MAC_GEN_XGMII_DFIFO_32_64_ENABLE (1 << 0)
|
|||
|
/* Read Write command every 2 cycles */
|
|||
|
#define ETH_MAC_GEN_XGMII_DFIFO_32_64_RW_2_CYCLES (1 << 1)
|
|||
|
/* Swap LSB MSB when creating wider bus */
|
|||
|
#define ETH_MAC_GEN_XGMII_DFIFO_32_64_SWAP_LSB_MSB (1 << 2)
|
|||
|
/* Software reset */
|
|||
|
#define ETH_MAC_GEN_XGMII_DFIFO_32_64_SW_RESET (1 << 4)
|
|||
|
/* Read threshold */
|
|||
|
#define ETH_MAC_GEN_XGMII_DFIFO_32_64_READ_TH_MASK 0x0000FF00
|
|||
|
#define ETH_MAC_GEN_XGMII_DFIFO_32_64_READ_TH_SHIFT 8
|
|||
|
/* FIFO used */
|
|||
|
#define ETH_MAC_GEN_XGMII_DFIFO_32_64_USED_MASK 0x00FF0000
|
|||
|
#define ETH_MAC_GEN_XGMII_DFIFO_32_64_USED_SHIFT 16
|
|||
|
|
|||
|
/**** xgmii_dfifo_64_32 register ****/
|
|||
|
/* FIFO enable */
|
|||
|
#define ETH_MAC_GEN_XGMII_DFIFO_64_32_ENABLE (1 << 0)
|
|||
|
/* Read Write command every 2 cycles */
|
|||
|
#define ETH_MAC_GEN_XGMII_DFIFO_64_32_RW_2_CYCLES (1 << 1)
|
|||
|
/* Swap LSB MSB when creating wider bus */
|
|||
|
#define ETH_MAC_GEN_XGMII_DFIFO_64_32_SWAP_LSB_MSB (1 << 2)
|
|||
|
/* Software reset */
|
|||
|
#define ETH_MAC_GEN_XGMII_DFIFO_64_32_SW_RESET (1 << 4)
|
|||
|
/* Read threshold */
|
|||
|
#define ETH_MAC_GEN_XGMII_DFIFO_64_32_READ_TH_MASK 0x0000FF00
|
|||
|
#define ETH_MAC_GEN_XGMII_DFIFO_64_32_READ_TH_SHIFT 8
|
|||
|
/* FIFO used */
|
|||
|
#define ETH_MAC_GEN_XGMII_DFIFO_64_32_USED_MASK 0x00FF0000
|
|||
|
#define ETH_MAC_GEN_XGMII_DFIFO_64_32_USED_SHIFT 16
|
|||
|
|
|||
|
/**** sd_fifo_ctrl register ****/
|
|||
|
/* FIFO enable */
|
|||
|
#define ETH_MAC_GEN_SD_FIFO_CTRL_ENABLE_MASK 0x0000000F
|
|||
|
#define ETH_MAC_GEN_SD_FIFO_CTRL_ENABLE_SHIFT 0
|
|||
|
/* Software reset */
|
|||
|
#define ETH_MAC_GEN_SD_FIFO_CTRL_SW_RESET_MASK 0x000000F0
|
|||
|
#define ETH_MAC_GEN_SD_FIFO_CTRL_SW_RESET_SHIFT 4
|
|||
|
/* Read threshold */
|
|||
|
#define ETH_MAC_GEN_SD_FIFO_CTRL_READ_TH_MASK 0x0000FF00
|
|||
|
#define ETH_MAC_GEN_SD_FIFO_CTRL_READ_TH_SHIFT 8
|
|||
|
|
|||
|
/**** sd_fifo_stat register ****/
|
|||
|
/* FIFO 0 used */
|
|||
|
#define ETH_MAC_GEN_SD_FIFO_STAT_USED_0_MASK 0x000000FF
|
|||
|
#define ETH_MAC_GEN_SD_FIFO_STAT_USED_0_SHIFT 0
|
|||
|
/* FIFO 1 used */
|
|||
|
#define ETH_MAC_GEN_SD_FIFO_STAT_USED_1_MASK 0x0000FF00
|
|||
|
#define ETH_MAC_GEN_SD_FIFO_STAT_USED_1_SHIFT 8
|
|||
|
/* FIFO 2 used */
|
|||
|
#define ETH_MAC_GEN_SD_FIFO_STAT_USED_2_MASK 0x00FF0000
|
|||
|
#define ETH_MAC_GEN_SD_FIFO_STAT_USED_2_SHIFT 16
|
|||
|
/* FIFO 3 used */
|
|||
|
#define ETH_MAC_GEN_SD_FIFO_STAT_USED_3_MASK 0xFF000000
|
|||
|
#define ETH_MAC_GEN_SD_FIFO_STAT_USED_3_SHIFT 24
|
|||
|
|
|||
|
/**** mux_sel register ****/
|
|||
|
/*
|
|||
|
* SGMII input selection selector
|
|||
|
* 00 – SerDes 0
|
|||
|
* 01 – SerDes 1
|
|||
|
* 10 – SerDes 2
|
|||
|
* 11 – SerDes 3
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_MUX_SEL_SGMII_IN_MASK 0x00000003
|
|||
|
#define ETH_MAC_GEN_MUX_SEL_SGMII_IN_SHIFT 0
|
|||
|
/*
|
|||
|
* RXAUI Lane 0 Input
|
|||
|
* 00 – SerDes 0
|
|||
|
* 01 – SerDes 1
|
|||
|
* 10 – SerDes 2
|
|||
|
* 11 – SerDes 3
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_MUX_SEL_RXAUI_0_IN_MASK 0x0000000C
|
|||
|
#define ETH_MAC_GEN_MUX_SEL_RXAUI_0_IN_SHIFT 2
|
|||
|
/*
|
|||
|
* RXAUI Lane 1 Input
|
|||
|
* 00 – SERDES 0
|
|||
|
* 01 – SERDES 1
|
|||
|
* 10 – SERDES 2
|
|||
|
* 11 – SERDES 3
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_MUX_SEL_RXAUI_1_IN_MASK 0x00000030
|
|||
|
#define ETH_MAC_GEN_MUX_SEL_RXAUI_1_IN_SHIFT 4
|
|||
|
/*
|
|||
|
* XAUI Lane 0 Input
|
|||
|
* 00 – SERDES 0
|
|||
|
* 01 – SERDES 1
|
|||
|
* 10 – SERDES 2
|
|||
|
* 11 – SERDES 3
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_MUX_SEL_XAUI_0_IN_MASK 0x000000C0
|
|||
|
#define ETH_MAC_GEN_MUX_SEL_XAUI_0_IN_SHIFT 6
|
|||
|
/*
|
|||
|
* XAUI Lane 1 Input
|
|||
|
* 00 – SERDES 0
|
|||
|
* 01 – SERDES 1
|
|||
|
* 10 – SERDES 2
|
|||
|
* 11 – SERDES 3
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_MUX_SEL_XAUI_1_IN_MASK 0x00000300
|
|||
|
#define ETH_MAC_GEN_MUX_SEL_XAUI_1_IN_SHIFT 8
|
|||
|
/*
|
|||
|
* XAUI Lane 2 Input
|
|||
|
* 00 – SERDES 0
|
|||
|
* 01 – SERDES 1
|
|||
|
* 10 – SERDES 2
|
|||
|
* 11 – SERDES 3
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_MUX_SEL_XAUI_2_IN_MASK 0x00000C00
|
|||
|
#define ETH_MAC_GEN_MUX_SEL_XAUI_2_IN_SHIFT 10
|
|||
|
/*
|
|||
|
* XAUI Lane 3 Input
|
|||
|
* 00 – SERDES 0
|
|||
|
* 01 – SERDES 1
|
|||
|
* 10 – SERDES 2
|
|||
|
* 11 – SERDES 3
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_MUX_SEL_XAUI_3_IN_MASK 0x00003000
|
|||
|
#define ETH_MAC_GEN_MUX_SEL_XAUI_3_IN_SHIFT 12
|
|||
|
/*
|
|||
|
* KR PCS Input
|
|||
|
* 00 - SERDES 0
|
|||
|
* 01 - SERDES 1
|
|||
|
* 10 - SERDES 2
|
|||
|
* 11 - SERDES 3
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_MUX_SEL_KR_IN_MASK 0x0000C000
|
|||
|
#define ETH_MAC_GEN_MUX_SEL_KR_IN_SHIFT 14
|
|||
|
/*
|
|||
|
* SerDes 0 input selection (TX)
|
|||
|
* 000 – XAUI lane 0
|
|||
|
* 001 – XAUI lane 1
|
|||
|
* 010 – XAUI lane 2
|
|||
|
* 011 – XAUI lane 3
|
|||
|
* 100 – RXAUI lane 0
|
|||
|
* 101 – RXAUI lane 1
|
|||
|
* 110 – SGMII
|
|||
|
* 111 – KR
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_MUX_SEL_SERDES_0_TX_MASK 0x00070000
|
|||
|
#define ETH_MAC_GEN_MUX_SEL_SERDES_0_TX_SHIFT 16
|
|||
|
/*
|
|||
|
* SERDES 1 input selection (Tx)
|
|||
|
* 000 – XAUI lane 0
|
|||
|
* 001 – XAUI lane 1
|
|||
|
* 010 – XAUI lane 2
|
|||
|
* 011 – XAUI lane 3
|
|||
|
* 100 – RXAUI lane 0
|
|||
|
* 101 – RXAUI lane 1
|
|||
|
* 110 – SGMII
|
|||
|
* 111 – KR
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_MUX_SEL_SERDES_1_TX_MASK 0x00380000
|
|||
|
#define ETH_MAC_GEN_MUX_SEL_SERDES_1_TX_SHIFT 19
|
|||
|
/*
|
|||
|
* SerDes 2 input selection (Tx)
|
|||
|
* 000 – XAUI lane 0
|
|||
|
* 001 – XAUI lane 1
|
|||
|
* 010 – XAUI lane 2
|
|||
|
* 011 – XAUI lane 3
|
|||
|
* 100 – RXAUI lane 0
|
|||
|
* 101 – RXAUI lane 1
|
|||
|
* 110 – SGMII
|
|||
|
* 111 – KR
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_MUX_SEL_SERDES_2_TX_MASK 0x01C00000
|
|||
|
#define ETH_MAC_GEN_MUX_SEL_SERDES_2_TX_SHIFT 22
|
|||
|
/*
|
|||
|
* SerDes 3 input selection (Tx)
|
|||
|
* 000 – XAUI lane 0
|
|||
|
* 001 – XAUI lane 1
|
|||
|
* 010 – XAUI lane 2
|
|||
|
* 011 – XAUI lane 3
|
|||
|
* 100 – RXAUI lane 0
|
|||
|
* 101 – RXAUI lane 1
|
|||
|
* 110 – SGMII
|
|||
|
* 111 – KR
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_MUX_SEL_SERDES_3_TX_MASK 0x0E000000
|
|||
|
#define ETH_MAC_GEN_MUX_SEL_SERDES_3_TX_SHIFT 25
|
|||
|
|
|||
|
/**** clk_cfg register ****/
|
|||
|
/*
|
|||
|
* Rx/Tx lane 0 clock MUX select
|
|||
|
* must be aligned with data selector MUXs)
|
|||
|
* 0 – SerDes 0 clock
|
|||
|
* 0 – SerDes 1 clock
|
|||
|
* 2 – SerDes 2 clock
|
|||
|
* 3 – SerDes 3 clock
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_CLK_CFG_LANE_0_CLK_SEL_MASK 0x00000003
|
|||
|
#define ETH_MAC_GEN_CLK_CFG_LANE_0_CLK_SEL_SHIFT 0
|
|||
|
/*
|
|||
|
* Rx/Tx lane 0 clock MUX select must be aligned with data selector MUXs)
|
|||
|
* 0 - SerDes 0 clock
|
|||
|
* 1 - SerDes 1 clock
|
|||
|
* 2 - SerDes 2 clock
|
|||
|
* 3 - SerDes 3 clock
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_CLK_CFG_LANE_1_CLK_SEL_MASK 0x00000030
|
|||
|
#define ETH_MAC_GEN_CLK_CFG_LANE_1_CLK_SEL_SHIFT 4
|
|||
|
/*
|
|||
|
* RX/TX lane 0 clock MUX select (should be aligned with data selector MUXs)
|
|||
|
* 0 - SERDES 0 clock
|
|||
|
* 1 - SERDES 1 clock
|
|||
|
* 2 - SERDES 2 clock
|
|||
|
* 3 - SERDES 3 clock
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_CLK_CFG_LANE_2_CLK_SEL_MASK 0x00000300
|
|||
|
#define ETH_MAC_GEN_CLK_CFG_LANE_2_CLK_SEL_SHIFT 8
|
|||
|
/*
|
|||
|
* Rx/Tx lane 0 clock MUX select must be aligned with data selector MUXs)
|
|||
|
* 0 - SerDes 0 clock
|
|||
|
* 1 - SerDes 1 clock
|
|||
|
* 2 - SerDes 2 clock
|
|||
|
* 3 - SerDes 3 clock
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_CLK_CFG_LANE_3_CLK_SEL_MASK 0x00003000
|
|||
|
#define ETH_MAC_GEN_CLK_CFG_LANE_3_CLK_SEL_SHIFT 12
|
|||
|
/*
|
|||
|
* MAC GMII Rx clock MUX select must be aligned with data selector MUXs)
|
|||
|
* 0 – RGMII
|
|||
|
* 1 – SGMII
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_CLK_CFG_GMII_RX_CLK_SEL (1 << 16)
|
|||
|
/*
|
|||
|
* MAC GMII Tx clock MUX select (should be aligned with data selector MUXs)
|
|||
|
* 0 - RGMII
|
|||
|
* 1 - SGMII
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_CLK_CFG_GMII_TX_CLK_SEL (1 << 18)
|
|||
|
/*
|
|||
|
* Tx clock MUX select,
|
|||
|
* Selects the internal clock for the Tx data path
|
|||
|
* 0 – SerDes[0] TX DWORD CLK REF (for RXAUI and SGMII)
|
|||
|
* 1 – SerDes[0] TX WORD CLK REF (for XAUI and KR)
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_CLK_CFG_TX_CLK_SEL (1 << 28)
|
|||
|
/*
|
|||
|
* Rxclock MUX select
|
|||
|
* Selects the internal clock for the Rx data path
|
|||
|
* 0 – XGMII TX CLK 32 LOCAL (for XAUI and RXAUI and KR)
|
|||
|
* 1 – SerDes[0] RX DWORD CLK GENERATED (125M)
|
|||
|
* (for SGMII)
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_CLK_CFG_RX_CLK_SEL (1 << 30)
|
|||
|
|
|||
|
/**** los_sel register ****/
|
|||
|
/*
|
|||
|
* Selected LOS/SD select
|
|||
|
* 00 – SerDes 0
|
|||
|
* 01 – SerDes 1
|
|||
|
* 10 – SerDes 2
|
|||
|
* 11 – SerDes 3
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_LOS_SEL_LANE_0_SEL_MASK 0x00000003
|
|||
|
#define ETH_MAC_GEN_LOS_SEL_LANE_0_SEL_SHIFT 0
|
|||
|
/*
|
|||
|
* Selected LOS/SD select
|
|||
|
* 00 - SerDes 0
|
|||
|
* 01 - SerDes 1
|
|||
|
* 10 - SerDes 2
|
|||
|
* 11 - SerDes 3
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_LOS_SEL_LANE_1_SEL_MASK 0x00000030
|
|||
|
#define ETH_MAC_GEN_LOS_SEL_LANE_1_SEL_SHIFT 4
|
|||
|
/*
|
|||
|
* Selected LOS/SD select
|
|||
|
* 00 - SerDes 0
|
|||
|
* 01 - SerDes 1
|
|||
|
* 10 - SerDes 2
|
|||
|
* 11 - SerDes 3
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_LOS_SEL_LANE_2_SEL_MASK 0x00000300
|
|||
|
#define ETH_MAC_GEN_LOS_SEL_LANE_2_SEL_SHIFT 8
|
|||
|
/*
|
|||
|
* Selected LOS/SD select
|
|||
|
* 00 - SerDes 0
|
|||
|
* 01 - SerDes 1
|
|||
|
* 10 - SerDes 2
|
|||
|
* 11 - SerDes 3
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_LOS_SEL_LANE_3_SEL_MASK 0x00003000
|
|||
|
#define ETH_MAC_GEN_LOS_SEL_LANE_3_SEL_SHIFT 12
|
|||
|
|
|||
|
/**** rgmii_sel register ****/
|
|||
|
/* Swap [3:0] input with [7:4] */
|
|||
|
#define ETH_MAC_GEN_RGMII_SEL_RX_SWAP_3_0 (1 << 0)
|
|||
|
/* Swap [4] input with [9] */
|
|||
|
#define ETH_MAC_GEN_RGMII_SEL_RX_SWAP_4 (1 << 1)
|
|||
|
/* Swap [7:4] input with [3:0] */
|
|||
|
#define ETH_MAC_GEN_RGMII_SEL_RX_SWAP_7_3 (1 << 2)
|
|||
|
/* Swap [9] input with [4] */
|
|||
|
#define ETH_MAC_GEN_RGMII_SEL_RX_SWAP_9 (1 << 3)
|
|||
|
/* Swap [3:0] input with [7:4] */
|
|||
|
#define ETH_MAC_GEN_RGMII_SEL_TX_SWAP_3_0 (1 << 4)
|
|||
|
/* Swap [4] input with [9] */
|
|||
|
#define ETH_MAC_GEN_RGMII_SEL_TX_SWAP_4 (1 << 5)
|
|||
|
/* Swap [7:4] input with [3:0] */
|
|||
|
#define ETH_MAC_GEN_RGMII_SEL_TX_SWAP_7_3 (1 << 6)
|
|||
|
/* Swap [9] input with [4] */
|
|||
|
#define ETH_MAC_GEN_RGMII_SEL_TX_SWAP_9 (1 << 7)
|
|||
|
|
|||
|
/**** led_cfg register ****/
|
|||
|
/*
|
|||
|
* LED source selection:
|
|||
|
* 0 – Default reg
|
|||
|
* 1 – Rx activity
|
|||
|
* 2 – Tx activity
|
|||
|
* 3 – Rx | Tx activity
|
|||
|
* 4-9 – SGMII LEDs
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_LED_CFG_SEL_MASK 0x0000000F
|
|||
|
#define ETH_MAC_GEN_LED_CFG_SEL_SHIFT 0
|
|||
|
|
|||
|
/* turn the led on/off based on default value field (ETH_MAC_GEN_LED_CFG_DEF) */
|
|||
|
#define ETH_MAC_GEN_LED_CFG_SEL_DEFAULT_REG 0
|
|||
|
#define ETH_MAC_GEN_LED_CFG_SEL_RX_ACTIVITY_DEPRECIATED 1
|
|||
|
#define ETH_MAC_GEN_LED_CFG_SEL_TX_ACTIVITY_DEPRECIATED 2
|
|||
|
#define ETH_MAC_GEN_LED_CFG_SEL_RX_TX_ACTIVITY_DEPRECIATED 3
|
|||
|
#define ETH_MAC_GEN_LED_CFG_SEL_LINK_ACTIVITY 10
|
|||
|
|
|||
|
/* LED default value */
|
|||
|
#define ETH_MAC_GEN_LED_CFG_DEF (1 << 4)
|
|||
|
/* LED signal polarity */
|
|||
|
#define ETH_MAC_GEN_LED_CFG_POL (1 << 5)
|
|||
|
/*
|
|||
|
* activity timer (MSB)
|
|||
|
* 32 bit timer @SB clock
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_LED_CFG_ACT_TIMER_MASK 0x00FF0000
|
|||
|
#define ETH_MAC_GEN_LED_CFG_ACT_TIMER_SHIFT 16
|
|||
|
/*
|
|||
|
* activity timer (MSB)
|
|||
|
* 32 bit timer @SB clock
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_LED_CFG_BLINK_TIMER_MASK 0xFF000000
|
|||
|
#define ETH_MAC_GEN_LED_CFG_BLINK_TIMER_SHIFT 24
|
|||
|
|
|||
|
/**** pcs_addr register ****/
|
|||
|
/* Address value */
|
|||
|
#define ETH_MAC_KR_PCS_ADDR_VAL_MASK 0x0000FFFF
|
|||
|
#define ETH_MAC_KR_PCS_ADDR_VAL_SHIFT 0
|
|||
|
|
|||
|
/**** pcs_data register ****/
|
|||
|
/* Data value */
|
|||
|
#define ETH_MAC_KR_PCS_DATA_VAL_MASK 0x0000FFFF
|
|||
|
#define ETH_MAC_KR_PCS_DATA_VAL_SHIFT 0
|
|||
|
|
|||
|
/**** an_addr register ****/
|
|||
|
/* Address value */
|
|||
|
#define ETH_MAC_KR_AN_ADDR_VAL_MASK 0x0000FFFF
|
|||
|
#define ETH_MAC_KR_AN_ADDR_VAL_SHIFT 0
|
|||
|
|
|||
|
/**** an_data register ****/
|
|||
|
/* Data value */
|
|||
|
#define ETH_MAC_KR_AN_DATA_VAL_MASK 0x0000FFFF
|
|||
|
#define ETH_MAC_KR_AN_DATA_VAL_SHIFT 0
|
|||
|
|
|||
|
/**** pma_addr register ****/
|
|||
|
/* Dddress value */
|
|||
|
#define ETH_MAC_KR_PMA_ADDR_VAL_MASK 0x0000FFFF
|
|||
|
#define ETH_MAC_KR_PMA_ADDR_VAL_SHIFT 0
|
|||
|
|
|||
|
/**** pma_data register ****/
|
|||
|
/* Data value */
|
|||
|
#define ETH_MAC_KR_PMA_DATA_VAL_MASK 0x0000FFFF
|
|||
|
#define ETH_MAC_KR_PMA_DATA_VAL_SHIFT 0
|
|||
|
|
|||
|
/**** mtip_addr register ****/
|
|||
|
/* Address value */
|
|||
|
#define ETH_MAC_KR_MTIP_ADDR_VAL_MASK 0x0000FFFF
|
|||
|
#define ETH_MAC_KR_MTIP_ADDR_VAL_SHIFT 0
|
|||
|
|
|||
|
/**** mtip_data register ****/
|
|||
|
/* Data value */
|
|||
|
#define ETH_MAC_KR_MTIP_DATA_VAL_MASK 0x0000FFFF
|
|||
|
#define ETH_MAC_KR_MTIP_DATA_VAL_SHIFT 0
|
|||
|
|
|||
|
/**** pcs_cfg register ****/
|
|||
|
/* Enable Auto-Negotiation after Reset */
|
|||
|
#define ETH_MAC_KR_PCS_CFG_STRAP_AN_ENA (1 << 0)
|
|||
|
/*
|
|||
|
* Signal detect selector for the EEE
|
|||
|
* 0 – Register default value
|
|||
|
* 1 – SerDes value
|
|||
|
*/
|
|||
|
#define ETH_MAC_KR_PCS_CFG_EEE_SD_SEL (1 << 4)
|
|||
|
/* Signal detect default value for the EEE */
|
|||
|
#define ETH_MAC_KR_PCS_CFG_EEE_DEF_VAL (1 << 5)
|
|||
|
/* Signal detect polarity reversal for the EEE */
|
|||
|
#define ETH_MAC_KR_PCS_CFG_EEE_SD_POL (1 << 6)
|
|||
|
/* EEE timer value */
|
|||
|
#define ETH_MAC_KR_PCS_CFG_EEE_TIMER_VAL_MASK 0x0000FF00
|
|||
|
#define ETH_MAC_KR_PCS_CFG_EEE_TIMER_VAL_SHIFT 8
|
|||
|
/*
|
|||
|
* Selects source for the enable SerDes DME signal
|
|||
|
* 0 – Register value
|
|||
|
* 1 – PCS output
|
|||
|
*/
|
|||
|
#define ETH_MAC_KR_PCS_CFG_DME_SEL (1 << 16)
|
|||
|
/* DME default value */
|
|||
|
#define ETH_MAC_KR_PCS_CFG_DME_VAL (1 << 17)
|
|||
|
/* DME default polarity reversal when selecting PCS output */
|
|||
|
#define ETH_MAC_KR_PCS_CFG_DME_POL (1 << 18)
|
|||
|
|
|||
|
/**** pcs_stat register ****/
|
|||
|
/* Link enable by the Auto-Negotiation */
|
|||
|
#define ETH_MAC_KR_PCS_STAT_AN_LINK_CONTROL_MASK 0x0000003F
|
|||
|
#define ETH_MAC_KR_PCS_STAT_AN_LINK_CONTROL_SHIFT 0
|
|||
|
/* Block lock */
|
|||
|
#define ETH_MAC_KR_PCS_STAT_BLOCK_LOCK (1 << 8)
|
|||
|
/* hi BER */
|
|||
|
#define ETH_MAC_KR_PCS_STAT_HI_BER (1 << 9)
|
|||
|
|
|||
|
#define ETH_MAC_KR_PCS_STAT_RX_WAKE_ERR (1 << 16)
|
|||
|
|
|||
|
#define ETH_MAC_KR_PCS_STAT_PMA_TXMODE_ALERT (1 << 17)
|
|||
|
|
|||
|
#define ETH_MAC_KR_PCS_STAT_PMA_TXMODE_QUIET (1 << 18)
|
|||
|
|
|||
|
#define ETH_MAC_KR_PCS_STAT_PMA_RXMODE_QUIET (1 << 19)
|
|||
|
|
|||
|
#define ETH_MAC_KR_PCS_STAT_RX_LPI_ACTIVE (1 << 20)
|
|||
|
|
|||
|
#define ETH_MAC_KR_PCS_STAT_TX_LPI_ACTIVE (1 << 21)
|
|||
|
|
|||
|
/**** reg_addr register ****/
|
|||
|
/* Address value */
|
|||
|
#define ETH_MAC_SGMII_REG_ADDR_VAL_MASK 0x0000001F
|
|||
|
#define ETH_MAC_SGMII_REG_ADDR_VAL_SHIFT 0
|
|||
|
|
|||
|
#define ETH_MAC_SGMII_REG_ADDR_CTRL_REG 0x0
|
|||
|
#define ETH_MAC_SGMII_REG_ADDR_IF_MODE_REG 0x14
|
|||
|
|
|||
|
/**** reg_data register ****/
|
|||
|
/* Data value */
|
|||
|
#define ETH_MAC_SGMII_REG_DATA_VAL_MASK 0x0000FFFF
|
|||
|
#define ETH_MAC_SGMII_REG_DATA_VAL_SHIFT 0
|
|||
|
|
|||
|
#define ETH_MAC_SGMII_REG_DATA_CTRL_AN_ENABLE (1 << 12)
|
|||
|
#define ETH_MAC_SGMII_REG_DATA_IF_MODE_SGMII_EN (1 << 0)
|
|||
|
#define ETH_MAC_SGMII_REG_DATA_IF_MODE_SGMII_AN (1 << 1)
|
|||
|
#define ETH_MAC_SGMII_REG_DATA_IF_MODE_SGMII_SPEED_MASK 0xC
|
|||
|
#define ETH_MAC_SGMII_REG_DATA_IF_MODE_SGMII_SPEED_SHIFT 2
|
|||
|
#define ETH_MAC_SGMII_REG_DATA_IF_MODE_SGMII_SPEED_10 0x0
|
|||
|
#define ETH_MAC_SGMII_REG_DATA_IF_MODE_SGMII_SPEED_100 0x1
|
|||
|
#define ETH_MAC_SGMII_REG_DATA_IF_MODE_SGMII_SPEED_1000 0x2
|
|||
|
#define ETH_MAC_SGMII_REG_DATA_IF_MODE_SGMII_DUPLEX (1 << 4)
|
|||
|
|
|||
|
/**** clk_div register ****/
|
|||
|
/* Value for 1000M selection */
|
|||
|
#define ETH_MAC_SGMII_CLK_DIV_VAL_1000_MASK 0x000000FF
|
|||
|
#define ETH_MAC_SGMII_CLK_DIV_VAL_1000_SHIFT 0
|
|||
|
/* Value for 100M selection */
|
|||
|
#define ETH_MAC_SGMII_CLK_DIV_VAL_100_MASK 0x0000FF00
|
|||
|
#define ETH_MAC_SGMII_CLK_DIV_VAL_100_SHIFT 8
|
|||
|
/* Value for 10M selection */
|
|||
|
#define ETH_MAC_SGMII_CLK_DIV_VAL_10_MASK 0x00FF0000
|
|||
|
#define ETH_MAC_SGMII_CLK_DIV_VAL_10_SHIFT 16
|
|||
|
/* Bypass PCS selection */
|
|||
|
#define ETH_MAC_SGMII_CLK_DIV_BYPASS (1 << 24)
|
|||
|
/*
|
|||
|
* Divider selection when bypass field is '1', one hot
|
|||
|
* 001 – 1000M
|
|||
|
* 010 – 100M
|
|||
|
* 100 – 10M
|
|||
|
*/
|
|||
|
#define ETH_MAC_SGMII_CLK_DIV_SEL_MASK 0x0E000000
|
|||
|
#define ETH_MAC_SGMII_CLK_DIV_SEL_SHIFT 25
|
|||
|
|
|||
|
/**** link_stat register ****/
|
|||
|
|
|||
|
#define ETH_MAC_SGMII_LINK_STAT_SET_1000 (1 << 0)
|
|||
|
|
|||
|
#define ETH_MAC_SGMII_LINK_STAT_SET_100 (1 << 1)
|
|||
|
|
|||
|
#define ETH_MAC_SGMII_LINK_STAT_SET_10 (1 << 2)
|
|||
|
|
|||
|
#define ETH_MAC_SGMII_LINK_STAT_LED_AN (1 << 3)
|
|||
|
|
|||
|
#define ETH_MAC_SGMII_LINK_STAT_HD_ENA (1 << 4)
|
|||
|
|
|||
|
#define ETH_MAC_SGMII_LINK_STAT_LED_LINK (1 << 5)
|
|||
|
|
|||
|
/**** afifo_ctrl register ****/
|
|||
|
/* enable tx input operation */
|
|||
|
#define ETH_MAC_GEN_V3_AFIFO_CTRL_EN_TX_IN (1 << 0)
|
|||
|
/* enable tx output operation */
|
|||
|
#define ETH_MAC_GEN_V3_AFIFO_CTRL_EN_TX_OUT (1 << 1)
|
|||
|
/* enable rx input operation */
|
|||
|
#define ETH_MAC_GEN_V3_AFIFO_CTRL_EN_RX_IN (1 << 4)
|
|||
|
/* enable rx output operation */
|
|||
|
#define ETH_MAC_GEN_V3_AFIFO_CTRL_EN_RX_OUT (1 << 5)
|
|||
|
/* enable tx FIFO input operation */
|
|||
|
#define ETH_MAC_GEN_V3_AFIFO_CTRL_EN_TX_FIFO_IN (1 << 8)
|
|||
|
/* enable tx FIFO output operation */
|
|||
|
#define ETH_MAC_GEN_V3_AFIFO_CTRL_EN_TX_FIFO_OUT (1 << 9)
|
|||
|
/* enable rx FIFO input operation */
|
|||
|
#define ETH_MAC_GEN_V3_AFIFO_CTRL_EN_RX_FIFO_IN (1 << 12)
|
|||
|
/* enable rx FIFO output operation */
|
|||
|
#define ETH_MAC_GEN_V3_AFIFO_CTRL_EN_RX_FIFO_OUT (1 << 13)
|
|||
|
|
|||
|
/**** tx_afifo_cfg_1 register ****/
|
|||
|
/* minimum packet size configuration */
|
|||
|
#define ETH_MAC_GEN_V3_TX_AFIFO_CFG_1_MIN_PKT_SIZE_MASK 0x0000FFFF
|
|||
|
#define ETH_MAC_GEN_V3_TX_AFIFO_CFG_1_MIN_PKT_SIZE_SHIFT 0
|
|||
|
|
|||
|
/**** tx_afifo_cfg_2 register ****/
|
|||
|
/* maximum packet size configuration */
|
|||
|
#define ETH_MAC_GEN_V3_TX_AFIFO_CFG_2_MAX_PKT_SIZE_MASK 0x0000FFFF
|
|||
|
#define ETH_MAC_GEN_V3_TX_AFIFO_CFG_2_MAX_PKT_SIZE_SHIFT 0
|
|||
|
|
|||
|
/**** tx_afifo_cfg_3 register ****/
|
|||
|
/* input bus width */
|
|||
|
#define ETH_MAC_GEN_V3_TX_AFIFO_CFG_3_INPUT_BUS_W_MASK 0x0000FFFF
|
|||
|
#define ETH_MAC_GEN_V3_TX_AFIFO_CFG_3_INPUT_BUS_W_SHIFT 0
|
|||
|
/* input bus width divide factor */
|
|||
|
#define ETH_MAC_GEN_V3_TX_AFIFO_CFG_3_INPUT_BUS_W_F_MASK 0xFFFF0000
|
|||
|
#define ETH_MAC_GEN_V3_TX_AFIFO_CFG_3_INPUT_BUS_W_F_SHIFT 16
|
|||
|
|
|||
|
/**** tx_afifo_cfg_4 register ****/
|
|||
|
/* output bus width */
|
|||
|
#define ETH_MAC_GEN_V3_TX_AFIFO_CFG_4_OUTPUT_BUS_W_MASK 0x0000FFFF
|
|||
|
#define ETH_MAC_GEN_V3_TX_AFIFO_CFG_4_OUTPUT_BUS_W_SHIFT 0
|
|||
|
/* output bus width divide factor */
|
|||
|
#define ETH_MAC_GEN_V3_TX_AFIFO_CFG_4_OUTPUT_BUS_W_F_MASK 0xFFFF0000
|
|||
|
#define ETH_MAC_GEN_V3_TX_AFIFO_CFG_4_OUTPUT_BUS_W_F_SHIFT 16
|
|||
|
|
|||
|
/**** tx_afifo_cfg_5 register ****/
|
|||
|
/*
|
|||
|
* determines if the input bus is valid/read or “write enable”.
|
|||
|
* 0 – write enable
|
|||
|
* 1 – valid/ready
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_V3_TX_AFIFO_CFG_5_INPUT_BUS_VALID_RDY (1 << 0)
|
|||
|
/*
|
|||
|
* determines if the output bus is valid/read or “write enable”.
|
|||
|
* 0 – write enable
|
|||
|
* 1 – valid/ready
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_V3_TX_AFIFO_CFG_5_OUTPUT_BUS_VALID_RDY (1 << 1)
|
|||
|
/* Swap input bus bytes */
|
|||
|
#define ETH_MAC_GEN_V3_TX_AFIFO_CFG_5_INPUT_BUS_SWAP_BYTES (1 << 4)
|
|||
|
/* Swap output bus bytes */
|
|||
|
#define ETH_MAC_GEN_V3_TX_AFIFO_CFG_5_OUTPUT_BUS_SWAP_BYTES (1 << 5)
|
|||
|
/*
|
|||
|
* output clock select
|
|||
|
* 0 – mac_ll_tx_clk
|
|||
|
* 1 – clk_mac_sys_clk
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_V3_TX_AFIFO_CFG_5_OUTPUT_CLK_SEL (1 << 8)
|
|||
|
|
|||
|
/**** rx_afifo_cfg_1 register ****/
|
|||
|
/* minimum packet size configuration */
|
|||
|
#define ETH_MAC_GEN_V3_RX_AFIFO_CFG_1_MIN_PKT_SIZE_MASK 0x0000FFFF
|
|||
|
#define ETH_MAC_GEN_V3_RX_AFIFO_CFG_1_MIN_PKT_SIZE_SHIFT 0
|
|||
|
|
|||
|
/**** rx_afifo_cfg_2 register ****/
|
|||
|
/* maximum packet size configuration */
|
|||
|
#define ETH_MAC_GEN_V3_RX_AFIFO_CFG_2_MAX_PKT_SIZE_MASK 0x0000FFFF
|
|||
|
#define ETH_MAC_GEN_V3_RX_AFIFO_CFG_2_MAX_PKT_SIZE_SHIFT 0
|
|||
|
|
|||
|
/**** rx_afifo_cfg_3 register ****/
|
|||
|
/* input bus width */
|
|||
|
#define ETH_MAC_GEN_V3_RX_AFIFO_CFG_3_INPUT_BUS_W_MASK 0x0000FFFF
|
|||
|
#define ETH_MAC_GEN_V3_RX_AFIFO_CFG_3_INPUT_BUS_W_SHIFT 0
|
|||
|
/* input bus width divide factor */
|
|||
|
#define ETH_MAC_GEN_V3_RX_AFIFO_CFG_3_INPUT_BUS_W_F_MASK 0xFFFF0000
|
|||
|
#define ETH_MAC_GEN_V3_RX_AFIFO_CFG_3_INPUT_BUS_W_F_SHIFT 16
|
|||
|
|
|||
|
/**** rx_afifo_cfg_4 register ****/
|
|||
|
/* output bus width */
|
|||
|
#define ETH_MAC_GEN_V3_RX_AFIFO_CFG_4_OUTPUT_BUS_W_MASK 0x0000FFFF
|
|||
|
#define ETH_MAC_GEN_V3_RX_AFIFO_CFG_4_OUTPUT_BUS_W_SHIFT 0
|
|||
|
/* output bus width divide factor */
|
|||
|
#define ETH_MAC_GEN_V3_RX_AFIFO_CFG_4_OUTPUT_BUS_W_F_MASK 0xFFFF0000
|
|||
|
#define ETH_MAC_GEN_V3_RX_AFIFO_CFG_4_OUTPUT_BUS_W_F_SHIFT 16
|
|||
|
|
|||
|
/**** rx_afifo_cfg_5 register ****/
|
|||
|
/*
|
|||
|
* determines if the input bus is valid/read or “write enable”.
|
|||
|
* 0 – write enable
|
|||
|
* 1 – valid/ready
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_V3_RX_AFIFO_CFG_5_INPUT_BUS_VALID_RDY (1 << 0)
|
|||
|
/*
|
|||
|
* determines if the output bus is valid/read or “write enable”.
|
|||
|
* 0 – write enable
|
|||
|
* 1 – valid/ready
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_V3_RX_AFIFO_CFG_5_OUTPUT_BUS_VALID_RDY (1 << 1)
|
|||
|
/* Swap input bus bytes */
|
|||
|
#define ETH_MAC_GEN_V3_RX_AFIFO_CFG_5_INPUT_BUS_SWAP_BYTES (1 << 4)
|
|||
|
/* Swap output bus bytes */
|
|||
|
#define ETH_MAC_GEN_V3_RX_AFIFO_CFG_5_OUTPUT_BUS_SWAP_BYTES (1 << 5)
|
|||
|
/*
|
|||
|
* input clock select
|
|||
|
* 0 – mac_ll_rx_clk
|
|||
|
* 1 – clk_serdes_int_0_tx_dword_ref
|
|||
|
* 2 – clk_mac_sys_clk
|
|||
|
* 3 – mac_ll_tx_clk
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_V3_RX_AFIFO_CFG_5_INPUT_CLK_SEL_MASK 0x00000300
|
|||
|
#define ETH_MAC_GEN_V3_RX_AFIFO_CFG_5_INPUT_CLK_SEL_SHIFT 8
|
|||
|
|
|||
|
/**** mac_sel register ****/
|
|||
|
/*
|
|||
|
* Select the MAC that is connected to the SGMII PCS.
|
|||
|
* 0 – 1G MAC
|
|||
|
* 1 – 10G MAC
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_V3_MAC_SEL_MAC_10G_SGMII (1 << 0)
|
|||
|
/*
|
|||
|
* Select between the 10G and 40G MAC
|
|||
|
* 0 – 10G MAC
|
|||
|
* 1 – 40G MAC
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_V3_MAC_SEL_MAC_10G_40G (1 << 4)
|
|||
|
|
|||
|
/**** mac_10g_ll_cfg register ****/
|
|||
|
/*
|
|||
|
* select between 10G (KR PCS) and 1G (SGMII) mode.
|
|||
|
* 0 – 10G
|
|||
|
* 1 – 1G
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_V3_MAC_10G_LL_CFG_MODE_1G (1 << 0)
|
|||
|
/* enable Magic packet detection in the MAC (all other packets are dropped) */
|
|||
|
#define ETH_MAC_GEN_V3_MAC_10G_LL_CFG_MAGIC_ENA (1 << 5)
|
|||
|
|
|||
|
/**** mac_10g_ll_ctrl register ****/
|
|||
|
/* Force the MAC to stop TX transmission after low power mode. */
|
|||
|
#define ETH_MAC_GEN_V3_MAC_10G_LL_CTRL_LPI_TXHOLD (1 << 0)
|
|||
|
|
|||
|
/**** pcs_10g_ll_cfg register ****/
|
|||
|
/* RX FEC Enable */
|
|||
|
#define ETH_MAC_GEN_V3_PCS_10G_LL_CFG_FEC_EN_RX (1 << 0)
|
|||
|
/* TX FEC enable */
|
|||
|
#define ETH_MAC_GEN_V3_PCS_10G_LL_CFG_FEC_EN_TX (1 << 1)
|
|||
|
/*
|
|||
|
* RX FEC error propagation enable,
|
|||
|
* (debug, always 0)
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_V3_PCS_10G_LL_CFG_FEC_ERR_ENA (1 << 2)
|
|||
|
/*
|
|||
|
* Gearbox configuration:
|
|||
|
* 00 -16
|
|||
|
* 01 – 20
|
|||
|
* 10 – 32
|
|||
|
* 11 – reserved
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_V3_PCS_10G_LL_CFG_TX_GB_CFG_MASK 0x00000030
|
|||
|
#define ETH_MAC_GEN_V3_PCS_10G_LL_CFG_TX_GB_CFG_SHIFT 4
|
|||
|
/*
|
|||
|
* Gearbox configuration:
|
|||
|
* 00 -16
|
|||
|
* 01 – 20
|
|||
|
* 10 – 32
|
|||
|
* 11 – reserved
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_V3_PCS_10G_LL_CFG_RX_GB_CFG_MASK 0x000000C0
|
|||
|
#define ETH_MAC_GEN_V3_PCS_10G_LL_CFG_RX_GB_CFG_SHIFT 6
|
|||
|
|
|||
|
/**** pcs_10g_ll_status register ****/
|
|||
|
/* FEC locked indication */
|
|||
|
#define ETH_MAC_GEN_V3_PCS_10G_LL_STATUS_FEC_LOCKED (1 << 0)
|
|||
|
|
|||
|
/**** pcs_40g_ll_cfg register ****/
|
|||
|
/* RX FEC Enable */
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_LL_CFG_FEC_EN_RX_MASK 0x0000000F
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_LL_CFG_FEC_EN_RX_SHIFT 0
|
|||
|
/* TX FEC enable */
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_LL_CFG_FEC_EN_TX_MASK 0x000000F0
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_LL_CFG_FEC_EN_TX_SHIFT 4
|
|||
|
/*
|
|||
|
* RX FEC error propagation enable,
|
|||
|
* (debug, always 0)
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_LL_CFG_FEC_ERR_EN_MASK 0x00000F00
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_LL_CFG_FEC_ERR_EN_SHIFT 8
|
|||
|
/*
|
|||
|
* SERDES width, 16 bit enable
|
|||
|
* 1 – 16
|
|||
|
* 2 – 32
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_LL_CFG_SD_16B (1 << 12)
|
|||
|
/* FEC 91 enable */
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_LL_CFG_FEC91_ENA (1 << 13)
|
|||
|
/*
|
|||
|
* PHY LOS indication selection
|
|||
|
* 00 - Select register value from phy_los_def
|
|||
|
* 01 - Select input from the SerDes
|
|||
|
* 10 - Select input from GPIO
|
|||
|
* 11 - Select inverted input from GPIO
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_LL_CFG_PHY_LOS_SEL_MASK 0x00030000
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_LL_CFG_PHY_LOS_SEL_SHIFT 16
|
|||
|
/* PHY LOS default value */
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_LL_CFG_PHY_LOS_DEF (1 << 18)
|
|||
|
/* PHY LOS polarity */
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_LL_CFG_PHY_LOS_POL (1 << 19)
|
|||
|
/*
|
|||
|
* Energy detect indication selection
|
|||
|
* 00 - Select register value from phy_los_def
|
|||
|
* 01 - Select input from the SerDes
|
|||
|
* 10 - Select input from GPIO
|
|||
|
* 11 - Select inverted input from GPIO
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_LL_CFG_ENERGY_DETECT_SEL_MASK 0x00300000
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_LL_CFG_ENERGY_DETECT_SEL_SHIFT 20
|
|||
|
/* Energy detect default value */
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_LL_CFG_ENERGY_DETECT_DEF (1 << 22)
|
|||
|
/* Energy detect polarity */
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_LL_CFG_ENERGY_DETECT_POL (1 << 23)
|
|||
|
|
|||
|
/**** pcs_40g_ll_status register ****/
|
|||
|
/* Block lock */
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_LL_STATUS_BLOCK_LOCK_MASK 0x0000000F
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_LL_STATUS_BLOCK_LOCK_SHIFT 0
|
|||
|
/* align done */
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_LL_STATUS_ALIGN_DONE (1 << 4)
|
|||
|
/* high BER */
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_LL_STATUS_HIGH_BER (1 << 8)
|
|||
|
/* FEC locked indication */
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_LL_STATUS_FEC_LOCKED_MASK 0x0000F000
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_LL_STATUS_FEC_LOCKED_SHIFT 12
|
|||
|
|
|||
|
/**** pcs_40g_ll_addr register ****/
|
|||
|
/* Address value */
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_LL_ADDR_VAL_MASK 0x0001FFFF
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_LL_ADDR_VAL_SHIFT 0
|
|||
|
|
|||
|
/**** pcs_40g_ll_data register ****/
|
|||
|
/* Data value */
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_LL_DATA_VAL_MASK 0x0000FFFF
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_LL_DATA_VAL_SHIFT 0
|
|||
|
|
|||
|
/**** mac_40g_ll_cfg register ****/
|
|||
|
/* change TX CRC polarity */
|
|||
|
#define ETH_MAC_GEN_V3_MAC_40G_LL_CFG_SWAP_FF_TX_CRC (1 << 0)
|
|||
|
/* force TX remote fault */
|
|||
|
#define ETH_MAC_GEN_V3_MAC_40G_LL_CFG_TX_REM_FAULT (1 << 4)
|
|||
|
/* force TX local fault */
|
|||
|
#define ETH_MAC_GEN_V3_MAC_40G_LL_CFG_TX_LOC_FAULT (1 << 5)
|
|||
|
/* force TX Link fault */
|
|||
|
#define ETH_MAC_GEN_V3_MAC_40G_LL_CFG_TX_LI_FAULT (1 << 6)
|
|||
|
/*
|
|||
|
* PHY LOS indication selection
|
|||
|
* 00 - Select register value from phy_los_def
|
|||
|
* 01 - Select input from the SerDes
|
|||
|
* 10 - Select input from GPIO
|
|||
|
* 11 - Select inverted input from GPIO
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_V3_MAC_40G_LL_CFG_PHY_LOS_SEL_MASK 0x00000300
|
|||
|
#define ETH_MAC_GEN_V3_MAC_40G_LL_CFG_PHY_LOS_SEL_SHIFT 8
|
|||
|
/* PHY LOS default value */
|
|||
|
#define ETH_MAC_GEN_V3_MAC_40G_LL_CFG_PHY_LOS_DEF (1 << 10)
|
|||
|
/* PHY LOS polarity */
|
|||
|
#define ETH_MAC_GEN_V3_MAC_40G_LL_CFG_PHY_LOS_POL (1 << 11)
|
|||
|
|
|||
|
/**** mac_40g_ll_status register ****/
|
|||
|
/* pause on indication */
|
|||
|
#define ETH_MAC_GEN_V3_MAC_40G_LL_STATUS_PAUSE_ON_MASK 0x000000FF
|
|||
|
#define ETH_MAC_GEN_V3_MAC_40G_LL_STATUS_PAUSE_ON_SHIFT 0
|
|||
|
/* local fault indication received */
|
|||
|
#define ETH_MAC_GEN_V3_MAC_40G_LL_STATUS_LOC_FAULT (1 << 8)
|
|||
|
/* remote fault indication received */
|
|||
|
#define ETH_MAC_GEN_V3_MAC_40G_LL_STATUS_REM_FAULT (1 << 9)
|
|||
|
/* Link fault indication */
|
|||
|
#define ETH_MAC_GEN_V3_MAC_40G_LL_STATUS_LI_FAULT (1 << 10)
|
|||
|
|
|||
|
/**** preamble_cfg_high register ****/
|
|||
|
/* preamble value */
|
|||
|
#define ETH_MAC_GEN_V3_PREAMBLE_CFG_HIGH_VAL_MASK 0x00FFFFFF
|
|||
|
#define ETH_MAC_GEN_V3_PREAMBLE_CFG_HIGH_VAL_SHIFT 0
|
|||
|
|
|||
|
/**** mac_40g_ll_addr register ****/
|
|||
|
/* Address value */
|
|||
|
#define ETH_MAC_GEN_V3_MAC_40G_LL_ADDR_VAL_MASK 0x000003FF
|
|||
|
#define ETH_MAC_GEN_V3_MAC_40G_LL_ADDR_VAL_SHIFT 0
|
|||
|
|
|||
|
/**** mac_40g_ll_ctrl register ****/
|
|||
|
/* Force the MAC to stop TX transmission after low power mode. */
|
|||
|
#define ETH_MAC_GEN_V3_MAC_40G_LL_CTRL_LPI_TXHOLD (1 << 0)
|
|||
|
|
|||
|
#define ETH_MAC_GEN_V3_MAC_40G_LL_CTRL_REG_LOWP_ENA (1 << 1)
|
|||
|
|
|||
|
/**** pcs_40g_fec_91_ll_addr register ****/
|
|||
|
/* Address value */
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_FEC_91_LL_ADDR_VAL_MASK 0x000001FF
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_FEC_91_LL_ADDR_VAL_SHIFT 0
|
|||
|
|
|||
|
/**** pcs_40g_fec_91_ll_data register ****/
|
|||
|
/* Data value */
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_FEC_91_LL_DATA_VAL_MASK 0x0000FFFF
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_FEC_91_LL_DATA_VAL_SHIFT 0
|
|||
|
|
|||
|
/**** pcs_40g_ll_eee_cfg register ****/
|
|||
|
/* Low power timer configuration */
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_LL_EEE_CFG_TIMER_VAL_MASK 0x000000FF
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_LL_EEE_CFG_TIMER_VAL_SHIFT 0
|
|||
|
/* Low power Fast wake */
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_LL_EEE_CFG_LPI_FW (1 << 8)
|
|||
|
|
|||
|
/**** pcs_40g_ll_eee_status register ****/
|
|||
|
/* TX LPI mode */
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_LL_EEE_STATUS_TX_LPI_MODE_MASK 0x00000003
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_LL_EEE_STATUS_TX_LPI_MODE_SHIFT 0
|
|||
|
/* TX LPI state */
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_LL_EEE_STATUS_TX_LPI_STATE_MASK 0x00000070
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_LL_EEE_STATUS_TX_LPI_STATE_SHIFT 4
|
|||
|
/* TX LPI mode */
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_LL_EEE_STATUS_RX_LPI_MODE (1 << 8)
|
|||
|
/* TX LPI state */
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_LL_EEE_STATUS_RX_LPI_STATE_MASK 0x00007000
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_LL_EEE_STATUS_RX_LPI_STATE_SHIFT 12
|
|||
|
/* TX LPI active */
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_LL_EEE_STATUS_RX_LPI_ACTIVE (1 << 15)
|
|||
|
|
|||
|
/**** serdes_32_tx_shift register ****/
|
|||
|
/* bit shift */
|
|||
|
#define ETH_MAC_GEN_V3_SERDES_32_TX_SHIFT_SERDES_0_MASK 0x0000001F
|
|||
|
#define ETH_MAC_GEN_V3_SERDES_32_TX_SHIFT_SERDES_0_SHIFT 0
|
|||
|
/* bit shift */
|
|||
|
#define ETH_MAC_GEN_V3_SERDES_32_TX_SHIFT_SERDES_1_MASK 0x000003E0
|
|||
|
#define ETH_MAC_GEN_V3_SERDES_32_TX_SHIFT_SERDES_1_SHIFT 5
|
|||
|
/* bit shift */
|
|||
|
#define ETH_MAC_GEN_V3_SERDES_32_TX_SHIFT_SERDES_2_MASK 0x00007C00
|
|||
|
#define ETH_MAC_GEN_V3_SERDES_32_TX_SHIFT_SERDES_2_SHIFT 10
|
|||
|
/* bit shift */
|
|||
|
#define ETH_MAC_GEN_V3_SERDES_32_TX_SHIFT_SERDES_3_MASK 0x000F8000
|
|||
|
#define ETH_MAC_GEN_V3_SERDES_32_TX_SHIFT_SERDES_3_SHIFT 15
|
|||
|
|
|||
|
/**** serdes_32_rx_shift register ****/
|
|||
|
/* bit shift */
|
|||
|
#define ETH_MAC_GEN_V3_SERDES_32_RX_SHIFT_SERDES_0_MASK 0x0000001F
|
|||
|
#define ETH_MAC_GEN_V3_SERDES_32_RX_SHIFT_SERDES_0_SHIFT 0
|
|||
|
/* bit shift */
|
|||
|
#define ETH_MAC_GEN_V3_SERDES_32_RX_SHIFT_SERDES_1_MASK 0x000003E0
|
|||
|
#define ETH_MAC_GEN_V3_SERDES_32_RX_SHIFT_SERDES_1_SHIFT 5
|
|||
|
/* bit shift */
|
|||
|
#define ETH_MAC_GEN_V3_SERDES_32_RX_SHIFT_SERDES_2_MASK 0x00007C00
|
|||
|
#define ETH_MAC_GEN_V3_SERDES_32_RX_SHIFT_SERDES_2_SHIFT 10
|
|||
|
/* bit shift */
|
|||
|
#define ETH_MAC_GEN_V3_SERDES_32_RX_SHIFT_SERDES_3_MASK 0x000F8000
|
|||
|
#define ETH_MAC_GEN_V3_SERDES_32_RX_SHIFT_SERDES_3_SHIFT 15
|
|||
|
|
|||
|
/**** serdes_32_tx_sel register ****/
|
|||
|
/*
|
|||
|
* 0 – directly from serdes
|
|||
|
* 1 – swapped
|
|||
|
* 2 – swapped with shift
|
|||
|
* 3 - legacy (based on gen cfg register)
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_V3_SERDES_32_TX_SEL_SERDES_0_MASK 0x00000003
|
|||
|
#define ETH_MAC_GEN_V3_SERDES_32_TX_SEL_SERDES_0_SHIFT 0
|
|||
|
/*
|
|||
|
* 0 – directly from serdes
|
|||
|
* 1 – swapped
|
|||
|
* 2 – swapped with shift
|
|||
|
* 3 - legacy (based on gen cfg register)
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_V3_SERDES_32_TX_SEL_SERDES_1_MASK 0x00000030
|
|||
|
#define ETH_MAC_GEN_V3_SERDES_32_TX_SEL_SERDES_1_SHIFT 4
|
|||
|
/*
|
|||
|
* 0 – directly from serdes
|
|||
|
* 1 – swapped
|
|||
|
* 2 – swapped with shift
|
|||
|
* 3 - legacy (based on gen cfg register)
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_V3_SERDES_32_TX_SEL_SERDES_2_MASK 0x00000300
|
|||
|
#define ETH_MAC_GEN_V3_SERDES_32_TX_SEL_SERDES_2_SHIFT 8
|
|||
|
/*
|
|||
|
* 0 – directly from serdes
|
|||
|
* 1 – swapped
|
|||
|
* 2 – swapped with shift
|
|||
|
* 3 - legacy (based on gen cfg register)
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_V3_SERDES_32_TX_SEL_SERDES_3_MASK 0x00003000
|
|||
|
#define ETH_MAC_GEN_V3_SERDES_32_TX_SEL_SERDES_3_SHIFT 12
|
|||
|
|
|||
|
/**** serdes_32_rx_sel register ****/
|
|||
|
/*
|
|||
|
* 0 – directly from serdes
|
|||
|
* 1 – swapped
|
|||
|
* 2 – swapped with shift
|
|||
|
* 3 - legacy (based on gen cfg register)
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_V3_SERDES_32_RX_SEL_SERDES_0_MASK 0x00000003
|
|||
|
#define ETH_MAC_GEN_V3_SERDES_32_RX_SEL_SERDES_0_SHIFT 0
|
|||
|
/*
|
|||
|
* 0 – directly from serdes
|
|||
|
* 1 – swapped
|
|||
|
* 2 – swapped with shift
|
|||
|
* 3 - legacy (based on gen cfg register)
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_V3_SERDES_32_RX_SEL_SERDES_1_MASK 0x00000030
|
|||
|
#define ETH_MAC_GEN_V3_SERDES_32_RX_SEL_SERDES_1_SHIFT 4
|
|||
|
/*
|
|||
|
* 0 – directly from serdes
|
|||
|
* 1 – swapped
|
|||
|
* 2 – swapped with shift
|
|||
|
* 3 - legacy (based on gen cfg register)
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_V3_SERDES_32_RX_SEL_SERDES_2_MASK 0x00000300
|
|||
|
#define ETH_MAC_GEN_V3_SERDES_32_RX_SEL_SERDES_2_SHIFT 8
|
|||
|
/*
|
|||
|
* 0 – directly from serdes
|
|||
|
* 1 – swapped
|
|||
|
* 2 – swapped with shift
|
|||
|
* 3 - legacy (based on gen cfg register)
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_V3_SERDES_32_RX_SEL_SERDES_3_MASK 0x00003000
|
|||
|
#define ETH_MAC_GEN_V3_SERDES_32_RX_SEL_SERDES_3_SHIFT 12
|
|||
|
|
|||
|
/**** an_lt_ctrl register ****/
|
|||
|
/* reset lane [3:0] */
|
|||
|
#define ETH_MAC_GEN_V3_AN_LT_CTRL_SW_RESET_MASK 0x0000000F
|
|||
|
#define ETH_MAC_GEN_V3_AN_LT_CTRL_SW_RESET_SHIFT 0
|
|||
|
|
|||
|
/* PHY LOS indication input selection
|
|||
|
* 0 - from serdes
|
|||
|
* 1 - from an_lt
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_V3_AN_LT_CTRL_PHY_LOS_SEL_LANE_0 (1 << 8)
|
|||
|
/* PHY LOS indication input selection
|
|||
|
* 0 - from serdes
|
|||
|
* 1 - from an_lt
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_V3_AN_LT_CTRL_PHY_LOS_SEL_LANE_1 (1 << 9)
|
|||
|
/* PHY LOS indication input selection
|
|||
|
* 0 - from serdes
|
|||
|
* 1 - from an_lt
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_V3_AN_LT_CTRL_PHY_LOS_SEL_LANE_2 (1 << 10)
|
|||
|
/* PHY LOS indication input selection
|
|||
|
* 0 - from serdes
|
|||
|
* 1 - from an_lt
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_V3_AN_LT_CTRL_PHY_LOS_SEL_LANE_3 (1 << 11)
|
|||
|
|
|||
|
/**** an_lt_0_addr register ****/
|
|||
|
/* Address value */
|
|||
|
#define ETH_MAC_GEN_V3_AN_LT_0_ADDR_VAL_MASK 0x0000FFFF
|
|||
|
#define ETH_MAC_GEN_V3_AN_LT_0_ADDR_VAL_SHIFT 0
|
|||
|
|
|||
|
/**** an_lt_1_addr register ****/
|
|||
|
/* Address value */
|
|||
|
#define ETH_MAC_GEN_V3_AN_LT_1_ADDR_VAL_MASK 0x0000FFFF
|
|||
|
#define ETH_MAC_GEN_V3_AN_LT_1_ADDR_VAL_SHIFT 0
|
|||
|
|
|||
|
/**** an_lt_2_addr register ****/
|
|||
|
/* Address value */
|
|||
|
#define ETH_MAC_GEN_V3_AN_LT_2_ADDR_VAL_MASK 0x0000FFFF
|
|||
|
#define ETH_MAC_GEN_V3_AN_LT_2_ADDR_VAL_SHIFT 0
|
|||
|
|
|||
|
/**** an_lt_3_addr register ****/
|
|||
|
/* Address value */
|
|||
|
#define ETH_MAC_GEN_V3_AN_LT_3_ADDR_VAL_MASK 0x0000FFFF
|
|||
|
#define ETH_MAC_GEN_V3_AN_LT_3_ADDR_VAL_SHIFT 0
|
|||
|
|
|||
|
/**** ext_serdes_ctrl register ****/
|
|||
|
/*
|
|||
|
* Lane 0, SERDES selection:
|
|||
|
* 0 – 10G SERDES, lane 0
|
|||
|
* 1 – 25G SERDES, lane 0
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_V3_EXT_SERDES_CTRL_LANE_0_SEL_25_10 (1 << 0)
|
|||
|
/*
|
|||
|
* Lane 1, SERDES selection:
|
|||
|
* 0 – 10G SERDES, lane 1
|
|||
|
* 1 – 25G SERDES, lane 1
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_V3_EXT_SERDES_CTRL_LANE_1_SEL_25_10 (1 << 1)
|
|||
|
/*
|
|||
|
* Lane 2, SERDES selection:
|
|||
|
* 0 – 10G SERDES, lane 2
|
|||
|
* 1 – 25G SERDES, lane 0
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_V3_EXT_SERDES_CTRL_LANE_2_SEL_25_10 (1 << 2)
|
|||
|
/*
|
|||
|
* Lane 3, SERDES selection:
|
|||
|
* 0 – 10G SERDES, lane 3
|
|||
|
* 1 – 25G SERDES, lane 1
|
|||
|
*/
|
|||
|
#define ETH_MAC_GEN_V3_EXT_SERDES_CTRL_LANE_3_SEL_25_10 (1 << 3)
|
|||
|
|
|||
|
/* Lane 0 Rx, 25G 40bit-32bit gearshitf sw reset */
|
|||
|
#define ETH_MAC_GEN_V3_EXT_SERDES_CTRL_LANE_0_RX_25_GS_SW_RESET (1 << 4)
|
|||
|
/* Lane 0 Tx, 25G 40bit-32bit gearshitf sw reset */
|
|||
|
#define ETH_MAC_GEN_V3_EXT_SERDES_CTRL_LANE_0_TX_25_GS_SW_RESET (1 << 5)
|
|||
|
/* Lane 1 Rx, 25G 40bit-32bit gearshitf sw reset */
|
|||
|
#define ETH_MAC_GEN_V3_EXT_SERDES_CTRL_LANE_1_RX_25_GS_SW_RESET (1 << 6)
|
|||
|
/* Lane 1 Tx, 25G 40bit-32bit gearshitf sw reset */
|
|||
|
#define ETH_MAC_GEN_V3_EXT_SERDES_CTRL_LANE_1_TX_25_GS_SW_RESET (1 << 7)
|
|||
|
/* SerDes 25G gear shift Tx lane selector */
|
|||
|
#define ETH_MAC_GEN_V3_EXT_SERDES_CTRL_SRDS25_GS_TX_LANE_CLK_SEL (1 << 8)
|
|||
|
|
|||
|
/*** MAC Core registers addresses ***/
|
|||
|
/* command config */
|
|||
|
#define ETH_MAC_GEN_V3_MAC_40G_COMMAND_CONFIG_ADDR 0x00000008
|
|||
|
#define ETH_MAC_GEN_V3_MAC_40G_COMMAND_CONFIG_TX_ENA (1 << 0)
|
|||
|
#define ETH_MAC_GEN_V3_MAC_40G_COMMAND_CONFIG_RX_ENA (1 << 1)
|
|||
|
#define ETH_MAC_GEN_V3_MAC_40G_COMMAND_CONFIG_PFC_MODE (1 << 19)
|
|||
|
|
|||
|
/* frame length */
|
|||
|
#define ETH_MAC_GEN_V3_MAC_40G_FRM_LENGTH_ADDR 0x00000014
|
|||
|
|
|||
|
#define ETH_MAC_GEN_V3_MAC_40G_CL01_PAUSE_QUANTA_ADDR 0x00000054
|
|||
|
#define ETH_MAC_GEN_V3_MAC_40G_CL23_PAUSE_QUANTA_ADDR 0x00000058
|
|||
|
#define ETH_MAC_GEN_V3_MAC_40G_CL45_PAUSE_QUANTA_ADDR 0x0000005C
|
|||
|
#define ETH_MAC_GEN_V3_MAC_40G_CL67_PAUSE_QUANTA_ADDR 0x00000060
|
|||
|
#define ETH_MAC_GEN_V3_MAC_40G_CL01_QUANTA_THRESH_ADDR 0x00000064
|
|||
|
#define ETH_MAC_GEN_V3_MAC_40G_CL23_QUANTA_THRESH_ADDR 0x00000068
|
|||
|
#define ETH_MAC_GEN_V3_MAC_40G_CL45_QUANTA_THRESH_ADDR 0x0000006C
|
|||
|
#define ETH_MAC_GEN_V3_MAC_40G_CL67_QUANTA_THRESH_ADDR 0x00000070
|
|||
|
|
|||
|
/* spare */
|
|||
|
#define ETH_MAC_GEN_V3_SPARE_CHICKEN_DISABLE_TIMESTAMP_STRETCH (1 << 0)
|
|||
|
|
|||
|
/*** PCS Core registers addresses ***/
|
|||
|
/* 40g control/status */
|
|||
|
#define ETH_MAC_GEN_V3_PCS_40G_CONTROL_STATUS_ADDR 0x00000000
|
|||
|
/* 10g control_1 */
|
|||
|
#define ETH_MAC_KR_PCS_CONTROL_1_ADDR 0x00000000
|
|||
|
|
|||
|
#define ETH_MAC_KR_AN_MILLISECONDS_COUNTER_ADDR 0x00008000
|
|||
|
#define ETH_MAC_AN_LT_MILLISECONDS_COUNTER_ADDR 0x00000020
|
|||
|
|
|||
|
#ifdef __cplusplus
|
|||
|
}
|
|||
|
#endif
|
|||
|
|
|||
|
#endif /* __AL_HAL_ETH_MAC_REGS_H__ */
|
|||
|
|
|||
|
/** @} end of Ethernet group */
|