xref: /openbmc/linux/drivers/net/ethernet/marvell/octeontx2/af/rpm.h (revision ecc23d0a422a3118fcf6e4f0a46e17a6c2047b02)
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