Florin Coras [Wed, 24 Nov 2021 00:20:15 +0000 (16:20 -0800)]
 
session: detach server from client on connect failure
Type: fix
Signed-off-by: Florin Coras <[email protected]>
Change-Id: Ie2ed2554578d6a2c671c552dc2bdc081f9754eed
Klement Sekera [Tue, 16 Nov 2021 11:22:25 +0000 (12:22 +0100)]
 
misc: vppctl - fix coverity warning
Check the return value and log failure in case send() fails.
Type: fix
Fixes: 
31f192434660
Signed-off-by: Klement Sekera <[email protected]>
Change-Id: I1809598ff4816f67c28a88264b6524b10d7ff6ce
Nathan Skrzypczak [Mon, 22 Nov 2021 16:44:30 +0000 (17:44 +0100)]
 
docs: add missing 21.10 rlsnotes
This patch extract the release notes that
went into v21.10 & v21.10.1 but that are
missing in master, due to the documentation
refactoring
Type: docs
Change-Id: Icb3c95c71e8cdc255f735990d19ee835e3ce6c6c
Signed-off-by: Nathan Skrzypczak <[email protected]>
Damjan Marion [Mon, 15 Nov 2021 14:33:11 +0000 (15:33 +0100)]
 
vppinfra: fallback to builtin memcpy if vector code is not enabled
Type: fix
Fixes: 
56f54af
Change-Id: I678ff3622640c911eefb57a9288ef95ed859eeb9
Signed-off-by: Damjan Marion <[email protected]>
Damjan Marion [Thu, 11 Nov 2021 17:34:01 +0000 (17:34 +0000)]
 
vppinfra: update CPU list
Type: improvement
Change-Id: Ibe1f23801d5eac6d1dae61c6df1a47d59455d42e
Signed-off-by: Damjan Marion <[email protected]>
Neale Ranns [Mon, 14 Sep 2020 07:41:48 +0000 (07:41 +0000)]
 
misc: deprecate gbp and its dependents
Type: improvement
Signed-off-by: Neale Ranns <[email protected]>
Signed-off-by: Benoît Ganne <[email protected]>
Change-Id: I2f30a4f04fd9a8635ce2d259b5fd5b0c85cee8c3
Ray Kinsella [Wed, 17 Nov 2021 10:03:04 +0000 (10:03 +0000)]
 
vxlan: multiarch optimization of vxlan
Fixing the mutliarch versions of vxlan, geneve and friends. Ensures that
main struct is correctly sized for all multiarch permutations.
Type: fix
Fixes: 
290526e3c
Signed-off-by: Ray Kinsella <[email protected]>
Change-Id: I7c4c435763a5dcb0c3b429cd4f361d373d480c03
Florin Coras [Tue, 23 Nov 2021 05:34:56 +0000 (21:34 -0800)]
 
devices: support build on older kernels
Type: improvement
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I10af028b5e57b36b8015b02240f1e4e9a42d0898
Florin Coras [Tue, 23 Nov 2021 05:25:39 +0000 (21:25 -0800)]
 
dpdk: enable vmxnet3 l4 checksum offload
Type: improvement
Signed-off-by: Florin Coras <[email protected]>
Change-Id: Ia25e671084dd2c0010c0577649bf51ba6495b6ac
Nathan Skrzypczak [Fri, 20 Aug 2021 13:53:43 +0000 (15:53 +0200)]
 
ip: unlock_fib on if delete
On interface delete we were not removing
the lock taken by a previous ip_table_bind()
call thus preventing the VRFs to be removed.
Type: fix
Change-Id: I11abbb51a09b45cd3390b23d5d601d029c5ea485
Signed-off-by: Nathan Skrzypczak <[email protected]>
Filip Varga [Mon, 22 Nov 2021 09:57:32 +0000 (10:57 +0100)]
 
nat: change nat44-ed test pool address
NAT pool address overlaps with pg4 network 10.0.0.1/24
this is not desirable because of upcoming change [1]. This
change uncovered configuration issue with hairpinning test
that would fail because of already configured pg4 interface
that  shares subnet with nat pool address. Packets would
incorectly end up in bad pg interface causing the test to fail.
This patch changes nat pool address to 10.0.10.3 that doesn't
belong to any of the subnets configured on pg interfaces in nat
tests.
[1] https://gerrit.fd.io/r/c/vpp/+/34441
Type: test
Change-Id: I49e63dacbf0847116adbcf1954ff5defd833a657
Signed-off-by: Filip Varga <[email protected]>
Benoît Ganne [Fri, 20 Aug 2021 07:18:31 +0000 (09:18 +0200)]
 
vlib: add virtual time support
Type: feature
Change-Id: Iabd76558e9c72ed8286cfeeb1fbaa4fde4832a90
Signed-off-by: Benoît Ganne <[email protected]>
Gabriel Oginski [Tue, 2 Nov 2021 11:19:01 +0000 (12:19 +0100)]
 
wireguard: add local variable in handshake process
Originally handshake process gets pointer to value of index peer.
In the meantime this pointer can be invalid due to resize hash table
for wireguard and passed poison value to another function.
The fixes add local variable to keep index of peer instead of value
from pointer.
Type: fix
Signed-off-by: Gabriel Oginski <[email protected]>
Change-Id: I1b2535c44b4f987d19077c75c778aaa5ed71a457
Mohsin Kazmi [Thu, 21 Oct 2021 20:20:24 +0000 (20:20 +0000)]
 
gso: implement gso segementation copy with checksum
Type: improvement
Signed-off-by: Mohsin Kazmi <[email protected]>
Change-Id: Iec9dacde170533ca16e8117787e62da8af69ae96
Klement Sekera [Thu, 18 Nov 2021 11:32:05 +0000 (12:32 +0100)]
 
vlib: fix coverity warning
Use correct signed type to allow testing for a failure (-1) from
readlinkat().
Type: fix
Fixes: 
5714a49f14
Signed-off-by: Klement Sekera <[email protected]>
Change-Id: I06f1c8d91e907c151012ff9758c6b52caca4d625
Klement Sekera [Fri, 19 Nov 2021 10:27:41 +0000 (11:27 +0100)]
 
dpdk: fix coverity warning
Add a hint so that it's obvious that fall through in switch statement is
intentional.
Type: fix
Fixes: 
34c54dff5c
Signed-off-by: Klement Sekera <[email protected]>
Change-Id: I12271227424761fb89b03a390f626c2ab466472c
Klement Sekera [Fri, 19 Nov 2021 10:49:48 +0000 (11:49 +0100)]
 
snort: fix coverity warning
Add error handling for incomplete read.
Type: fix
Fixes: 
839b1473e9
Signed-off-by: Klement Sekera <[email protected]>
Change-Id: Ibf1b2f633793510244ea1aa6af0902021aeb67ad
Klement Sekera [Fri, 19 Nov 2021 10:40:08 +0000 (11:40 +0100)]
 
snort: fix coverity warning
Add a cast to avoid coverity warning about potential integer underflow.
Type: fix
Fixes: 
839b1473e9
Signed-off-by: Klement Sekera <[email protected]>
Change-Id: Iae913e51c1e25aaeca6ce70438451c640d347383
Benoît Ganne [Fri, 19 Nov 2021 12:39:10 +0000 (13:39 +0100)]
 
vppinfra: annotate pool_dup() for asan
When using AddressSanitizer, pool objects are poisoned, but pool_dup()
deep copy is ok.
Type: fix
Change-Id: Id801c4ab35666474a297d885c4b92878e44feab6
Signed-off-by: Benoît Ganne <[email protected]>
Han Wu [Fri, 19 Nov 2021 09:45:40 +0000 (17:45 +0800)]
 
vppinfra: fix the memory leak while doing clib_bihash_free
Type: fix
Signed-off-by: Han Wu <[email protected]>
Change-Id: I6ad3c313dcab5ed193c135676c1cebd0a141fea1
Paul Atkins [Tue, 5 Oct 2021 07:51:48 +0000 (08:51 +0100)]
 
ipfix-export: support sending of ipv6 pkts
The current code that sends ipfix packets assumes IPv4. Modify this
so that it generates and sends packets based on whether the destination
address is IPv4 or IPv6. Where code is common across multiple places
pull it out into helper functions.
Type: improvement
Signed-off-by: Paul Atkins <[email protected]>
Change-Id: I216c6c4c1b58cacedca22019f74a38c64a368b7e
Paul Atkins [Mon, 4 Oct 2021 14:43:56 +0000 (15:43 +0100)]
 
ipfix-export: Change exp to use ip_address
Modify the ipfix_exporter to use ip_address instead of the ipv4 specific
version. Modify the current code so that it writes into the v4 specific
part of the address, i.e. we are not yet fully supporting IPv6.  For the
exporter configured via the original API (the one that is always in slot0)
we will not support IPv6 addresses.
Type: improvement
Signed-off-by: Paul Atkins <[email protected]>
Change-Id: Ic9854ac62aaee76a7a55a958234c456fd9828c4c
Paul Atkins [Mon, 4 Oct 2021 16:29:54 +0000 (17:29 +0100)]
 
ipfix-export: rename variables when building bufs
Rename the local variables used when building ipfix export packets to make
it clear that they are v4 specific variables.
Type: improvement
Signed-off-by: Paul Atkins <[email protected]>
Change-Id: I3a5a623aeb0b6f2b7fcdafb3fc19c500934c529b
Paul Atkins [Mon, 4 Oct 2021 15:29:52 +0000 (16:29 +0100)]
 
ipfix-export: refactor params to the callback fns
When a new flow-report is created the caller provides 2 callback functions.
These functions both take a pointer to the exporter, plus a pointer to the
source and dest address.  However the pointers to the address are not adding
any value as these are always set to the src/dest addresses of the exporter
(which is already being passed). Remove these parameters and leave the
callback functions to get the addresses out of the exporter.
Type: improvement
Signed-off-by: Paul Atkins <[email protected]>
Change-Id: I36dec394f30e85cdca120dd8706b5d90f5e07c48
Paul Atkins [Mon, 27 Sep 2021 20:30:13 +0000 (21:30 +0100)]
 
ipfix-export: Add APIs to get/send buffers
The ipfix exporter should be doing most of the work of building packets
and sending them rather than leaving every client of the exporter to do
all the work themselves. Start to move towards that by adding APIs to
get and send buffers. Store the state of this in new per thread data on
the report so that we can send with minimal use of atomics.  We do need
an atomic for the sequence number in the packet though as that contains
the number of data_records sent for the 'stream', not just for a single
core. As the state is stored on the flow_report_t the caller needs to
know which report they are using, so add a field to the args struct used
to create the report that is used to pass back the report index on success.
Type: improvement
Signed-off-by: Paul Atkins <[email protected]>
Change-Id: I222b98a3f0326b3b71b11e0866a8c9736bed6dc1
Paul Atkins [Thu, 23 Sep 2021 09:43:44 +0000 (10:43 +0100)]
 
ipfix-export: add mutliple ipfix_exporters tests
Now that we support multiple exporters add some basic tests to verify
that we can create/delete multiple exporters and that the streaming
commands work.
Type: test
Signed-off-by: Paul Atkins <[email protected]>
Change-Id: I577f38440790080bfdcf87a8a6828da6cb6f1707
Paul Atkins [Thu, 23 Sep 2021 08:28:50 +0000 (09:28 +0100)]
 
ipfix-export: add a new API to dump all exporters
Add a new API to dump all the exporters. As the destination struct
type is not the same as for the existing dump/details API no
attempt is made to use the existing code to populate the structure.
Type: improvement
Signed-off-by: Paul Atkins <[email protected]>
Change-Id: I409f80285b107a530e0e4f3c6a047a803815a0ec
Paul Atkins [Wed, 22 Sep 2021 13:56:17 +0000 (14:56 +0100)]
 
ipfix-export: support creating multiple exporters
The existing api set_ipfix_exporter only allows for the creation of
a single exporter. In some cases it is desirable to export data to
multiple different destinations.  Allow users to create multiple
ipfix exporters to support this.
Add a new api that allows for the creation of multiple exporters, and
store them in a pool of exporters. The exporter created by the old API
will always be in index 0 of the pool. Exporters created by the new API
will be given the next available index in the pool, and will return this
index to the API caller so that they can track the exporter they created.
The collector_address is the key for the exporter, so changes can be made
by doing a further call to the API with the same collector_address.
Type: improvement
Signed-off-by: Paul Atkins <[email protected]>
Change-Id: Id71c98cffcf8d141d890b40fb90a40b90a91d1d6
Paul Atkins [Wed, 22 Sep 2021 13:18:45 +0000 (14:18 +0100)]
 
ipfix-export: refactor ipfix_exporter_t_handler fn
Split this api handler into 2 parts. The first is the top level handler
and the second is the internal helper function that does all the work.
This is in preparation for having a similar API that allows multiple
exporters to exist at the same time.
Type: refactor
Signed-off-by: Paul Atkins <[email protected]>
Change-Id: Ibd4037682742f4c2f52b4cd1346d35fb2029461d
Paul Atkins [Wed, 22 Sep 2021 09:06:23 +0000 (10:06 +0100)]
 
ipfix-export: pass an exp to flow_report_add_del
Pass an ipfix_exporter to this function so that callers can choose which
exporter they are modifying.
Type: improvement
Signed-off-by: Paul Atkins <[email protected]>
Change-Id: Ice0ed19a57baf15b1dc85cd27fe01913e36d7f4f
Paul Atkins [Wed, 22 Sep 2021 07:15:03 +0000 (08:15 +0100)]
 
ipfix-export: make stream fns exporter aware
The functions that work on streams were getting the set of streams
directly from flow_report_main. Modify them to take an ipfix_exporter
as an argument, and then any processing they do is only for this
exporter.
Type: refactor
Signed-off-by: Paul Atkins <[email protected]>
Change-Id: I32bd9a6ba32a15ec4d4ec9556a9b75f3d83fcd6e
Paul Atkins [Tue, 21 Sep 2021 19:49:12 +0000 (20:49 +0100)]
 
ipfix-export: refactor fields in flow_report_main
Pull out the fields in flow_report_main_t that are specific to a single
exporter and move them into a new structure that represents an exporter.
Add a pool of exporters to flow_report_main_t and do a pool_get() to get
the entry at index 0, so that the existing users of the code need only
change the path at which they access the old fields and have no need to
make further code changes.  In functions that were accessing the fields
that now make up the ipfix_exporter create a local var that points to the
first (always valid) exporter and use this as the base for the fields
rather than finding them from flow_report_main.
This is in preparation for supporting multiple flow_exporters.
Note that at the moment the code supports multiple 'streams' for a given
exporter, where each stream has its own source port, domain id and template
space. But all streams within an exporter have the same destination address,
so this is not the same as multiple exporters.
Type: refactor
Signed-off-by: Paul Atkins <[email protected]>
Change-Id: I49f5c7fb9e901773351d31dc8a59178c37e99301
Florin Coras [Thu, 18 Nov 2021 23:25:31 +0000 (15:25 -0800)]
 
tls: add option to config additional segment size
Type: improvement
Signed-off-by: Florin Coras <[email protected]>
Change-Id: Idf3b49ec61bf5da498ffdd8cebab7148fce73f5f
Laszlo Kiraly [Tue, 2 Nov 2021 10:07:19 +0000 (11:07 +0100)]
 
build: (opensuse) Revert build remove opensuse build infra
Added missing deps
Removed Thumbleweed support
Changed python2 to python3
Added Dockerfile for suse-leap build
Type: make
Change-Id: Ie73d2382a73ebc9d4475ace1a8f818fe38cf40c0
Signed-off-by: Laszlo Kiraly <[email protected]>
Neale Ranns [Fri, 8 Oct 2021 07:30:47 +0000 (07:30 +0000)]
 
fib: Don't use [midchain] adjacencies to change an interface's feature arc
Type: fix
Using the adjacency to modify the interface's feature arc doesn't work, since there are potentially more than one adj per-interface.
Instead have the interface, when it is created, register what the end node of the feature arc is. This end node is then also used as the interface's tx node (i.e. it is used as the adjacency's next-node).
rename adj-midhcain-tx as 'tunnel-output', that's a bit more intuitive.
There's also a fix in config string handling to:
 1- prevent false sharing of strings when the end node of the arc is different.
 2- call registered listeners when the end node is changed
For IPSec the consequences are that one cannot provide per-adjacency behaviour using different end-nodes - this was previously done for the no-SA and an SA with no protection. These cases are no handled in the esp-encrypt node.
Signed-off-by: Neale Ranns <[email protected]>
Change-Id: If3a83d03a3000f28820d9a9cb4101d244803d084
arikachen [Wed, 10 Nov 2021 08:51:51 +0000 (08:51 +0000)]
 
af_xdp: integrate with new tx infra
Type: improvement
Signed-off-by: arikachen <[email protected]>
Signed-off-by: Benoît Ganne <[email protected]>
Change-Id: If8d57bcf033864935bd5e3a9912b2c1a7c712f44
arikachen [Fri, 12 Nov 2021 06:40:55 +0000 (06:40 +0000)]
 
af_xdp: introduce to netns api
In some situation, we support to deploy vpp as per host
and handler packet in container, so we use xdp to redirect
the flow.
Type: improvement
Signed-off-by: arikachen <[email protected]>
Change-Id: Iab42d6a0abb2b330a284d519018a90aff2fa4371
Florin Coras [Thu, 18 Nov 2021 07:57:30 +0000 (23:57 -0800)]
 
session: deprecate mq segments baseva
Type: improvement
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I5b6cb8dd9db7e003a470ca4aeb8472fa7cb9a128
Florin Coras [Thu, 18 Nov 2021 07:38:54 +0000 (23:38 -0800)]
 
session: improve wrk mq segment allocation
Type: improvement
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I9e5438a2f82762aa8a88bbacf4290151ef30969e
Neale Ranns [Mon, 25 Oct 2021 09:47:09 +0000 (09:47 +0000)]
 
ip: comparing IP prefixes should not modify them
Type: improvement
make the ip_prefix_cmp take const paramenters.
plus some other miscellaneous functions.
Signed-off-by: Neale Ranns <[email protected]>
Change-Id: Ib69bacfb09483a8a8f8b89900c92d3d55c354ac6
Florin Coras [Wed, 17 Nov 2021 19:41:10 +0000 (11:41 -0800)]
 
session: fix state check in switch pool
This affect udp only
Type: fix
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I5e05e9c77b733b9e10c14cc9ef610c9bff216fa0
Florin Coras [Tue, 16 Nov 2021 20:45:43 +0000 (12:45 -0800)]
 
session: support close during migration
Type: improvement
Signed-off-by: Florin Coras <[email protected]>
Change-Id: Ife1e046b62bb0679419fd1346e973d0e3ea55489
Florin Coras [Tue, 16 Nov 2021 03:01:52 +0000 (19:01 -0800)]
 
session: try to coalesce ct accept rpcs
Type: improvement
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I11de851949afd90a37c102ed0c00969a4cc73df4
Paul Atkins [Fri, 12 Nov 2021 13:09:46 +0000 (13:09 +0000)]
 
ip6: ip6_not_enabled_node is a sibling of ip6-drop
The node ip6_not_enabled should be marked as sibling of
ip6-drop as both are start nodes of the ip6-drop arc.
Type: fix
Signed-off-by: Paul Atkins <[email protected]>
Change-Id: I212c25444a81b11d8085ba7930ddb67b47502d5c
Paul Atkins [Wed, 22 Sep 2021 10:44:40 +0000 (11:44 +0100)]
 
ipfix-export: remove unused code in flow_report.h
There are no implementations for this function so remove it.
Type: improvement
Signed-off-by: Paul Atkins <[email protected]>
Change-Id: I793b015ea1657edd1de719c2a574799aeb8b74d5
Paul Atkins [Tue, 21 Sep 2021 20:08:14 +0000 (21:08 +0100)]
 
ipfix-export: tidy code style in flow_report.c
Indent sections of code properly in vec_foreach loops.
Type: style
Signed-off-by: Paul Atkins <[email protected]>
Change-Id: I90183ace164df753f3f47b6c4a6305ded21d744d
Paul Atkins [Thu, 23 Sep 2021 09:55:25 +0000 (10:55 +0100)]
 
ipfix-export: set msg id correctly for dump msg
When sending the reply to the VL_API_IPFIX_EXPORTER_DUMP message the
message id has to be added to the message base.
Type: fix
Signed-off-by: Paul Atkins <[email protected]>
Change-Id: I9565be7887046739b5f309e021f34ed75c9e370e
Paul Atkins [Wed, 29 Sep 2021 12:33:30 +0000 (13:33 +0100)]
 
misc: Volunteer as maintainer for ipfix-export
Type: improvement
I volunteer myself as another maintainer of the ipfix-export code.
Signed-off-by: Paul Atkins <[email protected]>
Change-Id: I1d0b7f1d426447cb6b52a7b4c4fdcd8b73bc122e
Daniel Béreš [Mon, 4 Oct 2021 07:51:59 +0000 (07:51 +0000)]
 
nat: VPP crashes when route is not reachable
The problem was reproducible only with icmp packet type
when det44 in, out interfaces were swapped.
Dst addr was unknown but packet has been forwarded.
Type: fix
Ticket: VPP-1958
Signed-off-by: Daniel Béreš <[email protected]>
Change-Id: Ie446cf2ac866955cc668fe2848f954a2ef92e3fa
Filip Varga [Mon, 8 Nov 2021 19:29:36 +0000 (20:29 +0100)]
 
nat: det44 plugin session scavenging fix
det44 plugin process node would only run once on
the first plugin enable call. this patch ads
the required calls into while loop in the
process node funciton.
Type: fix
Change-Id: I38c94b29fd1e2c842a1330e8628e3019f23f2b69
Signed-off-by: Filip Varga <[email protected]>
Paul Atkins [Wed, 29 Sep 2021 12:30:53 +0000 (13:30 +0100)]
 
misc: Add maintainer entry for ipfix-export
Type: improvement
Add Ole as a maintainer for the ipfix-export code
Signed-off-by: Paul Atkins <[email protected]>
Change-Id: I659292666d32cd223dfa31e00c7b5d005d1fbad5
Klement Sekera [Tue, 16 Nov 2021 11:39:12 +0000 (12:39 +0100)]
 
vlib: fix coverity warning
Remove now unused computation result.
Type: fix
Fixes: 
3f8b8d30cade20afa8975a5e7a6d79346cec8f3e
Signed-off-by: Klement Sekera <[email protected]>
Change-Id: Iea142cb044d31e364fdc5b8b6dd69681e77d745f
Dave Wallace [Fri, 12 Nov 2021 23:25:32 +0000 (18:25 -0500)]
 
build: upgrade to enchant-2
- Remove enchant from RPM builds since docs are
  generated on ubuntu-20.04 in CI jobs.
- Clean up DEB_DEPENDS copy-pasta
- Add clang-11 for newest Ubuntu/Debian OS
  variants
Type: docs
Signed-off-by: Dave Wallace <[email protected]>
Change-Id: I802f0b356bd412dbc23ee98d209f7cc3ab24ba4c
Nathan Skrzypczak [Fri, 29 Oct 2021 10:05:29 +0000 (12:05 +0200)]
 
docs: consume fd.io version list
Type: feature
This adds a version snippet in the
vpp docs, based on a json description
fetched from fd.io/vpp_versions.json
This relies on https://github.com/FDio/site/pull/108
being merged
Change-Id: I6dd22f09927841aef96011ed57af2cbdc5d409f5
Signed-off-by: Nathan Skrzypczak <[email protected]>
Klement Sekera [Tue, 16 Nov 2021 11:32:59 +0000 (12:32 +0100)]
 
perfmon: fix coverity warning
Check for possible hash lookup failure to avoid NULL dereference.
Type: fix
Fixes: 
e15c999c30
Signed-off-by: Klement Sekera <[email protected]>
Change-Id: Ib806b4d124be26fbccf36fe9d19af1aec63f487b
Dave Wallace [Fri, 12 Nov 2021 20:55:44 +0000 (15:55 -0500)]
 
build: Remove ubuntu-18.04 install dependencies
- Per agreement at VPP community meeting, end support for
  ubuntu-18.04
Type: make
Signed-off-by: Dave Wallace <[email protected]>
Change-Id: I20ae1531e571ba0aad233d47c2e5b73ee3f964b6
Florin Coras [Mon, 15 Nov 2021 22:01:02 +0000 (14:01 -0800)]
 
session: add per worker ct context
Type: improvement
Signed-off-by: Florin Coras <[email protected]>
Change-Id: Ie20dc1e369735965bd780f04cd8703c099065fcc
Klement Sekera [Mon, 15 Nov 2021 14:52:37 +0000 (15:52 +0100)]
 
vapi: verify message size when received
Verifying message size including VLA size allows to dismiss some
coverity warnings in generated code.
Type: improvement
Signed-off-by: Klement Sekera <[email protected]>
Change-Id: I824658881254b3e7a9bfca228a266cfee448cc2e
Nathan Skrzypczak [Thu, 4 Nov 2021 09:06:51 +0000 (10:06 +0100)]
 
docs: add jira link
Type: improvement
Change-Id: I9c53ff39e6d064437b5a2fdc29ecc2301b5cbd16
Signed-off-by: Nathan Skrzypczak <[email protected]>
Florin Coras [Sun, 14 Nov 2021 23:33:59 +0000 (15:33 -0800)]
 
session: postpone ct segment delete
Only delete segments only after both server and client detach.
Type: improvement
Signed-off-by: Florin Coras <[email protected]>
Change-Id: Idea6b2141f406aad1f19a5312ecea89d35f2b5de
Filip Tehlar [Mon, 15 Nov 2021 10:26:56 +0000 (10:26 +0000)]
 
vcl: add DSCP support in VCL
Type: feature
Signed-off-by: Filip Tehlar <[email protected]>
Change-Id: I835675267c997b5dc92a0aaccdb58648bc786bb9
Andrew Yourtchenko [Sun, 14 Nov 2021 23:40:18 +0000 (00:40 +0100)]
 
misc: vppctl - remove the dependency on vppinfra
56f54af21d18f9fdd471b81db77a3942b0aa4d9c introduced the new memcpy.
It also made a vector support mandatory in order to compile anything
that depends on vppinfra.
This broke extras/scripts/build_static_vppctl.sh
Since the vppctl is just a two-pronged epoll+basic telnet client handler,
remove dependencies on the vpp infra libs, and trim the build script accordingly.
Change-Id: I394bc65c485cbf8e7143a818ca0c86367bb15d90
Type: improvement
Signed-off-by: Andrew Yourtchenko <[email protected]>
Dmitry Valter [Sun, 14 Nov 2021 17:05:44 +0000 (17:05 +0000)]
 
vppinfra: fix masks in AVX512 clib_count_equal_*
Mask result of uAxB_is_equal_mask when buffer is masked. Otherwise it
return vector length B as a result for zeroed words.
This bug caused crashes in error_drop in tests on Ice Lake.
Type: fix
Fixes: 
7459be1b3626b608e60df574343a1432a068ebce
Change-Id: I56183e77f8a8ab6c530e79b465067958de84dceb
Signed-off-by: Dmitry Valter <[email protected]>
Mohsin Kazmi [Mon, 15 Nov 2021 11:12:51 +0000 (11:12 +0000)]
 
memif: fix the coverity warning
Type: fix
Fixes: 
2bae16b238bd ("memif: fix the default txq placement")
Signed-off-by: Mohsin Kazmi <[email protected]>
Change-Id: I8fbb2aa92dc31d84a5cd0f7b9a3c7f39dfb064ee
Ray Kinsella [Mon, 15 Nov 2021 06:48:50 +0000 (06:48 +0000)]
 
perfmon: rename bundle to memory stalls
Rename the memory bandwidth bundle to memory stalls, to differentiate it
from the bundle that measures memory controller bandwidth boundedness.
Type: refactor
Signed-off-by: Ray Kinsella <[email protected]>
Change-Id: I828c73b6f769046e1ab592712bdf81ceefcd7911
Neale Ranns [Fri, 8 Oct 2021 07:16:12 +0000 (07:16 +0000)]
 
fib: re-evaluate the import/export state of a prefix.
Type: fix
re-evaluate the import/export state of a prefix when the interface it is attached to rebinds to a different table.
Only attached routes have import/export requirements, so we can back walk from the glean adjacency when the interface rebinds tables.
There are two cases to consider.
 1. the rebind may change the prefix from/to import
 2. the import VRF may change
Signed-off-by: Neale Ranns <[email protected]>
Change-Id: I25b6af43b3b2d8f701dfbe7a08710dc56b3f5778
Daniel Béreš [Thu, 11 Nov 2021 09:16:44 +0000 (09:16 +0000)]
 
flowprobe: right values in records from subinterfaces
Skip 802.1q headers due to correct EtherType, ip addresses, ports.
Ticket: VPP-1997
Type: fix
Change-Id: I1a552fa6abe5b1459dd7d2c5ac6ad0f62c51417c
Signed-off-by: Daniel Béreš <[email protected]>
Filip Tehlar [Thu, 21 Oct 2021 14:07:31 +0000 (14:07 +0000)]
 
session: add support for DSCP
Type: feature
Signed-off-by: Filip Tehlar <[email protected]>
Change-Id: I817b1503ada1ae53c1134a85263f9b801d74e88a
Damjan Marion [Fri, 12 Nov 2021 15:00:24 +0000 (16:00 +0100)]
 
hash: refactor crc32_5tuple
Type: improvement
Change-Id: I31cae2367e2ec7fc89991ca0df994a73da93aaed
Signed-off-by: Damjan Marion <[email protected]>
Damjan Marion [Fri, 12 Nov 2021 11:32:47 +0000 (12:32 +0100)]
 
srtp: fix uninitialized value
Type: fix
Fixes: 
6621abf
Change-Id: I7cd4d6344613c950cc0018bed7306b8840292221
Signed-off-by: Damjan Marion <[email protected]>
Damjan Marion [Thu, 11 Nov 2021 18:46:08 +0000 (19:46 +0100)]
 
build: remove unnecesary link deps
Change-Id: I560c505ff754bf6856094c16494530a855fe287b
Type: make
Signed-off-by: Damjan Marion <[email protected]>
Florin Coras [Thu, 11 Nov 2021 17:24:34 +0000 (09:24 -0800)]
 
session: fix ct tracking of actual transport proto
Type: fix
Signed-off-by: Florin Coras <[email protected]>
Change-Id: If6a0b0ba9efc95180bdd2e26a1422663ab957ea0
Mohsin Kazmi [Thu, 11 Nov 2021 18:17:27 +0000 (19:17 +0100)]
 
virtio: improve the inline of clib_memcpy_fast
Type: refactor
Change-Id: Ia13a9cf6480aac280f3d287c59908e84c29c3443
Signed-off-by: Mohsin Kazmi <[email protected]>
Mohsin Kazmi [Thu, 11 Nov 2021 15:40:10 +0000 (15:40 +0000)]
 
memif: fix the default txq placement
Type: fix
Fixes: 
3effb4e63068 ("memif: integrate with new tx infra")
"memif: integrate with new tx infra" patch integrated memif
with new tx infra. There might be scenarios when txqs were
less than vpp threads, in which case, txqs should be shared
among threads. This patch fixes it.
Signed-off-by: Mohsin Kazmi <[email protected]>
Change-Id: I1c64a1370f5024240ab56311f75665db31714b60
Ole Troan [Thu, 11 Nov 2021 18:22:12 +0000 (19:22 +0100)]
 
tests: make code coverage for unit tests optional
Add a new cmake option VPP_BUILD_TESTS_WITH_COVERAGE to enable
building unittests with clang code coverage.
Type: improvement
Signed-off-by: Ole Troan <[email protected]>
Change-Id: I9cbe9e3031afdcd03bc8f9203d662b91677724ab
Signed-off-by: Ole Troan <[email protected]>
Florin Coras [Thu, 11 Nov 2021 06:44:52 +0000 (22:44 -0800)]
 
vcl: notify vpp if connected inexistent session
Type: improvement
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I6939a0cdb02067440dce01cb0771f07099ca841e
Filip Varga [Thu, 21 Oct 2021 12:27:43 +0000 (14:27 +0200)]
 
nat: nat44-ei/ed nat objects cleanup improvements
Improvements:
* Changed plugin disable call behavior from freeing data types
to calling appropriate nat plugin object delete calls for
pool addresses, mappings and interfaces.
* Added wrapper nat44_ei/ed_add_del_static_mapping function to
handle switch bound static mappings. This would also fix ip assignment
callback add/del bound static mapping issue preventing creation of the
mapping.
Fixes:
 * Fixed lingering object issue: some nat intertwined objects would
not free each other if not correctly deleted in proper order.
 * Fixed incorect order of FIB unlocks for pool addresses causing
syslog messages to use deleted FIBs in multiple VRF configuration.
 * Fixed incorrect value testing of flags instead of vrf_id for
multiple vrf configuration static mapping.
Type: improvement
Change-Id: I2743f7b1104b627bcc5ef937e3a50655313a26ea
Signed-off-by: Filip Varga <[email protected]>
Damjan Marion [Mon, 8 Nov 2021 11:18:30 +0000 (11:18 +0000)]
 
vppinfra: new vectorized ip checksum functions incl. csum_and_copy
Type: improvement
Change-Id: Id5810b7f4a6d6e4ce16b73c235b50db5d475ebf7
Signed-off-by: Damjan Marion <[email protected]>
Dave Barach [Wed, 10 Nov 2021 21:40:46 +0000 (16:40 -0500)]
 
vppinfra: deprecate test_mheap.c
The original mheap allocator found the exit a long time ago,
move test_mheap.c to .../extras/deprecated/vppinfra
Type: test
Signed-off-by: Dave Barach <[email protected]>
Change-Id: Ib1ed40ac605ad76f33c22a681a6df867985bbbba
Steven Luong [Wed, 10 Nov 2021 16:54:38 +0000 (08:54 -0800)]
 
ip: crash in ip_csum_fold due to illegal instruction shrx
Encounter a crash for the line
	shrx   edi,eax,edi
in ip_csum_fold. The target cpu is ivy bridge which does not support
shrx instruction.
Type: fix
Fixes: 
e6709ff37dc0f3a58ed5ad98aace73fe801f1e9d
Signed-off-by: Steven Luong <[email protected]>
Change-Id: Icc922d3b2ebfcfa721f63946a213b6c492874a9a
Damjan Marion [Tue, 12 Oct 2021 18:30:02 +0000 (20:30 +0200)]
 
vppinfra: new memcpy for x86_64
Change-Id: I5a5055580479960ac53e3f989aa188faf57fb05d
Type: improvement
Signed-off-by: Damjan Marion <[email protected]>
Florin Coras [Wed, 10 Nov 2021 15:39:51 +0000 (07:39 -0800)]
 
ip: always set ip rx_sw_if_index
Type: improvement
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I43f6bfa028ee37227f27a2fe0303662bf2631b10
Filip Varga [Thu, 21 Oct 2021 11:00:27 +0000 (13:00 +0200)]
 
nat: api autoendian fix
Fixed bad use of macros for autoendian API calls
and updated tests for the new API. Removed sw_if_index
check macro because of ntol conversion. Changed
REPLY_MACRO to REPLY_MACRO_END to fix ntohl conversions.
Type: fix
Change-Id: I878a07b3f80fe03179feab60f0abc662f408a2c8
Signed-off-by: Filip Varga <[email protected]>
arikachen [Tue, 9 Nov 2021 05:49:04 +0000 (13:49 +0800)]
 
af_xdp: fix thread 0 and 1 using one txq slot
Type: fix
Signed-off-by: arikachen <[email protected]>
Change-Id: Id0e98e0a1b04f2c1aba2c261b4e51fd53a4ee824
Damjan Marion [Tue, 9 Nov 2021 23:44:17 +0000 (00:44 +0100)]
 
misc: update extras/scripts/lsnet
Type: improvement
Change-Id: Iea45fa535ca562a1d424fd3d46b557a7d4775505
Signed-off-by: Damjan Marion <[email protected]>
Dave Wallace [Tue, 9 Nov 2021 18:58:12 +0000 (13:58 -0500)]
 
build: install clang-format-11
- Don't make it the default yet
Type: make
Change-Id: I3aabfd32f7ffd99e10db372747a0ba65fdc76db2
Signed-off-by: Dave Wallace <[email protected]>
Florin Coras [Tue, 9 Nov 2021 18:42:43 +0000 (10:42 -0800)]
 
session: reset if ct close with data
Type: improvement
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I9540948b8b5476af7558d741cbf15ee838d4e01b
Florin Coras [Tue, 9 Nov 2021 16:38:24 +0000 (08:38 -0800)]
 
session: postpone ct cleanups
Add infra to postpone cleanups while tx events are not delivered.
Type: improvement
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I7611ac2442116f71a229569a7e274eb58eb84546
Neale Ranns [Tue, 9 Nov 2021 16:15:48 +0000 (16:15 +0000)]
 
tests: Remove the error output from the linux-cp tests
Type: test
Signed-off-by: Neale Ranns <[email protected]>
Change-Id: Ib9899327897f36219c113fedb25366cd1be463a0
Damjan Marion [Tue, 9 Nov 2021 15:16:35 +0000 (16:16 +0100)]
 
build: missing clang in deps for ubuntu 20.04
Type: make
Change-Id: Ica706f0284873f6bd8b8d868c965812a139748cf
Signed-off-by: Damjan Marion <[email protected]>
Dave Wallace [Mon, 8 Nov 2021 17:23:01 +0000 (12:23 -0500)]
 
tests: fix missing dataclasses module in python 3.6
Type: fix
Fixes: 
b8165b96f
Signed-off-by: Dave Wallace <[email protected]>
Change-Id: Ic82a0404073a26e3d160b01c9038cde11eedf3ec
Daniel Béreš [Wed, 3 Nov 2021 08:55:04 +0000 (08:55 +0000)]
 
memif: memif linkstate can't become up
Admin down implies Link down but nothing came with admin up.
Ticket: VPP-1959
Type: fix
Change-Id: I43725329ae7918659c73d703280c25de5f0b1d14
Signed-off-by: Daniel Béreš <[email protected]>
Florin Coras [Mon, 8 Nov 2021 21:35:28 +0000 (13:35 -0800)]
 
tcp: refactor reset node
Use vectorized buffer translate function and refactor tracing.
Type: refactor
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I5a014cea1a753eb10a564ac316c1727a18f884ff
Damjan Marion [Thu, 28 Oct 2021 21:03:04 +0000 (23:03 +0200)]
 
vppinfra: vectorized index to pointer function
Type: improvement
Change-Id: I05e1a8fa31761b113355123429d72da18881d4b0
Signed-off-by: Damjan Marion <[email protected]>
Damjan Marion [Sat, 6 Nov 2021 12:26:58 +0000 (13:26 +0100)]
 
vppinfra: clib_count_equal_* tests
Type: improvement
Change-Id: I8f75cd9ce78ce686985e65c75dcddf498cef7621
Signed-off-by: Damjan Marion <[email protected]>
Damjan Marion [Fri, 5 Nov 2021 19:44:09 +0000 (20:44 +0100)]
 
vppinfra: AVX512 in clib_count_equal_*
Type: improvement
Change-Id: I8105d396cfc984e00cf5137bc57122510f5e6437
Signed-off-by: Damjan Marion <[email protected]>
Damjan Marion [Sat, 6 Nov 2021 16:09:37 +0000 (17:09 +0100)]
 
build: -Wno-stringop-overflow during LTO phase
Type: make
Change-Id: I735fa411366c41981e255921eceb18ebbb4b5fe1
Signed-off-by: Damjan Marion <[email protected]>
Ray Kinsella [Mon, 8 Nov 2021 07:22:49 +0000 (07:22 +0000)]
 
perfmon: fix iio-bw coverity issues
Fixes an number of coverity issues associated with the iio-bw feature.
Type: fix
Fixes: 
e15c999c3
Signed-off-by: Ray Kinsella <[email protected]>
Change-Id: I9ad2b336694132545d90a3483200a510226e9198
Tianyu Li [Thu, 29 Jul 2021 05:39:24 +0000 (13:39 +0800)]
 
l2: fix array-bounds error for prefetch on Arm
make build-release CC=gcc-10
vpp/src/vppinfra/cache.h:73:31: error: array subscript 80 is outside
array bounds of ‘l2_in_out_feat_arc_main_t[1]’ [-Werror=array-bounds]
__builtin_prefetch (_addr + (n) *CLIB_CACHE_PREFETCH_BYTES,
_CLIB_PREFETCH (3, size, type);
vpp/src/vnet/l2/l2_in_out_feat_arc.c:260:3:
note: in expansion of macro ‘CLIB_PREFETCH’
CLIB_PREFETCH (next_node_indices, 2 * CLIB_CACHE_LINE_BYTES, LOAD);
2 * CLIB_CACHE_LINE_BYTES is 256 bytes on Arm, the offset is out of range of
fam->feat_next_node_index[1], which is 128 bytes, use sizeof array instead.
Type: fix
Signed-off-by: Tianyu Li <[email protected]>
Change-Id: Ib7e06fcb643b2e863985ba89efcc274076752133
Gabriel Oginski [Wed, 22 Sep 2021 10:32:46 +0000 (11:32 +0100)]
 
crypto-native: fix uninitialized variable
Type: fix
Fixed coverity-issue CID 208547.
Originally using uninitialized value when calling one function.
This patch fixes the problem by initializing value for one variable.
Signed-off-by: Gabriel Oginski <[email protected]>
Change-Id: Iccfae1e825b4ca4d95a6f724d9b5c51c5addd1b2