c8419a3984be4d97d44d5a128c4d0aaca16a65a9
[dpdk.git] / drivers / net / qede / base / ecore_l2.h
1 /*
2  * Copyright (c) 2016 QLogic Corporation.
3  * All rights reserved.
4  * www.qlogic.com
5  *
6  * See LICENSE.qede_pmd for copyright and licensing details.
7  */
8
9 #ifndef __ECORE_L2_H__
10 #define __ECORE_L2_H__
11
12
13 #include "ecore.h"
14 #include "ecore_hw.h"
15 #include "ecore_spq.h"
16 #include "ecore_l2_api.h"
17
18 /**
19  * @brief ecore_sp_eth_tx_queue_update -
20  *
21  * This ramrod updates a TX queue. It is used for setting the active
22  * state of the queue.
23  *
24  * @note Final phase API.
25  *
26  * @param p_hwfn
27  *
28  * @return enum _ecore_status_t
29  */
30 enum _ecore_status_t ecore_sp_eth_tx_queue_update(struct ecore_hwfn *p_hwfn);
31
32 enum _ecore_status_t
33 ecore_sp_eth_vport_start(struct ecore_hwfn *p_hwfn,
34                          struct ecore_sp_vport_start_params *p_params);
35
36 /**
37  * @brief - Starts an Rx queue; Should be used where contexts are handled
38  * outside of the ramrod area [specifically iov scenarios]
39  *
40  * @param p_hwfn
41  * @param opaque_fid
42  * @param cid
43  * @param rx_queue_id
44  * @param vport_id
45  * @param stats_id
46  * @param sb
47  * @param sb_index
48  * @param bd_max_bytes
49  * @param bd_chain_phys_addr
50  * @param cqe_pbl_addr
51  * @param cqe_pbl_size
52  * @param b_use_zone_a_prod - support legacy VF producers
53  *
54  * @return enum _ecore_status_t
55  */
56 enum _ecore_status_t
57 ecore_sp_eth_rxq_start_ramrod(struct ecore_hwfn *p_hwfn,
58                               u16 opaque_fid,
59                               u32 cid,
60                               u16 rx_queue_id,
61                               u8 vf_rx_queue_id,
62                               u8 vport_id,
63                               u8 stats_id,
64                               u16 sb,
65                               u8 sb_index,
66                               u16 bd_max_bytes,
67                               dma_addr_t bd_chain_phys_addr,
68                               dma_addr_t cqe_pbl_addr,
69                               u16 cqe_pbl_size, bool b_use_zone_a_prod);
70
71 /**
72  * @brief - Starts a Tx queue; Should be used where contexts are handled
73  * outside of the ramrod area [specifically iov scenarios]
74  *
75  * @param p_hwfn
76  * @param opaque_fid
77  * @param tx_queue_id
78  * @param cid
79  * @param vport_id
80  * @param stats_id
81  * @param sb
82  * @param sb_index
83  * @param pbl_addr
84  * @param pbl_size
85  * @param p_pq_params - parameters for choosing the PQ for this Tx queue
86  *
87  * @return enum _ecore_status_t
88  */
89 enum _ecore_status_t
90 ecore_sp_eth_txq_start_ramrod(struct ecore_hwfn *p_hwfn,
91                               u16 opaque_fid,
92                               u16 tx_queue_id,
93                               u32 cid,
94                               u8 vport_id,
95                               u8 stats_id,
96                               u16 sb,
97                               u8 sb_index,
98                               dma_addr_t pbl_addr,
99                               u16 pbl_size,
100                               union ecore_qm_pq_params *p_pq_params);
101
102 u8 ecore_mcast_bin_from_mac(u8 *mac);
103
104 #endif