1 /* SPDX-License-Identifier: GPL-2.0 */
2 /* Marvell CN10K RPM driver
3  *
4  * Copyright (C) 2020 Marvell.
5  *
6  */
7 
8 #ifndef RPM_H
9 #define RPM_H
10 
11 #include <linux/bits.h>
12 
13 /* PCI device IDs */
14 #define PCI_DEVID_CN10K_RPM		0xA060
15 
16 /* Registers */
17 #define RPMX_CMRX_CFG			0x00
18 #define RPMX_RX_TS_PREPEND              BIT_ULL(22)
19 #define RPMX_TX_PTP_1S_SUPPORT          BIT_ULL(17)
20 #define RPMX_CMRX_SW_INT                0x180
21 #define RPMX_CMRX_SW_INT_W1S            0x188
22 #define RPMX_CMRX_SW_INT_ENA_W1S        0x198
23 #define RPMX_CMRX_LINK_CFG		0x1070
24 #define RPMX_MTI_PCS100X_CONTROL1       0x20000
25 #define RPMX_MTI_LPCSX_CONTROL1         0x30000
26 #define RPMX_MTI_PCS_LBK                BIT_ULL(14)
27 #define RPMX_MTI_LPCSX_CONTROL(id)     (0x30000 | ((id) * 0x100))
28 
29 #define RPMX_CMRX_LINK_RANGE_MASK	GENMASK_ULL(19, 16)
30 #define RPMX_CMRX_LINK_BASE_MASK	GENMASK_ULL(11, 0)
31 #define RPMX_MTI_MAC100X_COMMAND_CONFIG	0x8010
32 #define RPMX_MTI_MAC100X_COMMAND_CONFIG_RX_P_DISABLE	BIT_ULL(29)
33 #define RPMX_MTI_MAC100X_COMMAND_CONFIG_TX_P_DISABLE	BIT_ULL(28)
34 #define RPMX_MTI_MAC100X_COMMAND_CONFIG_PAUSE_IGNORE	BIT_ULL(8)
35 #define RPMX_MTI_MAC100X_COMMAND_CONFIG_PFC_MODE	BIT_ULL(19)
36 #define RPMX_MTI_MAC100X_CL01_PAUSE_QUANTA		0x80A8
37 #define RPMX_MTI_MAC100X_CL23_PAUSE_QUANTA		0x80B0
38 #define RPMX_MTI_MAC100X_CL45_PAUSE_QUANTA		0x80B8
39 #define RPMX_MTI_MAC100X_CL67_PAUSE_QUANTA		0x80C0
40 #define RPMX_MTI_MAC100X_CL01_QUANTA_THRESH		0x80C8
41 #define RPMX_MTI_MAC100X_CL23_QUANTA_THRESH		0x80D0
42 #define RPMX_MTI_MAC100X_CL45_QUANTA_THRESH		0x80D8
43 #define RPMX_MTI_MAC100X_CL67_QUANTA_THRESH		0x80E0
44 #define RPMX_MTI_MAC100X_CL89_PAUSE_QUANTA		0x8108
45 #define RPMX_MTI_MAC100X_CL1011_PAUSE_QUANTA		0x8110
46 #define RPMX_MTI_MAC100X_CL1213_PAUSE_QUANTA		0x8118
47 #define RPMX_MTI_MAC100X_CL1415_PAUSE_QUANTA		0x8120
48 #define RPMX_MTI_MAC100X_CL89_QUANTA_THRESH		0x8128
49 #define RPMX_MTI_MAC100X_CL1011_QUANTA_THRESH		0x8130
50 #define RPMX_MTI_MAC100X_CL1213_QUANTA_THRESH		0x8138
51 #define RPMX_MTI_MAC100X_CL1415_QUANTA_THRESH		0x8140
52 #define RPMX_CMR_RX_OVR_BP		0x4120
53 #define RPMX_CMR_RX_OVR_BP_EN(x)	BIT_ULL((x) + 8)
54 #define RPMX_CMR_RX_OVR_BP_BP(x)	BIT_ULL((x) + 4)
55 #define RPMX_CMR_CHAN_MSK_OR            0x4118
56 #define RPMX_MTI_STAT_RX_STAT_PAGES_COUNTERX 0x12000
57 #define RPMX_MTI_STAT_TX_STAT_PAGES_COUNTERX 0x13000
58 #define RPMX_MTI_STAT_DATA_HI_CDC            0x10038
59 
60 #define RPM_LMAC_FWI			0xa
61 #define RPM_TX_EN			BIT_ULL(0)
62 #define RPM_RX_EN			BIT_ULL(1)
63 #define RPMX_CMRX_PRT_CBFC_CTL                         0x5B08
64 #define RPMX_CMRX_PRT_CBFC_CTL_LOGL_EN_RX_SHIFT        33
65 #define RPMX_CMRX_PRT_CBFC_CTL_PHYS_BP_SHIFT           16
66 #define RPMX_CMRX_PRT_CBFC_CTL_LOGL_EN_TX_SHIFT        0
67 #define RPM_PFC_CLASS_MASK			       GENMASK_ULL(48, 33)
68 #define RPMX_MTI_MAC100X_CL89_QUANTA_THRESH		0x8128
69 #define RPMX_MTI_MAC100X_COMMAND_CONFIG_TX_PAD_EN              BIT_ULL(11)
70 #define RPMX_MTI_MAC100X_COMMAND_CONFIG_PAUSE_IGNORE           BIT_ULL(8)
71 #define RPMX_MTI_MAC100X_COMMAND_CONFIG_PAUSE_FWD              BIT_ULL(7)
72 #define RPMX_MTI_MAC100X_CL01_PAUSE_QUANTA              0x80A8
73 #define RPMX_MTI_MAC100X_CL89_PAUSE_QUANTA		0x8108
74 #define RPM_DEFAULT_PAUSE_TIME                          0x7FF
75 
76 #define RPMX_MTI_MAC100X_XIF_MODE		        0x8100
77 #define RPMX_ONESTEP_ENABLE				BIT_ULL(5)
78 #define RPMX_TS_BINARY_MODE				BIT_ULL(11)
79 
80 /* Function Declarations */
81 int rpm_get_nr_lmacs(void *rpmd);
82 u8 rpm_get_lmac_type(void *rpmd, int lmac_id);
83 u32 rpm_get_lmac_fifo_len(void *rpmd, int lmac_id);
84 int rpm_lmac_internal_loopback(void *rpmd, int lmac_id, bool enable);
85 void rpm_lmac_enadis_rx_pause_fwding(void *rpmd, int lmac_id, bool enable);
86 int rpm_lmac_get_pause_frm_status(void *cgxd, int lmac_id, u8 *tx_pause,
87 				  u8 *rx_pause);
88 void rpm_lmac_pause_frm_config(void *rpmd, int lmac_id, bool enable);
89 int rpm_lmac_enadis_pause_frm(void *rpmd, int lmac_id, u8 tx_pause,
90 			      u8 rx_pause);
91 int rpm_get_tx_stats(void *rpmd, int lmac_id, int idx, u64 *tx_stat);
92 int rpm_get_rx_stats(void *rpmd, int lmac_id, int idx, u64 *rx_stat);
93 void rpm_lmac_ptp_config(void *rpmd, int lmac_id, bool enable);
94 int rpm_lmac_rx_tx_enable(void *rpmd, int lmac_id, bool enable);
95 int rpm_lmac_tx_enable(void *rpmd, int lmac_id, bool enable);
96 int rpm_lmac_pfc_config(void *rpmd, int lmac_id, u8 tx_pause, u8 rx_pause,
97 			u16 pfc_en);
98 int rpm_lmac_get_pfc_frm_cfg(void *rpmd, int lmac_id, u8 *tx_pause,
99 			     u8 *rx_pause);
100 #endif /* RPM_H */
101