Ignas Bacius [Tue, 18 Feb 2020 10:33:09 +0000 (12:33 +0200)]
 
misc: fix typo in set-ipfix-exporter CLI short_help
Type: fix
Change-Id: Id6687780b9a740323bd2eef58447864e70dc0235
Signed-off-by: Ignas Bacius <[email protected]>
Damjan Marion [Tue, 12 May 2020 10:22:18 +0000 (12:22 +0200)]
 
misc: fix ubuntu 20.04 python deps
Type: fix
Change-Id: I9cdfbffd6333d090f970422bf047aaa90c1e4c65
Signed-off-by: Damjan Marion <[email protected]>
Damjan Marion [Fri, 15 May 2020 22:40:48 +0000 (00:40 +0200)]
 
vppinfra: remove trailing whitespace in longjmp.S
Type: refactor
Change-Id: I2acbd864186c1d7694701c047ba72f58750a8558
Signed-off-by: Damjan Marion <[email protected]>
Benoît Ganne [Fri, 15 May 2020 14:12:23 +0000 (16:12 +0200)]
 
vlib: restore commands for non-interactive sessions
'quit' and 'show terminal' are valid for non-interactive sessions too.
Type: fix
Fixes: 
a58be82dda89d6496f92e451b42eee31f0cf47b4
Change-Id: Ib63244c7b64ad2e30c257ed19e982295f59bfffa
Signed-off-by: Benoît Ganne <[email protected]>
Florin Coras [Fri, 15 May 2020 21:23:58 +0000 (21:23 +0000)]
 
vcl: remove udpc transport
Type: refactor
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I145ff3301f168973c4f7f32c337bbcac47900705
Ray Kinsella [Fri, 15 May 2020 13:50:09 +0000 (14:50 +0100)]
 
misc: removed executable bits from source files
Identified and removed executable bit from source files in the tree.
find . -perm 755 -name *.[ch] -exec chmod a-x {} \;
Type: improvement
Signed-off-by: Ray Kinsella <[email protected]>
Change-Id: I00710d59fcc46ce5be5233109af4c8077daff74b
Florin Coras [Thu, 14 May 2020 05:32:18 +0000 (05:32 +0000)]
 
session: track detached listener segment managers
Type: fix
Signed-off-by: Florin Coras <[email protected]>
Change-Id: Iae734a526d2e7befd9738054d028df0062b67000
Dave Barach [Fri, 15 May 2020 13:51:45 +0000 (09:51 -0400)]
 
g2: fix the g2 build for Ubuntu 20.04
Shut off deprecated declaration warnings
Type: fix
Signed-off-by: Dave Barach <[email protected]>
Change-Id: I65ea4bbc4d5ee5a11d4e8f554f414f57944c7e1c
Filip Tehlar [Thu, 2 Apr 2020 13:13:39 +0000 (13:13 +0000)]
 
ikev2: add support for NAT traversal
Type: feature
* initiator behind NAT supported
* tested with static NAT mappings
* works only with pre-configured tunnels
The pre-configured tunnel has to be defined as follows:
initiator (i) side: src=ip(i) dst=ip(r)
responder (r) side: src=ip(r) dst=ip(nat)
Change-Id: Ia9f79ddbbcc3f7dc8fde6bbeca2a433e3b784e94
Signed-off-by: Filip Tehlar <[email protected]>
Florin Coras [Thu, 14 May 2020 00:30:18 +0000 (00:30 +0000)]
 
tcp: fix bogus time update due to missing cast
Type: fix
Seems clang needs explicit casting to u64 of u64 and f64 multiplication
before truncating to u32
Signed-off-by: Florin Coras <[email protected]>
Change-Id: Ib0d7a33d4c5e68577e401e854fc3e55e0723da93
Klement Sekera [Wed, 13 May 2020 13:17:50 +0000 (13:17 +0000)]
 
nat: unhide tests
Parallel merges introduced two test clasess with a same name. Rename
latter, so that former is seen (and run) by test runner again.
Type: fix
Signed-off-by: Klement Sekera <[email protected]>
Change-Id: I47772b41bb940bfdda4536cdd1f9b5e3768ca18b
hanlin [Mon, 11 May 2020 14:20:37 +0000 (22:20 +0800)]
 
vcl svm: fix rx event loss
When vcl_epoll_wait_handle_mq handles rx events exceeding maxevents, VPP will not signal because cursize > 0, and the remaining rx events cannot be triggered because the eventfd event has been read. Therefore, we should dequeue all events until cursize = 0. And then handle msg up to maxevents with vcl_epoll_wait_handle_mq_event and those beyond with vcl_handle_mq_event.
Type: fix
Signed-off-by: hanlin <[email protected]>
Change-Id: I8a0c87cb41c837deb8284b40f668cc3c7d9d6e56
Signed-off-by: hanlin <[email protected]>
Klement Sekera [Wed, 13 May 2020 11:35:57 +0000 (11:35 +0000)]
 
nat: "users" dump for ED-NAT
Since the removal of "users" concept in ED-NAT nat44_user_dump API
returns empty array. This brings back previous behaviour at
a considerable runtime cost until a better API is introduced.
Type: improvement
Change-Id: I5a45923cfeb6b8ebe6fc906601264d6567386991
Signed-off-by: Klement Sekera <[email protected]>
Onong Tayeng [Wed, 13 May 2020 15:55:57 +0000 (21:25 +0530)]
 
lisp: API cleanup
Removing the comments around eid_type which seem to have been overlooked
by the original patch https://gerrit.fd.io/r/c/vpp/+/24663.
Type: refactor
Signed-off-by: Onong Tayeng <[email protected]>
Change-Id: I48e1993cf8869cb32e159d1956f3ec1e5943e33f
Benoît Ganne [Mon, 11 May 2020 14:27:29 +0000 (16:27 +0200)]
 
vlib: fix unix cli commands crash without session
If a cli command is run while there are no cli session, then
cm->cli_file_pool will not be initialized and we should not try to
operate on it.
Type: fix
Change-Id: Iaea15a23f7efd5b17fab13e6c1cbb3a9a34080e0
Signed-off-by: Benoît Ganne <[email protected]>
Filip Tehlar [Sat, 9 May 2020 17:50:31 +0000 (17:50 +0000)]
 
ikev2: use u32 in unformat
Type: fix
Change-Id: If240bd8b3579678c0a6b5ea723946a35b53e5c31
Signed-off-by: Filip Tehlar <[email protected]>
Benoît Ganne [Wed, 13 May 2020 12:48:01 +0000 (14:48 +0200)]
 
dpdk: fix crash with chelsio pmd
cxgbe PMD initializes its control channel as part of dev_configure(),
and trying to get link status prior to it will lead to a crash.
DPDK documentation loosely hints that we should not call any device
function before dev_start(), call link_state() only for the relevant
PMDs.
From DPDK API documentation:
The functions exported by the application Ethernet API to setup a device
designated by its port identifier must be invoked in the following
order:
    rte_eth_dev_configure()
    rte_eth_tx_queue_setup()
    rte_eth_rx_queue_setup()
    rte_eth_dev_start()
Then, the network application can invoke, in any order, the functions
exported by the Ethernet API to get the MAC address of a given device,
to get the speed and the status of a device physical link, to
receive/transmit [burst of] packets, and so on.
Type: fix
Change-Id: I12d2ab4d84e6bd72a9f695447e86f3222929c804
Signed-off-by: Benoît Ganne <[email protected]>
Mrityunjay Kumar [Thu, 5 Sep 2019 05:10:25 +0000 (05:10 +0000)]
 
memif: 14 bytes extra overhead issue fixed.
Type: fix
Signed-off-by: Mrityunjay Kumar <[email protected]>
Change-Id: I31cc5e853b57e285064647503231b251e5152d3f
Klement Sekera [Tue, 12 May 2020 10:00:34 +0000 (10:00 +0000)]
 
nat: remove unused code
Type: improvement
Signed-off-by: Klement Sekera <[email protected]>
Change-Id: I95286d6723fd1860bf6bb0e81c474d732ab25121
Klement Sekera [Wed, 22 Apr 2020 12:45:50 +0000 (12:45 +0000)]
 
nat: ED: store both thread&session idx in hash
By storing thread and session index in hash table we are able to skip
multiple hash lookups in multi-worker scenario, which were used for
handoff before. Also, by storing sesion index in vnet_buffer2, we can
avoid repeating the lookup after handoff.
Type: improvement
Signed-off-by: Klement Sekera <[email protected]>
Change-Id: I406fb12f4e2dd8f4a5ca5d83d59dbc37e1af9abf
Alexander Chernavin [Thu, 14 May 2020 07:35:47 +0000 (03:35 -0400)]
 
nat: fix segv if out of ports in ed mode
Type: fix
Change-Id: Ife726d2f6baaa3516c209011183f39670cf6a55d
Signed-off-by: Alexander Chernavin <[email protected]>
yedg [Thu, 14 May 2020 02:51:53 +0000 (10:51 +0800)]
 
ip: fix interface ip address del sw_if_index check
Type: fix
Signed-off-by: Ye donggang <[email protected]>
Change-Id: Ia9f72ff2be455ecd4ff3d16e884c5a50f9df69fe
Andrew Yourtchenko [Wed, 13 May 2020 17:50:21 +0000 (17:50 +0000)]
 
misc: Initial 20.09-rc0 commit
Change-Id: Ib9ff4e2e3bea2085834294fd2a0beb3c559c459f
Type:docs
Signed-off-by: Andrew Yourtchenko <[email protected]>
John Lo [Wed, 13 May 2020 05:38:12 +0000 (01:38 -0400)]
 
sr: fix srv6/srv6-ad/srv6-as promisc mode switch
Calling ethernet_set_flags() to switch interface to/from promiscuous
mode must use use hw_if_index instead of sw_if_index.
Type: fix
Signed-off-by: John Lo <[email protected]>
Change-Id: I72da286b913893227e32193ee11fbbc56e04804d
Neale Ranns [Mon, 11 May 2020 15:24:39 +0000 (15:24 +0000)]
 
gso: remove ordering dependency on esp-encrypt-tun
Type: fix
... it's not a feature anymore
Signed-off-by: Neale Ranns <[email protected]>
Change-Id: Ifbcaf7d832aa76336feb0556d0dc7d2002f19c35
Klement Sekera [Wed, 13 May 2020 12:34:21 +0000 (12:34 +0000)]
 
nat: fix broken build
Type: fix
Signed-off-by: Klement Sekera <[email protected]>
Change-Id: I2a70db3a25450e014adaed84989f4da9bb77b14d
Klement Sekera [Mon, 4 May 2020 09:56:58 +0000 (09:56 +0000)]
 
nat: fix LRU blocked by inactive session
This fixes a situation where long-lived inactive session blocks LRU
list. Solution is to have multiple LRU lists based on session type.
This helps because session timeout is same for all sessions of same
type.
Type: fix
Signed-off-by: Klement Sekera <[email protected]>
Change-Id: I5e54b2aab73b23911d6518d42e8c3f166c69a38c
Klement Sekera [Mon, 11 May 2020 08:58:05 +0000 (08:58 +0000)]
 
nat: perf improvement - replace branchy code
Use a lookup table instead.
Type: improvement
Signed-off-by: Klement Sekera <[email protected]>
Change-Id: Ia8461099828bb8824bf016201f135e6b69c444d1
Chenmin Sun [Tue, 12 May 2020 23:04:06 +0000 (07:04 +0800)]
 
dpdk: DPDK 20.05 iavf fdir bug-fix patch cherry pick
After VF reset, FDIR rule still takes effect. To solve the issue,
this patch adds to flush all flows before flow uninit. VIRTCHNL
sends message to PF by Admin Queue, so flow flush should be implemented
before Admin Queue shut down.
Type: fix
Signed-off-by: Chenmin Sun <[email protected]>
Change-Id: I8ba0db7cd7646eaabd5745f74952016b0b968bbb
Mohsin Kazmi [Tue, 5 May 2020 12:30:25 +0000 (14:30 +0200)]
 
interface: fix the checksum offload in quad loop
Type: fix
In quad loop, checksum will be calculated for all four packets,
if one packet needs checksum computation, without respecting their
respective flags. This patch fixes it.
Change-Id: I479b420ba0dcbd178ea4180bf05a0e55a6b13843
Signed-off-by: Mohsin Kazmi <[email protected]>
Neale Ranns [Tue, 12 May 2020 08:51:02 +0000 (08:51 +0000)]
 
feature: Config end nodes are user specific
Type: fix
it is possible for a user to change the end node of a feature arc, but
this change should only apply to that 'instnace' of the arc, not all
arcs. for example, if a tunnel has its ipx-output end node changed to
adj-midchain-tx, this shouldn't affect all ipx-output arcs. obviously...
Signed-off-by: Neale Ranns <[email protected]>
Change-Id: I41daea7ba6907963e42140307d065c8bcfdcb585
Mohsin Kazmi [Tue, 12 May 2020 12:28:13 +0000 (14:28 +0200)]
 
bonding: fix the GSO flags
Type: fix
Only add GSO and Checksum offload flags when gso is
enabled.
Change-Id: I58945a4ffbb9a0e6a8640fc01424c63feef16306
Signed-off-by: Mohsin Kazmi <[email protected]>
Neale Ranns [Tue, 12 May 2020 13:33:56 +0000 (13:33 +0000)]
 
ipsec: Support 4o6 and 6o4 for SPD tunnel mode SAs
Type: feature
the es4-encrypt and esp6-encrypt nodes need to be siblings so they both have the same edges for the DPO on which the tunnel mode SA stacks.
Signed-off-by: Neale Ranns <[email protected]>
Change-Id: I2126589135a1df6c95ee14503dfde9ff406df60a
Filip Varga [Tue, 12 May 2020 11:42:45 +0000 (13:42 +0200)]
 
nat: handoff next node feature fix
Type: fix
Change-Id: I14e323e7bb1db7a3d40668212535c07504374e59
Signed-off-by: Filip Varga <[email protected]>
Filip Tehlar [Sat, 9 May 2020 03:32:28 +0000 (03:32 +0000)]
 
ikev2: fix removing of expired SAs
Type: fix
Change-Id: Idf9b0ffb4e3a0113bece80d1195192bdf46feb89
Signed-off-by: Filip Tehlar <[email protected]>
Dave Barach [Tue, 12 May 2020 20:43:10 +0000 (16:43 -0400)]
 
misc: remove useless assignment
Type: fix
Signed-off-by: Dave Barach <[email protected]>
Change-Id: I7708587804bc979fa9c46fb11f96d264821e2357
Florin Coras [Mon, 11 May 2020 18:03:40 +0000 (18:03 +0000)]
 
api: use malloc for rx thread arg instead of heap
Type: fix
Avoids issues if thread with non-zero __os_thread_index attaches to
binary api.
Signed-off-by: Florin Coras <[email protected]>
Change-Id: Ib981f12c867fdee7590391ec43128145bb1abce6
Florin Coras [Mon, 11 May 2020 17:19:31 +0000 (17:19 +0000)]
 
vcl: de-init vcl on destroy
Type: fix
Signed-off-by: Florin Coras <[email protected]>
Change-Id: If3372e3edd403240c2c9da746246170549a3e644
Florin Coras [Fri, 8 May 2020 16:23:38 +0000 (16:23 +0000)]
 
tcp: avoid rcv wnd less than mss
Type: fix
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I84ec1c91a3a7b2195aad58923fa6f17f551444cb
Steven Luong [Wed, 6 May 2020 23:58:02 +0000 (16:58 -0700)]
 
lacp: missing endian conversions for trace packet format
Fix a couple endian conversions for displaying Marker Protocol packet
in the trace
Type: fix
Signed-off-by: Steven Luong <[email protected]>
Change-Id: I746a67fb6143b5ad52bc4af9604ff8760dbdec9b
Damjan Marion [Mon, 11 May 2020 12:03:29 +0000 (14:03 +0200)]
 
crypto-native: properly deal with broken or outdated toolchains
Avoids crash due to missing symbol, when build system detects toolchain
which is not able to produce binaries for all targets we need....
Type: fix
Change-Id: I77ee63cb8dca3c9e4e83a6235c60f1439a472444
Signed-off-by: Damjan Marion <[email protected]>
Florin Coras [Mon, 11 May 2020 15:31:20 +0000 (15:31 +0000)]
 
vlib: fix u64 error counter cli printing
Type: fix
Signed-off-by: Florin Coras <[email protected]>
Change-Id: Ie35dc623394cfb6c358740361fd85aa0924ab187
Michael Yu [Fri, 8 May 2020 08:42:58 +0000 (16:42 +0800)]
 
ip-neighbor: fix show ip neighbor issue
Fix the issue that vppctl show ip4{6} neighbor [interface] command can't
show entries correctly, example: both ip4 and ip6 entries can be shown
with command:
vppctl show ip4 neighbor.
Type: fix
Signed-off-by: Michael Yu <[email protected]>
Change-Id: I229368b71cd285adce994c8290cc9d7e4c4f5aa6
Signed-off-by: Michael Yu <[email protected]>
Zhiyong Yang [Sat, 9 May 2020 07:13:34 +0000 (07:13 +0000)]
 
ethernet: fix dmac stride error
Type: fix
Signed-off-by: Zhiyong Yang <[email protected]>
Change-Id: I617fb365def22a28d48f75013dea38f8e1703a44
Ole Troan [Tue, 5 May 2020 10:23:47 +0000 (12:23 +0200)]
 
vppapigen: api crc checker
crcchecker is a tool for enforcement of the binary API.
1. Production APIs should never change.
2. An API can be deprecated across three release cycles.
   Release 1: API is marked as deprecated.
   option deprecated="vyy.mm";
   option replaced_by="new_api_2";
   Release 2: both old and new APIs are supported
   Release 3: the deprecated API is deleted.
3. APIs that are experimental / not released are not checked.
   An API message can be individually marked as in progress, by:
   option status="in_progress";
   In the API definition.
The definition of a "production API" is if the major version in the API file is > 0.
extras/scripts/crcchecker.py --check-patchset # returns -1 if backwards incompatible
extras/scripts/crcchecker.py --dump-manifest
extras/scripts/crcchecker.py --git-revision v20.01 <files>
extras/scripts/crcchecker.py -- diff <oldfile> <newfile>
This patch integrates the tool in "make checkstyle-api".
A future patch is required to integrate the tool in the verify job.
I.e. this patch does not enable enforcement through Jenkins.
Change-Id: I5f13c0976d8a12a58131b3e270f2dc9c00dc7d8c
Type: feature
Signed-off-by: Ole Troan <[email protected]>
Chenmin Sun [Fri, 8 May 2020 19:17:54 +0000 (03:17 +0800)]
 
gtpu: fix coverity issue
Fix coverity issue #210194 in gtpu-decap
Type: fix
Signed-off-by: Chenmin Sun <[email protected]>
Change-Id: I5b172c8494527e7117c4e7e7083a8473165aa40f
Dave Barach [Fri, 8 May 2020 13:46:17 +0000 (09:46 -0400)]
 
build: reject merge conflict checkin attempts
Although attempts to build code containing merge conflict markers
USUALLY results in compile errors, this patch adds an explicit check
for the conflict end marker.
If for some unknown reason it's necessary to check in the text
'>>>>>>>', construct it by concatenation: ">>>"">>>>"
or '>>>' + '>>>>' depending on the language involved.
Type: improvement
Signed-off-by: Dave Barach <[email protected]>
Change-Id: Iaad2aa8b87a71137a3bb9a09f7f4159909bf79ab
Dave Wallace [Fri, 8 May 2020 15:58:24 +0000 (15:58 +0000)]
 
docs: fix merge damage in nat.h
Type: fix
Fixes: 
b5a575b09
Signed-off-by: Dave Wallace <[email protected]>
Change-Id: I22d35159a923075243df9760f1a74e2ca74e30e1
Steven Luong [Fri, 8 May 2020 11:50:05 +0000 (04:50 -0700)]
 
vppinfra: set explicit found in search_free_list loop
While https://gerrit.fd.io/r/c/vpp/+/26948 fixed avoid using -1 to
index into h->free_lists[b][l] by changing the loop counter, the
check for the value of the loop counter (l < 0) cannot be trusted
to decide whether we've found a large enough object within the bin
or not. When the loop is terminated, the value of the variable l
could be ambiguous if it equals to 0 and it is never less than 0,
ie, when we bail out of the loop, we don't know if it was due to the
breaking out of the condition in
  if ((s = f_size - size) >= 0)
     break;
or
  while (l > 0);
The fix is to explicitly set a variable when we have found a large enough
object inside the loop to be used to test whether the loop was prematurely
terminated (found == 1) or the loop just ran exhausted (found == 0)
Type: fix
Signed-off-by: Steven Luong <[email protected]>
Change-Id: I0161813fbd44dcba8982a767eac2e0930e9d77e3
Damjan Marion [Fri, 8 May 2020 17:01:22 +0000 (19:01 +0200)]
 
misc: add knob to generate compile_commands.json
Used for lanuguage servers like clangd and ccls
Type: improvement
Change-Id: I68d534dfa7b8ba3459fbd919d5ffccaa1fa1171e
Signed-off-by: Damjan Marion <[email protected]>
Damjan Marion [Thu, 7 May 2020 14:49:45 +0000 (16:49 +0200)]
 
build: various improvements
- add option to install only host tools
- add option to specify lib and runtime dir
Type: improvement
Change-Id: I6356b52df459120fc9b0127948bae7679fb10e52
Signed-off-by: Damjan Marion <[email protected]>
Dave Barach [Fri, 8 May 2020 12:16:06 +0000 (08:16 -0400)]
 
ethernet: fix coverity warning
Type: fix
Ticket: VPP-1837
Signed-off-by: Dave Barach <[email protected]>
Change-Id: I20daa023eed50f8b42e8dc2d17e47a54aa16ae31
Ole Troan [Fri, 8 May 2020 08:39:30 +0000 (10:39 +0200)]
 
papi: use python3 for papi install
Breaks on Ubuntu 20.04 otherwise.
Type: fix
Signed-off-by: Ole Troan <[email protected]>
Change-Id: I407215a03948d6e49152ee97099539bb625c12ef
Ole Troan [Fri, 8 May 2020 08:02:18 +0000 (10:02 +0200)]
 
nat: fix per thread data vlib_main_t usage take 2
The original fix access vlib_main before these was initialized.
Removed cached vlib_mains structure.
Type: fix
Fixes: 
9bb09afb56b1aa787ca574cc732085272059fd5f
Signed-off-by: Ole Troan <[email protected]>
Change-Id: I686bab9220e27891f66bf60489c1602855786aa8
Signed-off-by: Ole Troan <[email protected]>
Lijian.Zhang [Thu, 30 Apr 2020 06:52:15 +0000 (14:52 +0800)]
 
dpdk: fix compiling issue with clang
When building vpp image with below command, clang reports warnings/errors
on the unused option '-L', as it's not linking stage, and does not require
linking libraries.
In dpdk.mk, the linking library path should be attached to
DPDK_EXTRA_LDFLAGS, instead of DPDK_EXTRA_CFLAGS
$ make build-release CC=clang V=1
clang -Wp,-MD,./.ark_ddm.o.d.tmp  -fPIE -fPIC -pthread -I/root/origin/build-root/build-vpp-native/external/dpdk-20.02/lib/librte_eal/linux/eal/include  -march=armv8-a+crc -DRTE_MACHINE_CPUFLAG_NEON -DRTE_MACHINE_CPUFLAG_CRC32  -I/root/origin/build-root/build-vpp-native/external/dpdk-20.02/arm64-armv8a-linuxapp-clang/include -DRTE_USE_FUNCTION_VERSIONING -include /root/origin/build-root/build-vpp-native/external/dpdk-20.02/arm64-armv8a-linuxapp-clang/include/rte_config.h
-D_GNU_SOURCE -O3 -I./ -W -Wall -Wstrict-prototypes -Wmissing-prototypes -Wmissing-declarations -Wold-style-definition -Wpointer-arith -Wnested-externs -Wcast-qual -Wformat-nonliteral -Wformat-security -Wundef -Wwrite-strings -Wdeprecated -Wno-missing-field-initializers -Wno-address-of-packed-member -Werror   -g -mtune=generic -L/root/origin/build-root/install-vpp-native/external/lib -I/root/origin/build-root/install-vpp-native/external/include -o ark_ddm.o -c
/root/origin/build-root/build-vpp-native/external/dpdk-20.02/drivers/net/ark/ark_ddm.c
== Build drivers/vdpa/ifc
clang: warning: argument unused during compilation: '-L/root/origin/build-root/install-vpp-native/external/lib' [-Wunused-command-line-argument]
clang: error: argument unused during compilation: '-L/root/origin/build-root/install-vpp-native/external/lib' [-Werror,-Wunused-command-line-argument]
Type: fix
Change-Id: If8fd9b19d0aff9d3c27d77e78cd3064bb1ad6565
Signed-off-by: Lijian Zhang <[email protected]>
Reviewed-by: Jieqiang Wang <[email protected]>
Reviewed-by: Govindarajan Mohandoss <[email protected]>
Lijian.Zhang [Mon, 27 Apr 2020 02:46:06 +0000 (10:46 +0800)]
 
vppinfra: fix u32x4_byte_swap on Arm
Fix the endianness conversion function u32x4_byte_swap() on Arm. Here's
an example of using this function with and without the fix.
This issue is seen using Mellanox NIC RDMA driver on Arm servers.
The packet length cannot be parsed correctly.
Testing code:
u32x4 s = {0x12345678, 0x23456789, 0x3456789a, 0x456789ab};
u32x4 ss = u32x4_byte_swap (s);
Without the code change:
(gdb) p /x s
$1 = {0x12345678, 0x23456789, 0x3456789a, 0x456789ab}
(gdb) p /x ss
$2 = {0x23456789, 0x12345678, 0x456789ab, 0x3456789a}
With the code change:
(gdb) p /x s
$3 = {0x12345678, 0x23456789, 0x3456789a, 0x456789ab}
(gdb) p /x ss
$4 = {0x78563412, 0x89674523, 0x9a785634, 0xab896745}
Type: fix
Change-Id: Ie5f263e94331783940e7c00397092a64e4fc4279
Signed-off-by: Lijian Zhang <[email protected]>
Reviewed-by: Jieqiang Wang <[email protected]>
Reviewed-by: Govindarajan Mohandoss <[email protected]>
Steven Luong [Thu, 7 May 2020 17:47:33 +0000 (10:47 -0700)]
 
vppinfra: loop counter off by 1 in search_free_list()
In search_free_list(), we have this do while loop.
	do
	  {
	    l--;
	    f_index = h->free_lists[b][l];
	    f = elt_at (h, f_index);
	    f_size = heap_elt_size (v, f);
	    if ((s = f_size - size) >= 0)
	      break;
	  }
	while (l >= 0);
When (l == 0), we still go back up to execute l--. Then l become -1. The
next statement is we index h->free_lists[b][-1]. After that, elt_at() would
probably cause a crash in the ASSERT.
Type: fix
Ticket: VPPSUPP-63
Signed-off-by: Steven Luong <[email protected]>
Change-Id: I617d122aa221cfdfe38f8be50f4e0f0e76e11bb5
Klement Sekera [Wed, 6 May 2020 11:21:16 +0000 (11:21 +0000)]
 
nat: remove duplicate line of code
Type: fix
Signed-off-by: Klement Sekera <[email protected]>
Change-Id: I3c914d5c457df40205280ac589a2d353261343d5
Filip Varga [Thu, 7 May 2020 12:28:56 +0000 (14:28 +0200)]
 
nat: fix per thread data vlib_main_t usage
Type: fix
Change-Id: If6784c9eb278f525e05304d10fd1a00641faaaf0
Signed-off-by: Filip Varga <[email protected]>
Damjan Marion [Thu, 7 May 2020 07:49:27 +0000 (09:49 +0200)]
 
misc: deprecate elftool
Type: make
Change-Id: I34fec1c40ef660177c266517eaf41d60827609f4
Signed-off-by: Damjan Marion <[email protected]>
Florin Coras [Wed, 15 Apr 2020 01:30:46 +0000 (01:30 +0000)]
 
session: catch segment manager alloc failure
Type: improvement
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I4ac923fda84feee8d2ad76d0c3e3a252f53008ed
Elias Rudberg [Thu, 7 May 2020 12:29:21 +0000 (14:29 +0200)]
 
lacp: fix regarding vm arg for vlib_time_now calls
Use thread-specific vlib_main_t *vm pointers to avoid problems with
different threads accessing the same vlib_main_t data structure.
This avoids assertion failure when vlib_time_now() is called with a vm
corresponding to a different thread.
Type: fix
Signed-off-by: Elias Rudberg <[email protected]>
Change-Id: I359596ecff86e03d57aa8d2330f77bf9a913485f
Damjan Marion [Wed, 6 May 2020 21:38:58 +0000 (23:38 +0200)]
 
rdma: fix alignment issue
Type: fix
Change-Id: I0ff7a6f3354066c2252c1ebd0d43ac59db278bf0
Signed-off-by: Damjan Marion <[email protected]>
Signed-off-by: Elias Rudberg <[email protected]>
Paul Vinciguerra [Fri, 1 Nov 2019 17:00:58 +0000 (13:00 -0400)]
 
docs: clean up make docs job
Type: docs
Change-Id: I9b5e5137eb4c1e89f6e8d7a278cd11a0fd496471
Signed-off-by: Paul Vinciguerra <[email protected]>
Dave Barach [Tue, 5 May 2020 21:08:53 +0000 (17:08 -0400)]
 
vppinfra: add timer wheel section to Sphinx docs
Type: docs
Signed-off-by: Dave Barach <[email protected]>
Change-Id: Id0576d98b8e78cf4cd00161968d3eb6dbd58055a
Fan Zhang [Fri, 1 May 2020 12:06:57 +0000 (13:06 +0100)]
 
crypto: fix coverity issues
Fix coverity issues in crypto framework and cryptodev
engine.
Type: fix
Signed-off-by: Fan Zhang <[email protected]>
Change-Id: Ib261da0163c8182c803600db22c5a6dad5a19999
Dave Barach [Mon, 4 May 2020 18:47:45 +0000 (14:47 -0400)]
 
misc: fix coverity warnings
Type: fix
Ticket: VPP-1837
Signed-off-by: Dave Barach <[email protected]>
Change-Id: I51660e4b02f449bd2db12a8cfd395c6c343d2dee
Benoît Ganne [Tue, 5 May 2020 10:25:13 +0000 (12:25 +0200)]
 
rdma: fix clang build
Type: fix
Change-Id: I9b613f0af484f601dd20a851e2f59ee5e06b5c37
Signed-off-by: Benoît Ganne <[email protected]>
Paul Vinciguerra [Tue, 5 May 2020 15:46:26 +0000 (11:46 -0400)]
 
misc: fts add support for non-ascii author names in yaml
Type: fix
Change-Id: I3f034ca86412b58d3e41a627bd8902157683435a
Signed-off-by: Paul Vinciguerra <[email protected]>
Elias Rudberg [Thu, 23 Apr 2020 09:17:58 +0000 (11:17 +0200)]
 
nat: ipfix logging vlib_mains[thread_index] bugfix
Use thread-specific vlib_main_t *vm pointers to avoid problems
with different threads accessing the same vlib_main_t data
structure. This avoids crashing when ipfix logging is enabled
and several threads are used.
Type: fix
Signed-off-by: Elias Rudberg <[email protected]>
Change-Id: Ic1d3d335919d7666ead14be1153eb8c8c07b7356
Filip Varga [Sun, 19 Apr 2020 17:44:49 +0000 (19:44 +0200)]
 
nat: enable force session cleanup
Force session cleanup drops NAT db.
Also fixing user specific cli/api calls.
Type: improvement
Change-Id: Ia3e25fcf07fe5fb9a83d55c03fe90aca727b41ac
Signed-off-by: Filip Varga <[email protected]>
Klement Sekera [Mon, 27 Apr 2020 08:19:12 +0000 (08:19 +0000)]
 
nat: fix coverity warning
Type: fix
Signed-off-by: Klement Sekera <[email protected]>
Change-Id: I609fef6f96c6a3fc85a4dc07e75244b0e1ba9239
Paul Vinciguerra [Mon, 2 Dec 2019 03:24:28 +0000 (22:24 -0500)]
 
tests: clean up logging
Tests currently expect the logger to be poked from run_tests.py.
The tests should run without any magic values.  This change sets a default
null logger and removes the hasattr checks for the logger.
For reference, see: https://docs.python-guide.org/writing/logging/
Type: test
Change-Id: I98f953d73d12d00e74b59c94a0fb8c7a625b9c44
Signed-off-by: Paul Vinciguerra <[email protected]>
Dave Wallace [Tue, 5 May 2020 19:45:10 +0000 (19:45 +0000)]
 
tests: add test description to quic tests
Type: style
Signed-off-by: Dave Wallace <[email protected]>
Change-Id: Ief894e940a913a4ccf5368a2fdcf5479917f56cb
Neale Ranns [Wed, 1 Apr 2020 09:45:23 +0000 (09:45 +0000)]
 
ipsec: User can choose the UDP source port
Type: feature
thus allowing NAT traversal,
Signed-off-by: Neale Ranns <[email protected]>
Change-Id: Ie8650ceeb5074f98c68d2d90f6adc2f18afeba08
Signed-off-by: Paul Vinciguerra <[email protected]>
Vratko Polak [Mon, 6 Apr 2020 13:01:46 +0000 (15:01 +0200)]
 
session: improve .api comments slightly
Type: style
Change-Id: Iccd2c205059abcdf121093ff03da603fe3dda1f7
Signed-off-by: Vratko Polak <[email protected]>
Mohsin Kazmi [Tue, 5 May 2020 10:31:17 +0000 (10:31 +0000)]
 
gso: fix the make test for ipip
Type: test
This commit fixes the make test for GSO/IPIP which are added in
following commit id: 
84f91fa9c54f82c54b58ea3bf6e9ba22ff735d3a
Signed-off-by: Mohsin Kazmi <[email protected]>
Change-Id: I66a57fe195e626b432ff0acba3a5bdf242a7a46e
Christian Hopps [Mon, 4 May 2020 14:28:03 +0000 (10:28 -0400)]
 
api: ip: add IP_ROUTE_LOOKUP API
Add an IP_ROUTE_LOOKUP function that does either an exact match or
longest prefix match in a given fib table for a given prefix
returning the match if present.
Add API test.
Type: improvement
Signed-off-by: Christian Hopps <[email protected]>
Change-ID: I67ec5a61079f4acf1349a9c646185f91f5f11806
Filip Tehlar [Fri, 1 May 2020 06:37:39 +0000 (06:37 +0000)]
 
ikev2: remove sa from main thread
Type: fix
Change-Id: Ib73ce48552cfa9e825a6833f5594650783d82f3b
Signed-off-by: Filip Tehlar <[email protected]>
Chenmin Sun [Sun, 1 Mar 2020 16:08:20 +0000 (00:08 +0800)]
 
gtpu: RX offload for IPv6 payload supporting
this patch adds the offloading capability for the IPv4 GTPU
tunnel which the next-node is assigned as IPv6
Type: feature
Signed-off-by: Chenmin Sun <[email protected]>
Change-Id: Ie39cd43058d36514656351dc6e906a19d5de89c0
Chenmin Sun [Thu, 30 Apr 2020 12:00:09 +0000 (20:00 +0800)]
 
flow: explicitly convert RSS function types in dpdk_plugin
explicitly convert RSS function types from vnet_rss_function_t to
rte_eth_hash_function to avoid these two types go out of sync in the future...
Type: fix
Signed-off-by: Chenmin Sun <[email protected]>
Change-Id: Ic09f6bb7f2cfbcf7cc4d380e51554b7f2b7a3b90
Mohsin Kazmi [Thu, 23 Apr 2020 15:59:49 +0000 (17:59 +0200)]
 
gso: add support for IP-IP
Type: feature
Change-Id: I37752af8496e0042a1da91124f3d94216b39ff11
Signed-off-by: Mohsin Kazmi <[email protected]>
Klement Sekera [Mon, 4 May 2020 12:31:24 +0000 (12:31 +0000)]
 
nat: remove unused code
Type: refactor
Signed-off-by: Klement Sekera <[email protected]>
Change-Id: I33b2b38961b200dc3297b82124a7107b9ecbd0de
Dave Barach [Mon, 4 May 2020 16:33:18 +0000 (12:33 -0400)]
 
ethernet: add sanity checks to p2p_ethernet_add/del
Binary API message handlers need to check sw_if_index
values.
Found in binary api fuzz testing.
Type: fix
Signed-off-by: Dave Barach <[email protected]>
Change-Id: I51e717e9260e58a4c36d4d95981fd001be594fed
Signed-off-by: Paul Vinciguerra <[email protected]>
Andrew Yourtchenko [Thu, 30 Apr 2020 18:05:47 +0000 (18:05 +0000)]
 
misc: 19.08.2 Release Notes
Change-Id: I78f9edf9c15e9f4a2451be084c04c6318fbb978d
Type: docs
Signed-off-by: Andrew Yourtchenko <[email protected]>
(cherry picked from commit 
ec9ce338f05fb8bc90908ed17b8a0bc9eb8cd9f9)
Pivo [Mon, 4 May 2020 15:57:33 +0000 (17:57 +0200)]
 
vcl: allow vcl worker index to be set by applications
When using vppcom_session* apis to setup TCP sessions in applications build outside of the VPP repository, it is necessary to set the worker_index explicitly when these apis are called from the none-VCL worker threads. An example is when data is to be sent to the TCP session that is originated from a different thread, like the main program thread or from the bin api thread. This change allows the application to set it.
Type: fix
Signed-off-by: IJsbrand Wijnands <[email protected]>
Change-Id: I37f3654a49ea9a8cf3a0d3d0e672583018c12299
Florin Coras [Tue, 28 Apr 2020 01:54:22 +0000 (01:54 +0000)]
 
session: add option to preallocate fifo headers
Type: feature
Signed-off-by: Florin Coras <[email protected]>
Change-Id: Ie47546ef36590b90ed481b14cf812afbecf7981c
Filip Tehlar [Mon, 4 May 2020 16:30:57 +0000 (16:30 +0000)]
 
ikev2: fix string in api
Type: fix
key file name should be a string and not array of u8.
Change-Id: I7d280d2397030e73732b374ad9d3146fad0bb19f
Signed-off-by: Filip Tehlar <[email protected]>
Paul Vinciguerra [Fri, 1 May 2020 14:09:58 +0000 (10:09 -0400)]
 
vapi:  add support for defaults in typedefs
  refactored out of Neale's change:
    https://gerrit.fd.io/r/c/vpp/+/26276
Type: refactor
Change-Id: Ibb0c019856dc44640e94d6d80a5d119a6296d95c
Signed-off-by: Paul Vinciguerra <[email protected]>
(cherry picked from commit 
a751d8d61fe5880f6d447e63b81e2df30561e9f9)
Neale Ranns [Tue, 31 Mar 2020 13:21:29 +0000 (09:21 -0400)]
 
fib: midchain adjacency optimisations
Type: improvement
 - inline some common encap fixup functions into the midchain
   rewrite node so we don't incur the cost of the virtual function call
 - change the copy 'guess' from ethernet_header (which will never happen) to an ip4 header
 - add adj-midchain-tx to multiarch sources
 - don't run adj-midchain-tx as a feature, instead put this node as the
   adj's next and at the end of the feature arc.
 - cache the feature arc config index (to save the cache miss going to fetch it)
 - don't check if features are enabled when taking the arc (since we know they are)
the last two changes will also benefit normal adjacencies taking the arc (i.e. for NAT, ACLs, etc)
for IPSec:
 - don't run esp_encrypt as a feature, instead when required insert this
   node into the adj's next and into the end of the feature arc. this
   implies that encrypt is always 'the last feature' run, which is
   symmetric with decrypt always being the first.
 - esp_encrpyt for tunnels has adj-midchain-tx as next node
Change-Id: Ida0af56a704302cf2d7797ded5f118a781e8acb7
Signed-off-by: Neale Ranns <[email protected]>
Florin Coras [Sat, 2 May 2020 02:26:56 +0000 (02:26 +0000)]
 
tcp: fix max tx sack blocks upper bound
Type: fix
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I70c63db91c3512fb724bba4762e3ca1e369ca421
Dave Barach [Wed, 29 Apr 2020 21:04:10 +0000 (17:04 -0400)]
 
misc: binary api fuzz test fixes
Add a hook to src/vlibapi/api_shared.c to fuzz (screw up) binary API
messages, e.g. by xoring random data into them before processing. We
specifically exempt client connection messages, and inband debug CLI
messages. We step over msg_id, client index, client context, and
sw_if_index. Otherwise, "make test" vectors fail too rapidly to learn
anything.
The goal is to reduce the number of crashes caused to zero. We're
fairly close with this patch.
Add vl_msg_api_max_length(void *mp), which returns the maximum
plausible length for a binary API message.
Use it to hardern vl_api_from_api_to_new_vec(...) which takes an
additional argument - message pointer - so it can verify that
astr->length is sane. If it's not sane, return a u8 *vector of the
form "insane astr->length nnnn\0".
Verify array lengths in vl_api_dhcp6_send_client_message_t_handler(...)
and vl_api_dhcp6_pd_send_client_message_t_handler(...).
Add a fairly effective binary API fuzz hook to the unittest plugin,
and modify the "make test" framework.py to pass "api-fuzz { on|off }"
to enable API fuzzing: "make API_FUZZ=on TEST=xxx test-debug" or similar
Type: improvement
Signed-off-by: Dave Barach <[email protected]>
Change-Id: I0157267652a163c01553d5267620f719cc6c3bde
Mohsin Kazmi [Thu, 30 Apr 2020 17:05:56 +0000 (19:05 +0200)]
 
tap: refactor existing flags
Type: refactor
This patch refactor the existing flags and also add a new
flag for packet coalescing.
Change-Id: Ic826e4c81313f26d87c475cdf666b06cbed60a3a
Signed-off-by: Mohsin Kazmi <[email protected]>
Filip Varga [Thu, 16 Apr 2020 11:20:25 +0000 (13:20 +0200)]
 
nat: per vrf session limits
Type: improvement
Change-Id: I170256ab47978db34fb0ff6808d9cd54ab872410
Signed-off-by: Filip Varga <[email protected]>
Paul Vinciguerra [Sun, 3 May 2020 02:34:40 +0000 (22:34 -0400)]
 
tests: vpp_interface remove deprecated packed properties
The api no longer requires packed ip addresses.
Type: test
Change-Id: If67365d86b7c3189f871a58234e99f9c8f875371
Signed-off-by: Paul Vinciguerra <[email protected]>
Paul Vinciguerra [Sat, 2 May 2020 14:40:33 +0000 (10:40 -0400)]
 
tests: improve vpp_papi_provider exception output
saves time debugging tests by replacing 'API call' with
the actual function signature:
  vpp_papi_provider.UnexpectedApiReturnValueError: API call failed, expected 0 return value instead of -2 in vxlan_add_del_tunnel_reply(_0=247, context=5052, retval=-2, sw_if_index=
4294967295)
  vpp_papi_provider.UnexpectedApiReturnValueError: vxlan_add_del_tunnel(is_add=0, src_address=172.16.1.1, dst_address=239.1.1.209, vni=209, sw_if_index=26, mcast_sw_if_index=1, encap_vrf_id=None, instance=None, decap_next_index=None) failed, expected 0 return value instead of -2 in vxlan_add_del_tunnel_reply(_0=247, context=5052, retval=-2, sw_if_index=
4294967295)
Type: test
Change-Id: Ie3b6a5fdb4e1d427d60c51f7a7bf815af0bb3de6
Signed-off-by: Paul Vinciguerra <[email protected]>
Ruslan Babayev [Sat, 15 Feb 2020 01:45:02 +0000 (17:45 -0800)]
 
vlib: add nosyslog unix option
The "nosyslog" option disables syslog just like the "interactive" mode
but can be used together with "nodaemon".
This is useful for when VPP is running under a process supervisor like
runit or daemontools that pipe the stdout/stderr to a dedicated logger
service.
Type: feature
Change-Id: Ic4287338d6836fea9f3eabdcf960dc1f51875dd1
Signed-off-by: Ruslan Babayev <[email protected]>
Ruslan Babayev [Mon, 3 Feb 2020 01:30:31 +0000 (17:30 -0800)]
 
ip-neighbor: honor walk callback return value
Type: fix
Change-Id: I5e1f7c37d612f4666edf2262b457ae0e13f20791
Signed-off-by: Ruslan Babayev <[email protected]>
Ruslan Babayev [Thu, 31 Oct 2019 08:37:50 +0000 (01:37 -0700)]
 
api: fix include_guard when path contains a plus
The path to VPP source might contain a '+' when building it
with Yocto/OpenEmbedded.
Type: fix
Signed-off-by: Ruslan Babayev <[email protected]>
Change-Id: I205ac0de7d8726724af0e30f5b199391e05dc615
Paul Vinciguerra [Mon, 27 Apr 2020 05:12:48 +0000 (01:12 -0400)]
 
tap: implement sw_interface_tap_v2_dump filtering by sw_if_index
Type: feature
Change-Id: I6f607f383dc77a71e8712124f7613b38b4ac065a
Signed-off-by: Paul Vinciguerra <[email protected]>