xref: /openbmc/linux/drivers/net/ethernet/marvell/octeontx2/af/mcs.h (revision d0c44de2d8ffd2e4780d360b34ee6614aa4af080)
1ca7f49ffSGeetha sowjanya /* SPDX-License-Identifier: GPL-2.0 */
2ca7f49ffSGeetha sowjanya /* Marvell CN10K MCS driver
3ca7f49ffSGeetha sowjanya  *
4ca7f49ffSGeetha sowjanya  * Copyright (C) 2022 Marvell.
5ca7f49ffSGeetha sowjanya  */
6ca7f49ffSGeetha sowjanya 
7ca7f49ffSGeetha sowjanya #ifndef MCS_H
8ca7f49ffSGeetha sowjanya #define MCS_H
9ca7f49ffSGeetha sowjanya 
10ca7f49ffSGeetha sowjanya #include <linux/bits.h>
11ca7f49ffSGeetha sowjanya #include "rvu.h"
12ca7f49ffSGeetha sowjanya 
13ca7f49ffSGeetha sowjanya #define PCI_DEVID_CN10K_MCS		0xA096
14ca7f49ffSGeetha sowjanya 
15ca7f49ffSGeetha sowjanya #define MCSX_LINK_LMAC_RANGE_MASK	GENMASK_ULL(19, 16)
16ca7f49ffSGeetha sowjanya #define MCSX_LINK_LMAC_BASE_MASK	GENMASK_ULL(11, 0)
17ca7f49ffSGeetha sowjanya 
18ca7f49ffSGeetha sowjanya #define MCS_ID_MASK			0x7
196c635f78SGeetha sowjanya #define MCS_MAX_PFS                     128
20ca7f49ffSGeetha sowjanya 
21080bbd19SGeetha sowjanya #define MCS_PORT_MODE_MASK		0x3
22080bbd19SGeetha sowjanya #define MCS_PORT_FIFO_SKID_MASK		0x3F
23080bbd19SGeetha sowjanya #define MCS_MAX_CUSTOM_TAGS		0x8
24080bbd19SGeetha sowjanya 
25cfc14181SGeetha sowjanya #define MCS_CTRLPKT_ETYPE_RULE_MAX	8
26cfc14181SGeetha sowjanya #define MCS_CTRLPKT_DA_RULE_MAX		8
27cfc14181SGeetha sowjanya #define MCS_CTRLPKT_DA_RANGE_RULE_MAX	4
28cfc14181SGeetha sowjanya #define MCS_CTRLPKT_COMBO_RULE_MAX	4
29cfc14181SGeetha sowjanya #define MCS_CTRLPKT_MAC_RULE_MAX	1
30cfc14181SGeetha sowjanya 
31cfc14181SGeetha sowjanya #define MCS_MAX_CTRLPKT_RULES	(MCS_CTRLPKT_ETYPE_RULE_MAX + \
32cfc14181SGeetha sowjanya 				MCS_CTRLPKT_DA_RULE_MAX + \
33cfc14181SGeetha sowjanya 				MCS_CTRLPKT_DA_RANGE_RULE_MAX + \
34cfc14181SGeetha sowjanya 				MCS_CTRLPKT_COMBO_RULE_MAX + \
35cfc14181SGeetha sowjanya 				MCS_CTRLPKT_MAC_RULE_MAX)
36cfc14181SGeetha sowjanya 
37cfc14181SGeetha sowjanya #define MCS_CTRLPKT_ETYPE_RULE_OFFSET		0
38cfc14181SGeetha sowjanya #define MCS_CTRLPKT_DA_RULE_OFFSET		8
39cfc14181SGeetha sowjanya #define MCS_CTRLPKT_DA_RANGE_RULE_OFFSET	16
40cfc14181SGeetha sowjanya #define MCS_CTRLPKT_COMBO_RULE_OFFSET		20
41cfc14181SGeetha sowjanya #define MCS_CTRLPKT_MAC_EN_RULE_OFFSET		24
42cfc14181SGeetha sowjanya 
43ca7f49ffSGeetha sowjanya /* Reserved resources for default bypass entry */
44ca7f49ffSGeetha sowjanya #define MCS_RSRC_RSVD_CNT		1
45ca7f49ffSGeetha sowjanya 
46b8aebeaaSGeetha sowjanya /* MCS Interrupt Vector */
47b8aebeaaSGeetha sowjanya #define MCS_CNF10KB_INT_VEC_IP	0x13
48b8aebeaaSGeetha sowjanya #define MCS_CN10KB_INT_VEC_IP	0x53
496c635f78SGeetha sowjanya 
506c635f78SGeetha sowjanya #define MCS_MAX_BBE_INT			8ULL
516c635f78SGeetha sowjanya #define MCS_BBE_INT_MASK		0xFFULL
526c635f78SGeetha sowjanya 
53b8aebeaaSGeetha sowjanya #define MCS_MAX_PAB_INT		8ULL
546c635f78SGeetha sowjanya #define MCS_PAB_INT_MASK	0xFULL
556c635f78SGeetha sowjanya 
566c635f78SGeetha sowjanya #define MCS_BBE_RX_INT_ENA		BIT_ULL(0)
576c635f78SGeetha sowjanya #define MCS_BBE_TX_INT_ENA		BIT_ULL(1)
586c635f78SGeetha sowjanya #define MCS_CPM_RX_INT_ENA		BIT_ULL(2)
596c635f78SGeetha sowjanya #define MCS_CPM_TX_INT_ENA		BIT_ULL(3)
606c635f78SGeetha sowjanya #define MCS_PAB_RX_INT_ENA		BIT_ULL(4)
616c635f78SGeetha sowjanya #define MCS_PAB_TX_INT_ENA		BIT_ULL(5)
626c635f78SGeetha sowjanya 
636c635f78SGeetha sowjanya #define MCS_CPM_TX_INT_PACKET_XPN_EQ0		BIT_ULL(0)
646c635f78SGeetha sowjanya #define MCS_CPM_TX_INT_PN_THRESH_REACHED	BIT_ULL(1)
656c635f78SGeetha sowjanya #define MCS_CPM_TX_INT_SA_NOT_VALID		BIT_ULL(2)
666c635f78SGeetha sowjanya 
676c635f78SGeetha sowjanya #define MCS_CPM_RX_INT_SECTAG_V_EQ1		BIT_ULL(0)
686c635f78SGeetha sowjanya #define MCS_CPM_RX_INT_SECTAG_E_EQ0_C_EQ1	BIT_ULL(1)
696c635f78SGeetha sowjanya #define MCS_CPM_RX_INT_SL_GTE48			BIT_ULL(2)
706c635f78SGeetha sowjanya #define MCS_CPM_RX_INT_ES_EQ1_SC_EQ1		BIT_ULL(3)
716c635f78SGeetha sowjanya #define MCS_CPM_RX_INT_SC_EQ1_SCB_EQ1		BIT_ULL(4)
726c635f78SGeetha sowjanya #define MCS_CPM_RX_INT_PACKET_XPN_EQ0		BIT_ULL(5)
736c635f78SGeetha sowjanya #define MCS_CPM_RX_INT_PN_THRESH_REACHED	BIT_ULL(6)
746c635f78SGeetha sowjanya 
756c635f78SGeetha sowjanya #define MCS_CPM_RX_INT_ALL	(MCS_CPM_RX_INT_SECTAG_V_EQ1 |		\
766c635f78SGeetha sowjanya 				 MCS_CPM_RX_INT_SECTAG_E_EQ0_C_EQ1 |    \
776c635f78SGeetha sowjanya 				 MCS_CPM_RX_INT_SL_GTE48 |		\
786c635f78SGeetha sowjanya 				 MCS_CPM_RX_INT_ES_EQ1_SC_EQ1 |		\
796c635f78SGeetha sowjanya 				 MCS_CPM_RX_INT_SC_EQ1_SCB_EQ1 |	\
806c635f78SGeetha sowjanya 				 MCS_CPM_RX_INT_PACKET_XPN_EQ0 |	\
816c635f78SGeetha sowjanya 				 MCS_CPM_RX_INT_PN_THRESH_REACHED)
826c635f78SGeetha sowjanya 
836c635f78SGeetha sowjanya struct mcs_pfvf {
846c635f78SGeetha sowjanya 	u64 intr_mask;	/* Enabled Interrupt mask */
856c635f78SGeetha sowjanya };
866c635f78SGeetha sowjanya 
876c635f78SGeetha sowjanya struct mcs_intr_event {
886c635f78SGeetha sowjanya 	u16 pcifunc;
896c635f78SGeetha sowjanya 	u64 intr_mask;
906c635f78SGeetha sowjanya 	u64 sa_id;
916c635f78SGeetha sowjanya 	u8 mcs_id;
926c635f78SGeetha sowjanya 	u8 lmac_id;
936c635f78SGeetha sowjanya };
946c635f78SGeetha sowjanya 
956c635f78SGeetha sowjanya struct mcs_intrq_entry {
966c635f78SGeetha sowjanya 	struct list_head node;
976c635f78SGeetha sowjanya 	struct mcs_intr_event intr_event;
986c635f78SGeetha sowjanya };
996c635f78SGeetha sowjanya 
100cfc14181SGeetha sowjanya struct secy_mem_map {
101cfc14181SGeetha sowjanya 	u8 flow_id;
102cfc14181SGeetha sowjanya 	u8 secy;
103cfc14181SGeetha sowjanya 	u8 ctrl_pkt;
104cfc14181SGeetha sowjanya 	u8 sc;
105cfc14181SGeetha sowjanya 	u64 sci;
106cfc14181SGeetha sowjanya };
107cfc14181SGeetha sowjanya 
108ca7f49ffSGeetha sowjanya struct mcs_rsrc_map {
109ca7f49ffSGeetha sowjanya 	u16 *flowid2pf_map;
110ca7f49ffSGeetha sowjanya 	u16 *secy2pf_map;
111ca7f49ffSGeetha sowjanya 	u16 *sc2pf_map;
112ca7f49ffSGeetha sowjanya 	u16 *sa2pf_map;
113ca7f49ffSGeetha sowjanya 	u16 *flowid2secy_map;	/* bitmap flowid mapped to secy*/
114cfc14181SGeetha sowjanya 	u16 *ctrlpktrule2pf_map;
115ca7f49ffSGeetha sowjanya 	struct rsrc_bmap	flow_ids;
116ca7f49ffSGeetha sowjanya 	struct rsrc_bmap	secy;
117ca7f49ffSGeetha sowjanya 	struct rsrc_bmap	sc;
118ca7f49ffSGeetha sowjanya 	struct rsrc_bmap	sa;
119cfc14181SGeetha sowjanya 	struct rsrc_bmap	ctrlpktrule;
120ca7f49ffSGeetha sowjanya };
121ca7f49ffSGeetha sowjanya 
122ca7f49ffSGeetha sowjanya struct hwinfo {
123ca7f49ffSGeetha sowjanya 	u8 tcam_entries;
124ca7f49ffSGeetha sowjanya 	u8 secy_entries;
125ca7f49ffSGeetha sowjanya 	u8 sc_entries;
126ca7f49ffSGeetha sowjanya 	u16 sa_entries;
127ca7f49ffSGeetha sowjanya 	u8 mcs_x2p_intf;
128ca7f49ffSGeetha sowjanya 	u8 lmac_cnt;
129ca7f49ffSGeetha sowjanya 	u8 mcs_blks;
130ca7f49ffSGeetha sowjanya 	unsigned long	lmac_bmap; /* bitmap of enabled mcs lmac */
131b8aebeaaSGeetha sowjanya 	u16 ip_vec;
132ca7f49ffSGeetha sowjanya };
133ca7f49ffSGeetha sowjanya 
134ca7f49ffSGeetha sowjanya struct mcs {
135ca7f49ffSGeetha sowjanya 	void __iomem		*reg_base;
136ca7f49ffSGeetha sowjanya 	struct pci_dev		*pdev;
137ca7f49ffSGeetha sowjanya 	struct device		*dev;
138ca7f49ffSGeetha sowjanya 	struct hwinfo		*hw;
139ca7f49ffSGeetha sowjanya 	struct mcs_rsrc_map	tx;
140ca7f49ffSGeetha sowjanya 	struct mcs_rsrc_map	rx;
1416c635f78SGeetha sowjanya 	u16                     pf_map[MCS_MAX_PFS]; /* List of PCIFUNC mapped to MCS */
142ca7f49ffSGeetha sowjanya 	u8			mcs_id;
143ca7f49ffSGeetha sowjanya 	struct mcs_ops		*mcs_ops;
144ca7f49ffSGeetha sowjanya 	struct list_head	mcs_list;
1459312150aSGeetha sowjanya 	/* Lock for mcs stats */
1469312150aSGeetha sowjanya 	struct mutex		stats_lock;
1476c635f78SGeetha sowjanya 	struct mcs_pfvf		*pf;
1486c635f78SGeetha sowjanya 	struct mcs_pfvf		*vf;
1496c635f78SGeetha sowjanya 	u16			num_vec;
1506c635f78SGeetha sowjanya 	void			*rvu;
1516c635f78SGeetha sowjanya 	u16			*tx_sa_active;
152*00efd99eSNithin Dabilpuram 	bool                      bypass;
153ca7f49ffSGeetha sowjanya };
154ca7f49ffSGeetha sowjanya 
155ca7f49ffSGeetha sowjanya struct mcs_ops {
156ca7f49ffSGeetha sowjanya 	void	(*mcs_set_hw_capabilities)(struct mcs *mcs);
157ca7f49ffSGeetha sowjanya 	void	(*mcs_parser_cfg)(struct mcs *mcs);
158cfc14181SGeetha sowjanya 	void	(*mcs_tx_sa_mem_map_write)(struct mcs *mcs, struct mcs_tx_sc_sa_map *map);
159cfc14181SGeetha sowjanya 	void	(*mcs_rx_sa_mem_map_write)(struct mcs *mcs, struct mcs_rx_sc_sa_map *map);
160cfc14181SGeetha sowjanya 	void	(*mcs_flowid_secy_map)(struct mcs *mcs, struct secy_mem_map *map, int dir);
161b8aebeaaSGeetha sowjanya 	void	(*mcs_bbe_intr_handler)(struct mcs *mcs, u64 intr, enum mcs_direction dir);
162b8aebeaaSGeetha sowjanya 	void	(*mcs_pab_intr_handler)(struct mcs *mcs, u64 intr, enum mcs_direction dir);
163ca7f49ffSGeetha sowjanya };
164ca7f49ffSGeetha sowjanya 
165ca7f49ffSGeetha sowjanya extern struct pci_driver mcs_driver;
166ca7f49ffSGeetha sowjanya 
mcs_reg_write(struct mcs * mcs,u64 offset,u64 val)167ca7f49ffSGeetha sowjanya static inline void mcs_reg_write(struct mcs *mcs, u64 offset, u64 val)
168ca7f49ffSGeetha sowjanya {
169ca7f49ffSGeetha sowjanya 	writeq(val, mcs->reg_base + offset);
170ca7f49ffSGeetha sowjanya }
171ca7f49ffSGeetha sowjanya 
mcs_reg_read(struct mcs * mcs,u64 offset)172ca7f49ffSGeetha sowjanya static inline u64 mcs_reg_read(struct mcs *mcs, u64 offset)
173ca7f49ffSGeetha sowjanya {
174ca7f49ffSGeetha sowjanya 	return readq(mcs->reg_base + offset);
175ca7f49ffSGeetha sowjanya }
176ca7f49ffSGeetha sowjanya 
177ca7f49ffSGeetha sowjanya /* MCS APIs */
178ca7f49ffSGeetha sowjanya struct mcs *mcs_get_pdata(int mcs_id);
179ca7f49ffSGeetha sowjanya int mcs_get_blkcnt(void);
180ca7f49ffSGeetha sowjanya int mcs_set_lmac_channels(int mcs_id, u16 base);
181cfc14181SGeetha sowjanya int mcs_alloc_rsrc(struct rsrc_bmap *rsrc, u16 *pf_map, u16 pcifunc);
182cfc14181SGeetha sowjanya int mcs_free_rsrc(struct rsrc_bmap *rsrc, u16 *pf_map, int rsrc_id, u16 pcifunc);
183cfc14181SGeetha sowjanya int mcs_alloc_all_rsrc(struct mcs *mcs, u8 *flowid, u8 *secy_id,
184cfc14181SGeetha sowjanya 		       u8 *sc_id, u8 *sa1_id, u8 *sa2_id, u16 pcifunc, int dir);
185cfc14181SGeetha sowjanya int mcs_free_all_rsrc(struct mcs *mcs, int dir, u16 pcifunc);
186cfc14181SGeetha sowjanya void mcs_clear_secy_plcy(struct mcs *mcs, int secy_id, int dir);
187cfc14181SGeetha sowjanya void mcs_ena_dis_flowid_entry(struct mcs *mcs, int id, int dir, int ena);
188cfc14181SGeetha sowjanya void mcs_ena_dis_sc_cam_entry(struct mcs *mcs, int id, int ena);
189cfc14181SGeetha sowjanya void mcs_flowid_entry_write(struct mcs *mcs, u64 *data, u64 *mask, int id, int dir);
190cfc14181SGeetha sowjanya void mcs_secy_plcy_write(struct mcs *mcs, u64 plcy, int id, int dir);
191cfc14181SGeetha sowjanya void mcs_rx_sc_cam_write(struct mcs *mcs, u64 sci, u64 secy, int sc_id);
192cfc14181SGeetha sowjanya void mcs_sa_plcy_write(struct mcs *mcs, u64 *plcy, int sa, int dir);
193cfc14181SGeetha sowjanya void mcs_map_sc_to_sa(struct mcs *mcs, u64 *sa_map, int sc, int dir);
194cfc14181SGeetha sowjanya void mcs_pn_table_write(struct mcs *mcs, u8 pn_id, u64 next_pn, u8 dir);
195cfc14181SGeetha sowjanya void mcs_tx_sa_mem_map_write(struct mcs *mcs, struct mcs_tx_sc_sa_map *map);
196cfc14181SGeetha sowjanya void mcs_flowid_secy_map(struct mcs *mcs, struct secy_mem_map *map, int dir);
197cfc14181SGeetha sowjanya void mcs_rx_sa_mem_map_write(struct mcs *mcs, struct mcs_rx_sc_sa_map *map);
198cfc14181SGeetha sowjanya void mcs_pn_threshold_set(struct mcs *mcs, struct mcs_set_pn_threshold *pn);
199ca7f49ffSGeetha sowjanya int mcs_install_flowid_bypass_entry(struct mcs *mcs);
200ca7f49ffSGeetha sowjanya void mcs_set_lmac_mode(struct mcs *mcs, int lmac_id, u8 mode);
201080bbd19SGeetha sowjanya void mcs_reset_port(struct mcs *mcs, u8 port_id, u8 reset);
202080bbd19SGeetha sowjanya void mcs_set_port_cfg(struct mcs *mcs, struct mcs_port_cfg_set_req *req);
203080bbd19SGeetha sowjanya void mcs_get_port_cfg(struct mcs *mcs, struct mcs_port_cfg_get_req *req,
204080bbd19SGeetha sowjanya 		      struct mcs_port_cfg_get_rsp *rsp);
205080bbd19SGeetha sowjanya void mcs_get_custom_tag_cfg(struct mcs *mcs, struct mcs_custom_tag_cfg_get_req *req,
206080bbd19SGeetha sowjanya 			    struct mcs_custom_tag_cfg_get_rsp *rsp);
207cfc14181SGeetha sowjanya int mcs_alloc_ctrlpktrule(struct rsrc_bmap *rsrc, u16 *pf_map, u16 offset, u16 pcifunc);
208cfc14181SGeetha sowjanya int mcs_free_ctrlpktrule(struct mcs *mcs, struct mcs_free_ctrl_pkt_rule_req *req);
209cfc14181SGeetha sowjanya int mcs_ctrlpktrule_write(struct mcs *mcs, struct mcs_ctrl_pkt_rule_write_req *req);
210*00efd99eSNithin Dabilpuram bool is_mcs_bypass(int mcs_id);
211ca7f49ffSGeetha sowjanya 
212ca7f49ffSGeetha sowjanya /* CN10K-B APIs */
213ca7f49ffSGeetha sowjanya void cn10kb_mcs_set_hw_capabilities(struct mcs *mcs);
214cfc14181SGeetha sowjanya void cn10kb_mcs_tx_sa_mem_map_write(struct mcs *mcs, struct mcs_tx_sc_sa_map *map);
215cfc14181SGeetha sowjanya void cn10kb_mcs_flowid_secy_map(struct mcs *mcs, struct secy_mem_map *map, int dir);
216cfc14181SGeetha sowjanya void cn10kb_mcs_rx_sa_mem_map_write(struct mcs *mcs, struct mcs_rx_sc_sa_map *map);
217ca7f49ffSGeetha sowjanya void cn10kb_mcs_parser_cfg(struct mcs *mcs);
218b8aebeaaSGeetha sowjanya void cn10kb_mcs_pab_intr_handler(struct mcs *mcs, u64 intr, enum mcs_direction dir);
219b8aebeaaSGeetha sowjanya void cn10kb_mcs_bbe_intr_handler(struct mcs *mcs, u64 intr, enum mcs_direction dir);
220ca7f49ffSGeetha sowjanya 
221ca7f49ffSGeetha sowjanya /* CNF10K-B APIs */
222ca7f49ffSGeetha sowjanya struct mcs_ops *cnf10kb_get_mac_ops(void);
223ca7f49ffSGeetha sowjanya void cnf10kb_mcs_set_hw_capabilities(struct mcs *mcs);
224cfc14181SGeetha sowjanya void cnf10kb_mcs_tx_sa_mem_map_write(struct mcs *mcs, struct mcs_tx_sc_sa_map *map);
225cfc14181SGeetha sowjanya void cnf10kb_mcs_flowid_secy_map(struct mcs *mcs, struct secy_mem_map *map, int dir);
226cfc14181SGeetha sowjanya void cnf10kb_mcs_rx_sa_mem_map_write(struct mcs *mcs, struct mcs_rx_sc_sa_map *map);
227ca7f49ffSGeetha sowjanya void cnf10kb_mcs_parser_cfg(struct mcs *mcs);
2286c635f78SGeetha sowjanya void cnf10kb_mcs_tx_pn_thresh_reached_handler(struct mcs *mcs);
2296c635f78SGeetha sowjanya void cnf10kb_mcs_tx_pn_wrapped_handler(struct mcs *mcs);
230b8aebeaaSGeetha sowjanya void cnf10kb_mcs_bbe_intr_handler(struct mcs *mcs, u64 intr, enum mcs_direction dir);
231b8aebeaaSGeetha sowjanya void cnf10kb_mcs_pab_intr_handler(struct mcs *mcs, u64 intr, enum mcs_direction dir);
232ca7f49ffSGeetha sowjanya 
2339312150aSGeetha sowjanya /* Stats APIs */
2349312150aSGeetha sowjanya void mcs_get_sc_stats(struct mcs *mcs, struct mcs_sc_stats *stats, int id, int dir);
2359312150aSGeetha sowjanya void mcs_get_sa_stats(struct mcs *mcs, struct mcs_sa_stats *stats, int id, int dir);
2369312150aSGeetha sowjanya void mcs_get_port_stats(struct mcs *mcs, struct mcs_port_stats *stats, int id, int dir);
2379312150aSGeetha sowjanya void mcs_get_flowid_stats(struct mcs *mcs, struct mcs_flowid_stats *stats, int id, int dir);
2389312150aSGeetha sowjanya void mcs_get_rx_secy_stats(struct mcs *mcs, struct mcs_secy_stats *stats, int id);
2399312150aSGeetha sowjanya void mcs_get_tx_secy_stats(struct mcs *mcs, struct mcs_secy_stats *stats, int id);
2409312150aSGeetha sowjanya void mcs_clear_stats(struct mcs *mcs, u8 type, u8 id, int dir);
2419312150aSGeetha sowjanya int mcs_clear_all_stats(struct mcs *mcs, u16 pcifunc, int dir);
2429312150aSGeetha sowjanya int mcs_set_force_clk_en(struct mcs *mcs, bool set);
2439312150aSGeetha sowjanya 
2446c635f78SGeetha sowjanya int mcs_add_intr_wq_entry(struct mcs *mcs, struct mcs_intr_event *event);
2456c635f78SGeetha sowjanya 
246ca7f49ffSGeetha sowjanya #endif /* MCS_H */
247