2018-12-06 14:17:51 +00:00
|
|
|
/* SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
* Copyright(c) 2017 Intel Corporation
|
2017-04-21 10:43:26 +00:00
|
|
|
*/
|
|
|
|
|
2018-05-15 09:49:22 +00:00
|
|
|
#ifndef _RTE_DISTRIB_V1705_H_
|
|
|
|
#define _RTE_DISTRIB_V1705_H_
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @file
|
|
|
|
* RTE distributor
|
|
|
|
*
|
|
|
|
* The distributor is a component which is designed to pass packets
|
|
|
|
* one-at-a-time to workers, with dynamic load balancing.
|
|
|
|
*/
|
2017-04-21 10:43:26 +00:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2018-05-15 09:49:22 +00:00
|
|
|
struct rte_distributor *
|
|
|
|
rte_distributor_create_v1705(const char *name, unsigned int socket_id,
|
|
|
|
unsigned int num_workers,
|
|
|
|
unsigned int alg_type);
|
2017-04-21 10:43:26 +00:00
|
|
|
|
2018-05-15 09:49:22 +00:00
|
|
|
int
|
|
|
|
rte_distributor_process_v1705(struct rte_distributor *d,
|
|
|
|
struct rte_mbuf **mbufs, unsigned int num_mbufs);
|
|
|
|
|
|
|
|
int
|
|
|
|
rte_distributor_returned_pkts_v1705(struct rte_distributor *d,
|
|
|
|
struct rte_mbuf **mbufs, unsigned int max_mbufs);
|
|
|
|
|
|
|
|
int
|
|
|
|
rte_distributor_flush_v1705(struct rte_distributor *d);
|
|
|
|
|
|
|
|
void
|
|
|
|
rte_distributor_clear_returns_v1705(struct rte_distributor *d);
|
|
|
|
|
|
|
|
int
|
|
|
|
rte_distributor_get_pkt_v1705(struct rte_distributor *d,
|
|
|
|
unsigned int worker_id, struct rte_mbuf **pkts,
|
|
|
|
struct rte_mbuf **oldpkt, unsigned int retcount);
|
|
|
|
|
|
|
|
int
|
|
|
|
rte_distributor_return_pkt_v1705(struct rte_distributor *d,
|
|
|
|
unsigned int worker_id, struct rte_mbuf **oldpkt, int num);
|
|
|
|
|
|
|
|
void
|
|
|
|
rte_distributor_request_pkt_v1705(struct rte_distributor *d,
|
|
|
|
unsigned int worker_id, struct rte_mbuf **oldpkt,
|
|
|
|
unsigned int count);
|
2017-04-21 10:43:26 +00:00
|
|
|
|
2018-05-15 09:49:22 +00:00
|
|
|
int
|
|
|
|
rte_distributor_poll_pkt_v1705(struct rte_distributor *d,
|
|
|
|
unsigned int worker_id, struct rte_mbuf **mbufs);
|
2017-04-21 10:43:26 +00:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif
|