DPDK » Historique » Version 26
« Précédent -
Version 26/113
(diff) -
Suivant » -
Version actuelle
Laurent GUERBY, 11/11/2015 21:47
- Contenu
- DPDK
DPDK¶
Traitement haute performance en logiciel, 10 Gbit/s en petit paquets line rate
Liens¶
- http://dpdk.org
- AtelierPPS2012
- GIT http://chiliproject.tetaneutral.net/projects/git-tetaneutral-net/repository/dpdk
$ git clone ssh://git@git.tetaneutral.net/dpdk.git
- Nerim Antoine https://twitter.com/nerim_net/status/517592380841930752
- Du code maison fondé sur #DPDK en prod dans le réseau : première étape vers l'élimination des systèmes propriétaires ?
Misc¶
- https://www.kernel.org/doc/Documentation/networking/switchdev.txt
- https://www.usenix.org/conference/osdi14/technical-sessions/presentation/belay
- IX: A Protected Dataplane Operating System for High Throughput and Low Latency
- http://www.linuxfoundation.org/images/1/1c/Network_data_flow_through_kernel.png
- http://www.linuxfoundation.org/collaborate/workgroups/networking/kernel_flow
- https://blog.cloudflare.com/how-to-receive-a-million-packets/
- How to receive a million packets per second
- https://blog.cloudflare.com/how-to-achieve-low-latency/
- http://www.cs.cmu.edu/~dongz/papers/cuckooswitch.pdf
- We show that CUCKOOSWITCH can process 92.22 million minimum sized packets per second on a commodity server equipped with eight 10 Gbps Ethernet interfaces while maintaining a forwarding table of one billion forwarding entries.
- Improving Linux networking performance https://lwn.net/Articles/629155/
- http://www.bigswitch.com/sites/default/files/presentations/onug-baremetal-2014-final.pdf
- Intel PCI id http://www.intel.com/support/network/sb/cs-012904.htm
- http://www.intel.com/content/www/us/en/ethernet-controllers/ethernet-products.html?iid=embed_portal+hdprod_ethernet#s1=Gigabit%20Ethernet&s2=all&s3=all
- Intel Pro/1000 PT vs CT http://hardforum.com/showthread.php?t=1386042
- http://images.ncix.com/forumimages/C9864B87-583B-10FB-B0DE80742781CE07.jpg
- http://www.intel.com/content/www/us/en/ethernet-controllers/ethernet-controllers.html#s1=all&s2=82572EI&s3=all
- http://www.intel.com/content/www/us/en/ethernet-controllers/ethernet-controllers.html#s1=all&s2=82574L&s3=all
- https://github.com/Pktgen/Pktgen-DPDK
- Evaluating the Suitability of Server Network Cards for Software Routers http://kfall.net/ucbpage/papers/snc.pdf
- http://www.intel.fr/content/dam/www/public/us/en/documents/guides/intel-dpdk-sample-applications-user-guide.pdf
- rte_eth_rx_burst
- http://www.intel.fr/content/dam/www/public/us/en/documents/white-papers/aes-ipsec-performance-linux-paper.pdf
- http://networkbuilders.intel.com/docs/Network_Builders_RA_vBRAS_Final.pdf
Note sileht dpdk:¶
Extract from: http://www.intel.com/content/dam/www/public/us/en/documents/guides/intel-dpdk-getting-started-guide.pdf
configuration hugepages:¶
- 2M (1024*2k): hugepages=1024 (at runtime: echo 1024 > /sys/kernel/mm/hugepages/hugepages-2048kB/nr_hugepages)
- 4G (4x1G): default_hugepagesz=1G hugepagesz=1G hugepages=4 (only works at boot time via grub)
mkdir /mnt/huge mount -t hugetlbfs nodev /mnt/huge
Compile and load modules:¶
Note: source tools/setup.sh is a helper tools for this but works only with IGB driver not e1000e
# apt-get install make gcc linux-headers-amd64 # make config T=x86_64-default-linuxapp-gcc # make T=x86_64-default-linuxapp-gcc .. Build complete # modprobe uio (I think this is not useful) # insmod build/kmod/rte_kni.ko (I think this is not useful) # insmod build/kmod/igb_uio.ko (I think this is not useful) # ./tools/pci_unbind.py --status Network devices using IGB_UIO driver ==================================== <none> Network devices using kernel driver =================================== 0000:00:19.0 '82579LM Gigabit Network Connection' if=eth1 drv=e1000e unused=<none> 0000:01:00.0 '82599EB 10-Gigabit SFI/SFP+ Network Connection' if=eth6 drv=ixgbe unused=igb_uio *Active* 0000:01:00.1 '82599EB 10-Gigabit SFI/SFP+ Network Connection' if=eth7 drv=ixgbe unused=igb_uio 0000:04:00.0 '82571EB Gigabit Ethernet Controller' if=eth2 drv=e1000e unused=igb_uio *Active* 0000:04:00.1 '82571EB Gigabit Ethernet Controller' if=eth3 drv=e1000e unused=igb_uio 0000:05:00.0 '82571EB Gigabit Ethernet Controller' if=eth4 drv=e1000e unused=igb_uio 0000:05:00.1 '82571EB Gigabit Ethernet Controller' if=eth5 drv=e1000e unused=igb_uio 0000:06:00.0 'RTL8111/8168B PCI Express Gigabit Ethernet controller' if=eth0 drv=r8169 unused=<none> *Active* Other network devices ===================== <none>
test sur eth7:
# ip link set eth7 down # ./tools/pci_unbind.py --bind=igb_uio 0000:01:00.1
Prepare examples programs:¶
# export RTE_SDK=/root/sileht/dpdk-1.6.0r1 # export RTE_TARGET=build # cd /root/sileht/ # cp -r $RTE_SDK/examples/helloworld my_rte_app # cd my_rte_app # make
Tests¶
Limitation SPF carte intel:¶
Une fois le module igb_uio changé sur les:
01:00.0 Ethernet controller: Intel Corporation 82599ES 10-Gigabit SFI/SFP+ Network Connection (rev 01)
Un flags de l'eeprom change et le module ixgbe ne charge plus les ports de la carte qui n'ont pas des SFP+ intel avec le message d'erreur suivant:
[ 563.069683] ixgbe 0000:01:00.0: failed to load because an unsupported SFP+ or QSFP module type was detected. [ 563.069786] ixgbe 0000:01:00.0: Reload the driver after installing a supported module.
Pour contourner le problème:
modprobe ixgbe allow_unsupported_sfp=1 # allow_any_sfp=1 suivant le kernel
ou
echo "options ixgbe allow_unsupported_sfp=1" > /etc/modprobe.d/ixgbe_any_sfp.conf update-initramfs -u -k all
La carte fonctionnera à nouveau avec le message suivant:
[ 908.361767] ixgbe 0000:01:00.0 (unregistered net_device): WARNING: Intel (R) Network Connections are quality tested using Intel (R) Ethernet Optics. Using untested modules is not supported and may cause unstable operation or damage to the module or the adapter. Intel Corporation is not responsible for any harm caused by using untested modules.
Atelier 20140705¶
TODO