[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20140529172923.2f4aab8a@redhat.com>
Date: Thu, 29 May 2014 17:29:23 +0200
From: Jesper Dangaard Brouer <brouer@...hat.com>
To: Jesper Dangaard Brouer <brouer@...hat.com>
Cc: David Miller <davem@...emloft.net>, alexander.h.duyck@...el.com,
netdev@...r.kernel.org, jeffrey.t.kirsher@...el.com,
dborkman@...hat.com, fw@...len.de, shemminger@...tta.com,
paulmck@...ux.vnet.ibm.com, robert@...julf.se,
greearb@...delatech.com, john.r.fastabend@...el.com,
danieltt@....se, zhouzhouyi@...il.com, Thomas Graf <tgraf@...g.ch>
Subject: Re: [net-next PATCH 2/5] ixgbe: increase default TX ring buffer to
1024
On Wed, 14 May 2014 21:09:35 +0200
Jesper Dangaard Brouer <brouer@...hat.com> wrote:
> > From: Alexander Duyck <alexander.h.duyck@...el.com>
> > Date: Wed, 14 May 2014 09:28:50 -0700
> >
> > > I'd say that it might be better to just add a note to the documentation
> > > folder indicating what configuration is optimal for pktgen rather then
> > > changing everyone's defaults to support one specific test.
>
> I know, increasing these limits should not be taken lightly, but we
> just have to be crystal clear that the current 512 limit, is
> artificially limiting the capabilities of your hardware.
The above statement is mine and it is wrong ;-)
I'm dropping this patch because of the following understanding:
Alexander Duyck pointed out to me, that interrupt throttling might be
the reason behind the need to increase the TX ring size. I tested this
and Alex is right.
The needed TX ring size ("ethtool -g") for max performance, is
directly corrolated with how fast/often the TX cleanup is running.
Adjusting the "ethtool -C <ethx> rx-usecs" value affect how often we
cleanup the ring(s). The default value "1" is some auto interrupt throttling.
Notice with these coalesce tuning, the performance even increase from
6.7Mpps to 7.1Mpps on top of patchset V1.
On top of V1 patchset:
- 6,747,016 pps - rx-usecs: 1 tx-ring: 1024 (irqs: 9492)
- 6,684,612 pps - rx-usecs: 10 tx-ring: 1024 (irqs:99322)
- 7,005,226 pps - rx-usecs: 20 tx-ring: 1024 (irqs:50444)
- 7,113,048 pps - rx-usecs: 30 tx-ring: 1024 (irqs:34004)
- 7,133,019 pps - rx-usecs: 40 tx-ring: 1024 (irqs:25845)
- 7,168,399 pps - rx-usecs: 50 tx-ring: 1024 (irqs:20896)
Look same performance with 512 TX ring.
Lowering TX ring size to (default) 512:
(On top of V1 patchset)
- 3,934,674 pps - rx-usecs: 1 tx-ring: 512 (irqs: 9602)
- 6,684,066 pps - rx-usecs: 10 tx-ring: 512 (irqs:99370)
- 7,001,235 pps - rx-usecs: 20 tx-ring: 512 (irqs:50567)
- 7,115,047 pps - rx-usecs: 30 tx-ring: 512 (irqs:34105)
- 7,130,250 pps - rx-usecs: 40 tx-ring: 512 (irqs:25741)
- 7,165,296 pps - rx-usecs: 50 tx-ring: 512 (irqs:20898)
Look how even a 256 TX ring is enough, if we cleanup the TX ring fast
enough, and how performance decrease if we cleanup to slowly.
Lowering TX ring size to (default) 256:
(On top of V1 patchset)
- 1,883,360 pps - rx-usecs: 1 tx-ring: 256 (irqs: 9800)
- 6,683,552 pps - rx-usecs: 10 tx-ring: 256 (irqs:99786)
- 7,005,004 pps - rx-usecs: 20 tx-ring: 256 (irqs:50749)
- 7,108,776 pps - rx-usecs: 30 tx-ring: 256 (irqs:34536)
- 5,734,301 pps - rx-usecs: 40 tx-ring: 256 (irqs:25909)
- 4,590,093 pps - rx-usecs: 50 tx-ring: 256 (irqs:21183)
--
Best regards,
Jesper Dangaard Brouer
MSc.CS, Sr. Network Kernel Developer at Red Hat
Author of http://www.iptv-analyzer.org
LinkedIn: http://www.linkedin.com/in/brouer
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists