vpp.git
7 years agonsim: fix multiple definitions of nsim_node 58/14958/2
Damjan Marion [Mon, 24 Sep 2018 19:02:13 +0000 (21:02 +0200)]
nsim: fix multiple definitions of nsim_node

Change-Id: Iedd79eeba35fb7385c03a177f8ac7d3ddfeb6a84
Signed-off-by: Damjan Marion <[email protected]>
7 years agosvm: march svm_fifo take 2 83/14883/3
Florin Coras [Wed, 19 Sep 2018 06:11:55 +0000 (23:11 -0700)]
svm: march svm_fifo take 2

Change-Id: Ifa4fceef7edbe43d444790a624957db0817064de
Signed-off-by: Florin Coras <[email protected]>
7 years agoavf: rename interface name 53/14953/1
Damjan Marion [Mon, 24 Sep 2018 18:30:32 +0000 (20:30 +0200)]
avf: rename interface name

Change-Id: I4a1dca92a69547f8b26e9aec7574332f39e43c37
Signed-off-by: Damjan Marion <[email protected]>
7 years agoARP: don't use RPC for requests initiated from the main thread 44/14944/2
Neale Ranns [Mon, 24 Sep 2018 08:34:11 +0000 (08:34 +0000)]
ARP: don't use RPC for requests initiated from the main thread

Change-Id: If833680149eb33db6adc836c5330f350042869f4
Signed-off-by: Neale Ranns <[email protected]>
7 years agoNetwork delay simulator plugin 37/14937/6
Dave Barach [Fri, 21 Sep 2018 17:10:28 +0000 (13:10 -0400)]
Network delay simulator plugin

Change-Id: I4a70c7df8f0cb368a4e1cb16f30eeef5c6058c79
Signed-off-by: Dave Barach <[email protected]>
7 years agoTrivial: Clean up some typos. 40/14940/6
Paul Vinciguerra [Sat, 22 Sep 2018 12:32:50 +0000 (05:32 -0700)]
Trivial: Clean up some typos.

Change-Id: I085615fde1f966490f30ed5d32017b8b088cfd59
Signed-off-by: Paul Vinciguerra <[email protected]>
7 years agoLB: fix flush flow table issue 61/14861/7
Hongjun Ni [Tue, 18 Sep 2018 15:25:02 +0000 (23:25 +0800)]
LB: fix flush flow table issue

Change-Id: Ib0a06ab71aed42eb5bb2ab2edf4844b2167e0610
Signed-off-by: Hongjun Ni <[email protected]>
7 years agovcl: remove vcl_event 39/14939/2
Florin Coras [Sat, 22 Sep 2018 00:55:04 +0000 (17:55 -0700)]
vcl: remove vcl_event

Change-Id: I0f805ae47f6e9465070a54d85f164bc74877af01
Signed-off-by: Florin Coras <[email protected]>
7 years agofix following error in debian jessie: 41/14941/1
Khers [Sat, 22 Sep 2018 14:23:06 +0000 (17:53 +0330)]
fix following error in debian jessie:
'‘for’ loop initial declarations are only allowed in C99 or C11 mode'

Change-Id: Id842382f884122555abaa936c56cdfd305f2a5f3
Signed-off-by: Khers <[email protected]>
7 years agovmxnet3: Add hardware link status handling 35/14935/3
Steven [Fri, 21 Sep 2018 14:55:07 +0000 (07:55 -0700)]
vmxnet3: Add hardware link status handling

Added an interrupt line for monitoring and notifying hardware link status
Displayed additional information for show hardware for vmxnet3 interface
Fixed possible garbage display on interface name for show vmxnet3

Change-Id: If457bfe7c216287fb3a4e2630f00434d595f387b
Signed-off-by: Steven <[email protected]>
7 years agoadd: nasm and ipsec-mb into vpp-ext-deps packaging 33/14933/4
Damjan Marion [Fri, 21 Sep 2018 10:27:45 +0000 (12:27 +0200)]
add: nasm and ipsec-mb into vpp-ext-deps packaging

Change-Id: Ie5d85af84ae0d8b15edf5962213ed1b1953bee2f
Signed-off-by: Damjan Marion <[email protected]>
7 years agoFixed japi/java/Makefile.am so the JAR for NSH plugin builds as well. 95/14895/2
Tibor Král [Wed, 19 Sep 2018 14:14:22 +0000 (16:14 +0200)]
Fixed japi/java/Makefile.am so the JAR for NSH plugin builds as well.

Change-Id: I15b3e51d6e0206f4a387eb2ce764914167149385
Signed-off-by: Tibor Král <[email protected]>
7 years agoNAT: Refactoring / Housekeeping (VPP-1415) 26/14926/2
Matus Fabian [Fri, 21 Sep 2018 06:18:41 +0000 (23:18 -0700)]
NAT: Refactoring / Housekeeping (VPP-1415)

Change-Id: Ia3ce24cc94f9b2fb331ad62a4181ddcd41bc78ca
Signed-off-by: Matus Fabian <[email protected]>
7 years agoAdd more CLI options to vpp_api_test for calling ip_add_del_route 24/14924/3
John Lo [Thu, 20 Sep 2018 20:07:00 +0000 (16:07 -0400)]
Add more CLI options to vpp_api_test for calling ip_add_del_route

Change-Id: I114e93b6bc71cfcdcfe6d3ddde26f77118e36ab8
Signed-off-by: John Lo <[email protected]>
7 years agotcp: accept fin-ack in syn-rcvd state 25/14925/2
Florin Coras [Fri, 21 Sep 2018 01:36:54 +0000 (18:36 -0700)]
tcp: accept fin-ack in syn-rcvd state

Change-Id: Ibe57abc7d2a06be80146ce28edf4c60ecda991eb
Signed-off-by: Florin Coras <[email protected]>
7 years agovhost: show vhost may display garbage after the interface name 20/14920/2
Steven [Thu, 20 Sep 2018 18:50:35 +0000 (11:50 -0700)]
vhost: show vhost may display garbage after the interface name

DBGvpp# show vhost-user
Virtio vhost-user interfaces
Global:
  coalesce frames 32 time 1e-3
  number of rx virtqueues in interrupt mode: 0
Interface: VirtualEthernet0/0/0�?x�D (ifindex 3)

The fix is to use format_vnet_hw_if_index_name rather than hi->name. The former
format the name with %v rather than %s

Change-Id: If4d275e1eb249cf87b2d6b796b42f24769f9e3e3
Signed-off-by: Steven <[email protected]>
7 years agobihash template: avoid memory leak upon rehash 14/14914/4
Andrew Yourtchenko [Thu, 20 Sep 2018 13:36:51 +0000 (15:36 +0200)]
bihash template: avoid memory leak upon rehash

Call the BV (value_free) when we have performed the rehash
and thus no longer need the memory that old value for the
bucket refers to.

Change-Id: Ibb82174fc8002aeb3e1a6c8d1f90293d73bc45d8
Signed-off-by: Andrew Yourtchenko <[email protected]>
7 years agorename vpp-dpdk-dev to vpp-ext-deps 78/14878/4
Damjan Marion [Tue, 18 Sep 2018 16:41:38 +0000 (18:41 +0200)]
rename vpp-dpdk-dev to vpp-ext-deps

We need to have new tenants in the development package.
This is first of series of patches which will allow us to have multiple
external libs and tools packaged for developer's convenience.

Change-Id: I884bd75fba96005bbf8cea92774682b2228e0e22
Signed-off-by: Damjan Marion <[email protected]>
7 years agoUDP-Encap: name counters for the stats segment 34/14734/6
Neale Ranns [Fri, 7 Sep 2018 15:57:41 +0000 (08:57 -0700)]
UDP-Encap: name counters for the stats segment

change the ADD api so that is returns the 'ID' that can be used
by the client to read the stats from the stats segment and to
delete the object. Previously a similar value used required
to be chosen by the client, now VPP allocates one (like it
does e.g. for interfaces)

Change-Id: I563cf6092276eb990c52d5457c86e72546bcf69e
Signed-off-by: Neale Ranns <[email protected]>
7 years agoSR-MPLS: MPLS table checks (VPP-1422) 10/14910/2
Neale Ranns [Thu, 20 Sep 2018 09:49:25 +0000 (02:49 -0700)]
SR-MPLS: MPLS table checks (VPP-1422)

Change-Id: I397715ea8c1966f5ee61128f284d62d875c568e1
Signed-off-by: Neale Ranns <[email protected]>
7 years agosession/svm: add want_tx_event flag to fifo 01/14901/4
Florin Coras [Tue, 18 Sep 2018 05:09:02 +0000 (22:09 -0700)]
session/svm: add want_tx_event flag to fifo

Have applications use explicit flag to request events from vpp when it
transmits from a full fifo.

Change-Id: I687c8f050a066bd5ce739d880eaec1f286038d95
Signed-off-by: Florin Coras <[email protected]>
7 years agoRoute counters in the stats segment 97/14897/3
Neale Ranns [Fri, 7 Sep 2018 16:32:36 +0000 (09:32 -0700)]
Route counters in the stats segment

route ADD API changed to return the stats segment index to use to read the counters

Change-Id: I2ef41e01eaa2f9cfaa49d9c88968897793825925
Signed-off-by: Neale Ranns <[email protected]>
7 years agovhost-user: Add disable feature support in api 31/14431/6
Mohsin Kazmi [Tue, 21 Aug 2018 14:07:03 +0000 (16:07 +0200)]
vhost-user: Add disable feature support in api

Two flags to disable mergable rx buffers and indirect
descriptors are added to api.

Change-Id: Iba0ee9c48d19dfc3d3420a3fdaf44a1a1d325e99
Signed-off-by: Mohsin Kazmi <[email protected]>
7 years agoNAT44 virtual fragmentation reassembly for endpoint-dependent mode (VPP-1325) 05/13705/13
Juraj Sloboda [Mon, 23 Jul 2018 10:22:54 +0000 (12:22 +0200)]
NAT44 virtual fragmentation reassembly for endpoint-dependent mode (VPP-1325)

Change-Id: I36ece2ef2eaef9fa559d69ec7f7f07e7c16a7a9d
Signed-off-by: Juraj Sloboda <[email protected]>
7 years agovmxnet3: invoke vlib_buffer_enqueue_to_next() with the wrong buffers for chain buffers 00/14900/2
Steven [Wed, 19 Sep 2018 22:30:25 +0000 (15:30 -0700)]
vmxnet3: invoke vlib_buffer_enqueue_to_next() with the wrong buffers for chain buffers

If we invoke the subject API with 2 buffers, each with 2 chains, the content of
buffers[0] should be head of 1st buffer, and content of buffer[1] should be
head of 2nd buffer.

What the code did was to put
buffers[0] = head of 1st buffer
buffers[1] = next chain of 1st buffer
buffers[2] = head of 2nd buffer
buffers[3] = next chain of 2nd buffer

This is wrong and can cause crash.

The fix is to only increment bi when the entire packet is found which may consist
of multiple fragments.

Change-Id: If02cd5186a039d7a6c08a0959112840bdb242317
Signed-off-by: Steven <[email protected]>
7 years agoVPP-1421: Reworked results gathering 93/14893/6
juraj.linkes [Wed, 19 Sep 2018 13:01:47 +0000 (15:01 +0200)]
VPP-1421: Reworked results gathering

The previous version sent the whole VPPTestResult object through pipe,
which uses pickle to transfer objects. Pickle does not support sending
any arbitrary objects and was causing issues. Now just a tuple of
(test_id, result) is sent.

Change-Id: I3a3a9e6f1b9ac9b05889babfc1f7560c7ac4471c
Signed-off-by: juraj.linkes <[email protected]>
7 years agobihash template: reinstate the check for the available memory in the arena 94/14894/2
Andrew Yourtchenko [Wed, 19 Sep 2018 13:50:55 +0000 (15:50 +0200)]
bihash template: reinstate the check for the available memory in the arena

ffb14b9554afa1e58c3657e0c91dda3135008274 has changed the semantics
of alloc_arena_next to become an offset off alloc_arena, but
in the available memory check in BV (alloc_aligned) it still treats
it as a virtual address, resulting in the check always succeeding,
thus over a prolonged period bihash arena allocator
potentially overwriting whatever is following the arena.

Change-Id: I18882c5f340ca767a389e15cca2696a0a97ef015
Signed-off-by: Andrew Yourtchenko <[email protected]>
7 years agoGRE: fix 4o6 and 6o4 adj stacking 91/14891/2
Neale Ranns [Wed, 19 Sep 2018 11:55:32 +0000 (04:55 -0700)]
GRE: fix 4o6 and 6o4 adj stacking

Change-Id: I13dc5eab8835c4f3b95906816d42dccfeee8b092
Signed-off-by: Neale Ranns <[email protected]>
7 years agodpdk: mask and warn if rx/tx offload is not available 88/14888/2
Damjan Marion [Wed, 19 Sep 2018 08:39:43 +0000 (10:39 +0200)]
dpdk: mask and warn if rx/tx offload is not available

Warning messsage is displayed in system log:
vpp# show log
1970/ 1/ 1 01:00:01:198 warn       dpdk       unsupported rx offloads requested on port 0: scatter

Change-Id: I40021066daf2d37ca5233e3adce55e412f0d3932
Signed-off-by: Damjan Marion <[email protected]>
7 years agoL2-fib-dump: send 1 or 0 rather than flag value 89/14889/2
Neale Ranns [Wed, 19 Sep 2018 11:07:02 +0000 (04:07 -0700)]
L2-fib-dump: send 1 or 0 rather than flag value

Change-Id: I487b3b480347f60ffe3af4029adfb22b6700cea7
Signed-off-by: Neale Ranns <[email protected]>
7 years agosocket api: do not delay sending of messages 23/13923/7
Florin Coras [Thu, 2 Aug 2018 19:16:03 +0000 (12:16 -0700)]
socket api: do not delay sending of messages

Instead of relying on main epoll loop to send messages, try to send as
soon as possible.

Change-Id: I27c0b4076f3599ad6e968df4746881a6717d4299
Signed-off-by: Florin Coras <[email protected]>
7 years agonat: free port_bitmap 60/14760/5
dongjuan [Tue, 11 Sep 2018 11:20:30 +0000 (11:20 +0000)]
nat: free port_bitmap

Change-Id: Ied0fc50f1afb0f7fc563784544699726a6d03380
Signed-off-by: dongjuan <[email protected]>
7 years agosession: improve close procedure 81/14881/2
Florin Coras [Tue, 18 Sep 2018 23:12:50 +0000 (16:12 -0700)]
session: improve close procedure

Change-Id: I6201a044e70ab6a58db8212960c57edc77c41f96
Signed-off-by: Florin Coras <[email protected]>
7 years agoFix documentation for SHG in bridge domain 80/14880/1
Yichen Wang [Wed, 19 Sep 2018 00:32:29 +0000 (17:32 -0700)]
Fix documentation for SHG in bridge domain

Change-Id: If094971cf011d09fa0daf3ff393f490e584c1151
Signed-off-by: Yichen Wang <[email protected]>
7 years agovmxnet3: add support for "non-default" next node 79/14879/2
Steven [Tue, 18 Sep 2018 19:34:59 +0000 (12:34 -0700)]
vmxnet3: add support for "non-default" next node

Support feature arc
Support set interface next node
Enqueue packet to either ip4, ip6, or ethernet_input based on packet type

Change-Id: I11fb6bba98ee0bfa1d057474fc6cf3be48ef1c48
Signed-off-by: Steven <[email protected]>
7 years agodocs: Added Related Projects and Archive 56/14856/2
jdenisco [Mon, 17 Sep 2018 19:39:09 +0000 (15:39 -0400)]
docs: Added Related Projects and Archive

Change-Id: I9a6076aa53d810ec44761d9f9459eb91f2c05974
Signed-off-by: jdenisco <[email protected]>
7 years agofix TEST_JOBS=auto max jobs detection 74/14874/2
Klement Sekera [Tue, 18 Sep 2018 12:32:27 +0000 (14:32 +0200)]
fix TEST_JOBS=auto max jobs detection

Change-Id: I63f747e92d239e878550392df24fb7aac2b5a3e3
Signed-off-by: Klement Sekera <[email protected]>
7 years agodisable scatter/gather for ENA with DPDK 18.08 77/14877/1
Matthew Smith [Tue, 18 Sep 2018 15:52:58 +0000 (10:52 -0500)]
disable scatter/gather for ENA with DPDK 18.08

The scatter/gather rxmode flag was set for ENA when building
against DPDK >= 18.08. ENA does not support this, so disable
it. It looks like enabling it was a copy/paste error.

Also, after offloads are adjusted based on whether "no-multi-seg"
is set, those configurations are overwritten by copying
port_conf_template over the port config. That should only happen
for versions of DPDK older than 18.08 because 18.08 and newer
make changes directly on the port config instead of making changes
to the template. Make the clib_memcpy() conditional on the DPDK
version being less than 18.08. After doing so, compiler
errors complain about port_conf_template being declared but not
used, so make it's declaration conditional.

Change-Id: If81980d71c379a565b51dd700b953f8c811a8703
Signed-off-by: Matthew Smith <[email protected]>
7 years agoSTATS: First go at documentation 68/14868/2
Ole Troan [Tue, 18 Sep 2018 10:46:14 +0000 (12:46 +0200)]
STATS: First go at documentation

Change-Id: I4d586456c46994b60ff7670d1411997a3615a284
Signed-off-by: Ole Troan <[email protected]>
7 years agosvm: better march support for svm fifo 07/13307/13
Florin Coras [Fri, 29 Jun 2018 15:44:31 +0000 (08:44 -0700)]
svm: better march support for svm fifo

Change-Id: I6a4335654882a2ca66d3d465e35e350868242b8d
Signed-off-by: Florin Coras <[email protected]>
7 years agoSTATS: Optimistic concurrency handling in Python library. 66/14866/1
Ole Troan [Tue, 18 Sep 2018 09:06:33 +0000 (11:06 +0200)]
STATS: Optimistic concurrency handling in Python library.

Change-Id: I2135f3e77206fd171636a1e0b07c373c0bf093e4
Signed-off-by: Ole Troan <[email protected]>
7 years agoSTATS: Add Python 3 support to vpp_stats.py. 65/14865/1
Ole Troan [Tue, 18 Sep 2018 08:23:01 +0000 (10:23 +0200)]
STATS: Add Python 3 support to vpp_stats.py.

Change-Id: Iad0b0315fbd493b67e6ca490206ec8e8422790ea
Signed-off-by: Ole Troan <[email protected]>
7 years agoSTATS: Dynamically mapped shared memory segment 71/14671/10
Ole Troan [Tue, 4 Sep 2018 11:19:12 +0000 (13:19 +0200)]
STATS: Dynamically mapped shared memory segment

Move from using a hash to a vector with offsets into shared memory.
Limit exposure of VPP data structures and include files to
external stats library and applications.

Change-Id: Ic06129f12d10cf4c4946a86d9bc734eacff2c7da
Signed-off-by: Ole Troan <[email protected]>
7 years agoRegister cdp_input when enabled for the first time 42/14842/2
Dave Barach [Sun, 16 Sep 2018 15:03:04 +0000 (11:03 -0400)]
Register cdp_input when enabled for the first time

Graceful handling of unknown tlv types

Change-Id: Idbc9ed524fc8b865c8e12571813cc73548bde480
Signed-off-by: Dave Barach <[email protected]>
7 years agovmxnet3: fix clang initialization error 44/14844/1
Florin Coras [Sun, 16 Sep 2018 21:49:36 +0000 (14:49 -0700)]
vmxnet3: fix clang initialization error

Change-Id: I2958bd3bdec98d3e380a8ff8f970563020e28afd
Signed-off-by: Florin Coras <[email protected]>
7 years agofix nsh map index error, it will cause vpp appear Segmentation fault when vpp process... 34/14834/2
zhanglimao [Sat, 15 Sep 2018 05:19:41 +0000 (13:19 +0800)]
fix nsh map index error, it will cause vpp appear Segmentation fault when vpp process double packages

Change-Id: Ib32bb351356b84aaf696c57398610b52a5a1f4dd
Signed-off-by: zhanglimao <[email protected]>
7 years agotls: fix openssl engine write complete condition 33/14833/2
Florin Coras [Sat, 15 Sep 2018 00:56:29 +0000 (17:56 -0700)]
tls: fix openssl engine write complete condition

Change-Id: Ic1526f6916970ce2b0c4fc0d148d4396fa629b5f
Signed-off-by: Florin Coras <[email protected]>
7 years agosession: ensure detach is done with worker barrier 28/14828/3
Florin Coras [Fri, 14 Sep 2018 20:17:41 +0000 (13:17 -0700)]
session: ensure detach is done with worker barrier

Change-Id: I98a79f2c3b0268c414dd295c7ebfc561ce049d4b
Signed-off-by: Florin Coras <[email protected]>
7 years agotls: use application interface apis 32/14832/4
Florin Coras [Fri, 14 Sep 2018 21:46:39 +0000 (14:46 -0700)]
tls: use application interface apis

This also exposes app to tls sessions. As a result "sh session verbose"
will show for each tls session both the application's session (app to
tls) and the tls session (tls to tcp).

Change-Id: I1e65c63362ce58f314e762d7db78b44479e1e3a5
Signed-off-by: Florin Coras <[email protected]>
7 years agovmxnet3 device driver 77/11377/22
Steven Luong [Sun, 18 Mar 2018 15:01:27 +0000 (08:01 -0700)]
vmxnet3 device driver

Implemented vmxnet3 deivice driver for VMWare ESXi. Tested with Ubuntu 18.04
connected to ESXi 6.0

Ubuntu-18.04 (VPP) --- ESXi-6.0

Change-Id: I85fbc86f2d8532b017bc4271612d17e24e498e4d
Signed-off-by: Steven Luong <[email protected]>
7 years agoBIER API and load-balancing fixes 01/14801/2
Neale Ranns [Thu, 13 Sep 2018 15:45:12 +0000 (08:45 -0700)]
BIER API and load-balancing fixes

Change-Id: Ibda19d786070c942c75016ab568c8361de2f24af
Signed-off-by: Neale Ranns <[email protected]>
7 years agoRemove scaffolding 26/14826/2
Dave Barach [Fri, 14 Sep 2018 13:27:42 +0000 (09:27 -0400)]
Remove scaffolding

Change-Id: I4acebbf76556428bb45356c8e5b85c72a85a1656
Signed-off-by: Dave Barach <[email protected]>
7 years agocpack: add deb/rpm packaging to VPP module 04/14804/4
Damjan Marion [Thu, 13 Sep 2018 18:02:12 +0000 (20:02 +0200)]
cpack: add deb/rpm packaging to VPP module

This allows easy packaging of external projects, including
VOM and sample plugin.

i.e.

$ make -C build-root PLATFORM=vpp TAG=vpp sample-plugin-install

$ ninja -C build-root/build-vpp-native/sample-plugin package

ninja: Entering directory `build-root/build-vpp-native/sample-plugin'
[0/1] Run CPack packaging tool...
CPack: Create package using DEB
CPack: Install projects
CPack: - Install project: sample-plugin
CPack: -   Install component: vpp-plugin-sample
CPack: -   Install component: vpp-plugin-sample-dev
CPack: Create package
CPack: - package: build-root/build-vpp-native/sample-plugin/vpp-plugin-sample_18.10~rc0~413~g1433e9d1-1_amd64.deb generated.
CPack: - package: build-root/build-vpp-native/sample-plugin/vpp-plugin-sample-dev_18.10~rc0~413~g1433e9d1-1_amd64.deb generated.

Change-Id: I6b3ec2433961e53edd976b19659ce214d272c40a
Signed-off-by: Damjan Marion <[email protected]>
7 years agodpdk: add detection of mellanox PMDs 22/14822/4
Damjan Marion [Fri, 14 Sep 2018 09:35:14 +0000 (11:35 +0200)]
dpdk: add detection of mellanox PMDs

Change-Id: I523fc489f5e73ba726ab0711eab3fdde53dc35e8
Signed-off-by: Damjan Marion <[email protected]>
7 years agovlib: introduce user flags in vlib_frame_t 24/14824/2
Damjan Marion [Fri, 14 Sep 2018 12:38:53 +0000 (14:38 +0200)]
vlib: introduce user flags in vlib_frame_t

Those flags have local significance and they can be used for
sending hints to the next node.

Change-Id: Ic2596ee81c64cd16f96344365370e8fcdc465354
Signed-off-by: Damjan Marion <[email protected]>
7 years agoacl-plugin: do not do clib_smp_atomic_add on per-worker counters 95/14795/4
Andrew Yourtchenko [Thu, 13 Sep 2018 09:13:13 +0000 (11:13 +0200)]
acl-plugin: do not do clib_smp_atomic_add on per-worker counters

Just do a regular increment, since we are not contending for these counters.
This also makes the tests pass on ARM ThunderX (VPP-1395).

Change-Id: I333aaa11d4145d13d322868900bc114df85a020d
Signed-off-by: Andrew Yourtchenko <[email protected]>
7 years agoRevert "L2-input: use vlib_buffer_enqueue_to_next" 17/14817/2
John Lo [Thu, 13 Sep 2018 22:10:25 +0000 (22:10 +0000)]
Revert "L2-input: use vlib_buffer_enqueue_to_next"

The patch did not improve single input link performance and
degrade performance with multiple input links.

This reverts commit b1232555e91b286feab5667b5a22f29aa8e96626.

Change-Id: Ib9336a2e0610088b9145a43cacbdadb52dabd522
Signed-off-by: John Lo <[email protected]>
7 years agoEhnance and fix vpp_api_test and custom_dump to support SR-MPLS 05/14805/2
John Lo [Thu, 13 Sep 2018 18:08:59 +0000 (14:08 -0400)]
Ehnance and fix vpp_api_test and custom_dump to support SR-MPLS

Change-Id: I2e06de176f4272b4b7475857b42fe0d106382b6f
Signed-off-by: John Lo <[email protected]>
7 years agovcl: keep track of unexpected events 93/14793/7
Florin Coras [Wed, 12 Sep 2018 23:08:01 +0000 (16:08 -0700)]
vcl: keep track of unexpected events

If sessions are marked as blocking, events for other sessions received
while waiting for the blocking sessions, are added to a pending list and
processed later.

Change-Id: Ia6c71006b1c2bcb78af708390da0cd436af397cc
Signed-off-by: Florin Coras <[email protected]>
7 years agocmake: use VPP package in VOM 02/14802/2
Damjan Marion [Thu, 13 Sep 2018 16:43:19 +0000 (18:43 +0200)]
cmake: use VPP package in VOM

Change-Id: I83b244be920521e580085beffb7e40613e67c8ee
Signed-off-by: Damjan Marion <[email protected]>
7 years agoFix memory leak in API/CLI to create/modify SR policies 06/14806/2
John Lo [Thu, 13 Sep 2018 19:08:08 +0000 (15:08 -0400)]
Fix memory leak in API/CLI to create/modify SR policies

The segment list vector built by the API/CLI is not freed after
SR policy creation or modification.

Change-Id: If439005481cada6c6af7cb560fe7a4381dd49384
Signed-off-by: John Lo <[email protected]>
7 years agoAdd a polling configure to make thread bind with hardware engine 00/14800/2
Ping Yu [Thu, 13 Sep 2018 22:41:33 +0000 (18:41 -0400)]
Add a polling configure to make thread bind with hardware engine

Change-Id: Ib4130098dd9bf45370bdee9a04e4804074df58b1
Signed-off-by: Ping Yu <[email protected]>
7 years agoL2-FWD: use vlib_buffer_enqueue_to_next and cache prefetch fix 75/14775/5
Neale Ranns [Wed, 12 Sep 2018 10:53:03 +0000 (06:53 -0400)]
L2-FWD: use vlib_buffer_enqueue_to_next and cache prefetch fix

before:
  l2-fwd ...  1.72e1  256.00
after:
  l2-fwd ...  1.49e1  256.00

Change-Id: I24b29b799435776abc6e60df0dd0301b74aac99b
Signed-off-by: Neale Ranns <[email protected]>
7 years agovppinfra: optmize clib_count_equal functions 92/14792/5
Damjan Marion [Wed, 12 Sep 2018 20:37:30 +0000 (22:37 +0200)]
vppinfra: optmize clib_count_equal functions

Change-Id: Ia4c79d560bfa1118d4683a89a1209a08c5f546b3
Signed-off-by: Damjan Marion <[email protected]>
7 years agoNAT: TCP MSS clamping 97/14797/1
Matus Fabian [Thu, 13 Sep 2018 09:36:25 +0000 (02:36 -0700)]
NAT: TCP MSS clamping

NAT plugin changes the MSS value in TCP SYN packets to avoid fragmentation.
If the negotiated MSS value is greater than the configured value it is changed
to the configured value. If the negotiated MSS value is smaller than the
configured value it remains unchanged.

Change-Id: Ic3c4f94a2f1b76e2bf79f50f3ad36a4097f3f188
Signed-off-by: Matus Fabian <[email protected]>
7 years agoTrivial: Fix lisp flag label 94/14794/1
Paul Vinciguerra [Thu, 13 Sep 2018 01:02:21 +0000 (18:02 -0700)]
Trivial: Fix lisp flag label

Change-Id: Ic5339169124edc8ea1f82ffcba7cde8b7f224e83
Signed-off-by: Paul Vinciguerra <[email protected]>
7 years agoIP-neighbor: add and delete internal API 76/14776/4
Neale Ranns [Fri, 7 Sep 2018 18:04:52 +0000 (11:04 -0700)]
IP-neighbor: add and delete internal API

Change-Id: I4d1ab5ff0c8f0756e91bf63e045f88513bb7d039
Signed-off-by: Neale Ranns <[email protected]>
7 years agoFix: vppapigen make build fails on fresh install 91/14791/5
Paul Vinciguerra [Wed, 12 Sep 2018 20:40:13 +0000 (13:40 -0700)]
Fix: vppapigen make build fails on fresh install

Steps to reproduce:
  vagrant@localhost:/vagrant$ build-root/vagrant/build.sh
  ...
  @@@@ Building vpp in /vagrant/build-root/build-vpp-native/vpp @@@@
  [51/1169] Generating API header /vagrant/build-root/build-vpp-native/vpp/vlibmemory/memclnt.api.json
  FAILED: cd /vagrant/build-root/build-vpp-native/vpp/vlibmemory && mkdir -p /vagrant/build-root/build-vpp-native/vpp/vlibmemory && /vagrant/src/tools/vppapigen/vppapigen --includedir /vagrant/src --input /vagrant/src/vlibmemory/memclnt.api JSON --output /vagrant/build-root/build-vpp-native/vpp/vlibmemory/memclnt.api.json
  AttributeError: 'module' object has no attribute 'dumps'

  This seems to be due to JSON.py namespace colliding with the standard lib json.py

Change-Id: If389e4e05ef0c166b0c2b3bef7ec0185298679a8
Signed-off-by: Paul Vinciguerra <[email protected]>
7 years agoL2-input: use vlib_buffer_enqueue_to_next 83/14783/2
Neale Ranns [Wed, 12 Sep 2018 13:42:50 +0000 (09:42 -0400)]
L2-input: use vlib_buffer_enqueue_to_next

use the same trick as l2-ouput to group the processing of packets
on the same interface.

Change-Id: Ib2a6a1b5f362372936197f5bb2fdd0fe9439226b
Signed-off-by: Neale Ranns <[email protected]>
7 years agofix bihash test code 89/14789/2
Dave Barach [Wed, 12 Sep 2018 16:08:13 +0000 (12:08 -0400)]
fix bihash test code

Change-Id: Ie71b99385c33122cbf55f80ebabdc2ccdb4cf2ae
Signed-off-by: Dave Barach <[email protected]>
7 years agocmake: create cmake VPP module, update sample-plugin so it uses it 73/14773/4
Damjan Marion [Wed, 12 Sep 2018 10:12:36 +0000 (12:12 +0200)]
cmake: create cmake VPP module, update sample-plugin so it uses it

Change-Id: I32e91ba8e55797ffe169f98b09bdb42caa5c7de2
Signed-off-by: Damjan Marion <[email protected]>
7 years agoAlways use 'lib' instead of 'lib64' 80/14780/3
Damjan Marion [Wed, 12 Sep 2018 12:01:10 +0000 (14:01 +0200)]
Always use 'lib' instead of 'lib64'

It is packaging responsibility to put libs in the right place.
Use of lib64 resulted in huge amount of files with hardcoded lib64.
This patch simplifies things...

Change-Id: Iab0dea0583e480907732c5d2379eb951a00fa9e6
Signed-off-by: Damjan Marion <[email protected]>
7 years agoFix LB memory leak and remove useless code 77/14777/2
Pierre Pfister [Wed, 12 Sep 2018 12:08:53 +0000 (14:08 +0200)]
Fix LB memory leak and remove useless code

Vector sort_arr was actually never freed.

This change also removes some nearby code which
happens to be totally useless.

Change-Id: I2f265c1b4770cbcd75a2fb69ea54e46e1b54245a
Signed-off-by: Pierre Pfister <[email protected]>
7 years agofix missing extern in vnet/ethernet/node.c 74/14774/3
Damjan Marion [Wed, 12 Sep 2018 11:32:01 +0000 (13:32 +0200)]
fix missing extern in vnet/ethernet/node.c

Change-Id: Idabdd1112ba7e390a7b14a83cc7fbd198c8754df
Signed-off-by: Damjan Marion <[email protected]>
7 years agoL2-Learn: use vlib_buffer_enqueue_to_next 78/14778/2
Neale Ranns [Wed, 12 Sep 2018 11:37:43 +0000 (07:37 -0400)]
L2-Learn: use vlib_buffer_enqueue_to_next

before:
  l2-learn ... 2.00e1 256.00
after:
  l2-learn ... 1.77e1 256.00

Change-Id: I22fe9ab4ec995ee22c547cfe16bf88c04838520c
Signed-off-by: Neale Ranns <[email protected]>
7 years agovhost: Fix VPP crash when reloading VM with mixed-type ports [VPP-1406] 45/14545/6
Yichen Wang [Wed, 29 Aug 2018 06:05:27 +0000 (23:05 -0700)]
vhost: Fix VPP crash when reloading VM with mixed-type ports [VPP-1406]

When VM is having mixed type of vhost-user and SRIOV ports, QEMU (RedHat
v2.10) will not send disconnect signal to VPP, and just gives the new
memory region directly. VPP is not able to handle new memory region
mapping without disconnect signal first, which will result in a SEGV.
The fix will handle the VM reboot scenario without explict disconnect
signal from QEMU.

The fix is to invalidate the avail, desc, and used pointers in the txvq
when the new memory regions are received. This is because these pointers
are not valid anymore with the new memory regions. In the input node, check
to make sure the avail pointer is valid and punt if not.

Change-Id: Ieb8b427b202f4442a58907dab1661d63a03650de
Signed-off-by: Yichen Wang <[email protected]>
7 years agoVXLAN-GBP: use common types on the API 63/14763/3
Neale Ranns [Tue, 11 Sep 2018 14:39:43 +0000 (07:39 -0700)]
VXLAN-GBP: use common types on the API

Change-Id: I11ec0d7048d36c30a97d437e5b0abd05f06ab0eb
Signed-off-by: Neale Ranns <[email protected]>
7 years agodevice flags will set in dpdk_update_link_state. 47/14647/8
Khers [Tue, 4 Sep 2018 12:00:37 +0000 (16:30 +0430)]
device flags will set in dpdk_update_link_state.

Change-Id: If74acb0168bed2201d2a8b47bf3f860540d1574b
Signed-off-by: Khers <[email protected]>
7 years agoAdd patch for ixgbe x550 SFP+ to DPDK 18.08 66/14766/2
Matthew Smith [Tue, 11 Sep 2018 18:50:48 +0000 (13:50 -0500)]
Add patch for ixgbe x550 SFP+ to DPDK 18.08

Patch for ixgbe which has been used with DPDK 18.02, 18.05.
If the link flaps before link status has been successfully
collected, the MAC will be reset and the PMD will not wait
long enough for it to come back up before giving up, which
will continue happening every time an attempt is made to
check the link status.

This patch was submitted to upstream DPDK in July 2018 but
it has not been included in a release yet.

Change-Id: Ib2100b33d2a986f3cf74e42fc5538412f76f42c7
Signed-off-by: Matthew Smith <[email protected]>
7 years agoAdd and enable u32x4_extend_to_u64x2_high for aarch64 NEON intrinsics. 06/14606/7
Sirshak Das [Wed, 22 Aug 2018 00:46:52 +0000 (08:46 +0800)]
Add and enable u32x4_extend_to_u64x2_high for aarch64 NEON intrinsics.

This is the high version of extendto. This function accomplishes the
same task as both shuffling and extending done by SSE intrinsics.
This enables the NEON version for buffer indexes to buffer pointer
translation.

Change-Id: I52d7bbf3d76ba69c9acb0e518ff4bc6abf3bbbd4
Signed-off-by: Sirshak Das <[email protected]>
Reviewed-by: Steve Capper <[email protected]>
Reviewed-by: Yi He <[email protected]>
Verified-by: Lijian Zhang <[email protected]>
7 years agoFix create memif socket 24/13824/2
Ed Warnicke [Mon, 30 Jul 2018 20:48:32 +0000 (15:48 -0500)]
Fix create memif socket

create interface memif [id <id>] [socket-id <socket-id>] ...

Can optionally take a socket-id.

You create a socket-id with:

create memif socket [id <id>] [filename <path>]

Unfortunately, this doesn't work because "create memif" was
deprecated.  It results in:

vpp# create memif socket id 0 filename /run/vpp/test.socket
command deprecated. Please use 'create interface memif' instead.

This fixes it by clipping out the

create memif

command entirely.

Change-Id: If503758706bf758b6cb46e958200527a5856c600
Signed-off-by: Ed Warnicke <[email protected]>
7 years agovcl: add apis that expos fifo as buffer 68/14768/3
Florin Coras [Tue, 11 Sep 2018 23:33:36 +0000 (16:33 -0700)]
vcl: add apis that expos fifo as buffer

Change-Id: I4bd9c9f73499711e04b38d53daa5c917a4285bf5
Signed-off-by: Florin Coras <[email protected]>
7 years agovcl: improve read and fifo event handling 64/14764/9
Florin Coras [Tue, 11 Sep 2018 07:10:41 +0000 (00:10 -0700)]
vcl: improve read and fifo event handling

Change-Id: Ic1c51818b8aa8dbd164e70bb3b7471868e5af6f6
Signed-off-by: Florin Coras <[email protected]>
7 years agobihash 32/64 bit shared memory interop 67/14767/1
Dave Barach [Tue, 11 Sep 2018 21:20:23 +0000 (17:20 -0400)]
bihash 32/64 bit shared memory interop

This patch makes 32/64 bit interoperable shared memory bihash tables
work regardless of where they're mapped.

Change-Id: If5b4a37ccdaa75410eba755c7d7195633de1b30b
Signed-off-by: Dave Barach <[email protected]>
7 years agoindent off in ip_lookup_set_buffer_fib_index 62/14762/2
Neale Ranns [Tue, 11 Sep 2018 12:55:50 +0000 (05:55 -0700)]
indent off in ip_lookup_set_buffer_fib_index

when the name of the structure crosses a line boundary it's painful to parse...

Change-Id: I5d0606900802fb8d64a065f31f3e2a53bd8a5f40
Signed-off-by: Neale Ranns <[email protected]>
7 years agoL2-learn; cache prefetch fix 40/14740/4
Neale Ranns [Sun, 9 Sep 2018 08:41:02 +0000 (04:41 -0400)]
L2-learn; cache prefetch fix

the header is written (STORE) the data is only read (LOAD)

Change-Id: Ia3ac0c81224a0db736c329ed3e2e55b7417f08a0
Signed-off-by: Neale Ranns <[email protected]>
7 years agoGBP Endpoint Updates 09/14709/8
Neale Ranns [Wed, 5 Sep 2018 22:42:26 +0000 (15:42 -0700)]
GBP Endpoint Updates

- common types on the API
- endpoints keyed in various ways for DP lookup
- conparison functions for VPP IP address types

Change-Id: If7ec0bbc5cea71fd0983fe78987d147ec1bd7ec8
Signed-off-by: Neale Ranns <[email protected]>
7 years agovat: remove the endiness for u8 59/14759/2
Mohsin Kazmi [Tue, 11 Sep 2018 11:06:42 +0000 (13:06 +0200)]
vat: remove the endiness for u8

Change-Id: I9636a4e631cacf22d3189e292888c34f615298b0
Signed-off-by: Mohsin Kazmi <[email protected]>
7 years agoVAT: plugin load errors 56/14756/3
Ole Troan [Tue, 11 Sep 2018 09:26:12 +0000 (11:26 +0200)]
VAT: plugin load errors

- NSH plugin overrode vat_api_hookup()
- Missing format function in mactime.

Change-Id: I2dcbc2522d8f525d223c2ee3bb667111d1b3b78e
Signed-off-by: Ole Troan <[email protected]>
7 years agoremove libvlib from libvlibmemoryclient libs 39/14739/3
Matthew Smith [Fri, 7 Sep 2018 22:14:30 +0000 (17:14 -0500)]
remove libvlib from libvlibmemoryclient libs

On CentOS 7, having libvlibmemoryclient link libvlib causes
a SEGV when a program or library is run which links against
libvlibmemoryclient and dlopen() is called. This is because
dlopen() executes any functions with __attribute((constructor))
set. The VLIB_CLI_COMMAND macro creates CLI registration
functions that have this attribute set. So CLI registration
functions end up being run by applications which are clients
of the VPP API.

This doesn't occur on ubuntu 16.04, because ld seems to
omit shared libraries that were listed on the command line
if they are not used to resolve any symbols.

Removing the link to libvlib on vlibmemoryclient to fix this
problem results in another problem. Tests of libvcl_preload
fail when running 'make test'. This happens because
libvcl_preload calls dlopen but does not link against libdl.
When libvlibmemoryclient had libvlib linked, these errors
did not occur since libvlib links libdl. Adjusted the build
of libvcl_preload to explicitly link libdl.

Change-Id: I271ba2f9226ce1602e1f6c1525f3b093bb0345ed
Signed-off-by: Matthew Smith <[email protected]>
7 years agonat: fix busy ports of each thread 42/14642/8
dongjuan [Tue, 4 Sep 2018 09:40:53 +0000 (17:40 +0800)]
nat: fix busy ports of each thread

which can create dead loop in
nat_alloc_addr_and_port_default function

Change-Id: I468c25ce0f0a0b3f881de564623dea208b2ca700
Signed-off-by: dongjuan <[email protected]>
7 years agoReplacing vtbl NEON intrinsic with rev NEON intrinsic for byte_swap. 07/14607/6
Sirshak Das [Wed, 22 Aug 2018 04:02:04 +0000 (12:02 +0800)]
Replacing vtbl NEON intrinsic with rev NEON intrinsic for byte_swap.

Using rev16 vector intrinsic to reverse byteorder in each word
independently.

Change-Id: I071c40780baffe0bda614ec5d9dd92858f574b0d
Signed-off-by: Sirshak Das <[email protected]>
Reviewed-by: Steve Capper <[email protected]>
Reviewed-by: Brian Brooks <[email protected]>
Reviewed-by: Yi He <[email protected]>
Verified-by: Lijian Zhang <[email protected]>
7 years agoAdd u32x4_extend_to_u64x2 for aarch64 using NEON intrinsics 08/14608/5
Sirshak Das [Wed, 22 Aug 2018 06:04:33 +0000 (14:04 +0800)]
Add u32x4_extend_to_u64x2 for aarch64 using NEON intrinsics

This is used in vlib_get_buffers_with_offset.

Change-Id: If4ff776bc97d21a22e870300b164eeb6a5ec3638
Signed-off-by: Sirshak Das <[email protected]>
Reviewed-by: Steve Capper <[email protected]>
Reviewed-by: Brian Brooks <[email protected]>
Reviewed-by: Yi He <[email protected]>
Verified-by: Lijian Zhang <[email protected]>
7 years agoAdd horizontal add (hadd) vector intrinsic via NEON. 04/14604/5
Sirshak Das [Fri, 3 Aug 2018 16:24:51 +0000 (11:24 -0500)]
Add horizontal add (hadd) vector intrinsic via NEON.

Having the NEON equivalent of u32x4_hadd for CLIB_HAVE_VEC128

Change-Id: I210f96f7ecb9b80b4753311a68e5e09ccda7e95b
Signed-off-by: Sirshak Das <[email protected]>
Reviewed-by: Steve Capper <[email protected]>
Reviewed-by: Brian Brooks <[email protected]>
Reviewed-by: Yi He <[email protected]>
Verified-by: Lijian Zhang <[email protected]>
7 years agovapi: support VLAs in typedefs 04/14704/4
Klement Sekera [Thu, 6 Sep 2018 17:31:36 +0000 (19:31 +0200)]
vapi: support VLAs in typedefs

Change-Id: I3af3916b68189c2174020e5ecc29a7bc45b25efa
Signed-off-by: Klement Sekera <[email protected]>
7 years agodpdk: clean interface link information on admin down / stop 48/14748/3
Damjan Marion [Mon, 10 Sep 2018 11:55:46 +0000 (13:55 +0200)]
dpdk: clean interface link information on admin down / stop

Change-Id: Ie68814c8afc6cd67eb75da0b95dffa7b404cb7ba
Signed-off-by: Damjan Marion <[email protected]>
7 years agodpdk-plugin: do not request SCTP offload, some cards do not support it while supporti... 50/14750/3
Andrew Yourtchenko [Mon, 10 Sep 2018 15:26:36 +0000 (15:26 +0000)]
dpdk-plugin: do not request SCTP offload, some cards do not support it while supporting TCP/UDP

The DPDK plugin sets all of the offload flags, which may cause an initialization failure
on the NICs that do not support SCTP offload. The VPP code does not deal with the SCTP
offload at the moment at all, so after discussing with Damjan, we agreed
the best approach to fix the issue is to not request the SCTP offload.

The output of "show hardware" for the NIC in question before this patch:

            Name                Idx   Link  Hardware
GigabitEthernet1/0/0               1    down  GigabitEthernet1/0/0
  Ethernet address 00:e0:67:09:90:4b
  Intel 82540EM (e1000)
    carrier down
    flags: pmd pmd-init-fail maybe-multiseg tx-offload intel-phdr-cksum
    rx queues 1, rx desc 1024, tx queues 1, tx desc 1024
    cpu socket 0
  Errors:
    rte_eth_dev_configure[port:0, errno:-22]: Unknown error -22

And the excerpt from "show log":

1970/ 1/ 1 00:00:00:739 notice     dpdk       Ethdev port_id=0 requested Tx offloads 0x1c doesn't match Tx offloads capabilities 0xf in rte_eth_dev_configure()

Change-Id: I159d65c02fc3f044441972205f1f0ac08e52050c
Signed-off-by: Andrew Yourtchenko <[email protected]>
7 years agocmake VOM: j factor chosen based on number of cores 49/14749/2
Neale Ranns [Mon, 10 Sep 2018 12:42:56 +0000 (05:42 -0700)]
cmake VOM: j factor chosen based on number of cores

Change-Id: If1c27359cd93f6de6da9a93c3573997a51201959
Signed-off-by: Neale Ranns <[email protected]>
7 years agonew multiversioning on ethernet input nodes 46/14746/2
Damjan Marion [Mon, 10 Sep 2018 11:09:21 +0000 (13:09 +0200)]
new multiversioning on ethernet input nodes

Change-Id: I1aa196756b3ff4969b8ff2f117778d2cd87d6dd5
Signed-off-by: Damjan Marion <[email protected]>
7 years agovxlan-gbp: Add support for vxlan gbp 71/14371/15
Mohsin Kazmi [Mon, 20 Aug 2018 16:32:39 +0000 (18:32 +0200)]
vxlan-gbp: Add support for vxlan gbp

This patch implements vxlan with extension of group based
policy support.

Change-Id: I70405bf7332c02867286da8958d9652837edd3c2
Signed-off-by: Mohsin Kazmi <[email protected]>