Merge git://git.kernel.org/pub/scm/linux/kernel/git/netdev/net
[linux-2.6-microblaze.git] / drivers / net / ethernet / marvell / octeontx2 / nic / cn10k.h
1 /* SPDX-License-Identifier: GPL-2.0 */
2 /* Marvell RVU Ethernet driver
3  *
4  * Copyright (C) 2021 Marvell.
5  *
6  */
7
8 #ifndef CN10K_H
9 #define CN10K_H
10
11 #include "otx2_common.h"
12
13 static inline int mtu_to_dwrr_weight(struct otx2_nic *pfvf, int mtu)
14 {
15         u32 weight;
16
17         /* On OTx2, since AF returns DWRR_MTU as '1', this logic
18          * will work on those silicons as well.
19          */
20         weight = mtu / pfvf->hw.dwrr_mtu;
21         if (mtu % pfvf->hw.dwrr_mtu)
22                 weight += 1;
23
24         return weight;
25 }
26
27 void cn10k_refill_pool_ptrs(void *dev, struct otx2_cq_queue *cq);
28 void cn10k_sqe_flush(void *dev, struct otx2_snd_queue *sq, int size, int qidx);
29 int cn10k_sq_aq_init(void *dev, u16 qidx, u16 sqb_aura);
30 int cn10k_lmtst_init(struct otx2_nic *pfvf);
31 int cn10k_free_all_ipolicers(struct otx2_nic *pfvf);
32 int cn10k_alloc_matchall_ipolicer(struct otx2_nic *pfvf);
33 int cn10k_free_matchall_ipolicer(struct otx2_nic *pfvf);
34 int cn10k_set_matchall_ipolicer_rate(struct otx2_nic *pfvf,
35                                      u32 burst, u64 rate);
36 int cn10k_map_unmap_rq_policer(struct otx2_nic *pfvf, int rq_idx,
37                                u16 policer, bool map);
38 int cn10k_alloc_leaf_profile(struct otx2_nic *pfvf, u16 *leaf);
39 int cn10k_set_ipolicer_rate(struct otx2_nic *pfvf, u16 profile,
40                             u32 burst, u64 rate, bool pps);
41 int cn10k_free_leaf_profile(struct otx2_nic *pfvf, u16 leaf);
42 #endif /* CN10K_H */