Add APi `ff_dpdk_raw_packet_send` to suppoort RAW packet send direty with DPDK by user APP not via socket.

This commit is contained in:
fengbojiang 2024-09-06 16:28:35 +08:00
parent f4e3243725
commit 0dc9cb4bbd
3 changed files with 60 additions and 1 deletions

View File

@ -221,6 +221,22 @@ typedef int (*dispatch_func_t)(void *data, uint16_t *len,
/* regist a packet dispath function */
void ff_regist_packet_dispatcher(dispatch_func_t func);
/*
* RAW packet send direty with DPDK by user APP.
*
* @param data
* The data pointer of this packet.
* @param total
* The total length of this packet.
* @param port_id
* Current port of this packet.
*
* @return error_no
* 0 means success.
* -1 means error.
*/
int ff_dpdk_raw_packet_send(void *data, int total, uint16_t port_id);
/* dispatch api end */
/* pcb lddr api begin */

View File

@ -61,4 +61,5 @@ ff_zc_mbuf_read
ff_get_traffic
ff_pthread_create
ff_pthread_join
pcurthread
pcurthread
ff_dpdk_raw_packet_send

View File

@ -1983,6 +1983,48 @@ ff_dpdk_if_send(struct ff_dpdk_if_context *ctx, void *m,
return send_single_packet(head, ctx->port_id);
}
int
ff_dpdk_raw_packet_send(void *data, int total, uint16_t port_id)
{
struct rte_mempool *mbuf_pool = pktmbuf_pool[lcore_conf.socket_id];
struct rte_mbuf *head = rte_pktmbuf_alloc(mbuf_pool);
if (head == NULL) {
return -1;
}
head->pkt_len = total;
head->nb_segs = 0;
int off = 0;
struct rte_mbuf *cur = head, *prev = NULL;
while(total > 0) {
if (cur == NULL) {
cur = rte_pktmbuf_alloc(mbuf_pool);
if (cur == NULL) {
rte_pktmbuf_free(head);
return -1;
}
}
if (prev != NULL) {
prev->next = cur;
}
head->nb_segs++;
prev = cur;
void *cur_data = rte_pktmbuf_mtod(cur, void*);
int len = total > RTE_MBUF_DEFAULT_DATAROOM ? RTE_MBUF_DEFAULT_DATAROOM : total;
memcpy(cur_data, data + off, len);
cur->data_len = len;
off += len;
total -= len;
cur = NULL;
}
return send_single_packet(head, port_id);
}
static int
main_loop(void *arg)
{