xref: /dpdk/drivers/net/vmxnet3/vmxnet3_ring.h (revision c962dbf6e0da810429dbb717bec607cb39d33796)
15566a3e3SBruce Richardson /* SPDX-License-Identifier: BSD-3-Clause
25566a3e3SBruce Richardson  * Copyright(c) 2010-2014 Intel Corporation
309452c07SBruce Richardson  */
409452c07SBruce Richardson 
509452c07SBruce Richardson #ifndef _VMXNET3_RING_H_
609452c07SBruce Richardson #define _VMXNET3_RING_H_
709452c07SBruce Richardson 
809452c07SBruce Richardson #define VMXNET3_RX_CMDRING_SIZE 2
909452c07SBruce Richardson 
10*c962dbf6SRonak Doshi #define VMXNET3_DRIVER_VERSION_NUM 0x01013000
1109452c07SBruce Richardson 
1209452c07SBruce Richardson /* Default ring size */
1309452c07SBruce Richardson #define VMXNET3_DEF_TX_RING_SIZE 512
1409452c07SBruce Richardson #define VMXNET3_DEF_RX_RING_SIZE 128
1509452c07SBruce Richardson 
16c4be1a65SShrikrishna Khare /* Default rx data ring desc size */
17b7f60773SShraddha Joshi #define VMXNET3_DEF_RXDATA_DESC_SIZE 256
18c4be1a65SShrikrishna Khare 
1909452c07SBruce Richardson #define VMXNET3_SUCCESS 0
2009452c07SBruce Richardson #define VMXNET3_FAIL   -1
2109452c07SBruce Richardson 
2209452c07SBruce Richardson #define TRUE  1
2309452c07SBruce Richardson #define FALSE 0
2409452c07SBruce Richardson 
2509452c07SBruce Richardson 
2609452c07SBruce Richardson typedef struct vmxnet3_buf_info {
2709452c07SBruce Richardson 	uint16_t               len;
2809452c07SBruce Richardson 	struct rte_mbuf        *m;
2909452c07SBruce Richardson 	uint64_t               bufPA;
3009452c07SBruce Richardson } vmxnet3_buf_info_t;
3109452c07SBruce Richardson 
3209452c07SBruce Richardson typedef struct vmxnet3_cmd_ring {
3309452c07SBruce Richardson 	vmxnet3_buf_info_t     *buf_info;
3409452c07SBruce Richardson 	uint32_t               size;
3509452c07SBruce Richardson 	uint32_t               next2fill;
3609452c07SBruce Richardson 	uint32_t               next2comp;
3709452c07SBruce Richardson 	uint8_t                gen;
3809452c07SBruce Richardson 	uint8_t                rid;
3909452c07SBruce Richardson 	Vmxnet3_GenericDesc    *base;
4009452c07SBruce Richardson 	uint64_t               basePA;
4109452c07SBruce Richardson } vmxnet3_cmd_ring_t;
4209452c07SBruce Richardson 
4309452c07SBruce Richardson static inline void
vmxnet3_cmd_ring_adv_next2fill(struct vmxnet3_cmd_ring * ring)4409452c07SBruce Richardson vmxnet3_cmd_ring_adv_next2fill(struct vmxnet3_cmd_ring *ring)
4509452c07SBruce Richardson {
4609452c07SBruce Richardson 	ring->next2fill++;
4709452c07SBruce Richardson 	if (unlikely(ring->next2fill == ring->size)) {
4809452c07SBruce Richardson 		ring->next2fill = 0;
4909452c07SBruce Richardson 		ring->gen = (uint8_t)(ring->gen ^ 1);
5009452c07SBruce Richardson 	}
5109452c07SBruce Richardson }
5209452c07SBruce Richardson 
5309452c07SBruce Richardson static inline void
vmxnet3_cmd_ring_adv_next2comp(struct vmxnet3_cmd_ring * ring)5409452c07SBruce Richardson vmxnet3_cmd_ring_adv_next2comp(struct vmxnet3_cmd_ring *ring)
5509452c07SBruce Richardson {
5609452c07SBruce Richardson 	VMXNET3_INC_RING_IDX_ONLY(ring->next2comp, ring->size);
5709452c07SBruce Richardson }
5809452c07SBruce Richardson 
5909452c07SBruce Richardson static inline uint32_t
vmxnet3_cmd_ring_desc_avail(struct vmxnet3_cmd_ring * ring)6009452c07SBruce Richardson vmxnet3_cmd_ring_desc_avail(struct vmxnet3_cmd_ring *ring)
6109452c07SBruce Richardson {
6209452c07SBruce Richardson 	return (ring->next2comp > ring->next2fill ? 0 : ring->size) +
6309452c07SBruce Richardson 		   ring->next2comp - ring->next2fill - 1;
6409452c07SBruce Richardson }
6509452c07SBruce Richardson 
6609452c07SBruce Richardson static inline bool
vmxnet3_cmd_ring_desc_empty(struct vmxnet3_cmd_ring * ring)6709452c07SBruce Richardson vmxnet3_cmd_ring_desc_empty(struct vmxnet3_cmd_ring *ring)
6809452c07SBruce Richardson {
69693f715dSHuawei Xie 	return ring->next2comp == ring->next2fill;
7009452c07SBruce Richardson }
7109452c07SBruce Richardson 
7209452c07SBruce Richardson typedef struct vmxnet3_comp_ring {
7309452c07SBruce Richardson 	uint32_t               size;
7409452c07SBruce Richardson 	uint32_t               next2proc;
7509452c07SBruce Richardson 	uint8_t                gen;
7609452c07SBruce Richardson 	uint8_t                intr_idx;
7709452c07SBruce Richardson 	Vmxnet3_GenericDesc    *base;
7809452c07SBruce Richardson 	uint64_t               basePA;
7909452c07SBruce Richardson } vmxnet3_comp_ring_t;
8009452c07SBruce Richardson 
8109452c07SBruce Richardson struct vmxnet3_data_ring {
8209452c07SBruce Richardson 	struct Vmxnet3_TxDataDesc *base;
8309452c07SBruce Richardson 	uint32_t                  size;
8409452c07SBruce Richardson 	uint64_t                  basePA;
8509452c07SBruce Richardson };
8609452c07SBruce Richardson 
8709452c07SBruce Richardson static inline void
vmxnet3_comp_ring_adv_next2proc(struct vmxnet3_comp_ring * ring)8809452c07SBruce Richardson vmxnet3_comp_ring_adv_next2proc(struct vmxnet3_comp_ring *ring)
8909452c07SBruce Richardson {
9009452c07SBruce Richardson 	ring->next2proc++;
9109452c07SBruce Richardson 	if (unlikely(ring->next2proc == ring->size)) {
9209452c07SBruce Richardson 		ring->next2proc = 0;
9309452c07SBruce Richardson 		ring->gen = (uint8_t)(ring->gen ^ 1);
9409452c07SBruce Richardson 	}
9509452c07SBruce Richardson }
9609452c07SBruce Richardson 
9709452c07SBruce Richardson struct vmxnet3_txq_stats {
983df28ed5SStephen Hemminger 	uint64_t        drop_total; /* # of pkts dropped by the driver,
993df28ed5SStephen Hemminger 				     * the counters below track droppings due to
10009452c07SBruce Richardson 				     * different reasons
10109452c07SBruce Richardson 				     */
1027ba5de41SStephen Hemminger 	uint64_t        drop_too_many_segs;
10309452c07SBruce Richardson 	uint64_t        drop_tso;
10409452c07SBruce Richardson 	uint64_t        tx_ring_full;
10509452c07SBruce Richardson };
10609452c07SBruce Richardson 
10709452c07SBruce Richardson typedef struct vmxnet3_tx_queue {
10809452c07SBruce Richardson 	struct vmxnet3_hw            *hw;
10909452c07SBruce Richardson 	struct vmxnet3_cmd_ring      cmd_ring;
11009452c07SBruce Richardson 	struct vmxnet3_comp_ring     comp_ring;
11109452c07SBruce Richardson 	struct vmxnet3_data_ring     data_ring;
11209452c07SBruce Richardson 	uint32_t                     qid;
11309452c07SBruce Richardson 	struct Vmxnet3_TxQueueDesc   *shared;
11409452c07SBruce Richardson 	struct vmxnet3_txq_stats     stats;
11504df93d1SChas Williams 	const struct rte_memzone     *mz;
11609452c07SBruce Richardson 	bool                         stopped;
11709452c07SBruce Richardson 	uint16_t                     queue_id;      /**< Device TX queue index. */
118f8244c63SZhiyong Yang 	uint16_t                     port_id;       /**< Device port identifier. */
11901fef6e3SShrikrishna Khare 	uint16_t		     txdata_desc_size;
12009452c07SBruce Richardson } vmxnet3_tx_queue_t;
12109452c07SBruce Richardson 
12209452c07SBruce Richardson struct vmxnet3_rxq_stats {
12309452c07SBruce Richardson 	uint64_t                     drop_total;
12409452c07SBruce Richardson 	uint64_t                     drop_err;
12509452c07SBruce Richardson 	uint64_t                     drop_fcs;
12609452c07SBruce Richardson 	uint64_t                     rx_buf_alloc_failure;
12709452c07SBruce Richardson };
12809452c07SBruce Richardson 
129c4be1a65SShrikrishna Khare struct vmxnet3_rx_data_ring {
130c4be1a65SShrikrishna Khare 	uint8_t  *base;
131c4be1a65SShrikrishna Khare 	uint64_t basePA;
132c4be1a65SShrikrishna Khare 	uint32_t size;
133c4be1a65SShrikrishna Khare };
134c4be1a65SShrikrishna Khare 
13509452c07SBruce Richardson typedef struct vmxnet3_rx_queue {
13609452c07SBruce Richardson 	struct rte_mempool          *mp;
13709452c07SBruce Richardson 	struct vmxnet3_hw           *hw;
13809452c07SBruce Richardson 	struct vmxnet3_cmd_ring     cmd_ring[VMXNET3_RX_CMDRING_SIZE];
13909452c07SBruce Richardson 	struct vmxnet3_comp_ring    comp_ring;
140c4be1a65SShrikrishna Khare 	struct vmxnet3_rx_data_ring data_ring;
141c4be1a65SShrikrishna Khare 	uint16_t                    data_desc_size;
14209452c07SBruce Richardson 	uint32_t                    qid1;
14309452c07SBruce Richardson 	uint32_t                    qid2;
144c4be1a65SShrikrishna Khare 	/* rqID in RCD for buffer from data ring */
145c4be1a65SShrikrishna Khare 	uint32_t                    data_ring_qid;
14609452c07SBruce Richardson 	Vmxnet3_RxQueueDesc         *shared;
1472fdd835fSStephen Hemminger 	struct rte_mbuf             *start_seg;
1482fdd835fSStephen Hemminger 	struct rte_mbuf             *last_seg;
14909452c07SBruce Richardson 	struct vmxnet3_rxq_stats    stats;
15004df93d1SChas Williams 	const struct rte_memzone    *mz;
15109452c07SBruce Richardson 	bool                        stopped;
15209452c07SBruce Richardson 	uint16_t                    queue_id;      /**< Device RX queue index. */
153f8244c63SZhiyong Yang 	uint16_t                    port_id;       /**< Device port identifier. */
15409452c07SBruce Richardson } vmxnet3_rx_queue_t;
15509452c07SBruce Richardson 
15609452c07SBruce Richardson #endif /* _VMXNET3_RING_H_ */
157