Harald Welte wrote:
Hi!
I'm currently trying to help Robert Olsson improving the performance of
the Linux in-kernel packet generator (pktgen.c). At the moment, we seem
to be unable to get more than 760kpps from a single port of a 82546,
(or any other PCI-X MAC supported by e1000) - that's a bit more than 51%
wirespeed at 64byte packet sizes.
In my experience anything around 750Kpps is a PCI limitation,
specifically PCI bus arbitration latency. Note the clock speed of
the control signal used for bus arbitration has not increased
in proportion to the PCI data clock speed.
The application note #453 referenced below is very imformative:
http://www.intel.com/design/network/products/lan/docs/82546_docs.htm
I was able to confirm the above by passing 4x730Kpps
through a PCI-X system with 4 ethernet controllers,
but never more than 760Kpps through one particular controller.
Note also you may be able to tune for transmission
using setpci (google for setpci & MMRBC), or hacking with TSO?
Pádraig.
|