xref: /linux/drivers/net/ethernet/marvell/octeontx2/nic/cn10k.h (revision d09560435cb712c9ec1e62b8a43a79b0af69fe77)
1 /* SPDX-License-Identifier: GPL-2.0
2  * Marvell OcteonTx2 RVU Ethernet driver
3  *
4  * Copyright (C) 2020 Marvell.
5  */
6 
7 #ifndef CN10K_H
8 #define CN10K_H
9 
10 #include "otx2_common.h"
11 
12 void cn10k_refill_pool_ptrs(void *dev, struct otx2_cq_queue *cq);
13 void cn10k_sqe_flush(void *dev, struct otx2_snd_queue *sq, int size, int qidx);
14 int cn10k_sq_aq_init(void *dev, u16 qidx, u16 sqb_aura);
15 int cn10k_pf_lmtst_init(struct otx2_nic *pf);
16 int cn10k_vf_lmtst_init(struct otx2_nic *vf);
17 int cn10k_free_all_ipolicers(struct otx2_nic *pfvf);
18 int cn10k_alloc_matchall_ipolicer(struct otx2_nic *pfvf);
19 int cn10k_free_matchall_ipolicer(struct otx2_nic *pfvf);
20 int cn10k_set_matchall_ipolicer_rate(struct otx2_nic *pfvf,
21 				     u32 burst, u64 rate);
22 int cn10k_map_unmap_rq_policer(struct otx2_nic *pfvf, int rq_idx,
23 			       u16 policer, bool map);
24 int cn10k_alloc_leaf_profile(struct otx2_nic *pfvf, u16 *leaf);
25 int cn10k_set_ipolicer_rate(struct otx2_nic *pfvf, u16 profile,
26 			    u32 burst, u64 rate, bool pps);
27 int cn10k_free_leaf_profile(struct otx2_nic *pfvf, u16 leaf);
28 #endif /* CN10K_H */
29