vpp.git
2 years agoapi: tapv2 - Mark old message versions as deprecated 51/38651/3
Ondrej Fabry [Wed, 26 Apr 2023 22:00:46 +0000 (00:00 +0200)]
api: tapv2 - Mark old message versions as deprecated

List of changed messages:
- tap_create_v2
- tap_create_v2_reply

This change is part of VPP API cleanup initiative.

Type: fix
Signed-off-by: Ondrej Fabry <[email protected]>
Change-Id: I7b1b22cc4a0e31f5c19fe48e7a0f30631576f9df

2 years agoapi: vxlan - Mark old message versions as deprecated 46/38646/3
Ondrej Fabry [Wed, 26 Apr 2023 22:00:13 +0000 (00:00 +0200)]
api: vxlan - Mark old message versions as deprecated

List of changed messages:
- vxlan_add_del_tunnel
- vxlan_add_del_tunnel_v2
- vxlan_add_del_tunnel_reply
- vxlan_add_del_tunnel_v2_reply
- vxlan_tunnel_dump
- vxlan_tunnel_details

This change is part of VPP API cleanup initiative.

Type: fix
Signed-off-by: Ondrej Fabry <[email protected]>
Change-Id: I0a7227e76a493731fd136f8e6310ad372fab2494

2 years agoaf_xdp: create_api_v3 without namespace keyword 25/39125/2
Stanislav Zaikin [Thu, 22 Jun 2023 14:46:01 +0000 (16:46 +0200)]
af_xdp: create_api_v3 without namespace keyword

Namespace keyword is reverved c++ word, so it's not possible to include
vapi header for af_xdp plugin and use it.

Type: fix

Signed-off-by: Stanislav Zaikin <[email protected]>
Change-Id: I42a0e0a89ff2c407090d3c18c1bc5a5605ddf032

2 years agovirtio: use fast-path for ethernet-input if possible 10/36110/5
Stanislav Zaikin [Thu, 5 May 2022 10:04:39 +0000 (12:04 +0200)]
virtio: use fast-path for ethernet-input if possible

If a frame should be sent to 'ethernet-input' set the
ETH_INPUT_FRAME_F_SINGLE_SW_IF_IDX flag. It will force 'ethernet-input'
to use a fast-path for such frames.
This patch also aligns the behaviour with other input nodes.

Type: improvement

Change-Id: Icff0fa31204d5304a2ea0a4f4e7bc418dedbfe32
Signed-off-by: Stanislav Zaikin <[email protected]>
2 years agoudp: pass cless hdr to transport through buffer 29/39129/5
Florin Coras [Sat, 24 Jun 2023 21:43:42 +0000 (14:43 -0700)]
udp: pass cless hdr to transport through buffer

Type: improvement

Signed-off-by: Florin Coras <[email protected]>
Signed-off-by: Filip Tehlar <[email protected]>
Change-Id: I7177ada23e5a69ec8e362ec98b98010c3b44b3d7

2 years agotcp: avoid initializing counters multiple times 30/39130/3
Florin Coras [Sun, 25 Jun 2023 01:57:17 +0000 (18:57 -0700)]
tcp: avoid initializing counters multiple times

Type: fix

Signed-off-by: Florin Coras <[email protected]>
Change-Id: Ia98dae5fdde16426d5457742aff0a1b04db4d034

2 years agoipsec: manually binding an SA to a worker 28/38528/4
Maxime Peim [Mon, 20 Mar 2023 14:13:56 +0000 (14:13 +0000)]
ipsec: manually binding an SA to a worker

An SA is normally bound to the first thread using it. However, one
could want to manually bind an SA to a specific worker.

Type: improvement
Signed-off-by: Maxime Peim <[email protected]>
Change-Id: I05cbbf753e44a01d9964ee47812c964db9bbb488

2 years agofib: walk over adj glean per table 24/39124/2
Stanislav Zaikin [Tue, 14 Mar 2023 11:32:32 +0000 (12:32 +0100)]
fib: walk over adj glean per table

Type: fix

Signed-off-by: Stanislav Zaikin <[email protected]>
Change-Id: I07f54bb643c24b1839a2d0e93acc593d13a43fed

2 years agotcp: add simple stats collector 19/39119/4
Florin Coras [Thu, 22 Jun 2023 03:02:25 +0000 (20:02 -0700)]
tcp: add simple stats collector

Type: feature

Signed-off-by: Florin Coras <[email protected]>
Change-Id: I435ff10fa3af15b0bed83607aca508a1c087a159

2 years agotests docs: fix lcov code coverage report generation 20/39120/5
Dave Wallace [Thu, 22 Jun 2023 03:14:38 +0000 (23:14 -0400)]
tests docs: fix lcov code coverage report generation

- Updated/rebased version of https://gerrit.fd.io/r/c/vpp/+/34199

Type: test
Change-Id: I43913ecfd11a4578bdb10c4be76253fe38d57976
Signed-off-by: Nathan Skrzypczak <[email protected]>
Signed-off-by: Dave Wallace <[email protected]>
2 years agotcp: options support into pg 82/39082/4
Maxime Peim [Mon, 19 Jun 2023 16:19:48 +0000 (18:19 +0200)]
tcp: options support into pg

Packet-generator does not support TCP options.
Along with its support, a formatting function has been added.
Further work will be needed to update header formatting functions
to take into account TCP connection options. For now, TCP options
are taken on a per-packet basis.

Type: improvement
Change-Id: Id800887853c4941d893be353ce6d8624ed8bbc5d
Signed-off-by: Maxime Peim <[email protected]>
2 years agotests: do not run qemu interface tests if the environment does not allow it 95/38795/3
Andrew Yourtchenko [Tue, 20 Jun 2023 14:52:08 +0000 (14:52 +0000)]
tests: do not run qemu interface tests if the environment does not allow it

cdf73b973181ff4c67147900408216e37bae897a has added the qemu tests as part of the default test run,
which results in "make test" failure in more restricted environments which do not allow the
namespace creation.

Add a config flag to skip those tests, and skip them if the namespace creation fails.

Type: test
Signed-off-by: Andrew Yourtchenko <[email protected]>
Change-Id: Ie631f7fb2a80864f77c79619eba4a43712e950e5

2 years agosession: mark half-open transport closed on ntf 90/39090/2
Florin Coras [Tue, 20 Jun 2023 23:50:51 +0000 (16:50 -0700)]
session: mark half-open transport closed on ntf

Make sure half-open sessions are marked as transport closed once
connected notification is provided. This ensures that if they've been
scheduled for tx, the event is ignored.

Type: fix

Signed-off-by: Florin Coras <[email protected]>
Change-Id: I8c44584e843d93365ec737ae4e1bcb74eba35506

2 years agoaf_xdp: fix chained buffer free on failure 85/39085/2
Benoît Ganne [Tue, 20 Jun 2023 10:03:36 +0000 (12:03 +0200)]
af_xdp: fix chained buffer free on failure

Type: fix

Change-Id: I7c6fb783e5200773cbd02c86d39fd241efcc39f9
Signed-off-by: Benoît Ganne <[email protected]>
2 years agovcl: fix epoll lt coverity warning 88/39088/1
Florin Coras [Tue, 20 Jun 2023 15:47:37 +0000 (08:47 -0700)]
vcl: fix epoll lt coverity warning

Type: fix

Signed-off-by: Florin Coras <[email protected]>
Change-Id: I6900d9ab147d35f99f944bf741f6bb329c8ea0df

2 years agodpdk-cryptodev: enq/deq scheme rework 19/39019/3
Piotr Bronowski [Fri, 9 Jun 2023 15:08:54 +0000 (15:08 +0000)]
dpdk-cryptodev: enq/deq scheme rework

This rework tries to address issues found on SPR QAT, for traffic
reaching max possible throughoutput for single QAT PF packet drops were
observed.
Fix changes enq/deq scheme by utilizing software ring in enq call from
VNET but enq and deq to QAT happens only in deq callback function what
should enable better utlization of hardware resources.

Type: improvement
Signed-off-by: Dastin Wilski <[email protected]>
Signed-off-by: Piotr Bronowski <[email protected]>
Change-Id: I2e8c473d20a269fd5e93f0c8d1f8c8aa193712bd

2 years agovcl: no hup events in lt mode if session not epolled 67/39067/4
Florin Coras [Wed, 14 Jun 2023 18:15:36 +0000 (11:15 -0700)]
vcl: no hup events in lt mode if session not epolled

Type: fix

Signed-off-by: Florin Coras <[email protected]>
Change-Id: I9f7dfe086bf7e11b7e0de7392f020c1052ba656a

2 years agotests: Run interface tests as a regular test 68/39068/2
Dave Wallace [Mon, 12 Jun 2023 20:33:55 +0000 (16:33 -0400)]
tests: Run interface tests as a regular test

Type: test

Change-Id: I5cf5a0e6437b274e565066f1012d7225c62b87a8
Signed-off-by: Naveen Joy <[email protected]>
2 years agovcl: fix debug logging of mapped segments 59/39059/3
Florin Coras [Wed, 14 Jun 2023 00:18:56 +0000 (17:18 -0700)]
vcl: fix debug logging of mapped segments

Type: improvement

Signed-off-by: Florin Coras <[email protected]>
Change-Id: I73034cdba51157466713884c3fbeae7054d92ad7

2 years agoaf_xdp: linearize buffer chains before TX 33/39033/5
Shmuel Hazan [Tue, 13 Jun 2023 10:55:04 +0000 (13:55 +0300)]
af_xdp: linearize buffer chains before TX

The af_xdp plugin does not support chained buffers; attempting to send
chain buffers will result truncated packets or even send other packet's
data. As a workaround, turn any buffer chain into a single buffer before
tx.

Type: fix

Change-Id: I05dec912455eb2bb6c8122a28cd646f88983aa9a
Signed-off-by: Shmuel Hazan <[email protected]>
2 years agovppapigen: fix crash with autoendian arrays 02/39002/7
Dave Wallace [Tue, 6 Jun 2023 16:05:30 +0000 (12:05 -0400)]
vppapigen: fix crash with autoendian arrays

Type: fix
Ticket: VPP-2078

Change-Id: I418269632bdfc823c5f0ba7652957277276d294d
Signed-off-by: Dave Wallace <[email protected]>
2 years agodpdk-cryptodev: introduce sw_ring 18/39018/2
Piotr Bronowski [Fri, 9 Jun 2023 14:22:40 +0000 (14:22 +0000)]
dpdk-cryptodev: introduce sw_ring

This patch introduces sw_ring. This ring is used in next set of patchas
and plays role of a buffer for QAT, allowing collecting frame elements
in case QAT queue is fully utilized, and assembling frame
from QAT dequeued elements.

Type: improvement
Signed-off-by: Piotr Bronowski <[email protected]>
Signed-off-by: Dastin Wilski <[email protected]>
Change-Id: I20718e200986ab4dba5cbc31c05a904072a6981a

2 years agoaf_xdp: set frame_no_append flag 63/38963/2
Artem Glazychev [Thu, 1 Jun 2023 04:18:13 +0000 (11:18 +0700)]
af_xdp: set frame_no_append flag

Make sure the same frame is not used for multiple interfaces, otherwise it breaks the ETH_INPUT_FRAME_F_SINGLE_SW_IF_IDX promise.

Type: fix

Signed-off-by: Artem Glazychev <[email protected]>
Change-Id: I02546259ceaea36f65cb9f78b9b3ee45ed4075c9

2 years agotcp: cleanup next nodes and drop logic 15/39015/1
Florin Coras [Fri, 9 Jun 2023 03:47:11 +0000 (20:47 -0700)]
tcp: cleanup next nodes and drop logic

TCP nodes consume the buffers so they have no nexts. To avoid long drop
path through vlib graph, add drop node.

Type: improvement

Signed-off-by: Florin Coras <[email protected]>
Change-Id: Ibe6e075e83612ed16270934398c6a013f236ae35

2 years agosvm: convert fifo want_deq_ntf ops to atomics 99/38999/5
Florin Coras [Mon, 5 Jun 2023 21:58:15 +0000 (14:58 -0700)]
svm: convert fifo want_deq_ntf ops to atomics

Type: improvement

Signed-off-by: Florin Coras <[email protected]>
Change-Id: Iba2e4de24ff0724e31859f5d2f4ffa3cfe2cf284

2 years agohs-test: increase test run timeout 14/39014/2
Filip Tehlar [Thu, 8 Jun 2023 16:30:37 +0000 (18:30 +0200)]
hs-test: increase test run timeout

Type: test

Change-Id: Ica211c79373777c3352d6ccbb619c0d67b70fa06
Signed-off-by: Filip Tehlar <[email protected]>
2 years agohs-test: rename address allocator 13/39013/2
Filip Tehlar [Thu, 8 Jun 2023 15:39:39 +0000 (17:39 +0200)]
hs-test: rename address allocator

Type: test

Change-Id: I1745719315d4e0785df5a03aa4312f84c40cb18f
Signed-off-by: Filip Tehlar <[email protected]>
2 years agomisc: fix INFO.yaml mistakes 04/39004/2
Mohammed Hawari [Wed, 7 Jun 2023 08:15:05 +0000 (10:15 +0200)]
misc: fix INFO.yaml mistakes

Change-Id: If4e7911788b6aab67672b7e7228ecbdb402a85d5
Type: fix
Signed-off-by: Mohammed Hawari <[email protected]>
2 years agoaf_xdp: make sure all packets are transmitted 68/34668/3
Benoît Ganne [Thu, 2 Dec 2021 15:06:12 +0000 (16:06 +0100)]
af_xdp: make sure all packets are transmitted

AF_XDP socket will only tx enqueued packets up to a max batch size so
we need to retry until everything has been sent.

Type: fix

Change-Id: Ia487ab63d3e85a478471cd1d679c5fb471804ba3
Signed-off-by: Benoît Ganne <[email protected]>
2 years agocrypto: use fixed crypto frame pool 26/38926/5
gaoginskx [Mon, 7 Jun 2021 11:07:01 +0000 (12:07 +0100)]
crypto: use fixed crypto frame pool

The async frames pool may be resized once drained. This will cause 2 problems: original pool pointer is invalidated and pool size changed, both problems will confuse the crypto infra user graph nodes (like IPsec and Wireguard) and crypto engines if they expect the pool pointers always valid and the pool size never changed (for performance reason).

This patch introduces fixed size of the async frames pool. This helps zeroing surprise to the components shown above and avoiding segmentation fault when pool resizing happened. In addition, the crypto engine may take advantage of the feature to sync its own pool/vector with crypto infra.

Type: improvement

Signed-off-by: Gabriel Oginski <[email protected]>
Signed-off-by: Piotr Bronowski <[email protected]>
Change-Id: I2a71783b90149fa376848b9c4f84ce8c6c034bef

2 years agoaf_xdp: remove the previous program before loading a new one 71/38971/2
Artem Glazychev [Mon, 5 Jun 2023 08:02:46 +0000 (15:02 +0700)]
af_xdp: remove the previous program before loading a new one

Otherwise, we will get an error. The program could remain from the previous run.

Type: fix

Signed-off-by: Artem Glazychev <[email protected]>
Change-Id: I68e4072bd3b327592013804d67ccab7eb0ed3a0e

2 years agovcl: fix epoll ctl frequent deq ntf requests 65/38965/10
Florin Coras [Fri, 2 Jun 2023 04:50:03 +0000 (21:50 -0700)]
vcl: fix epoll ctl frequent deq ntf requests

SVM_FIFO_WANT_DEQ_NOTIF_IF_FULL should be treated as a
config option that is not frequently changed. Or alternatively, it
should be set together with SVM_FIFO_WANT_DEQ_NOTIF to elicit a one time
tx notification.

Type: fix

Signed-off-by: Florin Coras <[email protected]>
Change-Id: Ie4132c7789ee87227a875ff981eb98f9f4d898a9

2 years agomisc: fix the license header 90/38790/2
Mohsin Kazmi [Mon, 5 Jun 2023 16:15:38 +0000 (16:15 +0000)]
misc: fix the license header

Type: style

Signed-off-by: Mohsin Kazmi <[email protected]>
Change-Id: I6b3ecf0bdb6cfdf260cf4ccae89b6bc2335ff54c

2 years agovcl: avoid duplicate tx events with epoll lt 98/38998/2
Florin Coras [Mon, 5 Jun 2023 17:24:56 +0000 (10:24 -0700)]
vcl: avoid duplicate tx events with epoll lt

Type: fix

Signed-off-by: Florin Coras <[email protected]>
Change-Id: Ic6436426ead561e47fb77ed9a95afbd85f2998ae

2 years agoudp: improve port validity check 72/38972/3
Benoît Ganne [Mon, 5 Jun 2023 08:02:29 +0000 (10:02 +0200)]
udp: improve port validity check

 - do not allocate port sparse vector when only checking if a port is
   already in use
 - do not display port that have been unregistered by default

Type: improvement

Change-Id: I6cc94e35806dd8d415cd5d1c1c51e6b066ac26a1
Signed-off-by: Benoît Ganne <[email protected]>
2 years agolinux-cp: Fix add vs update on routes 54/38854/7
Pim van Pelt [Sun, 21 May 2023 06:35:26 +0000 (08:35 +0200)]
linux-cp: Fix add vs update on routes

Linux uses NLM_F_REPLACE in the netlink message to signal a FIB update
The code invariably does a FIB update for IPv4 and a addition for IPv6.
Without this fix, the following:
 ip route add 2001:db8::/48 via 2001:db8::1
 ip route replace 2001:db8::/48 via 2001:db8::2

ends up as two separate FIB entries in VPP. With the fix, there will be one FIB entry (the second one with nexthop ::2).

Type: fix
Change-Id: I8f98d6ded52ae0c60bfddaa7fc39acbbaa19d34a
Signed-off-by: Pim van Pelt <[email protected]>
2 years agomisc: update INFO.yaml 69/38969/2
Mohammed Hawari [Fri, 2 Jun 2023 13:10:32 +0000 (15:10 +0200)]
misc: update INFO.yaml

Change-Id: I55ea2c11148421aef8f891829671d88be171daa2
Type: improvement
Signed-off-by: Mohammed Hawari <[email protected]>
2 years agovcl: refactor want deq ntf checks for null fifos 27/38927/6
Florin Coras [Mon, 29 May 2023 23:19:38 +0000 (16:19 -0700)]
vcl: refactor want deq ntf checks for null fifos

Type: refactor

Signed-off-by: Florin Coras <[email protected]>
Change-Id: I5d0445ca381f1a4943bb2fe454433b3454043b56

2 years agosession: cleanup cless listeners from session lookup 64/38964/8
Florin Coras [Thu, 1 Jun 2023 16:11:27 +0000 (09:11 -0700)]
session: cleanup cless listeners from session lookup

Type: fix

Signed-off-by: Florin Coras <[email protected]>
Signed-off-by: Filip Tehlar <[email protected]>
Change-Id: I46b8194ff00c6a0a4a2bc19df9991f037856cede

2 years agowireguard: add support for chained buffers 97/38597/3
Alexander Chernavin [Wed, 29 Mar 2023 16:09:37 +0000 (16:09 +0000)]
wireguard: add support for chained buffers

Type: feature

With this change, packets that are larger than a single buffer can fit
will be able to be sent and received over a Wireguard tunnel. Also,
cover this with tests.

Signed-off-by: Alexander Chernavin <[email protected]>
Change-Id: Ifaf7325676d728580097bc389b51a9be39e44d88

2 years agoapi: nat44_ed - Mark old message versions as deprecated 47/38647/4
Ondrej Fabry [Wed, 26 Apr 2023 22:00:20 +0000 (00:00 +0200)]
api: nat44_ed - Mark old message versions as deprecated

List of changed messages:
 - nat44_add_del_static_mapping
 - nat44_user_session_dump
 - nat44_user_session_details
 - nat44_user_session_v2_dump
 - nat44_user_session_v2_details

This change is part of VPP API cleanup initiative.

Type: fix
Signed-off-by: Ondrej Fabry <[email protected]>
Change-Id: I317ae93a0e763c3759a8c24fd550e1c97f6f4987

2 years agohs-test: fix vcl test parameter 35/38935/2
Filip Tehlar [Wed, 31 May 2023 10:26:59 +0000 (12:26 +0200)]
hs-test: fix vcl test parameter

Type: test

Signed-off-by: Filip Tehlar <[email protected]>
Change-Id: Ieb6e46439d8e66a792f9c508e7dc49ecdd392487

2 years agocrypto: make crypto-dispatch node working in adaptive mode 53/38453/7
Xiaoming Jiang [Thu, 9 Mar 2023 02:03:50 +0000 (02:03 +0000)]
crypto: make crypto-dispatch node working in adaptive mode

This patch can make crypto dispatch node adaptively switching
between pooling and interrupt mode, and improve vpp overall
performance.

Type: improvement
Signed-off-by: Xiaoming Jiang <[email protected]>
Change-Id: I845ed1d29ba9f3c507ea95a337f6dca7f8d6e24e

2 years agofib: fix memory leak in fib_attached_export_purge 56/38956/2
Stanislav Zaikin [Wed, 31 May 2023 12:30:44 +0000 (14:30 +0200)]
fib: fix memory leak in fib_attached_export_purge

Type: fix

Change-Id: I879594fcade4e081190e8dfb1dbcfc53e8431edf
Signed-off-by: Stanislav Zaikin <[email protected]>
2 years agomisc: fix tracedump API 10/38910/2
Maxime Peim [Fri, 26 May 2023 07:52:35 +0000 (07:52 +0000)]
misc: fix tracedump API

In some cases, in the trace dump v2 dump function, we iterate over the
client cache even though this one could be empty.

Type: fix
Change-Id: Ice5cefa25bb93dabe86fe565347cdc32faa674ac
Signed-off-by: Maxime Peim <[email protected]>
2 years agovirtio: fix the packet buffering initialization order 86/38786/2
Mohsin Kazmi [Wed, 24 May 2023 11:25:39 +0000 (11:25 +0000)]
virtio: fix the packet buffering initialization order

Type: fix

Signed-off-by: Mohsin Kazmi <[email protected]>
Change-Id: Idada695432d2bfac8808f35f1e8cd16f84d963c6

2 years agolibmemif: add testing application 84/36484/4
Mohsin Kazmi [Wed, 22 Jun 2022 12:25:51 +0000 (12:25 +0000)]
libmemif: add testing application

Type: test

This application creates two memif interfaces which connect
to an external application i.e. VPP.

Usage:
1) Start VPP with following config.
create interface memif id 0 master
create interface memif id 1 master
set int state memif0/0 up
set int state memif0/1 up
create packet-generator interface pg0
set int state pg0 up
create packet-generator interface pg1
set int state pg1 up

set int l2 xconn pg0 memif0/0
set int l2 xconn memif0/0 pg0
set int l2 xconn pg1 memif0/1
set int l2 xconn memif0/1 pg1

packet-generator new { \
  name memif           \
  limit -1             \
  node ethernet-input  \
  size 64-64           \
  interface pg0        \
  worker 0             \
  data {               \
    IP4: 42:01:0a:00:00:0a -> 02:fe:4b:6e:4d:c1 \
    UDP: 172.16.2.2 -> 172.16.0.2               \
    UDP: 1234 -> 1234                           \
      length 30 checksum 0 incrementing 1       \
  }                                             \
}

2) Compile and Run the test_app in another terminal.
mkdir -p extras/libmemif/build
cd extras/libmemif/build
cmake ..
make
sudo ./examples/test_app

3) Run in VPP cli
vpp# packet enable

4) Run monitor to see the throughput and pps
vpp# monitor interface memif0/0
Or
vpp# monitor interface memif0/1

Signed-off-by: Mohsin Kazmi <[email protected]>
Change-Id: I4b9062fca8ad3020225adb7b1b09e5d66b1a7d48

2 years agoipsec: fix ipsec_set_next_index set with wrong sa index when async frame commit failed 57/38757/4
Xiaoming Jiang [Fri, 5 May 2023 02:28:20 +0000 (02:28 +0000)]
ipsec: fix ipsec_set_next_index set with wrong sa index when async frame commit failed

Type: fix
Signed-off-by: Xiaoming Jiang <[email protected]>
Change-Id: Ib4c61906a9cbb3eea1214394d164ecffb38fd36d

2 years agovppinfra: add bit_extract_u32 and bit_extract_u64 16/38916/2
Damjan Marion [Fri, 26 May 2023 19:08:38 +0000 (19:08 +0000)]
vppinfra: add bit_extract_u32 and bit_extract_u64

Type: improvement
Change-Id: Icfaa856aa4b50ad5c6828f1690ce3fb6ba08ec00
Signed-off-by: Damjan Marion <[email protected]>
2 years agovlib: add foreach_vlib_frame_bitmap_set_bit_index to .clang-format 14/38914/3
Damjan Marion [Fri, 26 May 2023 19:01:29 +0000 (19:01 +0000)]
vlib: add foreach_vlib_frame_bitmap_set_bit_index to .clang-format

Type: improvement
Change-Id: I6b999bcc6394bcc9325de1568dba98d1eb5a7b15
Signed-off-by: Damjan Marion <[email protected]>
2 years agovlib: add vlib_log_is_enabled 15/38915/2
Damjan Marion [Fri, 26 May 2023 19:06:10 +0000 (19:06 +0000)]
vlib: add vlib_log_is_enabled

Type: improvement
Change-Id: I052e0d56cc6d89cd66c83a9bb81e2273d396d510
Signed-off-by: Damjan Marion <[email protected]>
2 years agolinux-cp: update adjs for subifs too when mac changes 59/38859/3
Alexander Chernavin [Fri, 19 May 2023 15:43:06 +0000 (15:43 +0000)]
linux-cp: update adjs for subifs too when mac changes

The plugin creates and manages adjacencies for the physical interface in
each interface pair (they are part of the x-connect feature). When a
link update notification is received from the host system, MAC address
of the corresponding physical interface is updated (as needed) as well
as previously created adjacencies for it (because a new rewrite string
needs to be generated).

Subinterfaces inherit MAC address from the parent interface. When MAC
address of the parent interface changes, it also implies MAC address
change for its subinterfaces. The problem is that this is currently not
considered in the plugin. After MAC address update on the parent
interface, packets sent from subinterfaces might have wrong source MAC
address. For example, IPv6 Neighbor Solicitation messages will be sent
with the wrong (previous) MAC address and neighbor discovery will fail.

With this fix, when the plugin updates adjacencies for a physical
interface, it will also update adjacencies for the subinterfaces with
existing interface pair.

Type: fix
Change-Id: Ia5f617197e33cb79b9b025c02c2c126c31a551ec
Signed-off-by: Alexander Chernavin <[email protected]>
2 years agotls: fix memory leak when client/server init error 07/38907/1
Xiaoming Jiang [Fri, 26 May 2023 00:32:25 +0000 (00:32 +0000)]
tls: fix memory leak when client/server init error

Type: fix
Signed-off-by: Xiaoming Jiang <[email protected]>
Change-Id: I484f3759b6c27052e08741398ec389729285f035

2 years agoudp: fix local port reuse check 06/38906/2
Florin Coras [Thu, 25 May 2023 19:04:53 +0000 (12:04 -0700)]
udp: fix local port reuse check

Type: fix

Signed-off-by: Florin Coras <[email protected]>
Change-Id: I323946f7838507110c663f5a904399a74fc76691

2 years agohs-test: add vcl echo tests 58/38858/2
Filip Tehlar [Mon, 22 May 2023 13:48:51 +0000 (15:48 +0200)]
hs-test: add vcl echo tests

Type: test

Signed-off-by: Filip Tehlar <[email protected]>
Change-Id: I3e543cb292c7ed0f9d240f8f2473a1db07aff0fd

2 years agohash: add hash documentation 76/38776/6
Mohsin Kazmi [Fri, 5 May 2023 11:09:31 +0000 (11:09 +0000)]
hash: add hash documentation

Type: docs

Signed-off-by: Mohsin Kazmi <[email protected]>
Change-Id: I36764aa3c0e9657d228413aeafa0a54bbd755e49

2 years agomisc: Initial 23.10-rc0 commit 85/38785/3 v23.10-rc0
Andrew Yourtchenko [Wed, 24 May 2023 11:06:58 +0000 (11:06 +0000)]
misc: Initial 23.10-rc0 commit

Type: docs
Change-Id: Id9b0ca0d43db0e5a52fd9696a5cba77a6772db5b
Signed-off-by: Andrew Yourtchenko <[email protected]>
2 years agomisc: VPP 23.02 Release Notes 84/38784/2
Andrew Yourtchenko [Tue, 21 Feb 2023 12:27:15 +0000 (12:27 +0000)]
misc: VPP 23.02 Release Notes

Type: docs
Change-Id: I88ae8452ed1b39a4c6d82b790f63f31deae4c2fa
Signed-off-by: Andrew Yourtchenko <[email protected]>
Signed-off-by: Dave Wallace <[email protected]>
(cherry picked from commit 5516fc0f3bf50657446c4e68556c9f76ea2a43a4)

2 years agovcl: avoid reusing user provided events in lt mode 62/38862/3
Florin Coras [Mon, 22 May 2023 16:19:57 +0000 (09:19 -0700)]
vcl: avoid reusing user provided events in lt mode

Epoll events might not have been cleared by user so always compute event
flags locally and assign to user provided epoll event.

Type: fix

Signed-off-by: Ping Yu <[email protected]>
Signed-off-by: Florin Coras <[email protected]>
Change-Id: I3b594a0fd7be345a0e0ad81d1d3636e9354cc15d

2 years agomisc: fix tracedump API to match CLI behavior 24/38624/6
Maxime Peim [Tue, 11 Apr 2023 15:45:59 +0000 (15:45 +0000)]
misc: fix tracedump API to match CLI behavior

When dumping packets from multiple threads using the API, first all
packets from thread 0 are dumped then all ones from thread 1, etc
Until we reach the limit specified by the API call, so we could never
get packets trace from threads with higher ids.
However, the tracedump CLI dump a maximum number of packets from all
threads, which we can expect from the API to do.

We also add a trace_clear_cache API so the client gets an answer when
he only wants to clear its packet cache.

Type: improvement
Change-Id: I0d4df8f6210a298ac3f22cd651eb4d8f445e1034
Signed-off-by: Maxime Peim <[email protected]>
2 years agobufmon: ptd should be alloced in main thread 65/38865/1
Xiaoming Jiang [Tue, 23 May 2023 09:16:58 +0000 (09:16 +0000)]
bufmon: ptd should be alloced in main thread

Type: fix
Signed-off-by: Xiaoming Jiang <[email protected]>
Change-Id: I7f8c975fae5d71ce1226a8e19761fc75134e61e2

2 years agoteib: fix nh-table-id 05/38305/6
Stanislav Zaikin [Tue, 21 Feb 2023 08:26:41 +0000 (09:26 +0100)]
teib: fix nh-table-id

Peer fib index and nh fib index should be different when nh-table-id is
specified.

Type: fix

Change-Id: I4c8296adb5aeab1c0022bfc1046e9559331b79b2
Signed-off-by: Stanislav Zaikin <[email protected]>
2 years agompls: implement state change callbacks 26/38826/5
Adrian Pistol [Sat, 13 May 2023 22:00:41 +0000 (00:00 +0200)]
mpls: implement state change callbacks

There was already a basic type defined, but nothing more.
This implements callbacks similar to
ip4_enable_disable_interface_callback_t.

Type: feature
Change-Id: I34fcb146ca68af4eb8cdd244529eb149f884284d
Signed-off-by: Adrian Pistol <[email protected]>
2 years agoip-neighbor: fix aged neighbor probe 52/38852/2
Sergio Gonzalez Monroy [Wed, 3 May 2023 12:26:44 +0000 (14:26 +0200)]
ip-neighbor: fix aged neighbor probe

The order of the parameters when calling the ip_neighbor_probe_dst for
an aged neighbor is wrong and given that it runs on the master thread,
probes for IPv6 neighbors were never sent, leading to a certain neighbor
strike out and death and its removal from the neighbor cache.

Change-Id: Ic021bd0ece05bd2c1c6ab90eab0e2dc27cb10360
Type: fix
Fixes: fd2417b2a42
Signed-off-by: Sergio Gonzalez Monroy <[email protected]>
2 years agohsa: add an option to configure ns in http cli 45/38845/2
Filip Tehlar [Thu, 18 May 2023 08:38:11 +0000 (10:38 +0200)]
hsa: add an option to configure ns in http cli

Type: feature

Signed-off-by: Filip Tehlar <[email protected]>
Change-Id: Ia81f1d8e706dbce9e57319d993bff595e6ba6f03

2 years agohs-test: support for multiple workers 43/38743/8
Filip Tehlar [Fri, 28 Apr 2023 08:29:47 +0000 (10:29 +0200)]
hs-test: support for multiple workers

Type: test

Signed-off-by: Filip Tehlar <[email protected]>
Change-Id: Ie90e4b02c268bc3ca40171b03829f5686fb83162

2 years agotests: support for expected failures 72/38572/3
Klement Sekera [Wed, 29 Mar 2023 14:04:58 +0000 (16:04 +0200)]
tests: support for expected failures

- Add support for @unittest.expectedFailure decorator.

Type: improvement

Signed-off-by: Klement Sekera <[email protected]>
Change-Id: I761751cda505e962225dc680b97c1fffa96f5176
Signed-off-by: Dave Wallace <[email protected]>
2 years agotests: enhance counter comparison error message 42/38042/5
Klement Sekera [Thu, 26 Jan 2023 12:14:01 +0000 (13:14 +0100)]
tests: enhance counter comparison error message

- Make error message more human readable.

Type: improvement

Signed-off-by: Klement Sekera <[email protected]>
Change-Id: Iefc276b3a85ff82b927028a72bb91ed87ebd04ba
Signed-off-by: Dave Wallace <[email protected]>
2 years agomisc: long overdue update to maintainers file 53/38853/4
Sergio Gonzalez Monroy [Fri, 19 May 2023 19:49:40 +0000 (21:49 +0200)]
misc: long overdue update to maintainers file

Type: make

Change-Id: I2ee286985819974e02e34b8166c69ef7d767e47e
Signed-off-by: Sergio Gonzalez Monroy <[email protected]>
2 years agotests: refactor extra_vpp_punt_config 41/38041/3
Klement Sekera [Thu, 26 Jan 2023 11:35:35 +0000 (12:35 +0100)]
tests: refactor extra_vpp_punt_config

Rename extra_vpp_punt_config to a more generic name extra_vpp_config to
better fit its purpose. It's fit for general use and already used that
way by quic and vcl tests anyway.

Type: refactor
Signed-off-by: Klement Sekera <[email protected]>
Change-Id: Ib0a5789b0dbb3a8c3cae654dea4e32ac5e56dd41

2 years agostats: fix memory leak in stat_segment_dump_r() 50/37750/4
Duncan Eastoe [Wed, 30 Nov 2022 21:16:13 +0000 (21:16 +0000)]
stats: fix memory leak in stat_segment_dump_r()

The built stat_segment_data_t is leaked if stat_segment_access_end()
returns false.

Type: fix
Signed-off-by: Duncan Eastoe <[email protected]>
Change-Id: I70adabbe7947d3e8a798cdfb3eaa14c683dce9da

2 years agofib: fix load-balance and replicate dpos buckets overflow 15/38315/6
Benoît Ganne [Tue, 21 Feb 2023 15:09:47 +0000 (16:09 +0100)]
fib: fix load-balance and replicate dpos buckets overflow

load-balance and replicate dpos both store their number of buckets as
u16, which can overflow if too many paths are configured. For
load-balance it can happens quite quickly because of weights
normalization.

Type: fix

Change-Id: I0c78c39fc3d40626dfc58b49e7d99d71f9852b50
Signed-off-by: Benoît Ganne <[email protected]>
2 years agodpdk: fix compatibility with DPDK < 21.11 64/38064/4
Andrew Ying [Fri, 27 Jan 2023 17:38:18 +0000 (17:38 +0000)]
dpdk: fix compatibility with DPDK < 21.11

Signed-off-by: Andrew Ying <[email protected]>
Type: fix
Change-Id: I3c428c90146387ad9ce291c7f646d74f06952b40

2 years agotls: flag no app session on handshake failure 15/38815/3
Florin Coras [Fri, 12 May 2023 00:40:26 +0000 (17:40 -0700)]
tls: flag no app session on handshake failure

If openssl tls server handshake fails, track the fact that the context
does not have an app session.

Type: fix

Signed-off-by: Florin Coras <[email protected]>
Change-Id: I5f493059a3610067b59caffbbe441ce9e0868252

2 years agodpdk: fix format device name using wrong index 78/38778/2
Daniel Ding [Mon, 8 May 2023 01:59:01 +0000 (09:59 +0800)]
dpdk: fix format device name using wrong index

When I setup vpp by netvsc driver, occurs the following crash:

(format_dpdk_device_name) assertion `(i) < vec_len (dm->devices)' fails

vnet[100166]: #6  0x00007f434d651f6a _clib_error + 0x2da
vnet[100166]: #7  0x00007f430b4bef64 format_dpdk_device_name + 0xf4
vnet[100166]: #8  0x00007f434d6555f3 do_percent + 0xee3
vnet[100166]: #9  0x00007f434d654359 va_format + 0xb9
vnet[100166]: #10 0x00007f434d7ac16e vlib_log + 0x3ce
vnet[100166]: #11 0x00007f430b49ebe3 dpdk_device_start + 0x193
vnet[100166]: #12 0x00007f430b4aa233 dpdk_interface_admin_up_down + 0x163
vnet[100166]: #13 0x00007f434d988fc8 vnet_sw_interface_set_flags_helper + 0x378
vnet[100166]: #14 0x00007f434d989338 vnet_sw_interface_set_flags + 0x48

This patch fix it by device_index as a index for devices vec, and not
dpdk port_id.

Type: fix
Change-Id: I84c46616d06117c9ae3b2c7d0473050f1b8ded5f
Signed-off-by: Daniel Ding <[email protected]>
2 years agovcl: set want deq flag earlier in epoll ctl mod 43/38843/3
Florin Coras [Thu, 18 May 2023 06:20:56 +0000 (23:20 -0700)]
vcl: set want deq flag earlier in epoll ctl mod

On epoll ctl mod, set want deq flag before checking if unhandled events
are needed.

Type: fix

Signed-off-by: Florin Coras <[email protected]>
Change-Id: Id1491837c7156a66c21e0e45af60b04b1c18601c

2 years agovcl: always reset deq ntf flag in epoll evt handler 41/38841/4
Florin Coras [Thu, 18 May 2023 05:59:40 +0000 (22:59 -0700)]
vcl: always reset deq ntf flag in epoll evt handler

Reset deq notification flag even if session is no longer epolled.

Type: fix

Signed-off-by: Florin Coras <[email protected]>
Change-Id: I4e9aed1849aa2817176f3a54ae41910df5e704a0

2 years agointerface: add the transmit queue infrastructure document 77/38777/4
Mohsin Kazmi [Fri, 5 May 2023 12:32:59 +0000 (12:32 +0000)]
interface: add the transmit queue infrastructure document

Type: docs

Signed-off-by: Mohsin Kazmi <[email protected]>
Change-Id: I57f27f8ec4be7f3d8dc3d13ff4ea6b1b21c3cf6b

2 years agohsa: make http cli client thread safe 49/38849/1
Filip Tehlar [Fri, 19 May 2023 10:54:18 +0000 (12:54 +0200)]
hsa: make http cli client thread safe

Type: fix

Signed-off-by: Filip Tehlar <[email protected]>
Change-Id: I9e6fd29c0e09406e48215f06977b2d4678650669

2 years agohsa: detach app on unsuccessful listen 37/38837/2
Filip Tehlar [Tue, 16 May 2023 13:32:17 +0000 (15:32 +0200)]
hsa: detach app on unsuccessful listen

Type: fix

Signed-off-by: Filip Tehlar <[email protected]>
Change-Id: Idba74f880a251dbeec2205ee41e16b40d4799b06

2 years agovcl: avoid skipping last event in epoll lt 38/38838/1
Florin Coras [Tue, 16 May 2023 20:05:28 +0000 (13:05 -0700)]
vcl: avoid skipping last event in epoll lt

Type: fix

Signed-off-by: Florin Coras <[email protected]>
Change-Id: Ic89256d16230593b61a7b3e29582444fb3f93e4d

2 years agoip_session_redirect: add session redirect plugin 55/33455/35
Benoît Ganne [Tue, 10 Aug 2021 14:23:36 +0000 (16:23 +0200)]
ip_session_redirect: add session redirect plugin

This feature enables the use of the classifier and ip-in-out-acl nodes
to redirect matching sessions via arbitrary fib paths instead of relying
on additional VRFs.

Type: feature

Change-Id: Ia59d35481c2555aec96c806b62bf29671abb295a
Signed-off-by: Benoît Ganne <[email protected]>
2 years agodpdk: fix format rx/tx burst function name failed 15/38415/4
Xiaoming Jiang [Wed, 8 Mar 2023 06:49:19 +0000 (06:49 +0000)]
dpdk: fix format rx/tx burst function name failed

Type: fix
Signed-off-by: Xiaoming Jiang <[email protected]>
Change-Id: I9971e69135e0652a36e4b4754774a43ea1d92e8b

2 years agoethernet: fix adding p2p ethernet crash 68/38768/3
Xiaoming Jiang [Sat, 6 May 2023 08:22:08 +0000 (08:22 +0000)]
ethernet: fix adding p2p ethernet crash

Type: fix
Signed-off-by: Xiaoming Jiang <[email protected]>
Change-Id: Ib0ca3379439d6ee23e696f8f0840e6ddf42430b8

2 years agomemif: fix coverity warnings 66/38766/2
Marvin Liu [Fri, 5 May 2023 15:03:46 +0000 (23:03 +0800)]
memif: fix coverity warnings

Type: fix

Signed-off-by: Marvin Liu <[email protected]>
Change-Id: Ie3f390be16df81f6824344034377f9a6f4fa9f92

2 years agomisc: make format_hexdump length u32 94/38694/4
Benoît Ganne [Mon, 17 Apr 2023 12:50:00 +0000 (14:50 +0200)]
misc: make format_hexdump length u32

format_hexdump currently requires the length parameter to be uword
(64-bits) hence all callers must make sure to cast the length to uword.
Use u32 instead to benefit from C automatic integer promotion: any
length smaller or equal to u32 will be promoted to int fitting in u32).
Only callers using a length of u64 needs to downcast.
It also makes it similar to other variants.

Type: fix

Change-Id: I09b52fdde3970cec0be4150a29126ff63106c75b
Signed-off-by: Benoît Ganne <[email protected]>
2 years agoflow: fix wrong to use ntohl function to u64 type variable 27/38727/3
Yulong Pei [Tue, 25 Apr 2023 11:15:14 +0000 (11:15 +0000)]
flow: fix wrong to use ntohl function to u64 type variable

This caused that failed to create flow rule with rss types.

Type: fix

Signed-off-by: Yulong Pei <[email protected]>
Change-Id: I77696286a32804cbe884075cb027eec19eb5c7cb
Signed-off-by: Yulong Pei <[email protected]>
2 years agovppinfra: add aarch64 support for format_ucontext_pc 38/38738/2
Tianyu Li [Mon, 17 Apr 2023 02:49:22 +0000 (02:49 +0000)]
vppinfra: add aarch64 support for format_ucontext_pc

Add the missing AArch64 support for printing program counter.

Type: improvement
Signed-off-by: Tianyu Li <[email protected]>
Change-Id: Idb63737ed72e10fa29fd61e1eab5af059e2b8e28

2 years agohsi: interop with ip reassembly 22/38822/4
Florin Coras [Fri, 12 May 2023 23:27:13 +0000 (16:27 -0700)]
hsi: interop with ip reassembly

Type: improvement

Signed-off-by: Florin Coras <[email protected]>
Change-Id: I8d3a1939870601297ecccf4cda6767510c2abfa5

2 years agopacketforge: add option to show spec and mask only 99/38499/6
Ting Xu [Thu, 16 Mar 2023 01:22:33 +0000 (01:22 +0000)]
packetforge: add option to show spec and mask only

In some cases with Generic FLow, it is only required to show the pattern
of spec and mask, but no need to add the flow. Therefore, add an option
in packetforge so that users can show spec and mask only.

Type: improvement

Signed-off-by: Ting Xu <[email protected]>
Change-Id: I7b3040689eb82d0b58924712ee6fc9cfa0a42fa1

2 years agoudp: improvements to connection format fn 23/38823/5
Florin Coras [Fri, 12 May 2023 23:35:14 +0000 (16:35 -0700)]
udp: improvements to connection format fn

Print fib-index, next node index and opaque.

Type: improvement

Signed-off-by: Florin Coras <[email protected]>
Change-Id: Id2ff265c9acffc75f8b04fb9f26c6d571fc2ef98

2 years agoip: allow overriding fib index in reass 24/38824/3
Florin Coras [Fri, 12 May 2023 23:58:44 +0000 (16:58 -0700)]
ip: allow overriding fib index in reass

Type: improvement

Signed-off-by: Florin Coras <[email protected]>
Change-Id: Ic28da52b9c8286f71e472ef6c3afc23d464f85b0

2 years agodpdk: Be wary of the return value from rte_eth_dev_socket_id 27/38827/2
Steven Luong [Mon, 15 May 2023 04:47:21 +0000 (21:47 -0700)]
dpdk: Be wary of the return value from rte_eth_dev_socket_id

Prior to dpdk-22.11, VPP can count on rte_eth_dev_socket_id to return
numa node 0 if the device didn't set it. Ever since below patch is
committed in dpdk
https://patchwork.dpdk.org/project/dpdk/patch/20220929120512[email protected]/#152498
the aforementioned assumption is no longer true. If the device didn't
set the numa node, VPP gets -1 from the aforementioned API call. This
causes VPP to crash.

This fix is to set the numa node to 0 if the API returns -1, or SOCKET_ID_ANY

Type: fix

Change-Id: I2fde2870e5a3eb98473fe8d119fef594bfba9a8d
Signed-off-by: Steven Luong <[email protected]>
2 years agovcl: fix ldp ioctl FIONBIO handler 13/38813/3
Florin Coras [Thu, 11 May 2023 18:45:34 +0000 (11:45 -0700)]
vcl: fix ldp ioctl FIONBIO handler

Type: fix

Signed-off-by: Florin Coras <[email protected]>
Change-Id: Ife5f72dc9587c9f6b8aa513cd039fa28bb22fca3

2 years agogre: move to a plugin 48/38748/12
Chuhao Tang [Thu, 27 Apr 2023 13:43:42 +0000 (15:43 +0200)]
gre: move to a plugin

Move GRE folder under vnet to the plugin folder, and modify some of path
of the #inlude<header> to the new path.

Add a plugin.c file to register a plugin.

JIRA: VPP-2044

Type: improvement
Change-Id: I7f64cecd97538a7492e56a41558dab58281a9fa5
Signed-off-by: Chuhao Tang <[email protected]>
2 years agovppapigen: support counters only .api 14/38814/1
Ole Troan [Thu, 11 May 2023 20:02:30 +0000 (22:02 +0200)]
vppapigen: support counters only .api

In some cases an .api file may contain only counter definitions.
If so do not generate the setup_msg functions.

Type: improvement
Change-Id: Idf89a7a5ab135428e9577726bc356acfd7c30113
Signed-off-by: Ole Troan <[email protected]>
2 years agoapi: clean up error message 01/38801/2
Dave Wallace [Wed, 10 May 2023 16:05:55 +0000 (12:05 -0400)]
api: clean up error message

- remove non-inclusive language in message and improve
  clarity of the error message

Type: style

Change-Id: I3f4895d6a502c2583a8b6b3c325a3f30ced03f84
Signed-off-by: Dave Wallace <[email protected]>
2 years agordma: bump version to 45.0 74/38774/1
Dave Wallace [Wed, 10 May 2023 00:42:17 +0000 (20:42 -0400)]
rdma: bump version to 45.0

- Update rdma-core library to 45.0 to work with DPDK 23.03

Type: feature

Change-Id: I6bd54c509b93de905e1b0194dce414e4a6e11990
Signed-off-by: Dave Wallace <[email protected]>
2 years agodpdk: bump to DPDK 23.03 72/38772/1
Xinyao Cai [Tue, 9 May 2023 13:29:30 +0000 (21:29 +0800)]
dpdk: bump to DPDK 23.03

This patch bumps DPDK version from 22.11 to 23.03.

Type: feature

Signed-off-by: Xinyao Cai <[email protected]>
Change-Id: I10203a6408ceb5a40fe392924130652b91ebc993

2 years agodpdk: code preparation for bumping to DPDK 23.03 71/38771/1
Xinyao Cai [Tue, 9 May 2023 13:23:39 +0000 (21:23 +0800)]
dpdk: code preparation for bumping to DPDK 23.03

This patch prepares code for bumping DPDK version to 23.03, but the DPDK version of this patch keeps at 22.11 for compatibility.

the "no-dsa" parameter in DPDK configuration is removed, the "blacklist" parameter can be used to block the related DSA devices.

Type: feature

Signed-off-by: Xinyao Cai <[email protected]>
Change-Id: I589afba165e85138437e731531414a033f64f8d3