DPDK patches and discussions
 help / color / mirror / Atom feed
From: Alexander Belyakov <abelyako@gmail.com>
To: "De Lara Guarch, Pablo" <pablo.de.lara.guarch@intel.com>
Cc: "dev@dpdk.org" <dev@dpdk.org>
Subject: Re: [dpdk-dev] DPDK testpmd forwarding performace degradation
Date: Thu, 29 Jan 2015 15:43:45 +0300	[thread overview]
Message-ID: <CAAQJX_QaaqyHHrLd2DaGYhO1AFT=C728VdFHY0ZCrbm1Lf075Q@mail.gmail.com> (raw)
In-Reply-To: <CAAQJX_Q02FUipAYJgaXnHaJvjgnVa-fp_L4=bgjVUoz9aWXd-w@mail.gmail.com>

On Wed, Jan 28, 2015 at 3:24 PM, Alexander Belyakov <abelyako@gmail.com>
wrote:

>
>
> On Tue, Jan 27, 2015 at 7:21 PM, De Lara Guarch, Pablo <
> pablo.de.lara.guarch@intel.com> wrote:
>
>>
>>
>> > On Tue, Jan 27, 2015 at 10:51 AM, Alexander Belyakov
>>
>> > <abelyako@gmail.com> wrote:
>>
>> >
>>
>> > Hi Pablo,
>>
>> >
>>
>> > On Mon, Jan 26, 2015 at 5:22 PM, De Lara Guarch, Pablo
>>
>> > <pablo.de.lara.guarch@intel.com> wrote:
>>
>> > Hi Alexander,
>>
>> >
>>
>> > > -----Original Message-----
>>
>> > > From: dev [mailto:dev-bounces@dpdk.org <dev-bounces@dpdk.org>] On
>> Behalf Of Alexander
>>
>> > Belyakov
>>
>> > > Sent: Monday, January 26, 2015 10:18 AM
>>
>> > > To: dev@dpdk.org
>>
>> > > Subject: [dpdk-dev] DPDK testpmd forwarding performace degradation
>>
>> > >
>>
>> > > Hello,
>>
>> > >
>>
>> > > recently I have found a case of significant performance degradation
>> for our
>>
>> > > application (built on top of DPDK, of course). Surprisingly, similar
>> issue
>>
>> > > is easily reproduced with default testpmd.
>>
>> > >
>>
>> > > To show the case we need simple IPv4 UDP flood with variable UDP
>>
>> > payload
>>
>> > > size. Saying "packet length" below I mean: Eth header length (14
>> bytes) +
>>
>> > > IPv4 header length (20 bytes) + UPD header length (8 bytes) + UDP
>> payload
>>
>> > > length (variable) + CRC (4 bytes). Source IP addresses and ports are
>>
>> > selected
>>
>> > > randomly for each packet.
>>
>> > >
>>
>> > > I have used DPDK with revisions 1.6.0r2 and 1.7.1. Both show the same
>>
>> > issue.
>>
>> > >
>>
>> > > Follow "Quick start" guide (http://dpdk.org/doc/quick-start) to
>> build and
>>
>> > > run testpmd. Enable testpmd forwarding ("start" command).
>>
>> > >
>>
>> > > Table below shows measured forwarding performance depending on
>>
>> > packet
>>
>> > > length:
>>
>> > >
>>
>> > > No. -- UDP payload length (bytes) -- Packet length (bytes) --
>> Forwarding
>>
>> > > performance (Mpps) -- Expected theoretical performance (Mpps)
>>
>> > >
>>
>> > > 1. 0 -- 64 -- 14.8 -- 14.88
>>
>> > > 2. 34 -- 80 -- 12.4 -- 12.5
>>
>> > > 3. 35 -- 81 -- 6.2 -- 12.38 (!)
>>
>> > > 4. 40 -- 86 -- 6.6 -- 11.79
>>
>> > > 5. 49 -- 95 -- 7.6 -- 10.87
>>
>> > > 6. 50 -- 96 -- 10.7 -- 10.78 (!)
>>
>> > > 7. 60 -- 106 -- 9.4 -- 9.92
>>
>> > >
>>
>> > > At line number 3 we have added 1 byte of UDP payload (comparing to
>>
>> > > previous
>>
>> > > line) and got forwarding performance halved! 6.2 Mpps against 12.38
>> Mpps
>>
>> > > of
>>
>> > > expected theoretical maximum for this packet size.
>>
>> > >
>>
>> > > That is the issue.
>>
>> > >
>>
>> > > Significant performance degradation exists up to 50 bytes of UDP
>> payload
>>
>> > > (96 bytes packet length), where it jumps back to theoretical maximum.
>>
>> > >
>>
>> > > What is happening between 80 and 96 bytes packet length?
>>
>> > >
>>
>> > > This issue is stable and 100% reproducible. At this point I am not
>> sure if
>>
>> > > it is DPDK or NIC issue. These tests have been performed on Intel(R)
>> Eth
>>
>> > > Svr Bypass Adapter X520-LR2 (X520LR2BP).
>>
>> > >
>>
>> > > Is anyone aware of such strange behavior?
>>
>> > I cannot reproduce the issue using two ports on two different 82599EB
>> NICs,
>>
>> > using 1.7.1 and 1.8.0.
>>
>> > I always get either same or better linerate as I increase the packet
>> size.
>>
>> >
>>
>> > Thank you for trying to reproduce the issue.
>>
>> >
>>
>> > Actually, have you tried using 1.8.0?
>>
>> >
>>
>> > I feel 1.8.0 is little bit immature and might require some post-release
>>
>> > patching. Even tespmd from this release is not forwarding packets
>> properly
>>
>> > on my setup. It is up and running without visible errors/warnings, TX/RX
>>
>> > counters are ticking but I can not see any packets at the output.
>>
>>
>>
>> This is strange. Without  changing anything, forwarding works perfectly
>> for me
>>
>> (so, RTE_LIBRTE_IXGBE_RX_ALLOW_BULK_ALLOC is enabled).
>>
>>
>>
>> >Please note, both 1.6.0r2 and 1.7.1 releases work (on the same setup)
>> out-of-the-box just
>>
>> > fine with only exception of this mysterious performance drop.
>>
>> > So it will take some time to figure out what is wrong with dpdk-1.8.0.
>>
>> > Meanwhile we could focus on stable dpdk-1.7.1.
>>
>> >
>>
>> > Managed to get testpmd from dpdk-1.8.0 to work on my setup.
>>
>> > Unfortunately I had to disable RTE_LIBRTE_IXGBE_RX_ALLOW_BULK_ALLOC,
>>
>> > it is new comparing to 1.7.1 and somehow breaks testpmd forwarding. By
>> the
>>
>> > way, simply disabling RTE_LIBRTE_IXGBE_RX_ALLOW_BULK_ALLOC in
>>
>> > common_linuxapp config file breaks the build - had to make
>> quick'n'dirty fix
>>
>> > in struct igb_rx_queue as well.
>>
>> >
>>
>> > Anyway, issue is still here.
>>
>> >
>>
>> > Forwarding 80 bytes packets at 12.4 Mpps.
>>
>> > Forwarding 81 bytes packets at 7.2 Mpps.
>>
>> >
>>
>> > Any ideas?
>>
>> > As for X520-LR2 NIC - it is dual port bypass adapter with device id
>> 155d. I
>>
>> > believe it should be treated as 82599EB except bypass feature. I put
>> bypass
>>
>> > mode to "normal" in those tests.
>>
>>
>>
>> I have used a 82599EB first, and now a X520-SR2. Same results.
>>
>> I assume that X520-SR2 and X520-LR2 should give similar results
>>
>> (only thing that is changed is the wavelength, but the controller is the
>> same).
>>
>>
>>
> It seems I found what was wrong, at least got a hint.
>
> My build server machine type differs from test setup. Until now it was OK
> to build DPDK with -march=native.
>
> I found that building dpdk-1.8.0 with explicitly set core-avx-i (snb, ivb)
> or bdver2 (amd) machine types almost eliminates performance drop. The same
> goes for RTE_LIBRTE_IXGBE_RX_ALLOW_BULK_ALLOC option issues.
>
> It seems DPDK performance and stability depends on machine type more than
> I was expecting.
>
> Thank you for your help.
>
>
Mysteries are still here.

While single RX queue forwarding shows almost no degradation now, multiple
RX queues still do.

Launching

./testpmd -c7 -n3 -- -i --rxq=2 --txq=2 --nb-cores=2 --nb-ports=2

shows the following result:

80 bytes packets are being forwarded at 12.46Mpps rate (which is fine)
81 bytes packets are being forwarded at 7.5Mpps rate (which is weird)

Pablo, could you please check on your setup if multiple RX queues shows no
performance degradation depending on packet size?

Additional information about packets I'm sending.
80 bytes packet is IPv4 UDP packet (with random source IP/port) and 34
payload bytes.
81 bytes packet is IPv4 UDP packet (with random source IP/port) and 35
payload bytes.

Thank you,
Alexander



> Alexander
>
>  Pablo
>>
>> > Alexander
>>
>> >
>>
>> >
>>
>> > Pablo
>>
>> > >
>>
>> > > Regards,
>>
>> > > Alexander Belyakov
>>
>> >
>>
>> >
>>
>>
>>
>>
>>
>
>

  reply	other threads:[~2015-01-29 12:43 UTC|newest]

Thread overview: 12+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2015-01-26 10:17 Alexander Belyakov
2015-01-26 14:22 ` De Lara Guarch, Pablo
     [not found]   ` <CAAQJX_RueTvfr7UnANbLSKceerkfs5DZNguKdPhSVVn9OCGtrw@mail.gmail.com>
2015-01-27  7:51     ` [dpdk-dev] Fwd: " Alexander Belyakov
2015-01-27 10:14       ` [dpdk-dev] " Alexander Belyakov
2015-01-27 16:21         ` De Lara Guarch, Pablo
2015-01-28 12:24           ` Alexander Belyakov
2015-01-29 12:43             ` Alexander Belyakov [this message]
2015-02-05 14:39               ` Alexander Belyakov
2015-01-26 17:08 ` Stephen Hemminger
     [not found]   ` <CAAQJX_QN+HWS7k+MMw+NC3UnSKcdr-B=L1nLdOCh1br5eiYD+A@mail.gmail.com>
2015-01-27  7:51     ` [dpdk-dev] Fwd: " Alexander Belyakov
2015-01-27  2:49 [dpdk-dev] " 吴亚东
2015-01-27  8:04 ` Alexander Belyakov

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='CAAQJX_QaaqyHHrLd2DaGYhO1AFT=C728VdFHY0ZCrbm1Lf075Q@mail.gmail.com' \
    --to=abelyako@gmail.com \
    --cc=dev@dpdk.org \
    --cc=pablo.de.lara.guarch@intel.com \
    /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).