DPDK usage discussions
 help / color / mirror / Atom feed
From: Patrick Mahan <mahan@mahan.org>
To: users@dpdk.org
Subject: Expectations of an RX mbuf when using virtio PMD
Date: Sat, 7 Dec 2024 14:49:50 -0800	[thread overview]
Message-ID: <de7cb197-012c-4fb6-aa2f-ae0a42ef0cab@mahan.org> (raw)

Hello All,

Specifics:
    DPDK Version: dpdk-stable-18.11.11
    Linux Kernel: 4.19.87
    Intel 64-bit architecture

I am working on a code to support our socket based processes that need to run on 
our DPDK-enabled platform.  I am using the virtio_user exception path mechanism 
to support this and initial tests seem fine.

However, I am seeing issues when we receive the packet from the virtio port, that
the packet_type field is not set.

In my code, I have setup my physical PMD (i40e) as etherdev 0 and etherdev 1 and 
have setup the virtual side with virtio as  etherdev 2 and etherdev 3.

I am pairing this as etherdev 0 (physical) to etherdev 2 (virtio_user0) and
etherdev 1 (physical) to etherdev 3 (virtio_user1).

I am using the EAL function `rte_eal_hotplug_add()` as suggested in the 
documentation.

I have added code in my dispatch function to generate a syslog(3) to print the
contents of the packet_type field in the received mbuf.

I then generate traffic to etherdev 1 from connected host and I am seeing the 
following:

The inbound packet log shows -

Dec  7 21:24:45 2024 pmahan-dpdk pktdaemon-eal[27614]: CPU 2 TID 
1140607382984128: [pktdaemon.NOTICE]: pkt_dpdk::switch_q_pkts()[2][1=>3][Q=0]: 
mbuf packet type is 0x00000091

So etherdev 1 packet (physical) has packet_type of 0x91 which translates to
    RTE_PTYPE_L2_ETHER
    RTE_PTYPE_L3_IPV4_EXT_UNKNOWN

Which has been my experience for receiving packets from the physical PMD. 
However, now that I have added the virtio port, the return packet does not seemed 
to have this value set -

Dec  7 21:24:45 2024 pmahan-dpdk pktdaemon-eal[27614]: CPU 2 TID 
1140607382984128: [pktdaemon.NOTICE]: pkt_dpdk::switch_q_pkts()[2][3=>1][Q=0]: 
mbuf packet type is 0x00000000

I have looked into virtio PMD code and see that there is a function to fill in 
the packet type called `virtio_rx_offload()` but it is only called if the 
hardware associated with the virtual queue supports offloading and then only if 
the `virtio_net_hdr` has no flags or its `gso_type` is not GSO_NONE.

If I ignore the flags and just inject the packets directly, everything seems to 
work, but I have internal code that needs to know the basic ethernet type as well 
as the L3 options and I was hoping to rely on the packet_type of the mbuf instead 
of having to do packet groveling.

Is this an "as designed" or am I missing something in the configuration?

Thanks for any pointers,

Patrick

             reply	other threads:[~2024-12-07 22:49 UTC|newest]

Thread overview: 4+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2024-12-07 22:49 Patrick Mahan [this message]
2024-12-07 23:58 ` Oleksandr Nahnybida
2024-12-08  5:10   ` Patrick Mahan
2024-12-10 16:57     ` Stephen Hemminger

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=de7cb197-012c-4fb6-aa2f-ae0a42ef0cab@mahan.org \
    --to=mahan@mahan.org \
    --cc=users@dpdk.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).