Klement Sekera [Fri, 17 Apr 2020 18:42:28 +0000 (18:42 +0000)]
 
nat: improve perf - long read after short write
Type: improvement
Signed-off-by: Klement Sekera <[email protected]>
Change-Id: Idbbad246161d28f595c25e10d7282c8b33fa9876
Stanislav Zaikin [Thu, 23 Apr 2020 12:14:30 +0000 (12:14 +0000)]
 
dhcp: fix dhcp proxy behavior for qinq and dot1q subinterfaces
Previous behavior worked only when subinterface ID matches with dot1q tag and doesn't work at all in QinQ case.
In this patch I'm checking how subinterface is configured.
Type: fix
Signed-off-by: Stanislav Zaikin <[email protected]>
Change-Id: I7a662a0442fdc8e68aba5d6f469f3b1139a4bc2d
Florin Coras [Fri, 24 Apr 2020 16:59:49 +0000 (16:59 +0000)]
 
tls: improve cli state reporting
Type: improvement
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I02d60134d6069764da75dc6d206b376a0d46998e
Florin Coras [Fri, 24 Apr 2020 23:00:11 +0000 (23:00 +0000)]
 
session vcl: propagate transport cleanup notifications
Type: improvement
Can be used to force app to close a connection on which it still waits
for data.
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I7c3a8245cbbc23728e4408feb63a659a11f718ed
Florin Coras [Fri, 24 Apr 2020 17:09:25 +0000 (17:09 +0000)]
 
vcl: generate select events on read/write errors
Type: fix
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I3429f9d0406b6d710846fc82d77400f26f77fdf4
Dave Barach [Fri, 24 Apr 2020 20:07:37 +0000 (16:07 -0400)]
 
vppinfra: finish deprecating qsort.c
Minor change to vec_sort_with_function(...): don't depend on the qsort
implementation to deal with null, zero-long, or 1-long vectors
Type: fix
Signed-off-by: Dave Barach <[email protected]>
Change-Id: I7bd7b0421673d2a025363089562aa7c6266fba66
Neale Ranns [Thu, 23 Apr 2020 16:01:20 +0000 (16:01 +0000)]
 
acl: ACL creation CLI parsing fix
Type: fix
Signed-off-by: Neale Ranns <[email protected]>
Change-Id: I026f0d8385b538e543bae0c1f7e56e49e4713ba1
Klement Sekera [Wed, 15 Apr 2020 13:37:18 +0000 (15:37 +0200)]
 
nat: ignore user hash in ED NAT
With port overloading, port is no longer a scarce resource and there
is no need to limit connections per internal IP. This saves one hash
insert in slow path.
Type: improvement
Change-Id: I8a7a9713ac855fa99fa1617ec684f757cf6e09ae
Signed-off-by: Klement Sekera <[email protected]>
Klement Sekera [Fri, 24 Apr 2020 12:24:41 +0000 (12:24 +0000)]
 
nat: make usage of vnet_buffer2 transparent
Type: fix
Signed-off-by: Klement Sekera <[email protected]>
Change-Id: I50df248afb3f6b46c49e6695b3f124cfd584f016
Dave Barach [Fri, 24 Apr 2020 13:43:14 +0000 (09:43 -0400)]
 
tests: test vnet_calc_checksums_inline(...)
Use a hand-crafted packet generator script to inject packets with
deliberately broken ip4 and udp checksums - and the appropriate
checksum offload flags - into src/vnet/interface_output.c
vnet_interface_output_node_inline(...), and make sure that the
resulting checksums are correct.
Use the packet tracer to catch one of the packets. Parse through the
packet trace, and make sure that the checksums have been correctly
computed.
Type: test
Signed-off-by: Dave Barach <[email protected]>
Change-Id: Ic08b4b64d7ef27061558a3abf0b79917ead254b5
Klement Sekera [Thu, 9 Apr 2020 11:31:27 +0000 (13:31 +0200)]
 
nat: ED: reduce number of hash tables used
Use out2in_ed hash table for port overloading tracking instead of
global table. This reduces number of hash insertions in slowpath.
Type: improvement
Change-Id: Iad4e897d52033beb7f6d76a7ddb596eef586c6cb
Signed-off-by: Klement Sekera <[email protected]>
Klement Sekera [Thu, 23 Apr 2020 13:42:19 +0000 (13:42 +0000)]
 
nat: fix extended unit tests
Type: fix
Fixes: 
b86437b79b82493c2e9728929df417f55b153824
Signed-off-by: Klement Sekera <[email protected]>
Change-Id: I2c833928dcdceb4d23dfc161bcc3358272076980
Klement Sekera [Wed, 18 Dec 2019 12:17:06 +0000 (12:17 +0000)]
 
ip: reassembly: improve type safety
Type: refactor
Change-Id: Ib2d4a11ffa0e1e56ca05705ba8cdf84e6cc66427
Signed-off-by: Klement Sekera <[email protected]>
Neale Ranns [Thu, 23 Apr 2020 07:36:12 +0000 (07:36 +0000)]
 
ip: Setting the Link-Local address from the API enables IPv6 on the
interface
Type: fix
Signed-off-by: Neale Ranns <[email protected]>
Change-Id: I0b7c189006e30a357cd6be4f3c9c61fded4157cb
Steven Luong [Sun, 5 Apr 2020 23:09:17 +0000 (16:09 -0700)]
 
virtio: vhost checksum problem for ipv6
When checksum is enable for IPv6, it erroneously set the flag
VNET_BUFFER_F_OFFLOAD_IP_CKSUM. That flag is meant for ip4 packets only.
Type: fix
Ticket: VPP-1857
Signed-off-by: Steven Luong <[email protected]>
Change-Id: Id03b2937bfa34e2a9b50a36aafe0700bad7fb95e
(cherry picked from commit 
f78294d8468f156e066e7e69aab3a1b285810c3a)
ShivaShankarK [Tue, 14 Apr 2020 08:31:03 +0000 (14:01 +0530)]
 
ipsec: add input node bypass/discard functionality
add bypass/discard functionality to ipsec4-input-feature node
Type: feature
Signed-off-by: ShivaShankarK <[email protected]>
Change-Id: I152a5dfee0296109cccabe349a330dbbe395cc6c
Neale Ranns [Wed, 22 Apr 2020 16:06:45 +0000 (16:06 +0000)]
 
vapi: packed enum type generation
Type: fix
if the ,api/.json specifies that a enum should be u8/u16 that the
generated c enum needs to be packed.
Signed-off-by: Neale Ranns <[email protected]>
Change-Id: Ia0497b45e4c510a5c63cd02e966769bf20686838
Dave Barach [Thu, 23 Apr 2020 17:05:49 +0000 (13:05 -0400)]
 
misc: update INFO.yaml
Add Benoit Ganne to the committer list, remove committers who have
resigned, list committers in alphabetical order.
Type: fix
Signed-off-by: Dave Barach <[email protected]>
Change-Id: Ic51092df774464e228cd875acf118827e9cd1923
Dave Barach [Thu, 23 Apr 2020 20:56:15 +0000 (16:56 -0400)]
 
nat: add/del ed_ext_ports only if the table is instantiated
Add a suitable ASSERT in the bihash template in case this happens again.
Type: fix
Signed-off-by: Dave Barach <[email protected]>
Change-Id: Ib370d4238f6bae2995bc30fd17fad5c41053c3d1
Andrew Yourtchenko [Mon, 27 Jan 2020 11:09:17 +0000 (11:09 +0000)]
 
misc: Markdown cleanups for the 20.01 release
Type: docs
Signed-off-by: Andrew Yourtchenko <[email protected]>
Change-Id: I821197364a2fee9b52b1f014288b1f5e9e3c494c
(cherry picked from commit 
fc98203b5d06f19d613766815660e76c9f216f09)
Andreas Schultz [Thu, 23 Apr 2020 08:41:50 +0000 (10:41 +0200)]
 
session: fix session_table_get_or_alloc
Extending the fib_index_to_table_index could leave entries uninitialized,
pointing to the session tables at index 0. That session index exists by
default, but it is a IPv4 session table. That would break all IPv6 on
the unitilized fib indexes.
Type: fix
Change-Id: Ie3f0a87a7f829ceb39f75ec06658b0ad1d3813ae
Signed-off-by: Andreas Schultz <[email protected]>
Damjan Marion [Thu, 23 Apr 2020 11:41:47 +0000 (13:41 +0200)]
 
vppinfra: more bihash optimizatons
* Avoid doing expensive bit extraction for most likely case where bucket
  .log2_page_size == 0 and .linear_search == 0, saves 3-5 cycles for
  lookup, data_prefetch and add operation
* use bextr instruction when available (x86 BMI instruction set)
Type: improvement
Change-Id: I163df36a29287482c5f133be8b21d62a2f7440de
Signed-off-by: Damjan Marion <[email protected]>
Neale Ranns [Wed, 8 Apr 2020 12:19:38 +0000 (12:19 +0000)]
 
ip: Replace Sematics for Interface IP addresses
Type: feature
 - replace functions for prefixes attached to interfaces
 - add ip_interface.[ch] to consoldate the functions
Signed-off-by: Neale Ranns <[email protected]>
Change-Id: I9c0c39c09dbf80ea1aadefee02c9bd16f094b6ad
Neale Ranns [Thu, 2 Apr 2020 17:08:28 +0000 (17:08 +0000)]
 
ip-neighbor: Replace feature for the ip-neighbor data-base
Type: feature
DB replace is implemented with a mark and sweep algorithm (just the the
FIB)
Signed-off-by: Neale Ranns <[email protected]>
Change-Id: I54ab06e11552219e2a18e1b4a87d531321cf3829
Florin Coras [Wed, 22 Apr 2020 22:07:43 +0000 (22:07 +0000)]
 
tcp: avoid bt sample access after possible pool realloc
Type: fix
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I98f943c8862fa74fb576f9ec1fb9186289b1216b
Neale Ranns [Wed, 22 Apr 2020 16:14:52 +0000 (12:14 -0400)]
 
api: 'api trace' CLI consumes a line of input
Type: improvement
allows the CLI command to be used from a config file
Change-Id: Id9e7ad71b208317a65b1ed4065b0cb8777aee6ec
Signed-off-by: Neale Ranns <[email protected]>
Dave Barach [Wed, 22 Apr 2020 14:02:31 +0000 (10:02 -0400)]
 
vppinfra: move unused code to extras/deprecated/vppinfra
Type: improvement
Signed-off-by: Dave Barach <[email protected]>
Change-Id: Id28299a188feefa1899d835fd499f018af95d81b
Neale Ranns [Wed, 22 Apr 2020 16:02:47 +0000 (16:02 +0000)]
 
ip: fix format functions for u8 address_family
Type: fix
Signed-off-by: Neale Ranns <[email protected]>
Change-Id: I8c9f5330879fb8f51792b4476d5f0c873dbe4d7a
Florin Coras [Wed, 22 Apr 2020 18:10:58 +0000 (18:10 +0000)]
 
lisp: switch to new timer wheel code
Type: improvement
Signed-off-by: Florin Coras <[email protected]>
Change-Id: Ie212a43c435cfa7f8fac65d1620258913611c527
Benoît Ganne [Wed, 22 Apr 2020 17:14:03 +0000 (19:14 +0200)]
 
vcl: fix use-after-free
Make sure we disconnect from vlib prior to free-ing the last worker, as
we'll need to access it.
Type: fix
Change-Id: Id5bdd17f0f5efa1ce52021b4270eb4f1e95cc61d
Signed-off-by: Benoît Ganne <[email protected]>
Benoît Ganne [Wed, 22 Apr 2020 17:15:49 +0000 (19:15 +0200)]
 
tcp: fix use-after-free
bts can be freed by the call to bt_fix_overlapped(). Save flags for
later use.
Type: fix
Change-Id: If8b48c96ce39e38f2ed7f4db2815122523eb2e05
Signed-off-by: Benoît Ganne <[email protected]>
Florin Coras [Mon, 20 Apr 2020 21:07:06 +0000 (21:07 +0000)]
 
session: multiple dgrams per dispatch
Type: improvement
Signed-off-by: Florin Coras <[email protected]>
Change-Id: Ifa4916ffeaa30039e366011109bbd2e9c91a1b0b
Benoît Ganne [Mon, 20 Apr 2020 07:52:39 +0000 (09:52 +0200)]
 
svm: asan: fix asan support
 - restrict the unittests SVM address space to what is supported by ASan
 - mark SVM mmap()ed address space accessible for ASan
 - SVM shared memory heap scheme means some allocation can happen
   outside the current process. Lazily mark those accessible for ASan
Type: fix
Change-Id: I7c196c80b2a5297651d0afa54f1a8e478fcf59b1
Signed-off-by: Benoît Ganne <[email protected]>
Neale Ranns [Thu, 9 Apr 2020 11:34:08 +0000 (07:34 -0400)]
 
gre: Optimise encap node for tunnel types
Type: improvement
Change-Id: I6627e22110be94c8127486ae009761494e734c04
Signed-off-by: Neale Ranns <[email protected]>
Mohsin Kazmi [Fri, 17 Apr 2020 16:50:56 +0000 (16:50 +0000)]
 
gso: add vxlan tunnel support
Type: feature
Change-Id: I85f6ec77187a4983c66c5e22fd39fbb2cef82902
Signed-off-by: Mohsin Kazmi <[email protected]>
Dave Barach [Wed, 22 Apr 2020 12:01:52 +0000 (08:01 -0400)]
 
misc: fix coverity warnings
Type: fix
Ticket: VPP-1837
Signed-off-by: Dave Barach <[email protected]>
Change-Id: I9ec87d2293d8f92c3e488a0f61083cf815ac496c
Benoît Ganne [Thu, 16 Apr 2020 08:57:41 +0000 (10:57 +0200)]
 
misc: asan: mark parsed elf memory as readable for ASan
Type: fix
Change-Id: Ic7441a09bab2cabc7632ee502368584ac022f997
Signed-off-by: Benoît Ganne <[email protected]>
Zhiyong Yang [Sat, 11 Apr 2020 14:36:55 +0000 (14:36 +0000)]
 
ethernet: leverage vlib_buffer_get_current
Type: improvement
Signed-off-by: Zhiyong Yang <[email protected]>
Change-Id: I0eaedeee03dd3b4453edec7fca2a5c741a98de23
Benoît Ganne [Tue, 21 Apr 2020 17:25:14 +0000 (19:25 +0200)]
 
misc: asan: disable leak sanitizer by default
Leak Sanitizer is not stable yet with VPP. It can always be enabled at
runtime with ASAN_OPTIONS=detect_leaks=1.
Type: fix
Change-Id: Ieff01091e2976e127783ebd331cd0e50a1dbca12
Signed-off-by: Benoît Ganne <[email protected]>
Zhiyong Yang [Fri, 27 Mar 2020 17:12:35 +0000 (17:12 +0000)]
 
ethernet: put vlib_get_buffers together
The patch brings 0.8 clocks saved per pkt in IPv4 l3fwd case on Skylake.
Type: improvement
Signed-off-by: Zhiyong Yang <[email protected]>
Change-Id: Ia8d3a27773bf959433380d7c219602b1e4a8e5bd
Benoît Ganne [Wed, 22 Apr 2020 07:02:48 +0000 (09:02 +0200)]
 
misc: asan: do not poison memory after munmap()
It is a bad idea to poison memory after munmap because the address space
can be reused (eg. for global data of dlopen()ed object) and ASan model
allows access by default.
Moreover, access to a stale address space will fault.
Type: fix
Change-Id: I356de422f255447d9d50a3a71fb0c2eaa790d731
Signed-off-by: Benoît Ganne <[email protected]>
Damjan Marion [Tue, 21 Apr 2020 18:14:34 +0000 (20:14 +0200)]
 
vppinfra: fix potential race in bihash bucket lock
Type: improvement
Change-Id: Ia04bd26ecd689894753e036e52920316de611910
Signed-off-by: Damjan Marion <[email protected]>
Damjan Marion [Tue, 21 Apr 2020 17:42:30 +0000 (19:42 +0200)]
 
vppinfra: improve bihash add/del performance
Measured improvement is from 439 to 167 clocks for add operation
in 16_8 case...
Type: improvement
Change-Id: I975ff46ff30b983a3ec80a5cde25ccb68d7fa03b
Signed-off-by: Damjan Marion <[email protected]>
Chenmin Sun [Fri, 27 Mar 2020 16:34:19 +0000 (00:34 +0800)]
 
dpdk: DPDK 20.05 iavf flow director backporting to DPDK 20.02
0001 ~ 0014 patches are for virtual channel and PMD
0015 is the iavf fdir framework
0016 ~ 0017 are for the iavf fidr driver
Type: feature
Signed-off-by: Chenmin Sun <[email protected]>
Change-Id: I38e69ca0065a71cc6ba0b44ef7c7db51193a0899
Amir Zeidner [Wed, 22 Apr 2020 07:11:57 +0000 (10:11 +0300)]
 
devices: Adding ConnectX-6 DX Device ID for validation
Type: fix
Change-Id: I3c7ebbe91e7dffe9fd6851e5334fe920f2187cf0
Signed-off-by: Amir Zeidner <[email protected]>
Dave Barach [Tue, 21 Apr 2020 12:01:16 +0000 (08:01 -0400)]
 
vat: fix increment_address(...)
vl_api_address_t uses a packed enum for the address family, compare
a->af directly with ADDRESS_IP4 / ADDRESS_IP6 instead of running a->af
through clib_host_to_net_u32(...) before compare.
Indirectly fixes api_ip_route_add_del(...) w/ count > 1.
Type: fix
Signed-off-by: Dave Barach <[email protected]>
Change-Id: Ib7f562ec9e92ee63e52a338d318fcf1ce6221755
Elias Rudberg [Thu, 16 Apr 2020 14:01:52 +0000 (16:01 +0200)]
 
vlib: queue_hi_thresh fix to avoid deadlock
Adapt queue_hi_thresh value using num_threads to avoid risk of deadlock
between threads which could happen for example when different NAT
threads try to handoff work to each other at the same time when their
frame queues are congested. This change ensures that each thread can
reserve a queue entry without causing problems even in the most extreme
case when all threads attempt to add to the same queue simultaneously
when the queue is nearly full.
Type: fix
Signed-off-by: Elias Rudberg <[email protected]>
Change-Id: I9e02f753bd00833d8dd500d181b0d4f9a454d703
Vladimir Ratnikov [Mon, 13 Apr 2020 10:36:19 +0000 (06:36 -0400)]
 
nat: dslite ce mode in separate config entry
Previously dslite was moved to separate plugin folder
and CE mode was removed. But it still needed.
This patch adds CE option to separate config entry
Type: feature
Signed-off-by: Vladimir Ratnikov <[email protected]>
Change-Id: If153ae08fa385ba5a6605cb412e49bbb4d1db46c
Dave Barach [Thu, 16 Apr 2020 16:00:14 +0000 (12:00 -0400)]
 
vppinfra: bihash improvements
Template instances can allocate BIHASH_KVP_PER_PAGE data records
tangent to the bucket, to remove a dependent read / prefetch.
Template instances can ask for immediate memory allocation, to avoid
several branches in the lookup path.
Clean up l2 fib, gpb plugin codes: use clib_bihash_get_bucket(...)
Use hugepages for bihash allocation arenas
Type: improvement
Signed-off-by: Dave Barach <[email protected]>
Signed-off-by: Damjan Marion <[email protected]>
Change-Id: I92fc11bc58e48d84e2d61f44580916dd1c56361c
Benoît Ganne [Fri, 17 Apr 2020 10:11:26 +0000 (12:11 +0200)]
 
sr: fix non-NULL terminated string overflow
Type: fix
Change-Id: Ia5ae0e893a5358f61353d20f444d88d79953e482
Signed-off-by: Benoît Ganne <[email protected]>
Florin Coras [Fri, 17 Apr 2020 20:15:22 +0000 (20:15 +0000)]
 
svm: check if fifo free list index is valid on alloc
Type: fix
Signed-off-by: Florin Coras <[email protected]>
Signed-off-by: Benoît Ganne <[email protected]>
Change-Id: Ib85c2f01dc7ec9858f2f88b89e209f989d78c5d9
Benoît Ganne [Fri, 17 Apr 2020 10:09:37 +0000 (12:09 +0200)]
 
session: fix use-after-free in input node
Type: fix
Change-Id: Ie60b07abe76ad166f048f5885accd7038d8153b2
Signed-off-by: Benoît Ganne <[email protected]>
Florin Coras [Sun, 19 Apr 2020 22:41:55 +0000 (22:41 +0000)]
 
session: avoid rx notifications on accepting sessions
Type: fix
Signed-off-by: Florin Coras <[email protected]>
Change-Id: Iba37e528e968104c3ba9c8324438ba695ddddfd1
Florin Coras [Sun, 19 Apr 2020 23:12:08 +0000 (23:12 +0000)]
 
vcl: ensure sessions are open on select events
Type: fix
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I4d56b61af574dfdaf6028160ce331606bdf65609
Florin Coras [Mon, 20 Apr 2020 01:32:38 +0000 (01:32 +0000)]
 
vcl: expand vcl select maps in ldp if needed
Type: fix
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I56c487821233cebf2146745a4706cb573cc088a5
Klement Sekera [Fri, 17 Apr 2020 18:04:59 +0000 (18:04 +0000)]
 
nat: remove unused code
Type: improvement
Signed-off-by: Klement Sekera <[email protected]>
Change-Id: If5c00faa309cf3e1ea8bdf8b23250041f6a499c4
Benoît Ganne [Thu, 16 Apr 2020 14:57:00 +0000 (16:57 +0200)]
 
gbp: fix l3-out anonymous test cleanup
Type: fix
Change-Id: Ib455b0a57f9b4f9cb82bb295c220270d0c6e5fe5
Signed-off-by: Benoît Ganne <[email protected]>
Simon Zhang [Sun, 19 Apr 2020 13:50:17 +0000 (21:50 +0800)]
 
tls: fix Picotls tx hang issue
Type: fix
Signed-off-by: Simon Zhang <[email protected]>
Change-Id: Id84fbe412c99b39a0754b892ca971dd3e4434264
Florin Coras [Sun, 19 Apr 2020 19:20:19 +0000 (19:20 +0000)]
 
session: fix half-open cleanup
Type: fix
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I931d23cf617c8f24fe9a02982ab129785bbd184d
Benoît Ganne [Thu, 16 Apr 2020 10:39:39 +0000 (12:39 +0200)]
 
lisp: fix use-after-free
Type: fix
Change-Id: I42c3e3514ba50d40e09ee688d083f3e78fa0713a
Signed-off-by: Benoît Ganne <[email protected]>
Andreas Schultz [Tue, 7 Apr 2020 11:40:36 +0000 (13:40 +0200)]
 
vat: fix static analysis warning
replace hand crafted version with existing vector function
Type: fix
Signed-off-by: Andreas Schultz <[email protected]>
Change-Id: I94834852469ed316c7bdbd48bb7f479648b2c8e5
Florin Coras [Fri, 17 Apr 2020 16:10:51 +0000 (16:10 +0000)]
 
tcp: cubic as default cc algorithm
Type: improvement
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I48ce827966667a767440149769eb1b24616ce4c1
Mohsin Kazmi [Fri, 10 Apr 2020 14:57:06 +0000 (14:57 +0000)]
 
virtio: fix to use chained descriptors when missing indirect descriptor
Some vhost-backed missing the VIRTIO_RING_F_INDIRECT_DESC feature.
Previously, vpp doesn't support jumbo frames using chained descriptors.
This patch fixes this issue.
Type: fix
Change-Id: I20487e201e88ea136b556ac84dde058019ab3e78
Signed-off-by: Mohsin Kazmi <[email protected]>
Alexander Chernavin [Fri, 3 Apr 2020 14:18:44 +0000 (10:18 -0400)]
 
dpdk: fix udp-encap for esp in transport mode
Now UDP encapsulation doesn't work in transport mode because:
 - the encrypt node misses filling of UDP header and it gets sent with
   all zeros;
 - the decrypt node misses filling of new IP header and it contains
   garbage data.
With this commit, fill UDP header during encryption and fill IP header
during decryption.
Change-Id: I87a7bd594f0e312b16d3e5eb19e568b4e3164d36
Type: fix
Signed-off-by: Alexander Chernavin <[email protected]>
Florin Coras [Thu, 16 Apr 2020 04:30:22 +0000 (04:30 +0000)]
 
session tcp: track half open in app wrk
Type: improvement
Do extra checks when establishing an active connect and cleanup pending
connects if application detaches.
Signed-off-by: Florin Coras <[email protected]>
Change-Id: Ibe9349db57b313ba2aa5ea3960ef5cf755f5098a
Florin Coras [Thu, 16 Apr 2020 18:47:27 +0000 (18:47 +0000)]
 
vcl: fix app destroy
Type: fix
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I21daa87b1a301142270a1bf20680dd9e9395aac9
Yu Sun [Thu, 16 Apr 2020 17:56:12 +0000 (13:56 -0400)]
 
vppinfra: install missing tw_timer_2t_2w_512sl header file
Type: improvement
Signed-off-by: Yu Sun <[email protected]>
Change-Id: I68aea7c5776c5b31081c98388df4133d2062218a
Mohsin Kazmi [Mon, 6 Apr 2020 12:19:54 +0000 (14:19 +0200)]
 
tap: add initial support for tun
Type: feature
Change-Id: I699a01ac925fe5c475a36032edb7018618bb4dd4
Signed-off-by: Mohsin Kazmi <[email protected]>
Benoît Ganne [Thu, 16 Apr 2020 10:38:48 +0000 (12:38 +0200)]
 
fib: fix use-after-free
Type: fix
Change-Id: Ie7081d977dd0d3e7d09bc0d1b4d53863288e443b
Signed-off-by: Benoît Ganne <[email protected]>
Benoît Ganne [Thu, 16 Apr 2020 10:40:04 +0000 (12:40 +0200)]
 
ipsec: fix use-after-free
Type: fix
Change-Id: I1068ff1d03883addb5fe1005a8b608eab17e4168
Signed-off-by: Benoît Ganne <[email protected]>
Benoît Ganne [Thu, 16 Apr 2020 10:40:54 +0000 (12:40 +0200)]
 
bier: fix vector size confusing ASan
The vector is initialized to 1024 entries which is guaranteed to be
enough, but as its size can shrink between calls, make sure ASan is
aware of the expected size before using it.
Type: fix
Change-Id: I4bcc39867a886b3cb463854d2cda0b32155650e9
Signed-off-by: Benoît Ganne <[email protected]>
Benoît Ganne [Thu, 16 Apr 2020 10:47:47 +0000 (12:47 +0200)]
 
igmp: fix igmp proxy group merge
When merging proxy groups in igmp_proxy_device_merge_group(), the call
to igmp_proxy_device_merge_src() can end up removing the current proxy
group via igmp_group_clear(). When that happens, it must returns NULL so
that igmp_proxy_device_merge_config() does not send a IGMPv3 report for
a dead proxy group.
Make igmp_group_clear() reset the group pointer to NULL to fix this bug
and to detect similar bugs more easily.
Type: fix
Change-Id: I229e55b5bfa71734d7844893f5209a66fa3cc8ae
Signed-off-by: Benoît Ganne <[email protected]>
Andreas Schultz [Thu, 16 Apr 2020 14:18:57 +0000 (16:18 +0200)]
 
udp: fix buffer trace
Type: fix
Signed-off-by: Andreas Schultz <[email protected]>
Change-Id: I774ca50582281cb3cc5e43417e74d178bf4909bd
Filip Varga [Mon, 6 Apr 2020 10:52:33 +0000 (12:52 +0200)]
 
nat: scavenging functionality removed
Type: refactor
Change-Id: I9f743ba2818e1b1c5004c3575925cc7b479948d8
Signed-off-by: Filip Varga <[email protected]>
Damjan Marion [Wed, 15 Apr 2020 18:37:54 +0000 (20:37 +0200)]
 
vppinfra: don't use memcmp to compare keys in cuckoo
Type: improvement
Change-Id: I7e11bf72be5fad5967724c038eb649a261294ca0
Signed-off-by: Damjan Marion <[email protected]>
Damjan Marion [Wed, 15 Apr 2020 17:44:17 +0000 (19:44 +0200)]
 
vppinfra: delay bucket2 calc in cuckoo search
There is no need to calculate bucket2 if there is hit on bucket1
Type: improvement
Change-Id: Id01c37963497668c0160068501294568a181d011
Signed-off-by: Damjan Marion <[email protected]>
Damjan Marion [Wed, 15 Apr 2020 15:45:23 +0000 (17:45 +0200)]
 
vppinfra: add clib_cuckoo_search_inline_with_hash function
Type: improvement
Change-Id: I547263ae954506f11101666ff768524fbfdb579e
Signed-off-by: Damjan Marion <[email protected]>
Dave Barach [Wed, 15 Apr 2020 13:34:43 +0000 (09:34 -0400)]
 
pg: set vnet buffer flags in pg streams
See .../extras/pg/checksum_offload.pg for a nontrivial example, which
deliberately sets bogus ip and udp checksums in the generated packets,
then fixes the mess with (software emulated) hardware checksum
offload.
Validated via "pcap dispatch trace on max 1000 buffer-trace pg-input 100".
Packets stuffed into loop1-output have the configured bogus ip and udp
checksums. vnet_calc_checksums_inline(...) fixes the checksums, which
are correct when packets visit loop1-tx.
The packet generator is a dumb robot in this regard. If you ask for a
ridiculous flag combination - example: ip4 and ip6 - your mileage may
vary.
Type: feature
Signed-off-by: Dave Barach <[email protected]>
Change-Id: I6d9e790f373bcd9e445a89113ca8e4c8f9aa9419
Damjan Marion [Wed, 15 Apr 2020 15:44:27 +0000 (17:44 +0200)]
 
vppinfra: install missing cuckoo hash header files
Type: improvement
Change-Id: Ifb4eec00fd4f1d19e4b0af802d015a35e402e0af
Signed-off-by: Damjan Marion <[email protected]>
Florin Coras [Tue, 14 Apr 2020 23:52:12 +0000 (23:52 +0000)]
 
session: detach session from app on cleanup
Type: fix
Avoids unwanted notifications.
Signed-off-by: Florin Coras <[email protected]>
Change-Id: Ifff27fb0d3644194e3bb3f91d7ed1fd02c6730cd
Neale Ranns [Wed, 15 Apr 2020 11:53:36 +0000 (11:53 +0000)]
 
urpf: Allow locally generated packets on TX
Type: fix
Change-Id: I87d301aec20b9f5b34997b394493c796188fce14
Signed-off-by: Neale Ranns <[email protected]>
Florin Coras [Fri, 10 Apr 2020 14:51:46 +0000 (14:51 +0000)]
 
tcp: allow local port sharing if 5-tuple available
Type: improvement
Signed-off-by: Florin Coras <[email protected]>
Change-Id: Id0c4b46247e7419a328387678a4753cfb1e42d75
Dave Barach [Sun, 12 Apr 2020 12:31:39 +0000 (08:31 -0400)]
 
misc: refactor calc_checksums
Merge two mildly incompatible static inlines, and rename the results
vnet_calc_checksums_inline (...).
The resulting inline has three additional parameters: int is_ip4, int
is_ip6, and int with_gso. All calls manage to pass one or more as
compile-time constants, which causes a certain amount of code to
disappear in each instantiation.
Type: refactor
Signed-off-by: Dave Barach <[email protected]>
Change-Id: I1a2a0e353b9a7bca20bc81318e8c915617261e1a
Dave Barach [Tue, 14 Apr 2020 13:52:26 +0000 (09:52 -0400)]
 
vat: fix socket connection
vat_socket_connect(...) needs to set the api main client index. The M2
helper macro needed to allocate a buffer of size sizeof(*mp) + n, not
sizeof(*mp).
Type: fix
Signed-off-by: Dave Barach <[email protected]>
Change-Id: I7abf35d2ba045d82765bd27f88899287fd351602
Florin Coras [Mon, 13 Apr 2020 23:35:55 +0000 (23:35 +0000)]
 
session: avoid all session cleanup on unlisten
Type: improvement
Signed-off-by: Florin Coras <[email protected]>
Change-Id: Ifff49366ad538bf2dd64487cae17e7457dff064f
Neale Ranns [Thu, 2 Apr 2020 15:02:16 +0000 (15:02 +0000)]
 
urpf: Unicast reverse Path Forwarding (plugin)
Type: feature
 - move the IP4 code to plugin
 - add ip6 support
 - add suport for uRPF on TX
 - add tests
Change-Id: I074c2debc486d3e79c12fad4b8dbd72c41e841a0
Signed-off-by: Neale Ranns <[email protected]>
Matthew Smith [Sat, 11 Apr 2020 01:27:33 +0000 (20:27 -0500)]
 
ipsec: validate number of input sas
Type: fix
There is a statically allocated array for inbound SAs which can hold
4 IDs. The input parameter containing the IDs of th inbound SAs is a
vector and Its possible to pass a vector with more than 4 elements
and write the memory past the end of the array. Fail if more than 4
SAs are passed in the vector.
Change-Id: I0c9d321c902d6366b8aff816d04e343dcbd110eb
Signed-off-by: Matthew Smith <[email protected]>
Florin Coras [Mon, 13 Apr 2020 16:48:04 +0000 (16:48 +0000)]
 
session: remove ho with fifos support
Type: refactor
UDPC (removed) was the only consumer.
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I2812bf58d3c68fe021ec73acaa1bd00ef3172846
Dave Barach [Thu, 9 Apr 2020 21:24:07 +0000 (17:24 -0400)]
 
buffers: configurable buffer fault injector
When configured at compile time via the cmake
VPP_BUFFER_FAULT_INJECTOR option, the buffer allocator will appear to
fail a certain fraction of the time.
By default, the allocator succeeds 80% of the time. Detailed command
line configuration options are available, but only when the image has
been compiled with cmake option described above:
    vlib { buffer-alloc-success-rate [0.0 ... 1.0]
           buffer-alloc-success-seed <nnnn> }
Modify vlib_buffer_pool_create(...) so 0 is always an invalid buffer
index.
Debug images: add checks for bad buffer index enqueues, and also
verify that f->n_vectors doesn't accidentally map one or more
instances of the frame poison pattern 0xfefefefe.
Type: improvement
Signed-off-by: Dave Barach <[email protected]>
Change-Id: Iab939858014463d1e664682805013d334d6fcbe5
Dave Barach [Thu, 9 Apr 2020 22:34:29 +0000 (18:34 -0400)]
 
dhcp: fix unicast pkts, clean up state machine
Send dhcp unicast packets to ip4-lookup. Otherwise, these packets
won't reach a dhcp server on a different subnet.
Do an immediate client scan after processing wakeup events.
Calculate the next process wakeup time by scanning all
clients.
Increase maximum (idle, no-clients-configured) timeout to 1000
seconds.
Reduce log spew.
Type: fix
Signed-off-by: Dave Barach <[email protected]>
Change-Id: I3d10cd4c353298ed0b19e7e30887dc1d8d07b19e
Florin Coras [Mon, 13 Apr 2020 01:20:25 +0000 (01:20 +0000)]
 
session: cleanup debug code
Type: refactor
Signed-off-by: Florin Coras <[email protected]>
Change-Id: Ie6c03195019fe18c547b22f4387d7f2b14b71461
Srikanth Akula [Tue, 7 Apr 2020 02:19:49 +0000 (19:19 -0700)]
 
session: adding debug events
Type: feature
Enhancing the debugging capability of tcp session layer by measing time spent for various events.
This is meant only for debugging purpose
Signed-off-by: Srikanth Akula <[email protected]>
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I9f401881b345bcae5f7d8050338637fd47b3723b
Signed-off-by: Srikanth Akula <[email protected]>
Simon Zhang [Sat, 11 Apr 2020 11:09:03 +0000 (19:09 +0800)]
 
tls: make ctx_write function return the length of enqueue
Type: fix
Signed-off-by: Simon Zhang <[email protected]>
Change-Id: Ia8656fe2c48799e53c1b2c064009848ad3457659
ShivaShankarK [Fri, 10 Apr 2020 12:50:02 +0000 (18:20 +0530)]
 
fib: fix accessing empty dpo pool elements
Type: fix
Signed-off-by: ShivaShankarK <[email protected]>
Change-Id: Iee88a2101ce42d7f1cdb65df532c349d14829e4c
Florin Coras [Fri, 10 Apr 2020 19:52:04 +0000 (19:52 +0000)]
 
udp: remove connected udp transport proto
Type: refactor
To reproduce functionality, use udp in combination with
TRANSPORT_CFG_F_CONNECTED transport flag set in connect and listen
parameters.
Signed-off-by: Florin Coras <[email protected]>
Change-Id: Id88470c38326f8168b9646b0de49a674e0f4266f
Aloys Augustin [Wed, 8 Apr 2020 20:15:25 +0000 (22:15 +0200)]
 
quic: fix clean stream close
Properly close the stream sending side instead of resetting the entire
stream.
Change-Id: I2daca7e507daa7bf9cd6a27fa8828a9ea7d175f9
Type: fix
Signed-off-by: Aloys Augustin <[email protected]>
Florin Coras [Fri, 10 Apr 2020 02:01:51 +0000 (02:01 +0000)]
 
udp: fix local node no port error counter
Type: fix
Signed-off-by: Florin Coras <[email protected]>
Change-Id: Ie0c5a86aedfa38fdcbb835aee7c9e91d59b222d6
Mohsin Kazmi [Thu, 9 Apr 2020 20:11:29 +0000 (22:11 +0200)]
 
virtio: fix gso and csum offload errors handling
GSO and CSUM offloaded packets are transmitted
even itf doesn't support GSO/CSUM. This patch
fixes it by logging the respective errors and
dropping the packets.
Type: fix
Change-Id: I5ab19d15ce6aa9fda515313c313a5a56c0b96837
Signed-off-by: Mohsin Kazmi <[email protected]>
Neale Ranns [Fri, 3 Apr 2020 07:46:28 +0000 (07:46 +0000)]
 
geneve: Fix the byte swapping for the VNI
Type: fix
- swipe away the vomit indent left last time.
- add tests for VNIs > 16bit
Change-Id: I2d1f591bfb9d7a18996c38969365a509168d4193
Signed-off-by: Neale Ranns <[email protected]>
ShivaShankarK [Thu, 9 Apr 2020 15:45:58 +0000 (21:15 +0530)]
 
fib: fix adjacency cli command issue
Type: fix
Signed-off-by: ShivaShankarK <[email protected]>
Change-Id: I193023705003e664c50487fdfaa42b813604a078