Florin Coras [Fri, 12 Aug 2022 02:28:58 +0000 (19:28 -0700)]
 
http_static: validate session before sending
Type: fix
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I18b9d0d67f5fe4c1714427259df29026153d8dd1
Dave Wallace [Thu, 11 Aug 2022 19:29:54 +0000 (15:29 -0400)]
 
build: remove cnxk support from dpdk external deps
- the cnxk code fails to link using the gcc-11 toolchain
  included in the ARM64 Ubuntu-22.04 distro. This is required
  for Ubuntu-22.04 CI jobs (both docker image building & CI
  job execution on ARM64)
- Currently unable to replicate this failure on the dpdk repo.
Type: fix
Change-Id: Ice44aef9f0f721b4c88ac78f92a14bda87dc80a6
Signed-off-by: Dave Wallace <[email protected]>
Xiaoming Jiang [Thu, 11 Aug 2022 15:04:48 +0000 (15:04 +0000)]
 
ip: only set rx_sw_if_index when connection found to avoid following crash like tcp punt
Type: fix
Signed-off-by: Xiaoming Jiang <[email protected]>
Change-Id: I894a881cec1888b392d26fdfb385f97c31113ef1
Neale Ranns [Tue, 9 Aug 2022 01:24:41 +0000 (01:24 +0000)]
 
mpls: Use the .api for the definition of error/info counters
Type: improvement
Signed-off-by: Neale Ranns <[email protected]>
Change-Id: I9d25f5459ab70d9cf8556e44cfddfd7029e5b540
Neale Ranns [Tue, 9 Aug 2022 03:03:29 +0000 (03:03 +0000)]
 
ip: Use .api declared error counters
Type: improvement
Signed-off-by: Neale Ranns <[email protected]>
Change-Id: I822ead1495edb96ee62e53dc5920aa6c565e3621
Neale Ranns [Tue, 9 Aug 2022 03:34:51 +0000 (03:34 +0000)]
 
ipsec: Use .api declared error counters
Type: improvement
Signed-off-by: Neale Ranns <[email protected]>
Change-Id: Ica7de5a493389c6f53b7cf04e06939473a63d2b9
Neale Ranns [Tue, 9 Aug 2022 00:59:37 +0000 (00:59 +0000)]
 
arp: Use the new style error count declaration
Type: improvement
Signed-off-by: Neale Ranns <[email protected]>
Change-Id: Ifda8ca8d26912c750a77d2ca889e1638ca83d85a
Matthew Smith [Fri, 22 Apr 2022 18:02:32 +0000 (18:02 +0000)]
 
linux-cp: FIB lookup for P2MP tunnel interfaces
Type: improvement
If a tun/L3 interface is paired with a multipoint tunnel interface,
pass packets arriving from the host to ip[46]-lookup instead of
cross-connecting them to the tunnel interface. Adjacencies are used
to drive the rewrite for Multipoint tunnel interfaces, so the generic
adjacency used with a P2P tunnel will not work correctly.
Change-Id: I2d8be56dc5029760978c05bc4953f84c8924a412
Signed-off-by: Matthew Smith <[email protected]>
Neale Ranns [Thu, 5 May 2022 06:07:20 +0000 (06:07 +0000)]
 
tunnel: Fix API encoding of tunnel flags
Type: fix
API and internal flags do not match 1:1.
Signed-off-by: Neale Ranns <[email protected]>
Change-Id: I0f4e53b2e071d1c9fffd1b97bf28b4789887b032
Atzm Watanabe [Tue, 9 Aug 2022 05:00:03 +0000 (14:00 +0900)]
 
ikev2: do not accept rekey until old SA is deleted
Type: fix
Signed-off-by: Atzm Watanabe <[email protected]>
Change-Id: I11b6107492004a45104857dc2dae01b9a5a01e3b
Neale Ranns [Tue, 9 Aug 2022 00:03:17 +0000 (00:03 +0000)]
 
bfd: Express node stats using the .api file
Type: improvement
This method allows the assignment of a severity to the error.
Signed-off-by: Neale Ranns <[email protected]>
Change-Id: Id1a414a88018390d03bd6b16bd048a98903bab5a
Neale Ranns [Fri, 5 Aug 2022 03:40:43 +0000 (03:40 +0000)]
 
bfd: More descriptive error codes during packet receive handling
Type: improvement
Signed-off-by: Neale Ranns <[email protected]>
Change-Id: I8907fecde6d48f5362f0f91372d5a9a1bba6f931
Alexander Chernavin [Thu, 4 Aug 2022 08:11:57 +0000 (08:11 +0000)]
 
wireguard: add peers roaming support
Type: feature
With this change, peers are able to roam between different external
endpoints. Successfully authenticated handshake or data packet that is
received from a new endpoint will cause the peer's endpoint to be
updated accordingly.
Signed-off-by: Alexander Chernavin <[email protected]>
Change-Id: Ib4eb7dfa3403f3fb9e8bbe19ba6237c4960c764c
Alexander Chernavin [Wed, 20 Jul 2022 13:01:42 +0000 (13:01 +0000)]
 
wireguard: add handshake rate limiting support
Type: feature
With this change, if being under load a handshake message with both
valid mac1 and mac2 is received, the peer will be rate limited. Cover
this with tests.
Signed-off-by: Alexander Chernavin <[email protected]>
Change-Id: Id8d58bb293a7975c3d922c48b4948fd25e20af4b
Neale Ranns [Fri, 16 Jul 2021 14:00:16 +0000 (14:00 +0000)]
 
ip-neighbor: ARP and ND stats per-interface.
Type: feature
stats of the like from:
  https://datatracker.ietf.org/doc/html/draft-ietf-rtgwg-arp-yang-model-03#section-4
Signed-off-by: Neale Ranns <[email protected]>
Change-Id: Icb1bf4f6f7e6ccc2f44b0008d4774b61cae96184
Mohammed Hawari [Tue, 14 Jun 2022 09:44:45 +0000 (11:44 +0200)]
 
vnet: install reass headers
Change-Id: I42a138628b06a412b8fce7fb4fc500caf9057169
Type: improvement
Signed-off-by: Mohammed Hawari <[email protected]>
Mohammed Hawari [Thu, 2 Jun 2022 11:55:36 +0000 (13:55 +0200)]
 
vlib: vlib_validate_buffer_enqueue_with_aux_x1
This change implement a flavour of vlib_validate_buffer_enqueue_x1 with
aux data support
Change-Id: I2ecf7af49cf15ecd23b12d8acd57fe90546c1af7
Type: improvement
Signed-off-by: Mohammed Hawari <[email protected]>
Mohammed Hawari [Mon, 8 Aug 2022 08:31:11 +0000 (10:31 +0200)]
 
interface: fix show_or_clear_hw_interfaces
Change-Id: I2f3163a7a158afa8e2debc6f545c3d1a2a12ac1d
Type: fix
Fixes: 
3414977152ae6362277158dc732e6b9958a6e618
Signed-off-by: Mohammed Hawari <[email protected]>
Mohammed Hawari [Thu, 24 Feb 2022 14:19:01 +0000 (15:19 +0100)]
 
devices: af_packet, fix tx stall by retrying failed sendto
Change-Id: I6bed66f740b34673a4883eda1c7f7310c57e131b
Type: fix
Signed-off-by: Mohammed Hawari <[email protected]>
Signed-off-by: Benoît Ganne <[email protected]>
Alexander Chernavin [Wed, 20 Jul 2022 12:43:42 +0000 (12:43 +0000)]
 
wireguard: add dos mitigation support
Type: feature
With this change:
 - if the number of received handshake messages exceeds the limit
   calculated based on the peers number, under load state will activate;
 - if being under load a handshake message with a valid mac1 is
   received, but mac2 is invalid, a cookie reply will be sent.
Also, cover these with tests.
Signed-off-by: Alexander Chernavin <[email protected]>
Change-Id: I3003570a9cf807cfb0b5145b89a085455c30e717
Atzm Watanabe [Mon, 8 Aug 2022 06:45:36 +0000 (15:45 +0900)]
 
ikev2: fix rekeying with multiple notify payloads
Type: fix
Signed-off-by: Atzm Watanabe <[email protected]>
Change-Id: I065bd5c26055d863d786023970e7deeed261b31c
Wayne Morrison [Fri, 5 Aug 2022 13:47:24 +0000 (09:47 -0400)]
 
vnet: On rx-mode set, return error for an actual error.
In set_hw_interface_change_rx_mode(), when vnet_hw_if_set_rx_queue_mode()
returns an error it actually returns success.  This has been changed to
return a clib_error_return() value.
Type: fix
Change-Id: Iba39c875d9e15463cb6492d8a966234560a1f522
Signed-off-by: Wayne Morrison <[email protected]>
Benoît Ganne [Fri, 29 Jul 2022 08:52:34 +0000 (10:52 +0200)]
 
tests: fix node variant selection
Type: fix
Fixes: 
4830e4f78fb8e46b23a1a0711cd06969a77d8d95
Change-Id: Iddc73dbda633acd72bd82e52f8ae83c17e3940f6
Signed-off-by: Benoît Ganne <[email protected]>
Nathan Skrzypczak [Thu, 16 Jun 2022 15:00:02 +0000 (17:00 +0200)]
 
vppapigen: make json in parallel
Type: improvement
This patches makes the make json-api-files
run in parallel in the same python runtime.
Default number of workers is 8, and run time
goes from ~20s to ~2s on average.
Change-Id: Id8cff013889db2671f6b6b4af9a019460c656f81
Signed-off-by: Nathan Skrzypczak <[email protected]>
Naveen Joy [Tue, 11 May 2021 17:31:18 +0000 (10:31 -0700)]
 
tests: run a test inside a QEMU VM
Use the script test/run.py to run a test named test_vm_tap
inside a QEMU VM. The run script builds out a virtual env,
launches a light weight QEMU VM, mounts host directories,
starts VPP inside the VM and runs the test. The test named
test_vm_tap, creates two tap v2 interfaces in separate Linux
namespaces and using iPerf, streams traffic between the VM
and VPP. All data files are stored in the directory named
/tmp/vpp-vm-tests. To clean up, use the make test-wipe
command.
Usage:
test/run.py --vm --debug --test test_vm_tap
Type: improvement
Change-Id: I4425dbef52acee1e5b8af5acaa169b89a2c0f171
Signed-off-by: Naveen Joy <[email protected]>
Benoît Ganne [Wed, 27 Jul 2022 15:50:46 +0000 (17:50 +0200)]
 
dpdk: enable interrupt support for vmxnet3
Type: feature
Change-Id: I0abbe925d6b9d3dd7196cd8beaf4f471beb45bd6
Signed-off-by: Benoît Ganne <[email protected]>
GaoChX [Thu, 4 Aug 2022 02:04:33 +0000 (10:04 +0800)]
 
arping: validate am->interfaces before check address
May cause pointers point to unexpected non-zero addresses if not
validate vec
Type: fix
Change-Id: Ie4d3343d6734125b98e0dc962e33e0c7514da829
Signed-off-by: GaoChX <[email protected]>
Alexander Chernavin [Wed, 20 Jul 2022 10:48:56 +0000 (10:48 +0000)]
 
wireguard: add processing of received cookie messages
Type: feature
Currently, if a handshake message is sent and a cookie message is
received in reply, the cookie message will be ignored. Thus, further
handshake messages will not have valid mac2 and handshake will not be
able to be completed.
With this change, process received cookie messages to be able to
calculate mac2 for further handshake messages sent. Cover this with
tests.
Signed-off-by: Alexander Chernavin <[email protected]>
Change-Id: I6d51459778b7145be7077badec479b2aa85960b9
Piotr Bronowski [Mon, 18 Jul 2022 16:45:22 +0000 (16:45 +0000)]
 
ipsec: fix coverity warnings found in fast path implementation
This patch fixes followig coverity issues:
CID 274739 Out-of-bounds read
CID 274746 Out-of-bounds access
CID 274748 Out-of-bounds read
Type: fix
Signed-off-by: Piotr Bronowski <[email protected]>
Change-Id: I9bb6741f100a9414a5a15278ffa49b31ccd7994f
Takanori Hirano [Fri, 29 Jul 2022 11:21:30 +0000 (20:21 +0900)]
 
ip6-nd: fix ip6 ra cli issue
Fix parse problem with per-prefix settings (e.g. valid-lifetime)
in ip6 ra.
Type: fix
Signed-off-by: [email protected]
Change-Id: I2a00bf5b9621ebc16211227d70e376fc2f61bae1
Filip Tehlar [Thu, 28 Jul 2022 08:39:13 +0000 (08:39 +0000)]
 
session: fix a crash when using unregistered transport proto
Type: improvement
Signed-off-by: Filip Tehlar <[email protected]>
Change-Id: I39e3e007da2b99321bebf3e1c1ebb1d87547f532
liangrq [Mon, 4 Jul 2022 08:23:21 +0000 (16:23 +0800)]
 
ip6-nd: copy mac address to wrong buffer current_data
Type: fix
Receive router solicitation in pop vlan interface, it will cause copy mac address to wrong buffer current_data and can not reply the solicitation right
Signed-off-by: liangrq <[email protected]>
Change-Id: Ic40a5a47a52c8187aaf6c6854df761529e6f24d9
Pim van Pelt [Tue, 19 Jul 2022 08:32:22 +0000 (08:32 +0000)]
 
vppinfra: fix formatting of format_base10
format_base10 reads 64b but is fed 32b values at the callsite; change
to u64 consistently. The function has only one call site in
interface/monitor.c which has a few additional bugs (spurious
character, and ambiguous 'bits' versus 'bytes' in the output).
Type: improvement
Signed-off-by: Pim van Pelt <[email protected]>
Change-Id: I360f0d439cc13c09bd3f53db8184bd12ad4bc2e9
Mohsin Kazmi [Mon, 18 Jul 2022 11:21:05 +0000 (11:21 +0000)]
 
libmemif: fix chain buffer support
Type: fix
This patch fixes chain buffer support as transmit side
missing to set the flag to the descriptor in case of
chain buffers.
Signed-off-by: Mohsin Kazmi <[email protected]>
Change-Id: I73ff11be69a388f14fea39a19272d8eb76148fba
Stanislav Zaikin [Tue, 19 Jul 2022 14:08:15 +0000 (16:08 +0200)]
 
linux-cp: fix endianess for autoendian methods
If an API methos is specified as "autoendian" it should use macros with
_END at the end.
Type: fix
Change-Id: I73b7b4f6996b30631c4355ace156ed0665c4b8ad
Signed-off-by: Stanislav Zaikin <[email protected]>
Radha krishna Saragadam [Mon, 18 Jul 2022 14:11:05 +0000 (19:41 +0530)]
 
vcl: new vcl api to get detailed session errors
Sometimes VPP rejects application connection requests
due to various reasons. Some errors application can
retry to get a successful connection.
In a non-blocking session, VCL sends EPOLLHUP.
An application can call a new API
vppcom_session_get_error to find the details and retry
depending on the error.
Type: fix
Signed-off-by: Radha krishna Saragadam <[email protected]>
Change-Id: If0e21a8e25701f66a190a2799b2209e0c31f897c
Stanislav Zaikin [Mon, 18 Jul 2022 06:55:04 +0000 (08:55 +0200)]
 
linux-cp: change namespace to netns
namespace is a keyword for c++ compilers
Type: fix
Change-Id: Ia8fc9ef1cc15fe9d0e40b3f543f9e8f411203b89
Signed-off-by: Stanislav Zaikin <[email protected]>
Radha krishna Saragadam [Mon, 18 Jul 2022 14:20:23 +0000 (19:50 +0530)]
 
stats: add loops per second counter in the stats segment.
This change adds loops per second in the stats segment.
Applications using the stats segment to monitor VPP
can use this for better monitoring
Type: fix
Signed-off-by: Radha krishna Saragadam <[email protected]>
Change-Id: I53081f40ee918eec9763513a639b9d8a02488b20
Radha krishna Saragadam [Mon, 18 Jul 2022 13:53:06 +0000 (19:23 +0530)]
 
session: increase retries to  grab mq lock
With thousands of UDP sessions,
Sometimes VPP needs more time to grab the MQ lock for a session.
So increased tries from 5 to 75.
Type: fix
Signed-off-by: Radha krishna Saragadam <[email protected]>
Change-Id: Id8b877255aedcdcf206e9d0869fe5246645d76e7
Matthew Smith [Mon, 18 Jul 2022 13:19:26 +0000 (13:19 +0000)]
 
linux-cp: API downgrade due to namespace keyword
Type: fix
A user had trouble compiling C++ code to work with the linux-cp APIs
because some messages contain a field called namespace, which is a
reserved word for C++. We wish to rename those fields so the messages
which are affected are being set to in_progress.
Change-Id: I3bd1dc898c146a9980161a562b2b453313bb58fd
Signed-off-by: Matthew Smith <[email protected]>
Tianyu Li [Fri, 10 Jun 2022 09:30:47 +0000 (09:30 +0000)]
 
dpdk: fix mlx5 dpdk init with no-multi-seg
Build vpp with MLX DPDK PMD,
make DPDK_MLX4_PMD=y DPDK_MLX5_PMD=y DPDK_MLX5_COMMON_PMD=y build-release
With no-multi-seg in startup.conf,
Mellanox NIC init failed with following message,
rte_eth_rx_queue_setup[port:2, errno:-12]: Unknown error -12
mlx5_net: port 2 Rx queue 0: Scatter offload is not configured and
no enough mbuf space(2176) to contain the maximum RX packet length(2065)
with head-room(128)
In Mellanox NIC PMD driver, 'di.max_rx_pktlen' is returned as 65536,
and 'di.max_mtu' is returned as 65535, which makes
the driver_frame_overhead logic not suitable for Mellanox NICs.
So skip the logic code if MAX_MTU is returned as 65535.
Type: fix
Fixes: 
1cd0e5dd533f ("vnet: distinguish between max_frame_size and MTU")
Signed-off-by: Tianyu Li <[email protected]>
Change-Id: I027b76b8d07fb453015b8eebb36d160b4bc8df9c
Piotr Bronowski [Fri, 8 Jul 2022 12:45:51 +0000 (12:45 +0000)]
 
tests: add fast path ipv6 python tests for outbound policy matching
This patch introduces set of python tests for fast path ipv6, based on
ipv4 tests. Some missing parts of ipsec framework has been added
in order to test ipv6 implementation.
Type: feature
Signed-off-by: Piotr Bronowski <[email protected]>
Change-Id: Icc13322787d76485c08106bad2cb071947ad9846
Piotr Bronowski [Fri, 8 Jul 2022 12:45:05 +0000 (12:45 +0000)]
 
ipsec: fast path outbound policy matching implementation for ipv6
With this patch fast path for ipv6 policy lookup is enabled.
This impelentation scales and outperforms original implementation when
the number of defined flows is higher thatn 100k.
Type: feature
Signed-off-by: Piotr Bronowski <[email protected]>
Change-Id: I9364b5b8db4fc708790d48c538add272c7cea400
Florin Coras [Tue, 12 Jul 2022 18:24:34 +0000 (11:24 -0700)]
 
quic: fix coverity warning
Type: fix
Fixes: 
5b4b4c0
Signed-off-by: Florin Coras <[email protected]>
Change-Id: If4bd8f30cd23d862109cab665251ad89804b1734
Zachary Leaf [Mon, 23 May 2022 11:23:40 +0000 (06:23 -0500)]
 
perfmon: add Arm event bundles
Included statistic bundles (all NODE type):
  - Instructions and CPU cycles, including IPC
  - Data cache access/refills/%
  - Data TLB cache access/refills/%
  - Instruction cache access/refills/%
  - Instruction TLB cache access/refills/%
  - Memory/Bus accesses, memory errors
  - Branch (mis)predictions, architecturally & speculatively executed
  - Processor frontend/backend stalls (stalled cycles)
Type: feature
Signed-off-by: Zachary Leaf <[email protected]>
Tested-by: Jieqiang Wang <[email protected]>
Change-Id: I7ea4a27c8df8fc7222b743a98bdceaff727e4112
Zachary Leaf [Thu, 12 May 2022 07:26:00 +0000 (02:26 -0500)]
 
perfmon: enable perfmon plugin for Arm
This patch enables statistics from the Arm PMUv3 through the perfmon
plugin.
In comparison to using the Linux "perf" tool, it allows obtaining
direct, per node level statistics (rather than per thread). By accessing
the PMU counter registers directly from userspace, we can avoid the
overhead of using a read() system call and get more accurate and fine
grained statistics about the running of individual nodes.
A demo of perfmon on Arm can be found at:
https://asciinema.org/a/egVNN1OF7JEKHYmfl5bpDYxfF
*Important Note*
Perfmon on Arm is dependent on and works only on Linux kernel versions
of v5.17+ as this is when userspace access to Arm perf counters was
included.
On most Arm systems, a maximum of 7 PMU events can be configured at once
- (6x PMU events + 1x CPU_CYCLE counter). If some perf counters are in
use elsewhere by other applications, and there are insufficient counters
remaining to open the bundle, the perf_event_open call will fail
(provided the events are grouped with the group_fd param, which perfmon
currently utilises).
See arm/events.h for a list of PMUv3 events available, although it is
implementation defined whether most events are implemented or not. Only
a small set of 7 events is required to be implemented in Armv8.0, with
some additional events required in later versions. As such, depending on
the implementation, some statistics may not be available. See Arm
Architecture Reference Manual for Armv8-A, D7.10.2 "The PMU event number
space and common events" for more information.
arm/events.c:arm_init() gets information from the sysfs about what
events are implemented on a particular CPU at runtime. Arm's
implementation of the perfmon source callback .bundle_support uses this
information to disable unsupported events in a bundle, or in the case
no events are supported, disable the entire bundle.
Where a particular event in a bundle is not implemented, the statistic
for that event is shown as '-' in the 'show perfmon statistics' cli
output, by disabling the column.
There is additional code in perfmon.c to only open events which are
marked as implemented. Since we're only opening and reading events that
are implemented, some extra logic is required in cli.c to re-align
either perfmon_node_stats_t or perfmon_reading_t with the column
headings configured in each bundle, taking into account disabled
columns.
Userspace access to perf counters is disabled by default, and needs to
be enabled with 'sudo sysctl kernel/perf_user_access=1'.
There is a check built into the Arm event source init function
(arm/events.c:arm_init) to check that userspace reading of perf counters
is enabled in the /proc/sys/kernel/perf_user_access file.
If the above file does not exist, it means the kernel version is
unsupported. Users without a supported kernel will see a warning
message, and no Arm bundles will be registered to use in perfmon.
Enabling/using plugin:
  - include the following in startup.conf:
    - plugins { plugin perfmon_plugin.so { enable }
  - 'show perfmon bundle [verbose]' - show available statistics bundles
  - 'perfmon start bundle <bundle-name>' - enable and start logging
  - 'perfmon stop' - stop logging
  - 'show perfmon statistics' - show output
For a general guide on using and understanding Arm PMUv3 events, see
https://community.arm.com/arm-community-blogs/b/tools-software-ides-blog/posts/arm-neoverse-n1-performance-analysis-methodology
Type: feature
Signed-off-by: Zachary Leaf <[email protected]>
Tested-by: Jieqiang Wang <[email protected]>
Change-Id: I0620fe5b1bbe78842dfb1d0b6a060bb99e777651
Zachary Leaf [Mon, 23 May 2022 11:22:27 +0000 (06:22 -0500)]
 
perfmon: make less arch dependent
In preparation for enabling perfmon on Arm platforms, move some Intel
/arch specific logic into the /intel directory and update the CMake to
split the common code from arch specific files.
Since the dispatch_wrapper code is very different on Arm/Intel,
each arch can provide their own implementation + conduct any additional
arch specific config e.g. on Intel, all indexes from the mmap pages are
cached. The new method intel_config_dispatch_wrapper conducts this
config and returns a pointer to the dispatch wrapper to use.
Similarly, is_bundle_supported() looks very different on Arm/Intel, so
each implementation is to provide their own arch specific checks.
Two new callbacks/function ptrs are added in PERFMON_REGISTER_SOURCE to
support this - .bundle_support and .config_dispatch_wrapper.
Type: refactor
Signed-off-by: Zachary Leaf <[email protected]>
Change-Id: Idd121ddcfd1cc80a57c949cecd64eb2db0ac8be3
Artem Glazychev [Fri, 8 Jul 2022 12:01:19 +0000 (19:01 +0700)]
 
wireguard: fix coverity warnings
Type: fix
Signed-off-by: Artem Glazychev <[email protected]>
Change-Id: I62f13ee8cb9b86f8106505fd32a03d66c1a73bce
Matthew Smith [Wed, 6 Jul 2022 15:52:20 +0000 (10:52 -0500)]
 
dpdk: add ID for 4xxx QAT VF
Type: improvement
Enable use of 4th gen QAT devices. Will be available on Sapphire Rapids.
Signed-off-by: Matthew Smith <[email protected]>
Change-Id: I89e7d29e10ecb4c36c700ff5e017796161ec6c5e
Ivan Shvedunov [Tue, 5 Jul 2022 11:13:35 +0000 (15:13 +0400)]
 
gre: fix returning the flags in the API
Type: fix
Signed-off-by: Ivan Shvedunov <[email protected]>
Change-Id: I5ecfb242e5905c9bd8ce19cd9ab6efd657ee14d4
Sergey Matov [Mon, 23 Nov 2020 17:35:28 +0000 (21:35 +0400)]
 
vppinfra: fix memory leak in sparse_vec_free()
Type: fix
Signed-off-by: Ivan Shvedunov <[email protected]>
Signed-off-by: Sergey Matov <[email protected]>
Change-Id: I4ec1a68b7266f05ab7c543cd8207afb29e740743
Andreas Schultz [Fri, 15 May 2020 09:50:07 +0000 (11:50 +0200)]
 
misc: pass NULL instead of 0 for pointer in variadic functions
0 is not NULL (at least not in all cases), passing 0 into a variadic
function in a place where the consumer reads it as pointer might
leave parts of the pointer uninitilized and hence filled with random
data.
It seems that this used to work with gcc, but clang seems to treat the
0 in those places as a 32bit integer.
Type: fix
Signed-off-by: Ivan Shvedunov <[email protected]>
Signed-off-by: Andreas Schultz <[email protected]>
Change-Id: I37d975eef5a1ad98fbfb65ebe47d73458aafea00
Jon Loeliger [Mon, 13 Jun 2022 15:39:32 +0000 (10:39 -0500)]
 
buffers: protect against bad thread indices
There is a very rare bug in NAT processing that yeilds a thread
index of ~0.  When this happens, vlib_get_frame_queue_elt()
suffers a segfault and VPP quits.  Prevent an outright fault
by dropping the packet instead.
Type: fix
Signed-off-by: Jon Loeliger <[email protected]>
Change-Id: I48c7a268925bb821ea15e58db5d4bfb211c40c09
Florin Coras [Wed, 29 Jun 2022 03:01:20 +0000 (20:01 -0700)]
 
vcl: check if listener valid on disconnect cleanup
Type: fix
Signed-off-by: Florin Coras <[email protected]>
Change-Id: Ie057d0d5a51d3226a1a188cf9d48a5d82dc4a3c7
Andrew Yourtchenko [Thu, 23 Jun 2022 05:18:21 +0000 (05:18 +0000)]
 
misc: VPP 22.06 Release Notes
Type: docs
Change-Id: I15971b21fd660b4893218640c0d5e5a5247868f1
Signed-off-by: Andrew Yourtchenko <[email protected]>
(cherry picked from commit 
0d352a97c5e3ad1f5f6eab18a978a14b0b9e06a8)
GaoChX [Tue, 28 Jun 2022 08:25:03 +0000 (16:25 +0800)]
 
vrrp: while delete vr can't delete multi virtual address.
Here is bug example:
vpp# create loopback interface
loop0
vpp# vrrp vr add loop0 vr_id 1 priority 100 192.168.1.1 192.168.1.2
vpp# vrrp vr del loop0 vr_id 1
vpp# vrrp vr add loop0 vr_id 1 priority 100 192.168.1.1 192.168.1.2
vrrp vr add: vrrp_vr_add_del returned -105
Type: fix
Signed-off-by: GaoChX <[email protected]>
Change-Id: I3e0d086ac8fb52756339cff19b9a83911ec9748b
Ahmed Abdelsalam [Wed, 29 Jun 2022 17:11:08 +0000 (17:11 +0000)]
 
sr: SRv6 Path Tracing Sink node behavior
Type: feature
Signed-off-by: Ahmed Abdelsalam <[email protected]>
Change-Id: I2d3a0211abfee3501d3d77c80da20e67e1e9e133
Mohammed Hawari [Tue, 31 May 2022 16:11:05 +0000 (18:11 +0200)]
 
vlib: enqueue_to_next_with_aux implementation
Change-Id: I0e1bb39d765ec3efa7b28ca02fb7beeb23607e51
Type: improvement
Signed-off-by: Mohammed Hawari <[email protected]>
Benoît Ganne [Wed, 8 Jun 2022 08:49:17 +0000 (10:49 +0200)]
 
classify: use 32 bits hash
classify hash used to be stored as u64 in buffer metadata, use 32 bits
instead:
 - on almost all our supported arch (x86 and arm64) we use crc32c
   intrinsics to compute the final hash: we really get a 32-bits hash
 - the hash itself is used to compute a 32-bits bucket index by masking
   upper bits: we always discard the higher 32-bits
 - this allows to increase the l2 classify buffer metadata padding such
   as it does not overlap with the ip fib_index metadata anymore. This
   overlap is an issue when using the 'set metadata' action in the ip
   ACL node which updates both fields
Type: fix
Change-Id: I5d35bdae97b96c3cae534e859b63950fb500ff50
Signed-off-by: Benoît Ganne <[email protected]>
Ahmed Abdelsalam [Wed, 29 Jun 2022 16:30:21 +0000 (16:30 +0000)]
 
sr: code refactor and style fix
Type: refactor
Signed-off-by: Ahmed Abdelsalam <[email protected]>
Change-Id: Iff5e85952273526d5c9d9e7e73bd2b6c15bcd7f6
Ofer Heifetz [Wed, 29 Jun 2022 17:18:27 +0000 (20:18 +0300)]
 
svm: check svm_msg_q_size_to_alloc success
svm_msg_q_size_to_alloc must return a valid base address, if it fails
pass up the error for handling
Type: fix
Change-Id: I408492f65f646862122acb9a187819b3bbf4f91c
Signed-off-by: Ofer Heifetz <[email protected]>
Ahmed Abdelsalam [Wed, 29 Jun 2022 11:08:42 +0000 (11:08 +0000)]
 
sr: Add support for SRv6 Path Tracing Infrastructure
This patch adds support for the infrastructure
required to support SRv6 Path Tracing defined in
https://datatracker.ietf.org/doc/draft-filsfils-spring-path-tracing/
Type: feature
Change-Id: If3b09d6216490a60dd5a816577477b6399abc124
Signed-off-by: Ahmed Abdelsalam <[email protected]>
Florin Coras [Wed, 29 Jun 2022 02:21:32 +0000 (19:21 -0700)]
 
hsa: reduce number of preallocated vcl test server sessions
Type: improvement
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I7afc6116ca9a609992f26d9e78084732bba1b2ea
Fan Zhang [Wed, 25 May 2022 20:03:40 +0000 (20:03 +0000)]
 
ipsec: add fast path python tests
This patch introduces set of python tests for fast path, based on
flow cache tests. There was a bug in calculating of policy mask when
adding to fast path, which has been fixed. Memory size for bihash
tables for both ip4 and ip6 outbound fast path policies
has been increased.
Type: feature
Signed-off-by: Piotr Bronowski <[email protected]>
Change-Id: Ibeee904ae7179f5dafbd45bb44282436f0b80821
Piotr Bronowski [Thu, 5 May 2022 18:51:21 +0000 (18:51 +0000)]
 
tests: add ipsec flow performance unit test
This patch adds performacne and functional tests for ip4
outbound traffic policy matching.
Test setup is configurable in startup.conf and though the test
parameters. Cache, fast path, fast path burst mode can be enabled
and disabled,
and performance for different lookup setup can be measured.
Type: feature
Signed-off-by: Piotr Bronowski <[email protected]>
Change-Id: I1d04d196e412f47f43b7e5cbd46607bf6a9cc40e
Fan Zhang [Wed, 25 May 2022 19:42:08 +0000 (19:42 +0000)]
 
ipsec: show fast path flag in cli
This patch updates the "show ipsec spd" cli to display
policies maintained by fast path bihash table.
Type: feature
Signed-off-by: Piotr Bronowski <[email protected]>
Change-Id: I58b9f92f3132dc9809b50786dc912e09c4b84d81
Piotr Bronowski [Fri, 6 May 2022 13:52:24 +0000 (13:52 +0000)]
 
ipsec: add fast path configuration parser
Parser can be configured from the level of startup.conf file:
fast path can be enabled and disabled.
Type: feature
Signed-off-by: Piotr Bronowski <[email protected]>
Change-Id: Ifab83ddcb75bc44c8165e7fa87a1a56d047732a1
Piotr Bronowski [Tue, 10 May 2022 14:06:29 +0000 (14:06 +0000)]
 
ipsec: add spd fast path matching
This patch adds matching functionality for spd fast path
policy matching. Fast path matching has been introduced
for outbound traffic only.
Type: feature
Signed-off-by: Piotr Bronowski <[email protected]>
Change-Id: I03d5edf7d7fbc03bf3e6edbe33cb15bc965f9d4e
Piotr Bronowski [Tue, 10 May 2022 14:06:29 +0000 (14:06 +0000)]
 
ipsec: make match function inline
This patch introduces ipsec_output.h file. Matching implementation is
moved there. The reason behind is the possibility of unit testing
matching mechanism. Therefore we need to have functions that are in
scope of our intrest there and since these are inline their
implementation needs to be moved to the header file as well.
Type: improvement
Signed-off-by: Piotr Bronowski <[email protected]>
Change-Id: Id7c605375d1f3be146abf96ef70d336a5d156444
Piotr Bronowski [Tue, 10 May 2022 13:18:22 +0000 (13:18 +0000)]
 
ipsec: add/delete ipsec fast path policy
This patch introduces functions to add and delete fast path
policies.
Type: feature
Signed-off-by: Piotr Bronowski <[email protected]>
Change-Id: I3f1f1323148080c9dac531fbe9fa33bad4efe814
Florin Coras [Tue, 28 Jun 2022 23:01:35 +0000 (16:01 -0700)]
 
session: fix connected udp accepts
Type: fix
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I0963bae4b56b08c0a9ab4ee1f2738013217e1fb7
Florin Coras [Tue, 28 Jun 2022 21:34:45 +0000 (14:34 -0700)]
 
session quic: allow custom config of rx mqs seg size
Type: fix
Signed-off-by: Florin Coras <[email protected]>
Signed-off-by: Dave Wallace <[email protected]>
Change-Id: Idc0fdebfea29c241d8a36128241ccec03eace5fd
Pratikshya Prasai [Mon, 27 Jun 2022 15:02:04 +0000 (11:02 -0400)]
 
docs: fix broken links
Type: docs
Signed-off-by: Pratikshya Prasai <[email protected]>
Change-Id: I729de9e18624c63a72ec415a05c55617cb360c47
Piotr Bronowski [Tue, 10 May 2022 09:08:47 +0000 (09:08 +0000)]
 
ipsec: introduce spd fast path types
This patch introdcues basic types supporting fast path lookup.
Fast path performs policy matching with use of hash lookup
(particularly bihash tries has been used for that purpose). Fast path
lookup addresses situation where huge number of policies is created
(~100k or more). In such scenario adding/removing a policy
and policy matching is not efficient and poorly scales (for example
adding 500k policies takes a few hours. Also lookup time
increases significantly). With fast path adding and matching up to
1M flows scales up linearly (adding 1M of policies takes about 150s
on the test machine vs many hours in case of original implementation,
also matching time is significantly improved). Fast path will not
deal well with a huge number of policies that are spanning large
ip/port ranges. Large range will be masked out almost entirely leaving
only a few bits for calculating the hash key. Such keys will tend to
 gather much more policies than other keys and hash will match most of
the packets anihilating advantages of hashing. Having said that
we also think that it is not the real life scenario.
Type: feature
Signed-off-by: Piotr Bronowski <[email protected]>
Change-Id: I600dae5111a37768ed4b23aa18426e66bbf7b529
Piotr Bronowski [Thu, 9 Jun 2022 09:09:28 +0000 (09:09 +0000)]
 
ipsec: change wildcard value for any protocol of spd policy
Currently 0 has been used as the wildcard representing ANY type of
protocol. However 0 is valid value of ip protocol (HOPOPT) and therefore
it should not be used as a wildcard. Instead 255 is used which is
guaranteed by IANA to be reserved and not used as a protocol id.
Type: improvement
Signed-off-by: Piotr Bronowski <[email protected]>
Change-Id: I2320bae6fe380cb999dc5a9187beb68fda2d31eb
fanxb [Fri, 17 Jun 2022 08:19:43 +0000 (16:19 +0800)]
 
quic:fix crash rx_fifo full or grow
if when the rx_fifo grows, svm_fifo_enqueue() return -4,
stream_data->app_rx_data_len += rlen type conversion occurs,
Finally,stream->recvstate.data_off calculation is wrong.
Type:fix
Signed-off-by: fanxb <[email protected]>
Change-Id: Iae11f0c453f32d836f4148d70e3b121545a53a90
Alexander Chernavin [Wed, 15 Jun 2022 14:42:17 +0000 (14:42 +0000)]
 
stats: fix prometheus exporter crash on large number of FIB entries
Type: fix
Currently, prometheus exporter may crash because of memory exhaustion
when dumps metrics if the FIB contains large number of routes.
With this fix, increase memory size for prometheus exporter to be able
to handle large number of FIB entries.
Signed-off-by: Alexander Chernavin <[email protected]>
Change-Id: Ia2b9a665368883c87448deee9bcf8d2ac1168357
Dave Wallace [Tue, 14 Jun 2022 16:06:55 +0000 (12:06 -0400)]
 
docs: fix spelling errors
- also add docs-spell to checkstyle-all make target
Type: fix
Fixes: 
5f6422db9
Change-Id: I8e9d7d17a03ee7b55f4e1785983459c43af267f7
Signed-off-by: Dave Wallace <[email protected]>
Vijayabhaskar Katamreddy [Tue, 31 May 2022 15:58:10 +0000 (15:58 +0000)]
 
ip: reassembly - Add node level stats, fix customapp behavior
Type: fix
Added stats for success and failure cases
Fixed Custom app behaviors for the error / drop cases
Signed-off-by: Vijayabhaskar Katamreddy <[email protected]>
Change-Id: Id6e981c7be5c5b3cee5af2df505666d5558da470
Saima Yunus [Sat, 11 Jun 2022 02:34:04 +0000 (19:34 -0700)]
 
build: update makefile for ubuntu 22.04 docker executors
* apt '—force-yes' is deprecated in the version of apt in Ubuntu 22.04
* several Ubuntu-22.04-specific packages (e.g. python3-virtualenv, libssl-dev, clang clang-format-11)
are needed in the current VPP installation as well
Type: fix
Signed-off-by: Saima Yunus <[email protected]>
Change-Id: I96ead90152f692233da812cdc853792bedb47c3c
Saima Yunus [Thu, 19 May 2022 18:48:59 +0000 (11:48 -0700)]
 
docs: cleaning up VPP documents by deleting unnecessary info.
- cleaned up the 'build/run VPP' docs
Type: docs
Signed-off-by: Saima Yunus <[email protected]>
Change-Id: I9dbddbe1932804b8d507cb2f1631cd7116e59072
Benoît Ganne [Thu, 9 Jun 2022 10:09:19 +0000 (12:09 +0200)]
 
rdma: bump to rdma-core 41.0
Type: improvement
Change-Id: Ifdbb879d3018996c09f0caf55df11038ead173a2
Signed-off-by: Benoît Ganne <[email protected]>
Xiaoming Jiang [Wed, 8 Jun 2022 15:28:59 +0000 (15:28 +0000)]
 
dpdk: add support allow/block scan mode for vmbus dev
Type: improvement
Signed-off-by: Xiaoming Jiang <[email protected]>
Change-Id: Id3f45968cd24f53350dce365b2cc9b3191ec836f
Liangxing Wang [Fri, 13 May 2022 04:24:19 +0000 (04:24 +0000)]
 
vcl: fix iperf3 server crash issue when it runs over vpp host stack.
Issue:
Let iperf3 server run via ldp and vcl on top of vpp's host stack. If
iperf3 client connects this iperf3 server with tcp MSS setting option,
iperf3 server will always crash.
Root cause:
When MSS option is specified by iperf3 client, iperf3 server will
recreate the listening socket firstly, then call setsockopt() to set MSS
immediately. Iperf3 code can be referred here:
https://github.com/esnet/iperf/blob/
58332f8154e2140e40a6e0ea060a418138291718/src/iperf_tcp.c#L186.
However, in vcl layer vpp_evt_q of this recreated session is not
allocated yet. So iperf3 server crashes with vpp_evt_q null pointer access.
Fix:
Add session vpp_evt_q null pointer check in vcl_session_transport_attr().
Add a vcl test case for this MSS option scenario.
Type: fix
Signed-off-by: Liangxing Wang <[email protected]>
Change-Id: I2863bd0cffbe6e60108ab333f97c00530c006ba7
Benoît Ganne [Fri, 10 Jun 2022 07:40:47 +0000 (09:40 +0200)]
 
vppinfra: fix bihash_8_16 entry format function
Type: fix
Change-Id: I1e8655baaf09b455f7f0052452402a372f738d0f
Signed-off-by: Benoît Ganne <[email protected]>
Florin Coras [Thu, 9 Jun 2022 19:38:13 +0000 (12:38 -0700)]
 
hsa: allow first segments larger than 4g for proxy
Type: improvement
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I9c502a491ff56806a2e631f7a4c18903a2e93ab2
Benoît Ganne [Wed, 8 Jun 2022 08:56:33 +0000 (10:56 +0200)]
 
ip: improve ip ACL traces
Type: improvement
Change-Id: I85c73cb940d81d0b249eda0d57de135bcd798418
Signed-off-by: Benoît Ganne <[email protected]>
Damjan Marion [Wed, 1 Jun 2022 14:18:23 +0000 (16:18 +0200)]
 
vppinfra: missing __clib_export for clib_pmalloc_alloc_aligned
Type: improvement
Change-Id: I7489327d8b9c5f69b4ceb2159456f00f8a3612df
Signed-off-by: Damjan Marion <[email protected]>
Benoît Ganne [Wed, 8 Jun 2022 08:23:43 +0000 (10:23 +0200)]
 
udp: add cli to dump registered ports
Type: improvement
Change-Id: Ic949e3136a7cf27011d098a50e91920f83226ea9
Signed-off-by: Benoît Ganne <[email protected]>
Matthew Smith [Thu, 2 Jun 2022 19:11:28 +0000 (19:11 +0000)]
 
wireguard: increment interface RX counters
Type: improvement
When packets were received and processed successfully, increment the
byte/packet counters for the tunnel interface.
Change-Id: I42855607ac6916de641be42aac86c9942cc97140
Signed-off-by: Matthew Smith <[email protected]>
Nathan Skrzypczak [Tue, 7 Jun 2022 16:30:40 +0000 (18:30 +0200)]
 
classify: fix sesssion details api
We were not allocating space for the
variable length payload in the response
message.
Type: fix
Change-Id: I345102f4555f66c5632ab0882ca1dd178e98eb7b
Signed-off-by: Nathan Skrzypczak <[email protected]>
Pim van Pelt [Fri, 3 Jun 2022 21:05:26 +0000 (21:05 +0000)]
 
vlib: fix crash on packet on deleted interface
If ip4_neighbor_probe (or any other) is sending packet to a deleted interface,
ASSERT trips and dataplane crashes. Example:
create loopback interface instance 0
set interface ip address loop0 10.0.0.1/32
set interface state GigabitEthernet3/0/1 up
set interface state loop0 up
set interface state loop0 down
set interface ip address del loop0 10.0.0.1/32
delete loopback interface intfc loop0
set interface state GigabitEthernet3/0/1 down
set interface state GigabitEthernet3/0/1 up
comment { the following crashes VPP }
set interface state GigabitEthernet3/0/1 down
This sequence reliably crashes VPP:
(gdb)p n->name
$4 = (u8 *) 0x7fff82b47578 "interface-3-output-deleted”
If the interface doesn't exist, return ~0 and be tolerant of this in the
two call sites of counter_index()
Type: fix
Signed-off-by: Pim van Pelt <[email protected]>
Change-Id: I90ec58fc0d14b20c9822703fe914f2ce89acb18d
Ahmed Abdelsalam [Mon, 6 Jun 2022 15:54:02 +0000 (15:54 +0000)]
 
sr: SRv6 TEF behavior support
Adding support for the SRv6 TEF (Timestamp, Encapsulation and Forward) behavior defined in
draft-filsfils-spring-path-tracing (https://datatracker.ietf.org/doc/draft-filsfils-spring-path-tracing/).
Type: feature
Change-Id: I7f38b593147daf8d27af9c983448cf82947e5bed
Signed-off-by: Ahmed Abdelsalam <[email protected]>
Alexander Chernavin [Thu, 2 Jun 2022 09:55:37 +0000 (09:55 +0000)]
 
wireguard: fix crash by not sending arp via wg interface
Type: fix
Currently, neighbor adjacencies on a wg interface are converted into a
midchain only if one of the peers has a matching allowed prefix
configured. If create a route that goes through a wg interface but the
next-hop address does not match any allowed prefixes, an ARP/ND request
will try to be sent via the wg interface to resolve the next-hop address
when matching traffic occurs. And sending an ARP request will cause VPP
to crash while copying hardware address of the wg interface which is
NULL. Sending an ND message will not cause VPP to crash but the error
logged will be unclear (no source address).
With this fix, convert all neighbor adjacencies on a wg interface into a
midchain and update tests to cover the case. If there is no matching
allowed prefix configured, traffic going such routes will be dropped
because of "Peer error". No changes if there is matching allowed prefix
configured.
Also, fix getting peer by adjacency index.
Signed-off-by: Alexander Chernavin <[email protected]>
Change-Id: I15bc1e1f83de719e97edf3f7210a5359a35bddbd
Florin Coras [Fri, 3 Jun 2022 21:29:20 +0000 (14:29 -0700)]
 
hsa: dealloc proxy fifos on right thread
Type: fix
Signed-off-by: Florin Coras <[email protected]>
Change-Id: Ia66c12e1da126d0d8d101b645e6dc8454c3826d6
Florin Coras [Fri, 3 Jun 2022 17:51:27 +0000 (10:51 -0700)]
 
hsa: refactor proxy session lookup and cleanup
Type: improvement
Signed-off-by: Florin Coras <[email protected]>
Change-Id: Ic68627bbca676cc78b0be05bc1fa0f386f5d27fa
Filip Tehlar [Fri, 3 Jun 2022 12:21:16 +0000 (12:21 +0000)]
 
session: fix double free in CLI
Type: fix
Signed-off-by: Filip Tehlar <[email protected]>
Change-Id: I646ac946d0b07929dfdd1966a4f4a3b697768040
Jon Loeliger [Thu, 2 Jun 2022 20:18:54 +0000 (15:18 -0500)]
 
ipfix-export: Fix frame leak in flow_report_process_send()
The flow_report_process_send() function always allocates a frame.
However, when no template_send is needed, template_bi is ~0.
When this happens, no vectors are placed in the frame.  When
the frame is then "put", a check for n_vectors == 0 prevents
the frame from actually being placed back on the free list.
Fix that by using a direct call to vlib_frame_free() when
there are no frame vctors.
Type: fix
Signed-off-by: Jon Loeliger <[email protected]>
Change-Id: I936b5cea4cb3c358247c3d2e1a77d034a322ea76
Florin Coras [Wed, 1 Jun 2022 21:44:11 +0000 (14:44 -0700)]
 
session: make sure fifos are freed on right thread
Type: improvement
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I3c573641bd95fe899823b66f6c59a2525a18d293
Leland Krych [Thu, 26 May 2022 15:37:54 +0000 (08:37 -0700)]
 
stats: swap used and total stats
Type: fix
reported stats seem to have mixed up used and total counters
Signed-off-by: Leland Krych <[email protected]>
Change-Id: I221c7b114c0da2ed53171d7f047a4bda07ee6cb2