vpp.git
9 years agodpdk: fix wrong tx ring size calculations 47/2947/2
Damjan Marion [Mon, 19 Sep 2016 11:44:37 +0000 (13:44 +0200)]
dpdk: fix wrong tx ring size calculations

At many places code was using constant ring size od 4096
which was defined in macro DPDK_TX_RING_SIZE.

As we support differnet ring size and default value s now
1024, we need to remove DPDK_TX_RING_SIZE and use
value stored in device structure.

For that reason dpdk_device_t.nb_tx_desc is moved to
first cacheline.

Change-Id: I2c2ac11f0f5e8ae779d34f9a9104eaf2921ec34c
Signed-off-by: Damjan Marion <[email protected]>
9 years agodpdk: move number of sub-interfaces to 2nd cacheline, introduce flag 46/2946/4
Damjan Marion [Mon, 19 Sep 2016 11:31:49 +0000 (13:31 +0200)]
dpdk: move number of sub-interfaces to 2nd cacheline, introduce flag

This saves 2 bytes from the 1st cacheline.

Change-Id: I691a3a0ee07ec2db4ae85b96b451ef53ad8c9458
Signed-off-by: Damjan Marion <[email protected]>
9 years agodpdk: use flags for identifying interface types 45/2945/4
Damjan Marion [Mon, 19 Sep 2016 11:18:09 +0000 (13:18 +0200)]
dpdk: use flags for identifying interface types

This will allow us to handle some more complex situations
like in case when hqos needs to be enabled only for some PMDs.

Change-Id: I5421a8d4cf29b8394b9e956cc4e39737dd07dbbb
Signed-off-by: Damjan Marion <[email protected]>
9 years agoUse SSE instructions for matching tagged frames by ethertype 38/2938/4
Damjan Marion [Mon, 19 Sep 2016 09:32:03 +0000 (11:32 +0200)]
Use SSE instructions for matching tagged frames by ethertype

This change improves performance in l2 scenarios for about 1-2%.

Change-Id: Ie35ed8ad70a3b95dd78c0d158c485a10dabaf0eb
Signed-off-by: Damjan Marion <[email protected]>
9 years agoVPP-419 add thread-safety to LLDP feature 92/2992/2
Klement Sekera [Tue, 20 Sep 2016 13:45:58 +0000 (15:45 +0200)]
VPP-419 add thread-safety to LLDP feature

Change-Id: I3b1153a64674c2caef71c968739ecca6512e9929
Signed-off-by: Klement Sekera <[email protected]>
9 years agofd closed twice 63/2963/2
Eyal Bari [Mon, 19 Sep 2016 15:47:39 +0000 (18:47 +0300)]
fd closed twice

fd close()ed after call to unix_file_del of same fd

Change-Id: Ia8bf77b72b6cea7c70e004199ce11a33b6260720
Signed-off-by: Eyal Bari <[email protected]>
9 years agoAdded volatile to local variables needed by setjmp 34/2934/3
Eyal Bari [Mon, 19 Sep 2016 07:23:39 +0000 (10:23 +0300)]
Added volatile to local variables needed by setjmp

Function vlib_main uses nonlocal control transfer (setjmp, longjmp),
local variables might be mapped to cpu registers which might be
different when longjmp'ing back to it. Added volatile to keep those
variables on the stack. to fix vpp crash when exiting via SIGTERM.

Change-Id: I03e836966c68a966a84d635bc1f7b3a3c252f3ea
Signed-off-by: Eyal Bari <[email protected]>
9 years agoVPP-282: Document changes for vnet/vnet/ethernet 94/2894/2
Billy McFall [Wed, 14 Sep 2016 01:47:55 +0000 (21:47 -0400)]
VPP-282: Document changes for vnet/vnet/ethernet

Change-Id: Ie75f43516fdd76ba3720f65f38d66f14749e3e2d
Signed-off-by: Billy McFall <[email protected]>
9 years agoVPP-189: fix coverity issue in api_format.c 76/2976/3
Filip Tehlar [Tue, 20 Sep 2016 10:37:09 +0000 (12:37 +0200)]
VPP-189: fix coverity issue in api_format.c

Change-Id: Ib16fd69abe93c1afb2ee1d38144763f57888585c
Signed-off-by: Filip Tehlar <[email protected]>
9 years agoVPP-348 Return empty DumpReply instead of null 52/2952/3
Maros Marsalek [Mon, 19 Sep 2016 13:35:41 +0000 (15:35 +0200)]
VPP-348 Return empty DumpReply instead of null

Change-Id: If44f8d37649e5a9d5033ec2c0ab7452397e22691
Signed-off-by: Maros Marsalek <[email protected]>
9 years agoVPP-413 DTOs generated by JVpp improvements: 21/2921/4
Maros Marsalek [Fri, 16 Sep 2016 14:17:58 +0000 (16:17 +0200)]
VPP-413 DTOs generated by JVpp improvements:

- hashCode & equals
- toString

Change-Id: I5f8bc8868c216862a307dcc8f6b423f0ce29e7b5
Signed-off-by: Maros Marsalek <[email protected]>
9 years agovhost-user: announce VIRTIO_F_VERSION_1 49/2949/3
Damjan Marion [Mon, 19 Sep 2016 12:31:34 +0000 (14:31 +0200)]
vhost-user: announce VIRTIO_F_VERSION_1

On some setups with QEMU 2.7.0 and xenial guests following
error message is reported in guest dmesg:

[    0.895944] virtio_net virtio3: virtio: device uses modern interface
but does not have VIRTIO_F_VERSION_1

Change-Id: I5a0b3beffe75c9b0344d377098d94923b2ad7ae9
Signed-off-by: Damjan Marion <[email protected]>
9 years agoUpdate CSIT tests 160912 -> 160919 43/2943/2
Jan [Mon, 19 Sep 2016 10:32:59 +0000 (12:32 +0200)]
Update CSIT tests 160912 -> 160919

- update of CSIT operational branch to be used for VPP-patch test

Change-Id: Ibcc937f68311a9809cc31965633f2d21f111e2c7
Signed-off-by: Jan <[email protected]>
9 years agoAdd structure to some of the documentation; VPP-223 95/2895/2
Chris Luke [Wed, 14 Sep 2016 16:42:54 +0000 (12:42 -0400)]
Add structure to some of the documentation; VPP-223

Moves the random .md files, when rendered by Doxygen,
into a config examples tree. We may later flesh this
out into a more complete user documentation section.

Change-Id: If423b82f1047f1c84f90876a786313054b5f7c77
Signed-off-by: Chris Luke <[email protected]>
9 years agoAdd support for transparent ethernet bridging to GRE 66/2966/2
David Hotham [Mon, 19 Sep 2016 16:55:07 +0000 (09:55 -0700)]
Add support for transparent ethernet bridging to GRE

Change-Id: Iaa3cefe223eb48b128893029a17e092b72a5157c
Signed-off-by: David Hotham <[email protected]>
9 years agoCloned buffer refcount was set to 0 77/2877/3
Christophe Fontaine [Wed, 14 Sep 2016 12:46:35 +0000 (14:46 +0200)]
Cloned buffer refcount was set to 0

The cloned buffer returned by rte_mempool_get_bulk had a refcount set to 0. This triggered an assert in drop-punt node.

Change-Id: I77f53abd72dcdbf5dd512a05e13fe6d3fd569843
Signed-off-by: Christophe Fontaine <[email protected]>
9 years agoVPP-306: Document changes for vnet/vnet/vxlan 88/2888/2
Billy McFall [Wed, 14 Sep 2016 14:39:58 +0000 (10:39 -0400)]
VPP-306: Document changes for vnet/vnet/vxlan

Change-Id: I1ec4a80ee431758998716014e3fb6f80a5b9c168
Signed-off-by: Billy McFall <[email protected]>
9 years agoVPP-407 fix coverity warning 82/2882/2
Klement Sekera [Wed, 14 Sep 2016 12:19:04 +0000 (14:19 +0200)]
VPP-407 fix coverity warning

Change-Id: Ic3e5df2d272c2b31fbe875e1c09db0edac4813b8
Signed-off-by: Klement Sekera <[email protected]>
9 years agoVPP-408: fix coverity warning in run_ping_ip46_address() 89/2889/1
Andrew Yourtchenko [Wed, 14 Sep 2016 15:51:16 +0000 (15:51 +0000)]
VPP-408: fix coverity warning in run_ping_ip46_address()

CID 147141: Security best practices violations (DC.WEAK_CRYPTO)
/vnet/vnet/ip/ping.c: 496 in run_ping_ip46_address()
490 ping_main_t *pm = &ping_main;
491 uword curr_proc = vlib_current_process (vm);
492 u32 n_replies = 0;
493 u32 n_requests = 0;
494 ping_run_t *pr = 0;
495 u32 ping_run_index = 0;
CID 147141: Security best practices violations (DC.WEAK_CRYPTO)
"rand" should not be used for security related applications, as linear congruential algorithms are too easy to break.
496 u16 icmp_id = rand ();
497 while (hash_get (pm->ping_run_by_icmp_id, icmp_id))
498 { 499 vlib_cli_output (vm, "ICMP ID collision at %d, incrementing", icmp_id); 500 icmp_id++; 501 }

Change-Id: I822350c03afce0b2dd35f37e27f55df82ca3443f
Signed-off-by: Andrew Yourtchenko <[email protected]>
9 years agoAdd vlan-strip-offload help into startup.conf 66/2866/2
Alex Popovsky [Wed, 14 Sep 2016 01:02:53 +0000 (18:02 -0700)]
Add vlan-strip-offload help into startup.conf

Change-Id: Icb240ce9c62e9a2e2ff18107729cffb8e4884a0c
Signed-off-by: Alex Popovsky <[email protected]>
9 years agoVPP-404: IKEv2 profile auth rsa-sig cert-file fixed 70/2870/1
Matus Fabian [Wed, 14 Sep 2016 06:15:56 +0000 (23:15 -0700)]
VPP-404: IKEv2 profile auth rsa-sig cert-file fixed

Change-Id: Iaeca4a86eb96096d6840d38c16d60641e9179662
Signed-off-by: Matus Fabian <[email protected]>
9 years agol2_output: reset bit after mapping is created 56/2856/2
Damjan Marion [Tue, 13 Sep 2016 15:00:41 +0000 (17:00 +0200)]
l2_output: reset bit after mapping is created

Change-Id: I894d71b397e7451d4e596b10258933287b7e965f
Signed-off-by: Damjan Marion <[email protected]>
9 years agoVPP-344 Add LLDP feature 52/2852/3
Klement Sekera [Tue, 13 Sep 2016 10:27:08 +0000 (12:27 +0200)]
VPP-344 Add LLDP feature

Change-Id: Iac96773e7f9028c0f09c3388893e69f67177439d
Signed-off-by: Klement Sekera <[email protected]>
9 years agoImplement IPv6/IPv4 ping. 56/956/5
Andrew Yourtchenko [Thu, 4 Aug 2016 13:39:35 +0000 (13:39 +0000)]
Implement IPv6/IPv4 ping.

Change-Id: Id53797c795c17fbacce3659c945f5126dc9dee86
Signed-off-by: Andrew Yourtchenko <[email protected]>
9 years agoAdd some help into startup.conf 45/2845/2
Damjan Marion [Tue, 13 Sep 2016 08:47:35 +0000 (10:47 +0200)]
Add some help into startup.conf

Change-Id: I84e9d7c3ccd32814c3eebf1cef0a4887c75812a8
Signed-off-by: Damjan Marion <[email protected]>
9 years agoVPP-292 Document vnet/vnet/lisp-gpe 38/2738/3
Florin Coras [Mon, 5 Sep 2016 17:30:35 +0000 (19:30 +0200)]
VPP-292 Document vnet/vnet/lisp-gpe

Change-Id: I5b282964330f4c14f7991453ee02c455a8d367ea
Signed-off-by: Florin Coras <[email protected]>
9 years agoVPP-376: Refactor LISP dump API + VAT 23/2623/8
Filip Tehlar [Fri, 2 Sep 2016 10:14:31 +0000 (12:14 +0200)]
VPP-376: Refactor LISP dump API + VAT

- refactor VAT so it won't cache data
- remove unused filter flag from locator dump API call
- json structure changed for locator and EID table dump calls
- remote mapping VAT cli now accepts string for negative mapping action

Change-Id: I776fb50659aaa7e98ad93715d282a83f78287344
Signed-off-by: Filip Tehlar <[email protected]>
9 years agoVPP-288: Documentation changes via doxygen for vnet/vnet/l2. 27/2827/4
Billy McFall [Fri, 9 Sep 2016 12:46:40 +0000 (08:46 -0400)]
VPP-288: Documentation changes via doxygen for vnet/vnet/l2.

Change-Id: I55b552fd054610c993d14078ce048c8c4b676104
Signed-off-by: Billy McFall <[email protected]>
9 years agoPython API: Re-adding rudimentary variable length array pack support. 57/2557/3
Ole Troan [Tue, 30 Aug 2016 19:03:51 +0000 (21:03 +0200)]
Python API: Re-adding rudimentary variable length array pack support.

Fixed bug in message-id mapping with non-consequtive APIs.

Change-Id: Icd6073e4655f7ce5432816861ae58915e5b336af
Signed-off-by: Ole Troan <[email protected]>
9 years agoUse the correct thread stack alignment constraint, VPP-401 33/2833/3
Dave Barach [Mon, 12 Sep 2016 20:44:08 +0000 (16:44 -0400)]
Use the correct thread stack alignment constraint, VPP-401

Change-Id: Ia7837dfaa9ed200145aeea19177fe549ab4bd087
Signed-off-by: Dave Barach <[email protected]>
9 years agoUpdate CSIT tests 160904 -> 160912 30/2830/2
Jan [Mon, 12 Sep 2016 20:34:29 +0000 (22:34 +0200)]
Update CSIT tests 160904 -> 160912

- update of CSIT operational branch to be used for VPP-patch test

Change-Id: I7a8024378dee33c89b58835af1b7de020fac3e5e
Signed-off-by: Jan <[email protected]>
9 years agoProvide vpp-plugins rpm packaging 31/2831/1
Ed Warnicke [Mon, 12 Sep 2016 20:40:24 +0000 (20:40 +0000)]
Provide vpp-plugins rpm packaging

Change-Id: Ifbd99818ead5f38c5f8ad3ecdb36b24a9fa59798
Signed-off-by: Ed Warnicke <[email protected]>
9 years agoMAP: Doxyfying CLI macros - VPP-165 10/2810/2
Ole Troan [Mon, 12 Sep 2016 10:25:30 +0000 (12:25 +0200)]
MAP: Doxyfying CLI macros - VPP-165

Change-Id: Iee203bf24e8c68e1367d12f297bf31019cc44c5c
Signed-off-by: Ole Troan <[email protected]>
9 years agoaf_packet: allocate per-worker list of free buffers 95/2695/3
Damjan Marion [Wed, 7 Sep 2016 09:54:22 +0000 (11:54 +0200)]
af_packet: allocate per-worker list of free buffers

Change-Id: I7850f04787fa7ce10c0ae8adefa166c91420f02d
Signed-off-by: Damjan Marion <[email protected]>
9 years agoDPDK virtio patch: Enable indirect descriptor features 32/2732/2
Pierre Pfister [Thu, 8 Sep 2016 13:36:27 +0000 (14:36 +0100)]
DPDK virtio patch: Enable indirect descriptor features

http://dpdk.org/dev/patchwork/patch/15610/

This change only includes patch for DPDK 16.07 as
DPDK 16.04 doesn't seem to compile for me.

Change-Id: I18d84456ef6a15aa308d5e14673a24cb4a7b6909
Signed-off-by: Pierre Pfister <[email protected]>
9 years agoVPP-392 properly pass flags from vnet_hw_interface_set_flags_helper to 34/2734/2
Klement Sekera [Thu, 8 Sep 2016 15:53:13 +0000 (17:53 +0200)]
VPP-392 properly pass flags from vnet_hw_interface_set_flags_helper to
vnet_main->hw_interface_link_up_down_functions

Change-Id: I7aacaebade695e8fec8306426f693f287b605ed8
Signed-off-by: Klement Sekera <[email protected]>
9 years agoMove CLI examples from wiki to code - VPP-165 94/2794/2
Keith Burns (alagalah) [Sat, 10 Sep 2016 21:55:04 +0000 (14:55 -0700)]
Move CLI examples from wiki to code - VPP-165

Change-Id: I50ad0d79a6ffaf0a51848abf2c5ed57e83c8640f
Signed-off-by: Keith Burns (alagalah) <[email protected]>
9 years agoVPP-367: Peg vpp and vpp-plugins to depend on specific versions 96/2796/1
Ed Warnicke [Sat, 10 Sep 2016 23:13:36 +0000 (16:13 -0700)]
VPP-367: Peg vpp and vpp-plugins to depend on specific versions

vpp now depends on the version of vpp-lib it was built with
vpp-plugins now depends on the version of vpp it was built with

Change-Id: Idf706f94d3a35bdf51930badf61cac288855873d
Signed-off-by: Ed Warnicke <[email protected]>
9 years agoCheck for zero-sized Graphvix config file on Ubuntu; VPP-396 88/2788/1
Chris Luke [Sat, 10 Sep 2016 00:16:04 +0000 (20:16 -0400)]
Check for zero-sized Graphvix config file on Ubuntu; VPP-396

- The previous change only accounted for a missing Graphviz config
  file; apparently it can be zero-sized too.

Change-Id: Ic6957d10cdc7cb7b9da72d2b2a0f8913100870c5
Signed-off-by: Chris Luke <[email protected]>
9 years agoOn Ubuntu check for graphviz system config 85/2785/1
Chris Luke [Fri, 9 Sep 2016 21:51:42 +0000 (17:51 -0400)]
On Ubuntu check for graphviz system config

- Sometimes it seems Ubuntu doesn't always set up the Graphviz
  handler config. If it's missing, generate it.

Change-Id: I2c1e566817de8415f8b360c6f967cd76307a2a52
Signed-off-by: Chris Luke <[email protected]>
9 years agoFix bugs in IPFIX code discovered by coverity 03/2703/4
Juraj Sloboda [Tue, 6 Sep 2016 11:43:52 +0000 (04:43 -0700)]
Fix bugs in IPFIX code discovered by coverity

Change-Id: Ibe6ccb99c3c29c14efb34191f209a2f6a14293f7
Signed-off-by: Juraj Sloboda <[email protected]>
9 years agoFix Coverity issue in trace_util.c (REVERSE_INULL), thanks to Damjan for highlighting... 22/2722/1
Vengada Govindan [Thu, 8 Sep 2016 05:19:36 +0000 (22:19 -0700)]
Fix Coverity issue in trace_util.c (REVERSE_INULL), thanks to Damjan for highlighting this.

Change-Id: I22b1dc800624042e043e7632179f6281a6ccaafc
Signed-off-by: Vengada Govindan <[email protected]>
9 years agoVPP-346 Improve Doxygen include path mechanism 09/2709/2
Chris Luke [Wed, 7 Sep 2016 17:28:59 +0000 (13:28 -0400)]
VPP-346 Improve Doxygen include path mechanism

- If present, include the directories where API header files
  are generated into.
- Improve extraction of include paths from CPP
- Generalize the file/directory exclusion

This reduces some of the "warning" chatter from Doxygen.

Change-Id: I7ac02bff1639fe63f11263176020b0f040255017
Signed-off-by: Chris Luke <[email protected]>
9 years agoVPP-388 Improve IP header lookup in ipsec_output 82/2682/5
Florin Coras [Tue, 6 Sep 2016 13:18:21 +0000 (15:18 +0200)]
VPP-388 Improve IP header lookup in ipsec_output

Change-Id: I5df0067c9ce56d7a15a991b82d4761924d91758b
Signed-off-by: Florin Coras <[email protected]>
9 years agoFix MTU size for the bonded interface 06/2706/3
Steve Shin [Wed, 7 Sep 2016 15:25:04 +0000 (08:25 -0700)]
Fix MTU size for the bonded interface

Configure the MTU/L3 packet size of the bonded interface
as the lowest value of the slave intefaces

Change-Id: I34fb4c2156e8ad3d9bf45efe332405d53f72867c
Signed-off-by: Steve Shin <[email protected]>
9 years agoVPP-390: include *.so symlinks in vpp-lib 08/2708/2
Ed Warnicke [Wed, 7 Sep 2016 17:12:52 +0000 (17:12 +0000)]
VPP-390: include *.so symlinks in vpp-lib

Currently, vpp-lib rpm includes symlinks for

*.so.0 -> *.so.0.0.0

but not

*.so -> *.so.0.0.0

This causes linker issues in cases where vpp-lib and vpp-devel rpms
are installed and sources are built that rely on libraries in vpp-lib.

Example:

libtool: link: gcc -shared -fPIC -DPIC jvpp/.libs/libjvpp_nsh_la-jvpp_nsh.o -lvlibmemoryclient -lvlibapi -lsvm -lvppinfra -lpthread -lm -lrt -ljvpp_common -L/usr/lib64 -O2 -Wl,-soname -Wl,libjvpp_nsh.so.0 -o .libs/libjvpp_nsh.so.0.0.0
/usr/bin/ld: cannot find -lvlibmemoryclient
/usr/bin/ld: cannot find -lvlibapi
/usr/bin/ld: cannot find -lsvm
/usr/bin/ld: cannot find -lvppinfra
collect2: error: ld returned 1 exit status

Change-Id: Ic8eebc696f973ea348be0b43e7cfb289efbe44fe
Signed-off-by: Ed Warnicke <[email protected]>
9 years agoVPP-382: Add ipsec tunnel interface to sw_interface_dump 87/2687/2
Matus Fabian [Wed, 7 Sep 2016 06:19:43 +0000 (23:19 -0700)]
VPP-382: Add ipsec tunnel interface to sw_interface_dump

Change-Id: I9e49c9b6deedb750269da04e3332a3b0742d382c
Signed-off-by: Matus Fabian <[email protected]>
9 years agoVPP-387: Fixed ipsec-input trace 99/2699/2
Matus Fabian [Wed, 7 Sep 2016 12:57:09 +0000 (05:57 -0700)]
VPP-387: Fixed ipsec-input trace

Change-Id: I0a687c5d5f745a6c82a58c8e20b987180704a685
Signed-off-by: Matus Fabian <[email protected]>
9 years agoVhost-User: Implement Indirect Descriptors 06/2106/7
Pierre Pfister [Wed, 27 Jul 2016 15:38:20 +0000 (16:38 +0100)]
Vhost-User: Implement Indirect Descriptors

One of the main issue with virtio is the small queue size.
VPP can quickly fill the queue before Linux could empty it,
resulting in packet losses.
Virtio indirect descriptors double the number of packet
which may fit in the virtio queue (From 128 to 256 with standard qemu
which hardcodes queue size to 256).

Linux will not use such descriptors if the virtio MRG feature is
enabled. You may add mrg_rxbuff=off option to qemu commandline
when starting the VM such as to disable this feature. This way,
Linux will use indirect buffers to receive packets.

But it seems that Linux never uses indirect buffers to send packets.

This patch also includes some optimization modifications.

Change-Id: I26940d41ce6b7e3a08d5516018a8c46c5316ce1c
Signed-off-by: Pierre Pfister <[email protected]>
9 years agocheckstyle: improve speed by checking only recently changed files 97/2697/3
Damjan Marion [Wed, 7 Sep 2016 11:10:50 +0000 (13:10 +0200)]
checkstyle: improve speed by checking only recently changed files

This change makes checkstyle much faster by checking only recently
changed files. It only checks files changed in last commit and files
which are localy modified. Old behavior is preserved by specifying
argument "--full" when invoking script.

In addition "make checkstyle" and "make "fixstyle" actions are added
to the top-level Makefile.

Change-Id: I7d86225bd282f32ee508e7f52692a3778ac8dcda
Signed-off-by: Damjan Marion <[email protected]>
9 years agoVPP-204 Rework and finish IPFIX implementation 61/2261/7
Juraj Sloboda [Mon, 8 Aug 2016 06:43:42 +0000 (23:43 -0700)]
VPP-204 Rework and finish IPFIX implementation

Rework flow report registration system - add streams
Add support for IPv6 and src and dst ports for TCP and UDP protocols
Implement binary API for IPFIX classifier module

Change-Id: Id05cc0127a7b95ceaeebf9c79a32c6936449bd63
Signed-off-by: Juraj Sloboda <[email protected]>
9 years agoAvoid use of node index 0 by registering null-node 79/2679/3
Damjan Marion [Tue, 6 Sep 2016 20:26:03 +0000 (22:26 +0200)]
Avoid use of node index 0 by registering null-node

In some cases it is convenient to use 0 as an invalid node index
so here we make sure that index 0 is not used.

Change-Id: I5af6bef6769d56086ceb343423185f22843732bd
Signed-off-by: Damjan Marion <[email protected]>
9 years agoAdd support for input nodes in interrupt mode on the worker threads 80/2680/2
Damjan Marion [Tue, 6 Sep 2016 20:30:16 +0000 (22:30 +0200)]
Add support for input nodes in interrupt mode on the worker threads

Change-Id: Ice2e0e60c801bd6fb67f3a544e95e9ffaa22ca16
Signed-off-by: Damjan Marion <[email protected]>
9 years agoVPP-346 More VPP doc fixes 76/2676/2
Chris Luke [Tue, 6 Sep 2016 13:32:36 +0000 (09:32 -0400)]
VPP-346 More VPP doc fixes

- Fix issue in Doxy dependency check when nothing needs to be installed.
  'set -e' and plain '[]' logic don't mix well.
- Fix Makefile snafu when building Doxy output for a single file.
- Include only one of vnet/vnet/buffer.c/dpdk_buffer.c in docs depending on
  DPDKness. This could do with some improvement in future, eg to properly
  align the pre-doxy steps with what Doxy does.
- Fix rendering of 'inline' tag in Doxygen by having it interpret
  always_inline as "inline static".
- Bunch of duplicate CLI command structure names that confused docs and may
  one day have caused debugging issues.
- Several other Doxygen syntax issues fixed, like documenting non-existant
  parameters (usually just the wrong parameter name, typos, etc)

Change-Id: Ia8cca545e5de9f8750602bffa3c4548acc8971aa
Signed-off-by: Chris Luke <[email protected]>
9 years agoAdd packet/byte count output tx stats to tunap interface 21/2621/3
John Lo [Sun, 4 Sep 2016 12:55:34 +0000 (08:55 -0400)]
Add packet/byte count output tx stats to tunap interface

Change-Id: I167c49d2a64e7a36a176d57054ecd99b398a9cca
Signed-off-by: John Lo <[email protected]>
9 years agoMove iOAM Trace as a plugin 68/2468/8
Vengada Govindan [Thu, 25 Aug 2016 17:34:34 +0000 (10:34 -0700)]
Move iOAM Trace as a plugin

Change-Id: I78322e91485e5429871bd356f668b8ed90f4265a
Signed-off-by: Vengada Govindan <[email protected]>
9 years agoVPP-386 Fix map-server output in lisp-cp-lookup trace 72/2672/2
Florin Coras [Tue, 6 Sep 2016 14:29:34 +0000 (16:29 +0200)]
VPP-386 Fix map-server output in lisp-cp-lookup trace

Change-Id: I67dd7896932b8ea96062b9ff074959c172b51ba4
Signed-off-by: Florin Coras <[email protected]>
9 years agoVPP-381 Add LISP interfaces to sw_interface_dump 58/2658/3
Florin Coras [Tue, 6 Sep 2016 11:36:11 +0000 (13:36 +0200)]
VPP-381 Add LISP interfaces to sw_interface_dump

Change-Id: I62b65472e77a33b1fc94f7c4975b5e9cbf358f41
Signed-off-by: Florin Coras <[email protected]>
9 years agoIPsec speculative enqueue in exception path, fixes VPP-384 63/2663/2
Sergio Gonzalez Monroy [Tue, 6 Sep 2016 13:06:06 +0000 (14:06 +0100)]
IPsec speculative enqueue in exception path, fixes VPP-384

Enqueue buffers into next frame before validating them.

Change-Id: I466518bc6f304678136a2c3d37f136ce878eef05
Signed-off-by: Sergio Gonzalez Monroy <[email protected]>
9 years agoVPP-385: Fix ARP for indirect adjacencies 49/2649/3
Florin Coras [Mon, 5 Sep 2016 17:54:17 +0000 (19:54 +0200)]
VPP-385: Fix ARP for indirect adjacencies

Change-Id: I48cffb8acbd9e6655d7ec661ee8f7e0689b12a2d
Signed-off-by: Florin Coras <[email protected]>
9 years agoUpdate CSIT tests 160821 -> 160904 32/2632/1
Jan [Mon, 5 Sep 2016 09:32:30 +0000 (11:32 +0200)]
Update CSIT tests 160821 -> 160904

- update of CSIT operational branch to be used for VPP-patch test

Change-Id: I5159d0a320305fd3a8ca927fa742ddd4df87b271
Signed-off-by: Jan Gelety <[email protected]>
9 years agoVPP-358: Add IPv6 ND Event Notification and Termination 94/2594/3
John Lo [Fri, 2 Sep 2016 04:13:41 +0000 (00:13 -0400)]
VPP-358: Add IPv6 ND Event Notification and Termination

Additional fix to vpp_api_test to show which kind of arp/ip6-nd
event is received, whether it is address resolution or mac/ip binding.

Change-Id: Ic65b895cd1bfbe2f34d1b68891a1a580852fbcdb
Signed-off-by: John Lo <[email protected]>
9 years agoAdd in-message cli_request/cli_reply API 75/2575/6
Ole Troan [Wed, 31 Aug 2016 12:50:49 +0000 (14:50 +0200)]
Add in-message cli_request/cli_reply API

This new CLI API is meant to replace the
cli_request/cli_reply that uses shared memory.

PS: checkstyle -- *hate*

Change-Id: I6318f8f6b9be2c2398b49dac9e2193c1998ea724
Signed-off-by: Ole Troan <[email protected]>
9 years agoFix for invalid check of SPARSE_VEC_INVALID_INDEX 99/2599/2
Alex Popovsky [Fri, 2 Sep 2016 03:57:45 +0000 (20:57 -0700)]
Fix for invalid check of SPARSE_VEC_INVALID_INDEX

When looking up a UDP port / GRE protocol in the sparse vectors
next_by_dst_port / next_by_protocol a data from the vector was
tested for SPARSE_VEC_INVALID_INDEX instead of sparse index itself.

This doesn’t matter for most cases since V[0] = 0 is true for all
sparse vectors. This however could cause an issue when a valid
sparse entry e.g. V[1234] = 0, with data (0) mistakenly passing
the test for SPARSE_VEC_INVALID_INDEX, while the index itself (1234)
is a valid index.

Change-Id: I04818cc43efeae047a4dae79078157d48b8c359c
Signed-off-by: Alex Popovsky <[email protected]>
9 years agoVPP-221 Improve doxygen dependency check 85/2585/2
Chris Luke [Thu, 1 Sep 2016 13:04:01 +0000 (09:04 -0400)]
VPP-221 Improve doxygen dependency check

Only try to install packages if they're not installed.
Saves a trip through sudo which is useful when you have a
non-privileged account generating the docs.

Change-Id: I3709aceb15516a45ea2f9510d91c6d2e42c8c349
Signed-off-by: Chris Luke <[email protected]>
9 years agoVPP-374: getting jvppgen.py into rpm vpp-devel package 83/2583/6
Ed Warnicke [Thu, 1 Sep 2016 01:48:47 +0000 (18:48 -0700)]
VPP-374: getting jvppgen.py into rpm vpp-devel package

Change-Id: Ia2643f33170da92fde0f8228c8d8393f23e98d11
Signed-off-by: Ed Warnicke <[email protected]>
9 years agoClean-up unused context arrays in UDP and GRE nodes 93/2593/2
Alex Popovsky [Fri, 2 Sep 2016 00:38:09 +0000 (17:38 -0700)]
Clean-up unused context arrays in UDP and GRE nodes

Removed unused sparse_index_by_next_index vector in local context
of UDP and GRE nodes. Most probably copy paste leftovers from PPP
implementation where it is realy used

Change-Id: I97e81035e2fd451c6f5a7bc31df96db9e6d2cebf
Signed-off-by: Alex Popovsky <[email protected]>
9 years agoVPP-373: stop building from /vpp mount 89/2589/4
Ed Warnicke [Thu, 1 Sep 2016 18:54:27 +0000 (11:54 -0700)]
VPP-373: stop building from /vpp mount

Change-Id: I7f8fe8fa6c24b4229b0cb45e6c83e7cb2828e2da
Signed-off-by: Ed Warnicke <[email protected]>
9 years agoVPP-346 A swathe of doc fixes 87/2587/1
Chris Luke [Thu, 1 Sep 2016 18:31:46 +0000 (14:31 -0400)]
VPP-346 A swathe of doc fixes

Fixes various Doxygen warnings and other structural defects.

Note: This does not attempt to improve the content of the
documentation; only to improve the syntax and structure of it
and in some cases the consistency.

Change-Id: Ib1915f33edbdbc4558c85565de80dce323193906
Signed-off-by: Chris Luke <[email protected]>
9 years agoVPP-341: iOAM plugin documentation 69/2469/7
Shwetha [Thu, 1 Sep 2016 06:29:19 +0000 (07:29 +0100)]
VPP-341: iOAM plugin documentation

Change-Id: I0042ce8b8a70bb709765037c3636be667ad88aa2
Signed-off-by: Shwetha <[email protected]>
9 years agoFix for vl_client_get_first_plugin_msg_id:266: plugin 'export_eb694f98' not registered 60/2560/2
Shwetha [Wed, 31 Aug 2016 03:55:58 +0000 (04:55 +0100)]
Fix for vl_client_get_first_plugin_msg_id:266: plugin 'export_eb694f98' not registered

Change-Id: Iad6d8513e55a5f4609c7edb5505067d1136e84ea
Signed-off-by: Shwetha <[email protected]>
9 years agoVPP-369 Add an L2 output classification feature 58/2558/7
Dave Barach [Tue, 30 Aug 2016 21:01:52 +0000 (17:01 -0400)]
VPP-369 Add an L2 output classification feature

Change-Id: If03162d328c1ea179249e734537ebb01bade3331
Signed-off-by: Dave Barach <[email protected]>
9 years agoVPP-358: Add IPv6 ND Event Notification and Termination 24/2524/5
John Lo [Sat, 27 Aug 2016 05:11:57 +0000 (01:11 -0400)]
VPP-358: Add IPv6 ND Event Notification and Termination

Add IPv6 equivalent of IPv4 ARP event notification which covers address
resolution for L3 and MAC/IP binding in L2 BD and ARP termination in BD.
For IPv6, ICMP6 neighbor solicitation and advertisement packets are
utilized instead of ARP request and response packets for IPv4.

Change-Id: I0088fa173e4480de297c8053ea2fcd0821322815
Signed-off-by: John Lo <[email protected]>
9 years agoVPP-303 - Documentation changes for vnet/vnet/sr 78/2278/7
Keith Burns (alagalah) [Mon, 8 Aug 2016 22:56:50 +0000 (15:56 -0700)]
VPP-303 - Documentation changes for vnet/vnet/sr

Change-Id: If8b76959d7c29c216bf03609483a2c9e1d034f46
Signed-off-by: Keith Burns (alagalah) <[email protected]>
9 years agoVPP-210: Add "sh api status" 19/2119/3
Calvin [Thu, 28 Jul 2016 17:52:05 +0000 (13:52 -0400)]
VPP-210: Add "sh api status"

Change-Id: I164761bc2b242b6be527d057108dd09b99653ff5
Signed-off-by: Calvin <[email protected]>
9 years agoVPP-221 Loosen Doxygen CLI command struct parser 77/2577/1
Chris Luke [Wed, 31 Aug 2016 14:04:58 +0000 (10:04 -0400)]
VPP-221 Loosen Doxygen CLI command struct parser

Make the struct parser slighty slightly more accomodating of
whitespace in places it has no business being.

Also add missing OS_ID thing to Doxygen makefile.

Change-Id: Id3d198fd926f7a6c2ed40bc2d08907aad5d5ac33
Signed-off-by: Chris Luke <[email protected]>
9 years agoVPP-189 Tweak hash_foreach_pair to avoid static warning 44/2144/5
Chris Luke [Sat, 30 Jul 2016 19:05:07 +0000 (15:05 -0400)]
VPP-189 Tweak hash_foreach_pair to avoid static warning

Coverity doesn't like when an incrementing pointer is taken from
the address of a singleton; it cries that this is a potential
buffer overrun.

Since the cases of this in hash_foreach_pair are based on items
from a simple union used just to have different types point to
the same location it's a simple matter of using the pointer to
that location directly. Since we then aren't using the members
of the union, we can change that to an opaque pointer (void *).

This accounts for >60 issues in Coverity.

Whilst here, convert some useful existing comments into a docblock.

Change-Id: I114183ab7d7948d4a6a703451417f79fa37634eb
Signed-off-by: Chris Luke <[email protected]>
9 years agoVPP-221 CLI auto-documentation infrastructure 08/2408/6
Chris Luke [Mon, 25 Jul 2016 20:38:11 +0000 (16:38 -0400)]
VPP-221 CLI auto-documentation infrastructure

As a step before Doxygen, extract CLI-related struct initializers
from the code and parse that into a summary of the CLI commands
available with the provided help text, such as it is. At the moment
this only renders this into an indexed Markdown file that Doxygen
then picks up but later we can use this information to enrich the
existing VLIB_CLI_COMMAND macro documentor as well as provide
runtime documentation to VPP that is stored on disk outside the
binary image.

Additionally support a comment block immediately prior to
VLIB_CLI_COMMAND CLI command definitions in the form /*? ... ?*/
that can be used to include long-form documentation without having
it compiled into VPP.

Examples of documenting CLI commands can be found in
vlib/vlib/unix/cli.c which, whilst not perfect, should provide a
starting point. Screen captures of sample output can be seen at
https://chrisy.flirble.org/vpp/doxy-cli-example.png and
https://chrisy.flirble.org/vpp/doxy-cli-index.png .

Next, shift the Doxygen root makefile targets to their own Makefile.
The primary reason for this is that the siphon targets do dependency
tracking which means it needs to generate those dependencies whenever
make is run; that is pointless if we're not going to generate any
documentation. This includes the package dependencies since they since
they sometimes unnecessarily interfere with the code build in some cases
at the moment; later we will look to building a Python venv to host the
Python modules we use.

One final remark: In future we may consider deprecating .long_help
in the VLIB_CLI_COMMAND structure entirely but add perhaps .usage_help.
.short_help would be reserved for a summary of the command function
and .usage_help provide the syntax of that command. These changes would
provide great semantic value to the automaticly generated CLI
documentation. I could also see having .long_help replaced by a
mechanism that reads it from disk at runtime with a rudimentary
Markdown/Doxygen filter so that we can use the same text that is used in
the published documentation.

Change-Id: I80d6fe349b47dce649fa77d21ffec0ddb45c7bbf
Signed-off-by: Chris Luke <[email protected]>
9 years agoVPP-240: delete subinterface 14/2514/6
Pavel Kotucek [Fri, 26 Aug 2016 11:35:40 +0000 (13:35 +0200)]
VPP-240: delete subinterface

Added new CLI and API command to delete subinterface.

Change-Id: Ia92a8facc6ad84634bdec430093e6add02ee674e
Signed-off-by: Pavel Kotucek <[email protected]>
9 years agoFix for vppctl to suppress "load_one_plugin:63: Loaded plugin:" msgs 59/2559/1
Ed Warnicke [Wed, 31 Aug 2016 01:09:24 +0000 (18:09 -0700)]
Fix for vppctl to suppress "load_one_plugin:63: Loaded plugin:" msgs

Change-Id: I06fcb024036b48a6401d2865a2181b122cb32108
Signed-off-by: Ed Warnicke <[email protected]>
9 years agoVPP-365: Fix sending of bd_index in lisp_eid_table_add_del_map 49/2549/3
Filip Tehlar [Tue, 30 Aug 2016 13:05:18 +0000 (15:05 +0200)]
VPP-365: Fix sending of bd_index in lisp_eid_table_add_del_map

Change-Id: I1f8fd65fa33b0bc7ee07aa0eeb5f794a7ede9537
Signed-off-by: Filip Tehlar <[email protected]>
9 years agoVPP-364 Add vpp-api/python/build to gitignore 46/2546/3
Florin Coras [Tue, 30 Aug 2016 09:46:11 +0000 (11:46 +0200)]
VPP-364 Add vpp-api/python/build to gitignore

Change-Id: I16a594ad75c085b8d0b74cf2f472f88a655253c0
Signed-off-by: Florin Coras <[email protected]>
9 years agoVPP-361: Memory leak on delete of VXLAN over IPv6 tunnel 43/2543/2
John Lo [Tue, 30 Aug 2016 04:10:09 +0000 (00:10 -0400)]
VPP-361: Memory leak on delete of VXLAN over IPv6 tunnel

The key for VXLAN over IPv6 tunnel is allocated on create and should
be freed on delete.

Change-Id: I11bdd9465030fed57cc4bbd28dbccdf952633b34
Signed-off-by: John Lo <[email protected]>
9 years agoVPP-353: Fully support LISP negative mappings in API 25/2525/3
Filip Tehlar [Sat, 27 Aug 2016 06:40:26 +0000 (08:40 +0200)]
VPP-353: Fully support LISP negative mappings in API

Change-Id: I71943fb4ae2a2f71bcf1ad73512812edf96c06da
Signed-off-by: Filip Tehlar <[email protected]>
9 years agoVPP-360 Allow L2 classify to use dynamic graph arcs 39/2539/1
Dave Barach [Mon, 29 Aug 2016 20:31:47 +0000 (16:31 -0400)]
VPP-360 Allow L2 classify to use dynamic graph arcs

Simple change so we can program L2 classifier per-session next-indices
and per-table miss-next-indices using dynamically-created graph arcs.

Change-Id: I9d4a3c82b83e94557075d56a6842d7075ed58905
Signed-off-by: Dave Barach <[email protected]>
9 years agoVPP-310 Mapping algorithm compute wrong ea-bits 23/2523/2
Ole Troan [Thu, 25 Aug 2016 10:26:47 +0000 (12:26 +0200)]
VPP-310 Mapping algorithm compute wrong ea-bits

Mapping of IPv4 prefixes ended up writing past IPv6 prefix + EA bits
length.
(Added some unit testing code).

Change-Id: I59893b44eea5cebf00a23afc405832741f84cf4f
Signed-off-by: Ole Troan <[email protected]>
9 years agoVPP-307: Documentation for vnet/vnet/vxlan-gpe 06/2506/4
Keith Burns (alagalah) [Thu, 25 Aug 2016 18:21:39 +0000 (11:21 -0700)]
VPP-307: Documentation for vnet/vnet/vxlan-gpe

Change-Id: Iaab6f4b63ed0d986be1ac0636c692b46098ad54d
Signed-off-by: Keith Burns (alagalah) <[email protected]>
9 years agoVPP-357 Fix vni for LISP fwd entry removals 21/2521/1
Florin Coras [Thu, 25 Aug 2016 23:47:47 +0000 (19:47 -0400)]
VPP-357 Fix vni for LISP fwd entry removals

Change-Id: I5d20c1939f7a5a142bf696b34143f7ebca6afbcb
Signed-off-by: Florin Coras <[email protected]>
9 years agoVPP-356: Fix wrong byte order in LISP API 12/2512/2
Filip Tehlar [Fri, 26 Aug 2016 10:44:38 +0000 (12:44 +0200)]
VPP-356: Fix wrong byte order in LISP API

Change-Id: Ib2284025b8394a87f1d5765713adb7070b450cba
Signed-off-by: Filip Tehlar <[email protected]>
9 years agoVPP-305: Documentation for vnet/vnet/unix 08/2508/2
Keith Burns (alagalah) [Thu, 25 Aug 2016 20:37:37 +0000 (13:37 -0700)]
VPP-305: Documentation for vnet/vnet/unix

Change-Id: I3f1a225033ecebe0cedfc3466b552176461b76ab
Signed-off-by: Keith Burns (alagalah) <[email protected]>
9 years agoVPP-329: Add L2 support to lisp_eid_table_map_dump 79/2479/3
Filip Tehlar [Wed, 24 Aug 2016 12:11:07 +0000 (14:11 +0200)]
VPP-329: Add L2 support to lisp_eid_table_map_dump

Change-Id: Idfb115cd1f95394f4a4a569dc34c0488a1d58558
Signed-off-by: Filip Tehlar <[email protected]>
9 years agoVPP-271: Coding style cleanup vnet/vnet/snap 00/2500/2
Calvin Ference [Thu, 25 Aug 2016 14:04:09 +0000 (10:04 -0400)]
VPP-271: Coding style cleanup vnet/vnet/snap

Change-Id: I810082b5a4072b11ffd0bcc2917347562deb253a
Signed-off-by: Calvin Ference <[email protected]>
9 years agoSave rewrite length for post-rewrite rewind action 91/2491/3
Dave Barach [Wed, 24 Aug 2016 22:36:03 +0000 (18:36 -0400)]
Save rewrite length for post-rewrite rewind action

Change-Id: I5dd52714f8422c15bf78da19bcb63246f9d0103d
Signed-off-by: Dave Barach <[email protected]>
9 years agoFix vxlan-gpe next protocol value 28/2428/2
Yi Yang [Thu, 18 Aug 2016 06:06:52 +0000 (14:06 +0800)]
Fix vxlan-gpe next protocol value

vxlan4_gpe_rewrite and vxlan6_gpe_rewrite used the fixed value
VXLAN_GPE_PROTOCOL_IP4 for next protocol regardless of vxlan-gpe
port next protocol, this commit fixed it and used the value from
vxlan-gpe port.

Change-Id: I22ba25fbde1c0630960cbcfd196e14231fbf1af3
Signed-off-by: Yi Yang <[email protected]>
9 years agoAdding python-dev dependency to main Makefile. 93/2493/2
Ole Troan [Wed, 24 Aug 2016 19:10:46 +0000 (21:10 +0200)]
Adding python-dev dependency to main Makefile.

Change-Id: I9968015acfc2cc63f97dee25538a9b3e61fac5b6
Signed-off-by: Ole Troan <[email protected]>
9 years agoVPP-228 VPP-326: MAP: Adding additional API/CLI input parameter checks. 97/2497/3
Ole Troan [Wed, 24 Aug 2016 22:24:08 +0000 (00:24 +0200)]
VPP-228 VPP-326: MAP: Adding additional API/CLI input parameter checks.

Added checks for EA bits length + PSID length > 64.
Removed incorrect check in VAT that required all arguments as mandatory.

Change-Id: I33a138612d199d7c5ce59abe1a7d7ecede3522bc
Signed-off-by: Ole Troan <[email protected]>
9 years agoVPP-328: Add dump call for listing LISP VNIs 77/2477/3
Filip Tehlar [Wed, 24 Aug 2016 09:28:02 +0000 (11:28 +0200)]
VPP-328: Add dump call for listing LISP VNIs

Change-Id: I45c054ad638a0e918dddefa4468ff65452949970
Signed-off-by: Filip Tehlar <[email protected]>
9 years agoFix ip6-rewrite drops when no feature is configured 96/2496/2
AkshayaNadahalli [Thu, 25 Aug 2016 08:55:28 +0000 (10:55 +0200)]
Fix ip6-rewrite drops when no feature is configured

In ip6_rewrite_inline(), only in dual loop next0 and next1 are set to IP6_REWRITE_NEXT_DROP and never updated unless there is an o/p feature configured on it. So any packets processed under dual loop are dropped.
Single loop works fine as next0 is updated correctly.
Fix is to update next node from adjacency under dual packet loop processing.

Change-Id: I902fcc84ed307464d92499f9d37137af660b592c
Signed-off-by: AkshayaNadahalli <[email protected]>
9 years agoFix issues with vhost-user when dpdk vhost-user is disabled, fixes VPP-347, VPP-349 80/2480/2
Damjan Marion [Wed, 24 Aug 2016 12:32:39 +0000 (14:32 +0200)]
Fix issues with vhost-user when dpdk vhost-user is disabled, fixes VPP-347, VPP-349

Change-Id: I774bab98e43d55678a67a7708ca50edbbd4cbb06
Signed-off-by: Damjan Marion <[email protected]>
9 years agoVPP-345: pull in upstream checksum patch for ICMP packets 64/2464/3
Sean Chandler [Mon, 22 Aug 2016 20:32:22 +0000 (16:32 -0400)]
VPP-345: pull in upstream checksum patch for ICMP packets

http://www.dpdk.org/dev/patchwork/patch/15216/

Change-Id: I91b67f3e5c0abff52626e504e2707814ae0c3ed0
Signed-off-by: Sean Chandler <[email protected]>