191c6945eSHariprasad Kelam /* SPDX-License-Identifier: GPL-2.0 */ 2c7cd6c5aSSunil Goutham /* Marvell CN10K RPM driver 391c6945eSHariprasad Kelam * 491c6945eSHariprasad Kelam * Copyright (C) 2020 Marvell. 591c6945eSHariprasad Kelam * 691c6945eSHariprasad Kelam */ 791c6945eSHariprasad Kelam 891c6945eSHariprasad Kelam #ifndef RPM_H 991c6945eSHariprasad Kelam #define RPM_H 1091c6945eSHariprasad Kelam 11242da439SSubbaraya Sundeep #include <linux/bits.h> 12242da439SSubbaraya Sundeep 1391c6945eSHariprasad Kelam /* PCI device IDs */ 1491c6945eSHariprasad Kelam #define PCI_DEVID_CN10K_RPM 0xA060 15b9d0fedcSHariprasad Kelam #define PCI_SUBSYS_DEVID_CNF10KB_RPM 0xBC00 16b9d0fedcSHariprasad Kelam #define PCI_DEVID_CN10KB_RPM 0xA09F 1791c6945eSHariprasad Kelam 1891c6945eSHariprasad Kelam /* Registers */ 19d1489208SHariprasad Kelam #define RPMX_CMRX_CFG 0x00 20*fed89cfaSHariprasad Kelam #define RPMX_CMR_GLOBAL_CFG 0x08 21*fed89cfaSHariprasad Kelam #define RPM_NIX0_RESET BIT_ULL(3) 22d1489208SHariprasad Kelam #define RPMX_RX_TS_PREPEND BIT_ULL(22) 232958d17aSHariprasad Kelam #define RPMX_TX_PTP_1S_SUPPORT BIT_ULL(17) 24b9d0fedcSHariprasad Kelam #define RPMX_CMRX_RX_ID_MAP 0x80 2591c6945eSHariprasad Kelam #define RPMX_CMRX_SW_INT 0x180 2691c6945eSHariprasad Kelam #define RPMX_CMRX_SW_INT_W1S 0x188 2791c6945eSHariprasad Kelam #define RPMX_CMRX_SW_INT_ENA_W1S 0x198 28242da439SSubbaraya Sundeep #define RPMX_CMRX_LINK_CFG 0x1070 293ad3f8f9SHariprasad Kelam #define RPMX_MTI_PCS100X_CONTROL1 0x20000 303ad3f8f9SHariprasad Kelam #define RPMX_MTI_PCS_LBK BIT_ULL(14) 31ce7a6c31SHariprasad Kelam #define RPMX_MTI_LPCSX_CONTROL(id) (0x30000 | ((id) * 0x100)) 32242da439SSubbaraya Sundeep 33242da439SSubbaraya Sundeep #define RPMX_CMRX_LINK_RANGE_MASK GENMASK_ULL(19, 16) 34242da439SSubbaraya Sundeep #define RPMX_CMRX_LINK_BASE_MASK GENMASK_ULL(11, 0) 351845ada4SRakesh Babu #define RPMX_MTI_MAC100X_COMMAND_CONFIG 0x8010 361845ada4SRakesh Babu #define RPMX_MTI_MAC100X_COMMAND_CONFIG_RX_P_DISABLE BIT_ULL(29) 371845ada4SRakesh Babu #define RPMX_MTI_MAC100X_COMMAND_CONFIG_TX_P_DISABLE BIT_ULL(28) 381845ada4SRakesh Babu #define RPMX_MTI_MAC100X_COMMAND_CONFIG_PAUSE_IGNORE BIT_ULL(8) 391845ada4SRakesh Babu #define RPMX_MTI_MAC100X_COMMAND_CONFIG_PFC_MODE BIT_ULL(19) 401845ada4SRakesh Babu #define RPMX_MTI_MAC100X_CL01_PAUSE_QUANTA 0x80A8 411121f6b0SSunil Kumar Kori #define RPMX_MTI_MAC100X_CL23_PAUSE_QUANTA 0x80B0 421121f6b0SSunil Kumar Kori #define RPMX_MTI_MAC100X_CL45_PAUSE_QUANTA 0x80B8 431121f6b0SSunil Kumar Kori #define RPMX_MTI_MAC100X_CL67_PAUSE_QUANTA 0x80C0 441845ada4SRakesh Babu #define RPMX_MTI_MAC100X_CL01_QUANTA_THRESH 0x80C8 451121f6b0SSunil Kumar Kori #define RPMX_MTI_MAC100X_CL23_QUANTA_THRESH 0x80D0 461121f6b0SSunil Kumar Kori #define RPMX_MTI_MAC100X_CL45_QUANTA_THRESH 0x80D8 471121f6b0SSunil Kumar Kori #define RPMX_MTI_MAC100X_CL67_QUANTA_THRESH 0x80E0 481121f6b0SSunil Kumar Kori #define RPMX_MTI_MAC100X_CL89_PAUSE_QUANTA 0x8108 491121f6b0SSunil Kumar Kori #define RPMX_MTI_MAC100X_CL1011_PAUSE_QUANTA 0x8110 501121f6b0SSunil Kumar Kori #define RPMX_MTI_MAC100X_CL1213_PAUSE_QUANTA 0x8118 511121f6b0SSunil Kumar Kori #define RPMX_MTI_MAC100X_CL1415_PAUSE_QUANTA 0x8120 521121f6b0SSunil Kumar Kori #define RPMX_MTI_MAC100X_CL89_QUANTA_THRESH 0x8128 531121f6b0SSunil Kumar Kori #define RPMX_MTI_MAC100X_CL1011_QUANTA_THRESH 0x8130 541121f6b0SSunil Kumar Kori #define RPMX_MTI_MAC100X_CL1213_QUANTA_THRESH 0x8138 551121f6b0SSunil Kumar Kori #define RPMX_MTI_MAC100X_CL1415_QUANTA_THRESH 0x8140 561845ada4SRakesh Babu #define RPMX_CMR_RX_OVR_BP 0x4120 571845ada4SRakesh Babu #define RPMX_CMR_RX_OVR_BP_EN(x) BIT_ULL((x) + 8) 581845ada4SRakesh Babu #define RPMX_CMR_RX_OVR_BP_BP(x) BIT_ULL((x) + 4) 593e35d198SHariprasad Kelam #define RPMX_CMR_CHAN_MSK_OR 0x4118 60ce7a6c31SHariprasad Kelam #define RPMX_MTI_STAT_RX_STAT_PAGES_COUNTERX 0x12000 61ce7a6c31SHariprasad Kelam #define RPMX_MTI_STAT_TX_STAT_PAGES_COUNTERX 0x13000 62ce7a6c31SHariprasad Kelam #define RPMX_MTI_STAT_DATA_HI_CDC 0x10038 63ce7a6c31SHariprasad Kelam 6491c6945eSHariprasad Kelam #define RPM_LMAC_FWI 0xa 65fae80edeSGeetha sowjanya #define RPM_TX_EN BIT_ULL(0) 66fae80edeSGeetha sowjanya #define RPM_RX_EN BIT_ULL(1) 671121f6b0SSunil Kumar Kori #define RPMX_CMRX_PRT_CBFC_CTL 0x5B08 681121f6b0SSunil Kumar Kori #define RPMX_CMRX_PRT_CBFC_CTL_LOGL_EN_RX_SHIFT 33 691121f6b0SSunil Kumar Kori #define RPMX_CMRX_PRT_CBFC_CTL_PHYS_BP_SHIFT 16 701121f6b0SSunil Kumar Kori #define RPMX_CMRX_PRT_CBFC_CTL_LOGL_EN_TX_SHIFT 0 711121f6b0SSunil Kumar Kori #define RPM_PFC_CLASS_MASK GENMASK_ULL(48, 33) 721121f6b0SSunil Kumar Kori #define RPMX_MTI_MAC100X_CL89_QUANTA_THRESH 0x8128 731121f6b0SSunil Kumar Kori #define RPMX_MTI_MAC100X_COMMAND_CONFIG_TX_PAD_EN BIT_ULL(11) 741121f6b0SSunil Kumar Kori #define RPMX_MTI_MAC100X_COMMAND_CONFIG_PAUSE_IGNORE BIT_ULL(8) 751121f6b0SSunil Kumar Kori #define RPMX_MTI_MAC100X_COMMAND_CONFIG_PAUSE_FWD BIT_ULL(7) 761121f6b0SSunil Kumar Kori #define RPMX_MTI_MAC100X_CL01_PAUSE_QUANTA 0x80A8 771121f6b0SSunil Kumar Kori #define RPMX_MTI_MAC100X_CL89_PAUSE_QUANTA 0x8108 788e151457SHariprasad Kelam #define RPM_DEFAULT_PAUSE_TIME 0x7FF 792e3e94c2SHariprasad Kelam #define RPMX_CMRX_RX_LOGL_XON 0x4100 8091c6945eSHariprasad Kelam 812958d17aSHariprasad Kelam #define RPMX_MTI_MAC100X_XIF_MODE 0x8100 822958d17aSHariprasad Kelam #define RPMX_ONESTEP_ENABLE BIT_ULL(5) 832958d17aSHariprasad Kelam #define RPMX_TS_BINARY_MODE BIT_ULL(11) 84b9d0fedcSHariprasad Kelam #define RPMX_CONST1 0x2008 85b9d0fedcSHariprasad Kelam 8684ad3642SHariprasad Kelam /* FEC stats */ 8784ad3642SHariprasad Kelam #define RPMX_MTI_STAT_STATN_CONTROL 0x10018 8884ad3642SHariprasad Kelam #define RPMX_MTI_STAT_DATA_HI_CDC 0x10038 89f002f21cSHariprasad Kelam #define RPMX_RSFEC_RX_CAPTURE BIT_ULL(28) 9092ada6dfSSai Krishna #define RPMX_CMD_CLEAR_RX BIT_ULL(30) 9192ada6dfSSai Krishna #define RPMX_CMD_CLEAR_TX BIT_ULL(31) 92f002f21cSHariprasad Kelam #define RPMX_MTI_RSFEC_STAT_STATN_CONTROL 0x40018 93f002f21cSHariprasad Kelam #define RPMX_MTI_RSFEC_STAT_FAST_DATA_HI_CDC 0x40000 9484ad3642SHariprasad Kelam #define RPMX_MTI_RSFEC_STAT_COUNTER_CAPTURE_2 0x40050 9584ad3642SHariprasad Kelam #define RPMX_MTI_RSFEC_STAT_COUNTER_CAPTURE_3 0x40058 960bbba28dSHariprasad Kelam #define RPMX_MTI_FCFECX_VL0_CCW_LO(a) (0x38618 + ((a) * 0x40)) 970bbba28dSHariprasad Kelam #define RPMX_MTI_FCFECX_VL0_NCCW_LO(a) (0x38620 + ((a) * 0x40)) 980bbba28dSHariprasad Kelam #define RPMX_MTI_FCFECX_VL1_CCW_LO(a) (0x38628 + ((a) * 0x40)) 990bbba28dSHariprasad Kelam #define RPMX_MTI_FCFECX_VL1_NCCW_LO(a) (0x38630 + ((a) * 0x40)) 1000bbba28dSHariprasad Kelam #define RPMX_MTI_FCFECX_CW_HI(a) (0x38638 + ((a) * 0x40)) 10184ad3642SHariprasad Kelam 102b9d0fedcSHariprasad Kelam /* CN10KB CSR Declaration */ 103b9d0fedcSHariprasad Kelam #define RPM2_CMRX_SW_INT 0x1b0 1044c5a331cSHariprasad Kelam #define RPM2_CMRX_SW_INT_ENA_W1S 0x1c8 1054c5a331cSHariprasad Kelam #define RPM2_LMAC_FWI 0x12 106b9d0fedcSHariprasad Kelam #define RPM2_CMR_CHAN_MSK_OR 0x3120 107b9d0fedcSHariprasad Kelam #define RPM2_CMR_RX_OVR_BP_EN BIT_ULL(2) 108b9d0fedcSHariprasad Kelam #define RPM2_CMR_RX_OVR_BP_BP BIT_ULL(1) 109b9d0fedcSHariprasad Kelam #define RPM2_CMR_RX_OVR_BP 0x3130 110b9d0fedcSHariprasad Kelam #define RPM2_CSR_OFFSET 0x3e00 111b9d0fedcSHariprasad Kelam #define RPM2_CMRX_PRT_CBFC_CTL 0x6510 112b9d0fedcSHariprasad Kelam #define RPM2_CMRX_RX_LMACS 0x100 113b9d0fedcSHariprasad Kelam #define RPM2_CMRX_RX_LOGL_XON 0x3100 114b9d0fedcSHariprasad Kelam #define RPM2_CMRX_RX_STAT2 0x3010 115b9d0fedcSHariprasad Kelam #define RPM2_USX_PCSX_CONTROL1 0x80000 116b9d0fedcSHariprasad Kelam #define RPM2_USX_PCS_LBK BIT_ULL(14) 1172958d17aSHariprasad Kelam 11891c6945eSHariprasad Kelam /* Function Declarations */ 119ce7a6c31SHariprasad Kelam int rpm_get_nr_lmacs(void *rpmd); 1203ad3f8f9SHariprasad Kelam u8 rpm_get_lmac_type(void *rpmd, int lmac_id); 121459f326eSSunil Goutham u32 rpm_get_lmac_fifo_len(void *rpmd, int lmac_id); 122b9d0fedcSHariprasad Kelam u32 rpm2_get_lmac_fifo_len(void *rpmd, int lmac_id); 1233ad3f8f9SHariprasad Kelam int rpm_lmac_internal_loopback(void *rpmd, int lmac_id, bool enable); 1241845ada4SRakesh Babu void rpm_lmac_enadis_rx_pause_fwding(void *rpmd, int lmac_id, bool enable); 1251845ada4SRakesh Babu int rpm_lmac_get_pause_frm_status(void *cgxd, int lmac_id, u8 *tx_pause, 1261845ada4SRakesh Babu u8 *rx_pause); 1271845ada4SRakesh Babu void rpm_lmac_pause_frm_config(void *rpmd, int lmac_id, bool enable); 1281845ada4SRakesh Babu int rpm_lmac_enadis_pause_frm(void *rpmd, int lmac_id, u8 tx_pause, 1291845ada4SRakesh Babu u8 rx_pause); 130ce7a6c31SHariprasad Kelam int rpm_get_tx_stats(void *rpmd, int lmac_id, int idx, u64 *tx_stat); 131ce7a6c31SHariprasad Kelam int rpm_get_rx_stats(void *rpmd, int lmac_id, int idx, u64 *rx_stat); 132d1489208SHariprasad Kelam void rpm_lmac_ptp_config(void *rpmd, int lmac_id, bool enable); 133fae80edeSGeetha sowjanya int rpm_lmac_rx_tx_enable(void *rpmd, int lmac_id, bool enable); 134fae80edeSGeetha sowjanya int rpm_lmac_tx_enable(void *rpmd, int lmac_id, bool enable); 1351121f6b0SSunil Kumar Kori int rpm_lmac_pfc_config(void *rpmd, int lmac_id, u8 tx_pause, u8 rx_pause, 1361121f6b0SSunil Kumar Kori u16 pfc_en); 137e7400038SHariprasad Kelam int rpm_lmac_get_pfc_frm_cfg(void *rpmd, int lmac_id, u8 *tx_pause, 138e7400038SHariprasad Kelam u8 *rx_pause); 139b9d0fedcSHariprasad Kelam int rpm2_get_nr_lmacs(void *rpmd); 140b9d0fedcSHariprasad Kelam bool is_dev_rpm2(void *rpmd); 14184ad3642SHariprasad Kelam int rpm_get_fec_stats(void *cgxd, int lmac_id, struct cgx_fec_stats_rsp *rsp); 1422e3e94c2SHariprasad Kelam int rpm_lmac_reset(void *rpmd, int lmac_id, u8 pf_req_flr); 14392ada6dfSSai Krishna int rpm_stats_reset(void *rpmd, int lmac_id); 144*fed89cfaSHariprasad Kelam void rpm_x2p_reset(void *rpmd, bool enable); 145*fed89cfaSHariprasad Kelam int rpm_enadis_rx(void *rpmd, int lmac_id, bool enable); 14691c6945eSHariprasad Kelam #endif /* RPM_H */ 147