[dpdk-users] Proper way of notifying the application that DPDK received messages
Stephen Hemminger
stephen at networkplumber.org
Thu Aug 30 02:44:36 CEST 2018
On Wed, 29 Aug 2018 16:56:51 -0700
Sungho Hong <maverickjin88 at gmail.com> wrote:
> Hello
>
> currently, I'am using dpdk by sending and receiving the packets in to the
> rte-rings. I'am having difficulty of finding the proper way of to notify
> the application that the DPDK received incoming messages.
>
> In order to check the whether the rte_ring has received the data or not, I
> run a busy loop on the rte_ring.
> here is the example below
>
> while (1) {
> if (rte_ring_dequeue(rx_ring, &_msg) < 0) {
> usleep(5);
> } else {
> recv_msg = (char *) _msg;
> if (chara_debug) printf("[%d] Server merge
> data::[%.24s...]__length::[%ld]\n", batched_packets, recv_msg,
> strlen(recv_msg));
> collect_packets++;
> if (collect_packets > MERGE_PACKETS) break;
> }
> }
>
> However, my fellow developers say that this is not a efficient way nor the
> proper way of checking received messages. Busy polling should be only done
> in the DPDK API and not in the application.
>
> Is there a way for DPDK to send a signal to the application so that the
> application can only check the rte_ring only when there is a received
> message?.
If you notification, look into the interrupt mode.
More information about the users
mailing list