Vratko Polak [Thu, 17 Aug 2023 14:15:38 +0000 (16:15 +0200)]
 
crypto-sw-scheduler: improve function indentation
The checkstyle --fix command remains confused
around the def/foreach/undef usage in convert_async_crypto_id,
but at least the other functions now look correctly indented to me.
Type: style
Change-Id: Ic8f7b580267386b7a6b07d33d9ba7ae9787c0e0a
Signed-off-by: Vratko Polak <[email protected]>
Florin Coras [Thu, 7 Sep 2023 02:38:44 +0000 (19:38 -0700)]
 
session: make sure rx evt flag is cleared for builtin rx
Type: fix
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I99631b1be6e19f0cefd1cefa82a51e6f8e9be2ac
Frédéric Perrin [Fri, 14 Jul 2023 10:13:42 +0000 (11:13 +0100)]
 
ipsec: clear L4-cksum flags when decap'ing packets
Type: fix
Signed-off-by: Frédéric Perrin <[email protected]>
Change-Id: I45191b7316c88038bcd57d62aeb07bb109cf4a4d
Piotr Bronowski [Tue, 5 Sep 2023 21:18:59 +0000 (21:18 +0000)]
 
dpdk-cryptodev: fix cache ring stats cli command
The logic for calcuating processed elements in the cache ring was broken.
In case tail and deq_tail equals and frame element pointed by the tile
is not NULL it means there is exactly one processed element in the ring.
Type: fix
Signed-off-by: Piotr Bronowski <[email protected]>
Change-Id: I69c978334fc952049393214ccc9cc5245351f7f7
Damjan Marion [Thu, 31 Aug 2023 15:00:16 +0000 (17:00 +0200)]
 
build: add option to specify native -march= flag with VPP_BUILD_NATIVE_ARCH
Type: improvement
Change-Id: I98eeba1ad2f9ed0531a7c615e0e70e535f24f813
Signed-off-by: Damjan Marion <[email protected]>
Vladislav Grishenko [Thu, 16 Mar 2023 14:31:00 +0000 (19:31 +0500)]
 
nat: improve nat44-ed outside address distribution
Use client address hash to pick the first outside address
instead of just address high octet, becasue it may denegerate
into stable 10/172/192, depending on nat address count.
Fix outside address distribution test to acually test the
distribution, not the algo, so previous distribution will
fail with 65 nat addresses and 100 clients:
FAIL: Outside address distribution based on source address
Traceback (most recent call last):
  File ".../test/test_nat44_ed.py", line 2048, in test_outside_address_distribution
    msg="Bad outside address distribution")
AssertionError: 156.25 not less than 0.33 : Bad outside address distribution
Type: improvement
Change-Id: I604b1294422f20d211db5614c47559557a78a193
Signed-off-by: Vladislav Grishenko <[email protected]>
Mohsin Kazmi [Tue, 29 Aug 2023 09:18:20 +0000 (09:18 +0000)]
 
virtio: add support for tx-queue-size
Type: improvement
DBGvpp# set loggin class virtio level debug
DBGvpp# create int virtio 0000:00:03.0 tx-queue-size 1024
show virtio pci
```
  Virtqueue (TX) 1
    qsz 1024, last_used_idx 0, desc_next 0, desc_in_use 0
    avail.flags 0x1 avail.idx 0 used.flags 0x0 used.idx 0
```
show logging
```
2022/07/22 23:20:22:557 debug      virtio         0000:00:03.0: tx-queue: number 1, default-size 256
2022/07/22 23:20:22:557 debug      virtio         0000:00:03.0: tx-queue: number 1, new size 1024
```
Change-Id: Ib1a3ebe742b3a6c9fe72bd1c5accfe07682cbdd1
Signed-off-by: Mohsin Kazmi <[email protected]>
Ole Troan [Tue, 5 Sep 2023 06:27:53 +0000 (08:27 +0200)]
 
ip: punt add punt socket support for icmp6
Punt support for ICMP6 messages allows for an external IPv6 RA advertisement agent.
Type: feature
Change-Id: I0cc928b747ac1f8335ee9f7c42a3231424825dbc
Signed-off-by: Ole Troan <[email protected]>
Vladislav Grishenko [Sat, 18 Mar 2023 21:57:01 +0000 (02:57 +0500)]
 
api: fix mp-safe mark for some messages and add more
Several api messages were not mp-safe although marked as such
because non-zero base id was not taken into account, and therefore
some other (from zero base id) were falsely mp-safe instead.
Keep messages as mp-safe, as they falsely were before:
    10   get_first_msg_id                              0       1
    12   api_versions                                  0       1
Messages that are no longer mp-safe as they weren't marked:
    15   sockclnt_create                               0       1
    33   proxy_arp_intfc_dump                          0       1
Fix messages to be really mp-safe:
    809  bridge_domain_dump                            0       1
    920  ip_route_add_del                              0       1
    921  ip_route_add_del_v2                           0       1
    1362 get_node_graph                                0       1
    1671 create_vhost_user_if                          0       1
    1675 create_vhost_user_if_v2                       0       1
Additionally mark messages as mp-safe, seems they need no barrier:
    1360 show_threads                                  0       1
    1370 show_version                                  0       1
    1372 show_vpe_system_time                          0       1
Type: fix
Change-Id: Ie6c1e3aa89f26bf51bfbcb7e7c4d9fee885487b7
Signed-off-by: Vladislav Grishenko <[email protected]>
Sylvain Cadilhac [Wed, 26 Jul 2023 14:16:47 +0000 (16:16 +0200)]
 
vapi: fix verification for reply message
Type: fix
Byte swapping should be done before verifying message otherwise the message length will be wrongly computed.
Change-Id: I90b2f60bd33e5362e0edd5ee425f6a6f07886f1e
Signed-off-by: Sylvain Cadilhac <[email protected]>
Filip Tehlar [Tue, 5 Sep 2023 13:36:28 +0000 (15:36 +0200)]
 
hs-test: point gdb to vpp source files
Type: test
Change-Id: Ie5867737e5d49fd45cc15b690af3493263fb2f6f
Signed-off-by: Filip Tehlar <[email protected]>
Filip Tehlar [Tue, 5 Sep 2023 13:58:28 +0000 (15:58 +0200)]
 
hs-test: verbose output on single test run
Type: test
Change-Id: I12ae7db36a6f7f9758fd195088877dfcd5606f84
Signed-off-by: Filip Tehlar <[email protected]>
Ole Troan [Fri, 1 Sep 2023 12:18:23 +0000 (14:18 +0200)]
 
npt66: make plugin default disabled
Plugin is still in experimental state. No reason why it needs
to be default enabled.
Type: fix
Change-Id: Ibf1810215d4c8079a068bfc60aa7dd49306ee4e4
Signed-off-by: Ole Troan <[email protected]>
Filip Tehlar [Sat, 2 Sep 2023 06:54:21 +0000 (08:54 +0200)]
 
hs-test: log external apps
Type: test
Change-Id: Id2b0d408bd46f20b81422506f9db4eb655feddac
Signed-off-by: Filip Tehlar <[email protected]>
Filip Tehlar [Sat, 2 Sep 2023 06:39:25 +0000 (08:39 +0200)]
 
hs-test: fix gdb attach
Type: test
Change-Id: Ic48ca7a3aab47df50d4e38e6123c90140c944172
Signed-off-by: Filip Tehlar <[email protected]>
Florin Coras [Sat, 2 Sep 2023 00:19:33 +0000 (17:19 -0700)]
 
udp: buffer packets for connections in accepting state
Type: fix
Fixes: 
0242d30
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I6e313000bccce749b813f20a52432154bfd494ed
Ole Troan [Thu, 31 Aug 2023 07:48:45 +0000 (09:48 +0200)]
 
arping: api to return responder mac address
The new arping_acd call includes the responders mac address in the reply.
Enabling a client doing address conflict detection to identify if it
is itself that is replying or that it is another host uses the IP
address.
Type: feature
Change-Id: Ia4bab2af1086f06ed71ba42e2e07368d4e330a27
Signed-off-by: Ole Troan <[email protected]>
Ole Troan [Fri, 1 Sep 2023 12:15:39 +0000 (14:15 +0200)]
 
npt66: checksum applied to src address instead of dst address on rx
Applied the checksum delta to the source address instead of the destination address
in the RX direction.
Cleaned up tests a little.
Type: fix
Change-Id: I871f3448365587e5319dfbca6ea356935321ff9b
Signed-off-by: Ole Troan <[email protected]>
Maxime Peim [Tue, 11 Jul 2023 07:45:56 +0000 (09:45 +0200)]
 
tracenode: filtering feature
In order to be able to filter on encapsulated packet, a new node
has been added to the ip4/6-unicast arcs.
Type: feature
Change-Id: I1e8ee05bc6d0fce20cadd8319c81bab260c17d21
Signed-off-by: Maxime Peim <[email protected]>
Florin Coras [Fri, 1 Sep 2023 00:33:47 +0000 (17:33 -0700)]
 
session: fix allocation of proxy fifos
Fifos need to be synchronously allocated once a transport like tcp
accepts a session. Since events are now delivered asynchronously,
proxy apps must explicitly register a cb function that manages
fifo allocation prior to being notified of connect event.
Type: fix
Fixes: 
0242d30
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I7df973b7014e53e0766ea2bdc61e9871160bc18b
Maxime Peim [Tue, 1 Aug 2023 09:29:15 +0000 (11:29 +0200)]
 
map: test fix feature disabling
Upon test teardown, MAP features were not disabled, potentially
leading packets to be treated by the wrong node.
Type: test
Change-Id: I0c1c614318d1308f825c5cc0bf95688e92f6d00a
Signed-off-by: Maxime Peim <[email protected]>
Florin Coras [Mon, 28 Aug 2023 06:14:50 +0000 (23:14 -0700)]
 
vcl: set min threshold for tx ntf
Make sure there's at least 3% space in the tx fifo before notifying vcl
of a tx event. The threshold is somewhat arbibrary but for a 4M fifo, it
now means that ~120kB of space should be available.
Should help minimize the amount of tx notifications generated by
session layer when apps are faster.
Type: improvement
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I11dd0931dca8f989000a2481f1f495bd267589c4
Andrew Yourtchenko [Mon, 14 Mar 2022 09:49:15 +0000 (09:49 +0000)]
 
fateshare: a plugin for managing child processes
For the reasons of modularity and security, it is useful
to have various functionality split into processes different from VPP.
However, this approach presents the challenges of managing those processes,
and is markedly different from simply running everything within VPP process.
This plugin is an experiment in having the VPP itself start off a monitor
process which in turn starts the child processes, and restarts them if they
quit.
If the VPP process ceases to exist, the monitor process terminates all
the descendant processes and quits itself.
This allows to preserve the "single entity to manage" approach of
simply running a barebones VPP.
An example of running it:
export DPDK_CONFIG=""
export DISABLED_PLUGINS=dpdk
export EXTRA_VPP_CONFIG="fateshare { monitor ./build-root/install-vpp_debug-native/vpp/bin/vpp_fateshare_monitor command ./test1 }"
make run
Signed-off-by: Andrew Yourtchenko <[email protected]>
Change-Id: I66221fd7403f220d9652fe76958ca499cfd070a7
Type: feature
Florin Coras [Mon, 28 Aug 2023 06:30:39 +0000 (23:30 -0700)]
 
session: fix compilation when SESSION_DEBUG is on
Wrap SESSION_EVT in do loop to avoid complaints about if statement
having no arguments which can happen if debugging for groups is not
enabled.
Type: fix
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I35af179b806ed47a1e20816a19291c31fdb7566a
Pim van Pelt [Sat, 10 Jun 2023 14:46:34 +0000 (16:46 +0200)]
 
mpls: add mpls_interface_dump
Add an API call mpls_interface_dump() which returns a list of mpls_interface_details:
- If no sw_if_index is given, all MPLS enabled sw_if_index are returned.
- If a particular sw_if_index is given, and it doesn't exist, an empty list is returned.
- If a sw_if_index exists and has MPLS enabled, a list of that one sw_if_index is returned.
Tested:
- Create 3 loopback interfaces
- Call for ~0 and for sw_if_index 0..5 all return empty lists
- set int mpls loop0 enable
- set int mpls loop1 enable
- Call for ~0 returns 2, and the call for sw_if_index=1 and =2 (the loopbacks) returns
  each a list of one sw_if_index 1 resp 2, the other values of sw_if_index return empty list
- set int mpls loop0 disable
- Call for ~0 returns 1, and the call for sw_if_index=2 (loop1) returns both a list of one
  sw_if_index=2, the other values of sw_if_index return empty list
- set int mpls loop1 disable
- Call for ~0 and for sw_if_index 0..5 all return empty lists
Example Python3 API program:
```
api_response = vpp.api.mpls_interface_dump()
print(f"Response is {api_response}")
for i in [ 0, 1, 2, 3, 4, 5 ]:
  api_response = vpp.api.mpls_interface_dump(sw_if_index=i)
  print(f"Response[{i}] = {api_response}")
```
Type: improvement
Change-Id: If87f7d7f8972d99260e859757dbcb251c6fa54a8
Signed-off-by: Pim van Pelt <[email protected]>
Florin Coras [Sat, 26 Aug 2023 19:59:11 +0000 (12:59 -0700)]
 
perftool: fix delsvec use of _vec_len
Type: fix
Signed-off-by: Florin Coras <[email protected]>
Change-Id: Iab80e009d8717f759edb8133beaa55ed05e57bd5
Wei Li [Wed, 8 Mar 2023 11:36:55 +0000 (11:36 +0000)]
 
nat: nat44-ed bug fix
fix lb static mapping
"nat44_ed_sm_o2i_add" laddr and lport
Type: fix
Signed-off-by: Wei Li <[email protected]>
Change-Id: I249a00919e8154d92cbce03f6db196c13612948f
Wei Li [Wed, 8 Mar 2023 08:01:01 +0000 (08:01 +0000)]
 
nat: nat44-ed cli bug fix
lport and eport in Cli "nat44 add load-balancing static mapping" should hton()
Type: fix
Signed-off-by: Wei Li <[email protected]>
Change-Id: I2eadb7e341efb70cc406e10b3b189e5ebff09ff4
Benoît Ganne [Thu, 24 Aug 2023 12:40:41 +0000 (14:40 +0200)]
 
cnat: fix cnat_endpoint_encode
Type: fix
Change-Id: I4ab713811626c097c7927228f3819b7785bbb951
Signed-off-by: Benoît Ganne <[email protected]>
Ole Troan [Thu, 17 Aug 2023 11:36:08 +0000 (13:36 +0200)]
 
npt66: network prefix translation for ipv6
This is the initial commit of a NPTv6 (RFC6296) implementation for VPP.
It's restricted to a single internal to external binding and runs
as an output/input feature on the egress interface.
Type: feature
Change-Id: I0e3497af97f1ebd99377b84dbf599ecea935ca24
Signed-off-by: Ole Troan <[email protected]>
spencercoder [Tue, 22 Aug 2023 04:42:09 +0000 (12:42 +0800)]
 
build: support linuxmint OS
Support compiling in Linux Mint OS
Type: improvement
Change-Id: I08721227352b00127fe0acac67269775997fd974
Signed-off-by: spencercoder <[email protected]>
Piotr Bronowski [Mon, 21 Aug 2023 13:36:38 +0000 (13:36 +0000)]
 
dpdk-cryptodev: fix coverity issues
This patch addresses coverity issues CID 322716 and CID 322717.
Type: fix
Signed-off-by: Piotr Bronowski <[email protected]>
Change-Id: I59d6f40c1af8e829d8cb3c042a52e144aeaf1e6b
Vratko Polak [Wed, 12 Jul 2023 11:24:45 +0000 (13:24 +0200)]
 
l2: fix prefetch
This is a clone of Gerrit 35419.
(It is abandoned and I am not the owner so I cannot reopen.)
Ticket: CSIT-1816
Type: fix
Fixes: 
5e0ea09d96010e99a7ce0d2f3370f0de50c46c83
Change-Id: I2265cf38a9ce3155460a1025821c2749afca0add
Signed-off-by: Vratko Polak <[email protected]>
Julian Klaiber [Mon, 14 Aug 2023 11:39:13 +0000 (11:39 +0000)]
 
sr: SRv6 Path Tracing midpoint processing performance improvement
Moved the kernel call for the timestamp outside of the inner loop to improve the batch proccessing, and minimizing the kernel calls.
Type: improvement
Change-Id: I0245c223fc8a178724bb8c5df2b98083be046c26
Signed-off-by: Julian Klaiber <[email protected]>
Steven Luong [Fri, 18 Aug 2023 18:20:00 +0000 (11:20 -0700)]
 
nat: documention fix
s/nat44 enable sessions/nat44 plugin enable sessions/
Type: docs
Change-Id: I93dbd161f085bff5b98df50cd29c9bedf5038307
Signed-off-by: Steven Luong <[email protected]>
Piotr Bronowski [Thu, 6 Jul 2023 23:02:57 +0000 (23:02 +0000)]
 
dpdk-cryptodev: improve cryptodev cache ring implementation
Sw ring is renamed to the cache ring. This name better reflects the
puropse of this ring. We've introduced push/pop functions, as well as
other utility functions which remove code repetition. Error handlig
is improved: previously in case of an error all frame elements were
marked as bad, now only these for which errors occured have the error
status set.
Unnecessary stats counters have been removed.
Type: improvement
Signed-off-by: Piotr Bronowski <[email protected]>
Change-Id: I2fd42a529ac84ce5ad260611d6b35a861d441c79
Klement Sekera [Sun, 6 Aug 2023 17:33:16 +0000 (19:33 +0200)]
 
vapi: improve vl_api_string_t handling
Define vl_api_string_t to correspond with vlibapi/api_types.h
Fix allocation and size calculation routine generation.
Type: improvement
Change-Id: I6b0a3eb3459d75d326e67bfb76dac8125e480afa
Signed-off-by: Klement Sekera <[email protected]>
Stanislav Zaikin [Thu, 21 Jul 2022 17:07:50 +0000 (19:07 +0200)]
 
vapi: support services
Add missing support for
service { rpc X_get returns X_get_reply stream X_details; }
Type: improvement
Change-Id: I27555f61a2974e414cb6554f32c550b8ee5eb037
Signed-off-by: Stanislav Zaikin <[email protected]>
Signed-off-by: Klement Sekera <[email protected]>
HediBouattour [Wed, 16 Aug 2023 11:26:22 +0000 (13:26 +0200)]
 
cnat: add host tag to bitmap in cnat snat
Type: feature
this patch adds a new tag "host" to interfaces for cnat-snat
if an interface is tagged pod and host we do not snat traffic outgoing through it
Change-Id: I71f5bfcb85581bb8508ba547374f0603f1079ac6
Signed-off-by: hedi bouattour <[email protected]>
Klement Sekera [Thu, 17 Aug 2023 17:38:34 +0000 (19:38 +0200)]
 
tests: more descriptive error message
Type: improvement
Change-Id: Icf8a5dc711e1e11ec919b515d7af2f487a1c04c2
Signed-off-by: Klement Sekera <[email protected]>
Signed-off-by: Dave Wallace <[email protected]>
Ting Xu [Thu, 15 Dec 2022 02:10:59 +0000 (02:10 +0000)]
 
idpf: add native idpf driver plugin
Add a new native idpf driver. This patch enables the device
initialization. Add some necessary functions and definations
for input and output. A new version of virtchnl is introduced.
Type: feature
Signed-off-by: Ting Xu <[email protected]>
Change-Id: Ibbd9cd645e64469f1c4c8b33346c1301be3f6927
nucleo [Tue, 15 Aug 2023 17:59:35 +0000 (20:59 +0300)]
 
dpdk: Newer meson 0.55.3
Fixes error with python 3.12
No module named 'pkg_resources'
'import pkg_resources' removed in 0.55.3
Type: fix
Change-Id: I15c8cf195fd07a0eb2f3b58f895ef4b26cc17b90
Signed-off-by: nucleo <[email protected]>
Dave Wallace [Tue, 15 Aug 2023 23:05:26 +0000 (19:05 -0400)]
 
tests docs: update python3 venv packages
- Package update performed by
  1. updating pip, pip-tools, setuptools
  2. 'make test-refresh-deps' on ubuntu 22.04
  3. fixing 'make test' and 'make docs' issues
     on ubuntu 22.04
  4. 'make test-refresh-deps' on ubuntu 20.04
- Add dependency for 'make test-refresh-deps'
  to insure python venv is set up.
- Update of python formatter, black,
  caused reformating of 41 python code
  files.
Type: make
Change-Id: I7cafdf4b5189065ac57cb6b254937f6e0897a924
Signed-off-by: Dave Wallace <[email protected]>
yanlong [Tue, 8 Aug 2023 03:36:32 +0000 (11:36 +0800)]
 
l2:Add doc for l2 rewrite, and add examples
Supplemented the documentation of "l2 rewrite", and added examples
Type:docs
Change-Id: If49ae0b22989b3cd1c88a27a4e51b74be32d75e7
Signed-off-by: yanlong <[email protected]>
Andrew Yourtchenko [Tue, 1 Aug 2023 11:03:29 +0000 (13:03 +0200)]
 
nat: mark several messages as production
As per discussion on the VPP call, since they are being
used in CSIT tests and have not seen changes in a while,
mark the messages as production from the change process
standpoint.
Type: improvement
Signed-off-by: Andrew Yourtchenko <[email protected]>
Change-Id: I7fda71edd923b798d034380320a869f7c35cb5a6
Florin Coras [Tue, 15 Aug 2023 19:11:50 +0000 (12:11 -0700)]
 
vcl: fix ldp epoll events array overrun
Type: fix
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I3dd65946c220f958a4fda0551b053d690bf06c39
Florin Coras [Tue, 15 Aug 2023 18:16:34 +0000 (11:16 -0700)]
 
vcl: handle postponed disconnects with select
Type: fix
Signed-off-by: Florin Coras <[email protected]>
Change-Id: Ia8449344a471129c0d148b39d97a5d310c2a1fc7
wanghanlin [Tue, 8 Aug 2023 02:40:04 +0000 (10:40 +0800)]
 
vcl: fix error state switch for vcl_handle_mq_event
When a listen session receives an ACCEPTED message, but then
receives either a RESET or DISCONNECTED message from VPP before the
session is accepted, the listen session state is switched to
VPP_CLOSING or DISCONNECT.
The subsequent CLEANUP message handler attempts to send a
disconneted or reset reply message to VPP, but since the vpp_evt_q
for the listen session is null, this leads to a crash.
Type: fix
Change-Id: Ic51f78f631fe8d15bf8c56b795f4a900c3e2f724
Signed-off-by: wanghanlin <[email protected]>
Dave Wallace [Mon, 14 Aug 2023 20:19:46 +0000 (16:19 -0400)]
 
dpdk: bump rdma-core to 46.1
- Per dpdk 23.07 release notes (rdma-core >= 46.0)
Type: feature
Change-Id: I7c15e15e1cf4b6f652711f9446d9f8324f6c4092
Signed-off-by: Dave Wallace <[email protected]>
Kai Ji [Tue, 8 Aug 2023 23:46:12 +0000 (23:46 +0000)]
 
dpdk: bump to DPDK 23.07
This patch bumps DPDK version from 23.03 to 23.07.
Type: feature
Change-Id: I15140cecd008bfafb358f6348a1cb8fc08f70f02
Signed-off-by: Kai Ji <[email protected]>
Florin Coras [Fri, 11 Aug 2023 21:40:13 +0000 (14:40 -0700)]
 
session: fix coverity warnings
Type: fix
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I910c8ce1713c6d346cc5ea4eb58a89c1c30a10a1
Dave Wallace [Wed, 9 Aug 2023 16:58:22 +0000 (12:58 -0400)]
 
tests: filter coverage report output
- Remove test code & non-vpp code from coverage report
- Remove driver/hardware vpp code which cannot be tested
  in 'make test' from coverage report
Type: fix
Change-Id: I04b50c14bc3437b845f2afafae47297189e61e3f
Signed-off-by: Dave Wallace <[email protected]>
Vratko Polak [Mon, 31 Jul 2023 15:08:21 +0000 (17:08 +0200)]
 
crypto-sw-scheduler: avoid crypto work on vpp_main
+ Checkstyle demanded indentation edits.
Type: fix
Ticket: VPP-2083
Fixes: 
9a9604b09f15691d7c4ddf29afd99a31e7e31eed
Change-Id: Ie2d33d290330247d36435a073675b732bb64ae93
Signed-off-by: Vratko Polak <[email protected]>
Steven Luong [Tue, 8 Aug 2023 18:20:09 +0000 (11:20 -0700)]
 
docs: correct the directory path for index.html
Type: fix
Change-Id: Ia0d6f57790dbca92662c6d8b986c325f1c399131
Signed-off-by: Steven Luong <[email protected]>
Florin Coras [Thu, 22 Dec 2022 23:03:44 +0000 (15:03 -0800)]
 
session: async rx event notifications
Move from synchronous flushing of io and ctrl events from transports to
applications to an async model via a new session_input input node that
runs in interrupt mode. Events are coalesced per application worker.
On the one hand, this helps by minimizing message queue locking churn.
And on the other, it opens the possibility for further optimizations of
event message generation, obviates need for rx rescheduling rpcs and is
a first step towards a fully async data/io rx path.
Type: improvement
Signed-off-by: Florin Coras <[email protected]>
Change-Id: Id6bebcb65fc9feef8aa02ddf1af6d9ba6f6745ce
Nathan Skrzypczak [Wed, 4 Nov 2020 10:41:05 +0000 (11:41 +0100)]
 
cnat: remove rwlock on ts
Type: improvement
Remove rwlock contention on timestamps. ~10% pps with
10k sessions. Use fixed-size-pools of increasing sizes
starting with 4K, and with a x2 step each time.
We don't free/shrink allocated pools.
Change-Id: I5fea51faba40430106c823275a6356e81709d118
Signed-off-by: Nathan Skrzypczak <[email protected]>
Nathan Skrzypczak [Fri, 4 Jun 2021 16:37:27 +0000 (18:37 +0200)]
 
cnat: add ip/client bihash
This replace the cnat ip4/ip6 to client
lookups previously done with a regular
hash, by a bihash lookup.
Type: improvement
Do the client lookup in a bihash instead of
a hash.
Change-Id: I730c1893525c002b44ada8e290a36802835e88e9
Signed-off-by: Nathan Skrzypczak <[email protected]>
Dave Wallace [Tue, 8 Aug 2023 19:25:21 +0000 (15:25 -0400)]
 
tests: fix setting gcov flag for test-cov target
Type: fix
Change-Id: I3c663babe4f32f5d2870265336b5d272cc029ce7
Signed-off-by: Dave Wallace <[email protected]>
Nathan Skrzypczak [Thu, 14 Oct 2021 15:41:57 +0000 (18:41 +0300)]
 
cnat: flag to disable rsession
This adds a flag on the translation
asking the VIP & input-feature nodes
not to create the return session when
translating / load-balancing an incoming
flow. This is needed with maglev & DSR
Type: feature
Change-Id: I699012310ddc59f6ceeeb4878638eac6da5128dc
Signed-off-by: Nathan Skrzypczak <[email protected]>
yanlong [Wed, 26 Jul 2023 07:12:04 +0000 (15:12 +0800)]
 
docs:Improve the README of vpp docs
Type:fix
Change-Id: Ie2ae728450ef123379b697cdf9c873d5bec01b47
Signed-off-by: yanlong <[email protected]>
Benoît Ganne [Fri, 10 Mar 2023 16:33:03 +0000 (17:33 +0100)]
 
ipsec: add support for RFC-4543 ENCR_NULL_AUTH_AES_GMAC
Type: improvement
Change-Id: I830f7a2ea3ac0aff5185698b9fa7a278c45116b0
Signed-off-by: Benoît Ganne <[email protected]>
Gao Feng [Mon, 17 Jul 2023 14:19:32 +0000 (22:19 +0800)]
 
vcl: Fix the ldp init check
Maybe some function calls the wrapper funtion like read which invokes
the ldp_init_check in the other libs as a constructor before
ldp_constructor. Then the ldp has been initialized already when
ldp_constructor is invoked. And it's normal case, we shouldn't treat it
as an error.
So ldp_init should return success if ldp is initialized already instead
of an assert.
Type: fix
Change-Id: Ifa2a7b1d5471981a3f840b14a4fa5d48fb1f1374
Signed-off-by: Gao Feng <[email protected]>
Damjan Marion [Sun, 6 Aug 2023 23:15:37 +0000 (01:15 +0200)]
 
vlib: support sibling node creation with vlib_register_node()
Type: improvement
Change-Id: I7e82a262692b2b6513f81889d78a43c10ca7bfb2
Signed-off-by: Damjan Marion <[email protected]>
Damjan Marion [Sun, 6 Aug 2023 23:07:09 +0000 (01:07 +0200)]
 
vppinfra: add clib_file_get_resolved_basename
more generic version of clib_sysfs_link_to_name with support for
format strings...
Type: improvement
Change-Id: I0cb263748970378c661415196eb7e08450370677
Signed-off-by: Damjan Marion <[email protected]>
Damjan Marion [Sun, 6 Aug 2023 18:41:40 +0000 (20:41 +0200)]
 
vppinfra: add vec_foreach_pointer macro
works with vectors of pointers...
Type: improvement
Change-Id: I530653978fcf981be299cf42a1133be000d74d0c
Signed-off-by: Damjan Marion <[email protected]>
Damjan Marion [Sun, 6 Aug 2023 18:39:38 +0000 (20:39 +0200)]
 
vppinfra: add unformat_init_path
More conveninet way to unformat file by providing filesystem path.
Takes format string for easier constuction of path...
Type: improvement
Change-Id: I433204fa20dc98e2b11c53914883d047a7fc62c6
Signed-off-by: Damjan Marion <[email protected]>
wanghanlin [Mon, 7 Aug 2023 09:23:53 +0000 (17:23 +0800)]
 
vcl: fix error state switch for VCL_STATE_LISTEN_NO_MQ sessions
When a VCL_STATE_LISTEN_NO_MQ session receives an ACCEPTED message,
but then receives either a RESET or DISCONNECTED message from VPP
before the session is unlistened, the listen session state is
switched to DISCONNECT.
The subsequent CLEANUP message handler attempts to send a reset
reply message to VPP, but since the vpp_evt_q for the listen
session is null, this leads to a crash.
Type: fix
Change-Id: Id7e88dcb16df3eda912b3f763730ec8d8973473a
Signed-off-by: wanghanlin <[email protected]>
Nathan Skrzypczak [Thu, 25 Feb 2021 18:13:19 +0000 (19:13 +0100)]
 
cnat: Support offloaded check sums
This patch removes zero checks for new_addr, new_port
meaning sessions with zero values will rewrite the packet
with a 0 value instead of leaving it in place. This allows
to reduce branchiness in the code, and sessions are fully
resolved at creation time anyway.
This also adds support for checksum offloads:
- IP checksum offload : we always compute the checksum to
avoid issues with drivers. We'll revert this if we realize
cost gets too important.
- TCP/UDP checksum offload : we add the implementation for
pseudo header checksum computation. This is needed for the
drivers that do not re-compute this pseudo-checksum before
the packet is TX-ed (e.g. a few DPDK drivers).
Type: improvement
Change-Id: I6543f3aec8c120ec50f4219108609138283620ef
Signed-off-by: Nathan Skrzypczak <[email protected]>
Benoît Ganne [Fri, 4 Aug 2023 14:13:43 +0000 (16:13 +0200)]
 
nsh: fix nsh gre references
Since gre is a plugin, nsh should not use symbol names directly.
Type: fix
Fixes: 
cefb178aa487a217d4ac75d7d4fa62db4b7d70fd
Change-Id: I1a1c20740aabdaafd69f507cd71016c3109b0205
Signed-off-by: Benoît Ganne <[email protected]>
Damjan Marion [Fri, 4 Aug 2023 10:47:44 +0000 (10:47 +0000)]
 
vpp: detect early nosyslog and interactive flags
So error logs are displayed on console earlier....
Type: improvement
Change-Id: If31b76c9d06254b0fec5b5b3f4e92a881b4cf786
Signed-off-by: Damjan Marion <[email protected]>
Damjan Marion [Wed, 2 Aug 2023 15:58:58 +0000 (15:58 +0000)]
 
vppinfra: add pool_foreach_pointer()
Works on pools of pointers...
Type: improvement
Change-Id: I194dec389ca4c5ec2ce3361b54a9968c9caecefc
Signed-off-by: Damjan Marion <[email protected]>
Florin Coras [Tue, 1 Aug 2023 17:53:22 +0000 (10:53 -0700)]
 
quic: fix closing of streams
Avoid explicit manipulation of session state and generate closing event
if need be.
Type: fix
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I07cda1db08a2673b27b496ea1371b0dfd8e6f98a
Damjan Marion [Fri, 28 Jul 2023 18:06:09 +0000 (20:06 +0200)]
 
vlib: remove dependency on libuuid
Type: improvement
Change-Id: I4e2b2e4f227dfcb3df36166db13c8aa5c0b603f5
Signed-off-by: Damjan Marion <[email protected]>
Damjan Marion [Mon, 31 Jul 2023 18:07:31 +0000 (20:07 +0200)]
 
vppinfra: add unformat_c_string_array
Type: improvement
Change-Id: Iea5ecca5d4cbc6c7aea69104830afcfe78c708ee
Signed-off-by: Damjan Marion <[email protected]>
Sylvain Cadilhac [Fri, 28 Jul 2023 21:36:35 +0000 (23:36 +0200)]
 
ipsec: fix IPv6 IPsec tunnel punting
Type: fix
Buffer needs to be rewinded before being passed to punt-dispatch node.
Change-Id: I43d103515d372e425f4c3b08ca1779398f1fced4
Signed-off-by: Sylvain Cadilhac <[email protected]>
Mohsin Kazmi [Thu, 27 Jul 2023 16:58:41 +0000 (16:58 +0000)]
 
libmemif: add support for buffer size
Type: improvement
buffer size can be configurable:
./test_app -b 9216
Signed-off-by: Mohsin Kazmi <[email protected]>
Change-Id: Id77f6baac27d45dec3d5b7ea8a9a53acf2a302fc
Dave Wallace [Fri, 28 Jul 2023 20:31:51 +0000 (16:31 -0400)]
 
vlib: fix gcc build breakage
Type: fix
Fixes: 
00ea98ad6
Change-Id: I4ac8c9c5902299d5f283ba4912d52d9bfcedef5c
Signed-off-by: Dave Wallace <[email protected]>
Filip Tehlar [Tue, 27 Jun 2023 08:01:37 +0000 (10:01 +0200)]
 
hs-test: improve get stats
Type: test
Change-Id: Ie681ee43007f4fe787d51d80bda9b433dcb6c09a
Signed-off-by: Filip Tehlar <[email protected]>
Florin Coras [Fri, 28 Jul 2023 16:11:23 +0000 (09:11 -0700)]
 
session: regrab evt llist elt for app transports tx
App transports like TLS can close sessions on tx and consequently
generate new events. That can realloc the event pool.
Type: fix
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I58a97502acc1182b3d051ba1aa9e0e98c16f4593
Damjan Marion [Fri, 28 Jul 2023 11:02:00 +0000 (13:02 +0200)]
 
vnet: add vnet_register_device_class function
To allow dynamic registration of device classes..."
Change-Id: Ie8435e8c55b7e300be06abe97b653c0c3ce7f732
Type: improvement
Signed-off-by: Damjan Marion <[email protected]>
Damjan Marion [Fri, 28 Jul 2023 11:19:49 +0000 (13:19 +0200)]
 
vlib: pci cleanup and improvements
Change-Id: Ieafbed6f2db3dec65e4b43d84a4661f6a1bbe891
Type: improvement
Signed-off-by: Damjan Marion <[email protected]>
Damjan Marion [Fri, 28 Jul 2023 10:57:15 +0000 (12:57 +0200)]
 
vlib: fix coverity issue in vlib_node_set_interrupt_pending
Type: fix
Fixes: 
cc8249c
Change-Id: Iebfbbd1e00782c4097cc840460b5177d18921131
Signed-off-by: Damjan Marion <[email protected]>
Filip Tehlar [Thu, 27 Jul 2023 13:49:12 +0000 (15:49 +0200)]
 
hsa: add total bytes parameter to vcl_test_client
Type: test
Change-Id: Ib1131eedb8eeaa9adfed9cfc47beeb1c7c8adb5c
Signed-off-by: Filip Tehlar <[email protected]>
Filip Tehlar [Thu, 20 Jul 2023 16:09:36 +0000 (18:09 +0200)]
 
session: remove unused code
Type: improvement
Change-Id: I7525aa81acf073707550b23541fdcc358b9bf49c
Signed-off-by: Filip Tehlar <[email protected]>
Maxime Peim [Mon, 3 Jul 2023 07:42:58 +0000 (09:42 +0200)]
 
ipsec: fix sa bind cli
Small mistake was made, reported by coverty scan.
Type: fix
Change-Id: I98ca16c0275a94b2def99831f9353d4ff3fe93a9
Signed-off-by: Maxime Peim <[email protected]>
Denys Haryachyy [Wed, 12 Jul 2023 14:32:55 +0000 (17:32 +0300)]
 
ikev2: cleanup stuck sessions
The following issues are fixed:
* in responder code: do lookup again as the old pointer could be
  invalidated during the cleanup operation
* in initiar code: do the cleanup of session if there're no child SAs or
  if there's no response from the responder during initial request (this
  can easily happen if the response packet was lost/dropped/etc)
* print the state of ikev2 profile (for easier tshooting)
Type: fix
Change-Id: I853d9851c0cf131696585e3c98fa97e66789badd
Signed-off-by: Stanislav Zaikin <[email protected]>
Florin Coras [Wed, 26 Jul 2023 18:27:33 +0000 (11:27 -0700)]
 
vcl: allow rx of zero length dgrams
Type: fix
Change-Id: I438ef488357456e9415e51a17355e9eba8518808
Signed-off-by: Florin Coras <[email protected]>
Vratko Polak [Wed, 26 Jul 2023 11:48:20 +0000 (13:48 +0200)]
 
vlib: rename vnet_log_get_class_data
It is a function in vlib, so no reason to mention vnet.
Type: fix
Fixes: 
bf179a91d8d224c64d08643a2bb52580f68ce96b
Change-Id: Ic5f601d94d88b667f7ce44a017a0e1d5b4db5da1
Signed-off-by: Vratko Polak <[email protected]>
Steven Luong [Tue, 25 Jul 2023 19:32:01 +0000 (12:32 -0700)]
 
stats: remove extra format line
The extra format line was added for no reason from patch 
ff27c9f8e.
Type: fix
Fixes: 
ff27c9f8e
Change-Id: Ib25149cc8a17c29d0c8a0dbc06f0ea12ca4f328c
Signed-off-by: Steven Luong <[email protected]>
Filip Tehlar [Wed, 28 Jun 2023 08:47:32 +0000 (10:47 +0200)]
 
session: use session error type instead of vnet error
Type: improvement
Change-Id: Ie0bad9e03ac2e29da23af01ee7f63cb44489ad9c
Signed-off-by: Filip Tehlar <[email protected]>
Damjan Marion [Sun, 23 Jul 2023 12:24:22 +0000 (14:24 +0200)]
 
vlib: interrupt mode support for pre-input nodes
Type: improvement
Change-Id: Ic6e60597d2be63e3a0ae4399a81dbbd72392f30d
Signed-off-by: Damjan Marion <[email protected]>
Maxime Peim [Mon, 3 Jul 2023 15:45:51 +0000 (17:45 +0200)]
 
classify: add bpf support to pcap classifier
Type: feature
Change-Id: I28fb38e49c89f4c4d4cc58c1a5c0aa8502678472
Signed-off-by: Maxime Peim <[email protected]>
Tianyu Li [Fri, 7 Jul 2023 06:38:06 +0000 (06:38 +0000)]
 
dpdk: fix signed single bit field
clang-16 complains about signed one-bit bitfield value changes
from 1 to -1. Use unsigned type instead.
Type: fix
Signed-off-by: Tianyu Li <[email protected]>
Change-Id: I84f8cf314d36183a5e6f544cd756c01d1d10a1a5
Gabriel Oginski [Fri, 7 Jul 2023 11:58:26 +0000 (11:58 +0000)]
 
vpp-swan: fix handler API messages
In the current implementation there is a bug related to the incorrect
message handling due to the wrong id.
The fix changes logic responsible for handling incoming API messages
by correcting their ids.
Type: fix
Signed-off-by: Gabriel Oginski <[email protected]>
Change-Id: Iea29506053c9fd2e1d01bce83e7f4a6e1de39321
qinyang [Tue, 27 Jun 2023 08:11:53 +0000 (01:11 -0700)]
 
vcl: ldp support SO_ORIGINAL_DST
Type: improvement
Support SO_ORIGINAL_DST socket option to get original dst_ip4 and dst_port if nat44 rule enabled.
Change-Id: If00e00d03e48f3b78a23a68f1b078954d79dd0f7
Signed-off-by: qinyang <[email protected]>
Naveen Joy [Tue, 27 Jun 2023 21:28:57 +0000 (14:28 -0700)]
 
tests: Add checksum offload interface tests
Type: test
Change-Id: I6edc8858b802d3d32159d71c1e867a06cc1025d5
Signed-off-by: Naveen Joy <[email protected]>
Piotr Bronowski [Thu, 23 Feb 2023 09:56:49 +0000 (09:56 +0000)]
 
ipsec: fix logic in ext_hdr_is_pre_esp
When _VEC128 instructions are not enabled logic is buggy.
The function always returned 1.
Type: fix
Signed-off-by: Piotr Bronowski <[email protected]>
Change-Id: I603200637e8d65813f4e49ef15d798e74b79b9cf
Steven Luong [Wed, 19 Jul 2023 06:25:15 +0000 (23:25 -0700)]
 
vcl: zero out cmsg for recvmsg API
When msg->msg_controllen is set in recvmsg, the caller wants to receive
additional information about the messages. However, they might not
always be available. In that case, we should clear cmsg since
the caller uses CMSG_NXTHDR which might access uninitialized fields in
cmsg.
Type: fix
Change-Id: Ifdf9634bfcb1427f7ae3812014a46bfd7f4bc473
Signed-off-by: Steven Luong <[email protected]>
Gabriel Oginski [Fri, 14 Jul 2023 07:22:12 +0000 (07:22 +0000)]
 
vpp-swan: change flow in function for add route
This patch addresses the issue when the list of available interfaces
is not up to date. Due to this issue adding a new route fails
and finally the connection is not established.
Type: fix
Signed-off-by: Gabriel Oginski <[email protected]>
Change-Id: I3a63c0dd99ebc28ea149b4b23867440937682761
Gabriel Oginski [Thu, 6 Jul 2023 11:13:16 +0000 (11:13 +0000)]
 
vpp-swan: fix incorrect msg ID in register_event
This patch addresses the issue where the message ID registration
in the register_event function is incorrect. Due to this incorrect
registration, the lookup for the corresponding callback on received
messages fails, eventually leading to a segmentation fault
and double-free memory space.
Type: fix
Signed-off-by: Gabriel Oginski <[email protected]>
Change-Id: If95182f972f64adb44d514e18c831cc9627d8f0f