Steven Luong [Thu, 29 Aug 2019 19:47:57 +0000 (12:47 -0700)]
 
vmxnet3: per interface gso support
gso option for vmxnet3 is per VPP process currently. There is no reason why
we cannot provide per interface gso support.
Type: feature
Signed-off-by: Steven Luong <[email protected]>
Change-Id: Ife962b52221191050dedd18252b859880ccd7599
Michael Yu [Thu, 29 Aug 2019 16:50:16 +0000 (00:50 +0800)]
 
devices: fix issue of per_interface_next_index
Per interface, next hop graph node can be customized
with vnet_hw_interface_rx_redirect_to_node function,
but it doesn't work well for af-packet type interface.
In current implementation, with function
af_packet_set_interface_next_node invoked next hop graph
node index can be set to apif->per_interface_next_index,
but it's not set to next0 properly for packet processing
in af_packet_device_input_fn.
Type: fix
Signed-off-by: Michael Yu <[email protected]>
Change-Id: I8e132ddd1c3c01b6f476de78546d4a9389b3ff87
Signed-off-by: Michael Yu <[email protected]>
Florin Coras [Wed, 24 Jul 2019 17:27:20 +0000 (10:27 -0700)]
 
tcp: force zero window on full rx fifo
Type: feature
Change-Id: I7c5684a9f88e56fd62d83a59c14c4e4a6f096b89
Signed-off-by: Florin Coras <[email protected]>
John Lo [Thu, 29 Aug 2019 19:40:26 +0000 (15:40 -0400)]
 
dpdk: enable checksum offload for Intel SRIOV NIC drivers
Type: fix
Signed-off-by: John Lo <[email protected]>
Change-Id: I3ee59106ba45164a4ee3788bf4dcf5bf4c2dc1c2
Florin Coras [Tue, 27 Aug 2019 19:15:43 +0000 (12:15 -0700)]
 
tcp: improve mss computation
Type: fix
Use different mss for v4 and v6 packets.
Change-Id: Ifcd322c1fd74f749a42bae671dd6cfed8c32b150
Signed-off-by: Florin Coras <[email protected]>
Florin Coras [Fri, 30 Aug 2019 05:45:04 +0000 (22:45 -0700)]
 
vcl: initialize ctrl_mq in workers
Type: fix
Change-Id: I1b9c8b0f9292f039b941e18d8aca5d734d5f1e77
Signed-off-by: Florin Coras <[email protected]>
Florin Coras [Thu, 29 Aug 2019 19:03:17 +0000 (12:03 -0700)]
 
vcl: allow non-blocking connects
Type: feature
Change-Id: I55349f482ce6781337f747b2f0d2c0a027c3a675
Signed-off-by: Florin Coras <[email protected]>
Florin Coras [Fri, 30 Aug 2019 01:33:24 +0000 (18:33 -0700)]
 
tcp: track zero rwnd errors
Type: feature
Distinguish between rcv window errors and errors after we advertised a
zero rcv window, i.e., potential window probes.
Change-Id: I6cb453c7aaae456c0a05a8328cfaa55eaca10bf7
Signed-off-by: Florin Coras <[email protected]>
Guanghua Zhang [Sat, 24 Aug 2019 02:52:19 +0000 (10:52 +0800)]
 
session : make sure session layer is enabled when cli operate the sessions.
Type: fix
show session rules tcp
vpp/src/vnet/session/application_namespace.c:34 (app_namespace_get)
 assertion `! pool_is_free (app_namespace_pool, _e)' fails
Thread 1 "vpp_main" received signal SIGABRT, Aborted.
Signed-off-by: Guanghua Zhang <[email protected]>
Change-Id: I3430339a598a92d0a38826471adeb4547b0b7df4
Benoît Ganne [Thu, 29 Aug 2019 16:16:14 +0000 (18:16 +0200)]
 
stats: null-terminate default socket name
Type: fix
Fixes: 
d991a798ff
Change-Id: I1920a40d7bbb01593676d9d8564158fdba9452bb
Signed-off-by: Benoît Ganne <[email protected]>
Steven Luong [Thu, 29 Aug 2019 16:50:28 +0000 (09:50 -0700)]
 
lacp: continuing input packet trace from device driver
lacp gets the packet from the device driver. Let's continue the input
packet trace's trajectory instead of restarting it in lacp-input.
Type: fix
Signed-off-by: Steven Luong <[email protected]>
Change-Id: I4d4537e050742a23f74287086d38d39673ebd60f
Simon Zhang [Sun, 25 Aug 2019 07:30:45 +0000 (15:30 +0800)]
 
ip: remove unused function parameter
Type: refactor
Signed-off-by: Simon Zhang <[email protected]>
Change-Id: I8674ff5f6f6336b256b7df8187afbb36ddef71fb
Yulong Pei [Fri, 23 Aug 2019 09:24:13 +0000 (17:24 +0800)]
 
lb: fix memcpy error issue
vl_api_prefix_t size is 21 byte, ip46_address_t size is 16 byte, only copy
16 byte of vl_api_prefix_t to ip46_address_t is not correct.
Type:fix
Change-Id: I35ede7836a0c878d39388b29b15d91bb08f87a07
Signed-off-by: Yulong Pei <[email protected]>
Florin Coras [Thu, 29 Aug 2019 00:12:32 +0000 (17:12 -0700)]
 
svm: fix fifo hdr freelist allocation
Type: fix
Change-Id: Ia362ad821db1fd506e973e1844cc3ec74703cc17
Signed-off-by: Florin Coras <[email protected]>
Jakub Grajciar [Thu, 4 Apr 2019 08:20:21 +0000 (10:20 +0200)]
 
bier: API cleanup
Use consistent API types.
Type: fix
Change-Id: I416171c729193e64a68e85a3f1f25d03a9a559d1
Signed-off-by: Jakub Grajciar <[email protected]>
Dave Wallace [Thu, 22 Aug 2019 21:15:54 +0000 (21:15 +0000)]
 
hsa: clean up vpp_echo json output
Type: style
Change-Id: I8dbf2197b78690b94a346d6ff564648ab42f8235
Signed-off-by: Dave Wallace <[email protected]>
Dave Wallace [Fri, 23 Aug 2019 14:37:51 +0000 (14:37 +0000)]
 
quic: enable stable quic tests
Type: test
Signed-off-by: Dave Wallace <[email protected]>
Change-Id: I041c011ee955acba656b774049b530efe1d50f22
Steven Luong [Fri, 16 Aug 2019 03:30:23 +0000 (20:30 -0700)]
 
lacp: mark is_mp_safe for show and dump binary API
show and dump binary APIs for lacp neighbors are running in the same thread
as the create and delete interface. There is no need for barrier lock.
Type: fix
Signed-off-by: Steven Luong <[email protected]>
Change-Id: Id584bd7408210fcc23b464ef2084f11f88bca58b
Andrew Yourtchenko [Mon, 26 Aug 2019 12:25:42 +0000 (12:25 +0000)]
 
acl: perform a sanity check of ACL rules before creating ACL
Adding acl with incorrect arguments like 1.1.1.1/24 (instead of 1.1.1.0/24)
don't cause a disaster, but doesn't match either, as some might expect.
Add an explicit sanity check which returns an error.
Type: fix
Change-Id: Id1601f4b9c9887d3e7e70aac419d1f1de0c0e012
Signed-off-by: Andrew Yourtchenko <[email protected]>
Florin Coras [Tue, 27 Aug 2019 22:13:35 +0000 (15:13 -0700)]
 
session: fix unbind coverity warning
Type:fix
Change-Id: If4fce6bd9b06ed545d72df847afd6a74cdefe042
Signed-off-by: Florin Coras <[email protected]>
Nathan Skrzypczak [Wed, 28 Aug 2019 13:19:17 +0000 (15:19 +0200)]
 
quic: Fix listener vpp_session_handle
Type: fix
Change-Id: I19f70403e15cd180e9d337fbdad47191de333b34
Signed-off-by: Nathan Skrzypczak <[email protected]>
Benoît Ganne [Tue, 27 Aug 2019 08:58:59 +0000 (10:58 +0200)]
 
rdma: fix pending packets check on tx
Fix coverity CID 203636: Control flow issues  (NO_EFFECT).
This greater-than-or-equal-to-zero comparison of an unsigned value is
always true. "n_left_from >= 0U".
Type: fix
Fixes: 
e7e8bf37f100b20acb99957572f1796f648c2853
Change-Id: Ibbf8c82defb12d6d532345eea657d5f300e6a514
Signed-off-by: Benoît Ganne <[email protected]>
Neale Ranns [Tue, 27 Aug 2019 12:47:17 +0000 (12:47 +0000)]
 
ipsec: Add 'detail' option to 'sh ipsec sa'
Type: feature
with detail option prints all details for all SAs
Change-Id: Ic3c423c085dfc849cf9c3e18a6f624b82150d961
Signed-off-by: Neale Ranns <[email protected]>
Steven Luong [Tue, 27 Aug 2019 14:43:27 +0000 (07:43 -0700)]
 
interface: Remove residual dpdk bonding code
dpdk bonding code was removed in 19.08. However, there are still references
to VNET_SW_INTERFACE_FLAG_BOND_SLAVE which was set by the already removed
code.
Type: fix
Signed-off-by: Steven Luong <[email protected]>
Change-Id: I949a7281e6273f2733dd7532cc4a3bb4f3ce30de
Florin Coras [Wed, 21 Aug 2019 23:20:44 +0000 (16:20 -0700)]
 
session: move ctrl messages from bapi to mq
Type:refactor
Moves connect, disconnect, bind, unbind and app detach to message
queue from binary api. Simplifies app/vcl interaction with the session
layer since all session control messages are now handled over the mq.
Add/del segment messages require internal C api changes which affect all
builtin applications. They'll be moved in a different patch and might
not be back portable to 19.08.
Change-Id: I93f6d18e551b024effa75d47f5ff25f23ba8aff5
Signed-off-by: Florin Coras <[email protected]>
Ole Troan [Tue, 27 Aug 2019 13:05:27 +0000 (15:05 +0200)]
 
api: revert use string type for strings in memclnt.api
This reverts commit 
2959d42feb576c0e00c28c4e27658b25f6c783e9.
Lacks client side fixes.
Type: fix
Change-Id: Ib94b18e74325cede41ed1733e57896f17a952526
Signed-off-by: Ole Troan <[email protected]>
Neale Ranns [Tue, 27 Aug 2019 12:26:14 +0000 (12:26 +0000)]
 
ipsec: Fix NULL encryption algorithm
Type: fix
Ticket: VPP-1756
the block-size was set to 0 resulting in incorrect placement of the ESP
footer.
add tests for NULL encrypt + integ.
Change-Id: I8ab3afda8e68f9ff649540cba3f2cac68f12bbba
Signed-off-by: Neale Ranns <[email protected]>
Klement Sekera [Tue, 27 Aug 2019 09:20:33 +0000 (09:20 +0000)]
 
ip: reassembly: remove unnecessary code
Type: refactor
Change-Id: I30cb324006c3c6ab88d01c044cf80fab3a34f13a
Signed-off-by: Klement Sekera <[email protected]>
Ole Troan [Thu, 22 Aug 2019 07:02:59 +0000 (09:02 +0200)]
 
api: use string type for strings in memclnt.api
Explicitly using string type in API allows for autogenerating tools to print
strings instead of hex-dumping byte strings.
Type: fix
Signed-off-by: Ole Troan <[email protected]>
Signed-off-by: Klement Sekera <[email protected]>
Change-Id: I573962d6b34d5d10aab9dc6a5fdf101c9b12a6a6
Signed-off-by: Ole Troan <[email protected]>
Mohsin Kazmi [Thu, 22 Aug 2019 16:40:28 +0000 (18:40 +0200)]
 
gso: fix segmentation when gso_size greater than vlib buffer size
Type: fix
Ticket: VPP-1751
Change-Id: I5ffb078492adc97374290de404f2ec0102b75184
Signed-off-by: Mohsin Kazmi <[email protected]>
Andrew Yourtchenko [Tue, 20 Aug 2019 16:31:34 +0000 (16:31 +0000)]
 
misc: 19.08 new features
The full RELEASE.md diff is 
b610f2022c9f4e10a922e7b57c80ec77cd45d021
Change-Id: Ide6d85d41bdc836a03390a50ab94f6ebbaae0b28
Signed-off-by: Andrew Yourtchenko <[email protected]>
(cherry picked from commit 
1c586de48cc76fc6eac50f5d87003e2a80aa43e7)
Andrew Yourtchenko [Sat, 17 Aug 2019 14:57:13 +0000 (14:57 +0000)]
 
misc: VPP 19.08 Release Notes
Change-Id: I81c7ad50c66b4b8d690e87aad1f3c16af065fc85
Type: docs
Signed-off-by: Andrew Yourtchenko <[email protected]>
(cherry picked from commit 
b610f2022c9f4e10a922e7b57c80ec77cd45d021)
Andrew Yourtchenko [Mon, 26 Aug 2019 12:58:48 +0000 (12:58 +0000)]
 
ip: ip6_preflen_to_mask incorrect result for prefix len > 64
The as_u64[0] in the result was not correctly filled in for
longer prefix lengths.
Type: fix
Fixes: 
1c7104514c
Change-Id: I871772c618475396d1c1c4c699ff77e35097f07e
Signed-off-by: Andrew Yourtchenko <[email protected]>
Benoît Ganne [Wed, 21 Aug 2019 13:11:43 +0000 (15:11 +0200)]
 
rdma: use rings for buffers management
Refactor rdma driver for improved performance and prepare for raw
datapath access.
Type: refactor
Change-Id: Iae31872055a6947708ea9f430bd1dc083ea63b5a
Signed-off-by: Benoît Ganne <[email protected]>
Florin Coras [Fri, 23 Aug 2019 17:28:01 +0000 (10:28 -0700)]
 
tcp: fix byte tracker samples flush
Type: fix
Change-Id: I3b4cb8fc17387693d6ad6cdef004ca99cd56bc23
Signed-off-by: Florin Coras <[email protected]>
Ole Troan [Fri, 23 Aug 2019 12:19:37 +0000 (14:19 +0200)]
 
vppapitrace: add text output
Add new argument --todump, to mimic the VPP
api trace dump output.
Type: feature
Signed-off-by: Ole Troan <[email protected]>
Change-Id: Ia8c845b321ef9d55dd6e2f388165ca5498406ab6
Dave Barach [Thu, 22 Aug 2019 23:32:49 +0000 (19:32 -0400)]
 
dns: fix trivial multi-thread deadlock
Add a simple lock trace mechanism
Type: fix
Ticket: VPP-1752
Signed-off-by: Dave Barach <[email protected]>
Change-Id: Idc82b1ad59adb0f7c185d27ced57e9a4c25ce62f
Dave Wallace [Thu, 22 Aug 2019 00:32:29 +0000 (00:32 +0000)]
 
tests: move plugin tests to src/plugins/*/test
- Relocate plugin tests for 'make test' into
  src/plugins/*/test so that plugin test cases
  are co-located with the plugin source code.
Type: refactor
Signed-off-by: Dave Wallace <[email protected]>
Change-Id: I503e6a43528e14981799b735fa65674155713f67
Signed-off-by: Dave Wallace <[email protected]>
Dave Barach [Wed, 21 Aug 2019 23:23:00 +0000 (19:23 -0400)]
 
dns: make the dns name resolver a plugin
Type: refactor
Signed-off-by: Dave Barach <[email protected]>
Change-Id: I823c2cd307a4613653a2d20f564dda062d4da31b
Damjan Marion [Thu, 22 Aug 2019 11:36:15 +0000 (13:36 +0200)]
 
avf: properly set irq queue masks
Type: fix
Fixes: 
ae91180
Change-Id: I9c55c3fdf41089d337b998e2e28abb23d81525ef
Signed-off-by: Damjan Marion <[email protected]>
Filip Varga [Mon, 12 Aug 2019 12:24:39 +0000 (14:24 +0200)]
 
nat: handoff traffic matching for dynamic NAT
Type: feature
Change-Id: I5c5af6f9acb340cc674323305104b8ce23e6d21d
Signed-off-by: Filip Varga <[email protected]>
Klement Sekera [Thu, 22 Aug 2019 11:34:33 +0000 (11:34 +0000)]
 
ip: fix merge issue
Signed-off-by: Klement Sekera <[email protected]>
Change-Id: Idd64b0b3eedb7179f6d316b66cea8160ad577990
Type: fix
Fixes: 
630ab5846bceddf8d663e9f488a2dc0378949827
Signed-off-by: Klement Sekera <[email protected]>
Steven Luong [Wed, 21 Aug 2019 18:35:27 +0000 (11:35 -0700)]
 
vlib: fix null pointer crash on strncmp
Program received signal SIGSEGV, Segmentation fault.
0x00007ffff4b71de0 in __strncmp_sse42 () from /lib64/libc.so.6
(gdb) up
up
    vm=0x7ffff6664d40 <vlib_global_main>, addr=0x7fffb4bec6d0,
    ids=0x7fffb31675f0 <avf_pci_device_ids>, handle=0x7fffb4bec594)
    at /usr/src/debug/vpp-20.01/src/vlib/linux/pci.c:1250
1250	  if (strncmp ("vfio-pci", (char *) di->driver_name, 8) == 0)
(gdb) p di
p di
$1 = (vlib_pci_device_info_t *) 0x7fffb6446164
(gdb) p di->driver_name
p di->driver_name
$2 = (u8 *) 0x0
(gdb)
driver_name may be null. strncmp is not forgiving. Change to use C11 safeC
version.
Type: fix
Signed-off-by: Steven Luong <[email protected]>
Change-Id: I1777a5966ceee7409d7bde86c30b14dc75534a5a
Benoît Ganne [Wed, 21 Aug 2019 18:32:18 +0000 (20:32 +0200)]
 
hsa: fix http response
http_ok is a const null-terminated string, not a vector.
Type: fix
Fixes: 
844a36d1a6
Change-Id: Ide1a23506d9f43cd33c3a4b8ba11658c67fbecc8
Signed-off-by: Benoît Ganne <[email protected]>
Vratko Polak [Wed, 21 Aug 2019 16:40:03 +0000 (18:40 +0200)]
 
sr: fix sr_set_encap_source reply
Can we get a reply macro that would avoid such copypaste errors?
Type: fix
Change-Id: I753efb1d82fced668c27f2e44b0318bfd31c0a23
Signed-off-by: Vratko Polak <[email protected]>
Benoît Ganne [Wed, 21 Aug 2019 16:27:23 +0000 (18:27 +0200)]
 
vcl: fix ldp_set_app_name overflow
In case of overflow, we null-terminate the parameter ('app_name')
instead of ldp global name ('ldp->app_name').
Moreover, snprintf() always safely null-terminate the destination string
even in case of overflow.
Type: fix
Fixes: 
048b1d6ab7
Change-Id: I4d8b0e020a228e982b6699d652b341c5afe92993
Signed-off-by: Benoît Ganne <[email protected]>
Florin Coras [Tue, 20 Aug 2019 14:09:31 +0000 (07:09 -0700)]
 
tcp: add option for always on event logging
Type: feature
Add option to always compile in debugging infra. Debug verbosity can be
controlled via configuration updatable via cli. Compile time inclusion
and configuration of event logging verbosity is still available in order
to minimize event logging impact.
Change-Id: I9d946efe9fa4204fdace1adb1d6588c97b5ae758
Signed-off-by: Florin Coras <[email protected]>
Damjan Marion [Wed, 21 Aug 2019 14:33:56 +0000 (16:33 +0200)]
 
avf: print queue id in packet trace
Type: feature
Change-Id: If3deb26b9ee3b9e677c9dc50789bf81fe6c11dee
Signed-off-by: Damjan Marion <[email protected]>
Dave Barach [Wed, 21 Aug 2019 13:11:41 +0000 (09:11 -0400)]
 
dns: add basic functional "make test" case
Type: test
Signed-off-by: Dave Barach <[email protected]>
Change-Id: I88e93b510d8d4f7b59f3e630539dc7e0264afa47
Jakub Grajciar [Wed, 31 Jul 2019 12:40:52 +0000 (14:40 +0200)]
 
libmemif: introduce 'memif_per_thread_' namespace
APIs in 'memif_per_thread_' namespace are used to split the global
database into separate databases, to improve multi-thread use cases.
Using 'memif_per_thread_init' client can create separate libmemif
databases (libmemif_main_t). Client will reference these databases
using memif_per_thread_handle_t. Each database requires unique socket.
Created interface will be stored in the same database as the socket
passed in connection arguments.
Example code: extras/libmemif/examples/icmp_responder_3-1/main.c
Type: feature
Signed-off-by: Jakub Grajciar <[email protected]>
Change-Id: I261563ecc34761a76e94f20c20015394398ddfd7
Signed-off-by: Jakub Grajciar <[email protected]>
Damjan Marion [Tue, 20 Aug 2019 10:38:08 +0000 (12:38 +0200)]
 
dpdk: bump DPDK version to 19.08
Type: feature
Change-Id: I16b8cdf0b6af6715a5f01ad84365a8c8a1b76237
Signed-off-by: Damjan Marion <[email protected]>
Damjan Marion [Tue, 20 Aug 2019 15:51:22 +0000 (17:51 +0200)]
 
avf: fix init when num_rx_queues > num_tx_queues
Type: fix
Fixes: 
ae91180
Change-Id: Id93b0f4d23ad7022e341e305bbd93ef2fff5787d
Signed-off-by: Damjan Marion <[email protected]>
Florin Coras [Tue, 20 Aug 2019 14:14:00 +0000 (07:14 -0700)]
 
tcp: default to debug disabled
Type:fix
Change-Id: Ib5c33f0bdb3a8b1c2585135fcc8c07b151e47df3
Signed-off-by: Florin Coras <[email protected]>
Steven Luong [Tue, 20 Aug 2019 18:39:00 +0000 (11:39 -0700)]
 
misc: missing ntohl for bond_slave's custom dump
sw_if_index argument is u32 and it needs to be converted to host order
for format in custom dump, a very highly sophisticated stuff.
Type: fix
Signed-off-by: Steven Luong <[email protected]>
Change-Id: Ie6d49a17e4411df5d567dbb2a7c95993dceda31b
Ping Yu [Mon, 19 Aug 2019 11:01:17 +0000 (07:01 -0400)]
 
tls: Add C API for TLS openssl to set engine
Type: feature
Parameters of the engine can be set by C API.
After this patch, it is easier to integrate TLS into CSIT test.
Change-Id: I063cabf613aabbfad831727551579328705afb41
Signed-off-by: Ping Yu <[email protected]>
Paul Vinciguerra [Wed, 7 Aug 2019 04:05:59 +0000 (00:05 -0400)]
 
vppapigen: remove support for legacy typedefs
vppapigen has remapped legacy to typedefs behind the scenes
for some time now.
- update .api files to use new style typedefs.
- issue error on 'typeonly define' in .api files
- remove unneeded macros redefining vl_noop_handler
Type: refactor
Change-Id: I7a8c4a6dafacee6a131f95cd0e9b03a8c60dea8b
Signed-off-by: Paul Vinciguerra <[email protected]>
Klement Sekera [Fri, 19 Jul 2019 09:14:19 +0000 (09:14 +0000)]
 
ip: reassembly: send packet out on correct worker
Note which worker received fragment with offset zero and use this worker
to send out the reassembled packet.
Type: fix
Change-Id: I1d3cee16788db3b230682525239c0100d51dc380
Signed-off-by: Klement Sekera <[email protected]>
Ole Troan [Mon, 19 Aug 2019 12:51:45 +0000 (14:51 +0200)]
 
vlib: create unix runtime directory
Ensure the runtime directory is created at startup.
Default /run/vpp
Type: fix
Fixes: I53d70939c8125d04a365ac51a6cbf8926dc52adf
Change-Id: I6d70364ea756b86768c4dd1f6a9383238ed275c8
Signed-off-by: Ole Troan <[email protected]>
Klement Sekera [Wed, 31 Jul 2019 13:14:16 +0000 (13:14 +0000)]
 
tests: support worker threads
Add support for specifying the worker thread when adding packet stream.
Type: feature
Change-Id: I8a98b91c211e60cd53e1166f9f51365394ecacfd
Signed-off-by: Klement Sekera <[email protected]>
Jack Xu [Wed, 27 Mar 2019 15:51:32 +0000 (11:51 -0400)]
 
fix pcap_write function
when use pcap cli to capture pcakets into two files rx01.pcap && rx02.pcap,
the first time:
1)pcap rx trace on max 100 intfc any file rx01.pcap
2)......the process of capture data to buffer......
3)pcap rx trace off
the second time:
4)pcap rx trace on max 100 intfc any file rx02.pcap
5)......the process of capture data to buffer......
6)pcap rx trace off
the pcap_write function bug in this two lines
pm->n_packets_captured = 0;
if (pm->n_packets_captured >= pm->n_packets_to_capture) referring to calling pcap_close()
will result in that the twice pcap cli both writes the packets
into rx01.pcap, but nothing into rx02.pcap. Beside, the rx02.pcap
file will not be created.
solution: separate the pcap_close() out of pcap_write()
Change-Id: Iedeb46f9cf0a4cb12449fd75a4014f95f3bb3fa8
Signed-off-by: Jack Xu <[email protected]>
Jakub Grajciar [Mon, 18 Mar 2019 12:17:53 +0000 (13:17 +0100)]
 
api: Cleanup APIs interface.api
Use of consistent API types for interface.api
Type: fix
Change-Id: I88206d7d0907cffd564031f73c9a996df2e5e21a
Signed-off-by: Jakub Grajciar <[email protected]>
Florin Coras [Mon, 19 Aug 2019 01:09:28 +0000 (18:09 -0700)]
 
tcp: forward conn resets through tcp-output
Type: refactor
Change-Id: I5718853d89ebeae9d66be975a803a3674bec5986
Signed-off-by: Florin Coras <[email protected]>
Klement Sekera [Wed, 24 Jul 2019 12:40:37 +0000 (12:40 +0000)]
 
tests: Revert "Tests: Example duplicate code refactoring."
This reverts commit 
6955595a577e1b7d316b5b69267bf1d1d951a4ab. The result
is that test filtering for reassembly tests works again.
Type: fix
Change-Id: I4acb094b5b4aa264745986afa0bb0528789807b3
Signed-off-by: Klement Sekera <[email protected]>
Paul Vinciguerra [Wed, 7 Aug 2019 02:02:45 +0000 (22:02 -0400)]
 
vppapigen: remove python2 support
vppapigen has been running under python3 for months.
Remove the python2 conditional code.
In case of an error, explicitly log and return non-0.
Type: refactor
Change-Id: I20a73e0f2cb875aab6441959a85a35e88c9f8250
Signed-off-by: Paul Vinciguerra <[email protected]>
Dave Barach [Mon, 19 Aug 2019 22:15:51 +0000 (18:15 -0400)]
 
dns: handle multiple replies for single requests
The world is a mess. A single DNS request may yield multiple, subtly
different responses; all with the same DNS protocol-level ID.
Last response wins in terms of what ends up in the cache.
First response wins in terms of the response sent to the client. Hard
to do otherwise since we have no clue that more than one answer will
be forthcoming.
Type: fix
Signed-off-by: Dave Barach <[email protected]>
Change-Id: I3175a40eb1fea237048d16b852a430f5ab51eaef
Nathan Skrzypczak [Mon, 12 Aug 2019 14:12:48 +0000 (16:12 +0200)]
 
hsa: move udp_echo to vpp_echo
Type: refactor
Change-Id: I9b8bc4e54bfae9fa3ed367d4a9676fb09c27fb2a
Signed-off-by: Nathan Skrzypczak <[email protected]>
Nathan Skrzypczak [Mon, 12 Aug 2019 10:02:25 +0000 (12:02 +0200)]
 
hsa: move tcp_echo to vpp_echo
Type: refactor
Change-Id: Ic23859a1686eff2ae4d08a86b69ff4813498459e
Signed-off-by: Nathan Skrzypczak <[email protected]>
Nathan Skrzypczak [Mon, 19 Aug 2019 15:49:56 +0000 (17:49 +0200)]
 
quic: fix rx_callback refactoring
* check_quic_client_connected might allocate ctx
and invalidate our pointer
Type: fix
Change-Id: I885ca5a1a6db9a7765c9047a7df9cdf66c94f1cb
Signed-off-by: Nathan Skrzypczak <[email protected]>
Paul Vinciguerra [Tue, 6 Aug 2019 23:58:24 +0000 (19:58 -0400)]
 
vppapigen map: raise ValueError when fieldname is python keyword
When working on the lb api, one of the field names was chosen as 'as'
(application server). Since 'as' is a python keyword, the field was
renamed to _1 in vpp_papi.
This changeset instead fails early with a descriptive message,
hopefully saving others time troubleshooting the issue.
    ValueError: Fieldname 'as' is a python keyword and
    is not accessible via the python API.
Type: feature
Change-Id: Ib048d97de0e392645540092e356cf8989848c947
Signed-off-by: Paul Vinciguerra <[email protected]>
Matthew Smith [Fri, 16 Aug 2019 16:30:02 +0000 (11:30 -0500)]
 
dpdk: fix ipsec coverity warning
Type: fix
Fixes: 
5025d40a1134272ab57c3c3f10311e31a65cd63c
Update the expression for a conditional block which should be executed
when an encrypted packet will be sent via IPv6. Coverity was
complaining that a NULL pointer could be dereferenced. It is unclear
whether that ever would have actually happened, but the updated
expression should quell the warning and should more accurately detect
whether the block for IPv6 should be executed.
Change-Id: I731cad1f982e8f55bd44e6e05e98eff96f1957bb
Signed-off-by: Matthew Smith <[email protected]>
Guanghua Zhang [Sun, 18 Aug 2019 00:35:04 +0000 (08:35 +0800)]
 
vlib: fix vlib_buffer_main_init_numa_node memory leak.
Type: fix
Signed-off-by: Guanghua Zhang <[email protected]>
Change-Id: I8252ed2555f5af6db2f12dc7c30e41cc1ec7dde0
Jianlin Lv [Thu, 27 Jun 2019 05:50:30 +0000 (13:50 +0800)]
 
build: fix vpp compilation failure on ThunderX2 and Amp
fix compile issue that caused by enabling "-mtune=thunderx2t99"
flag during compilation, such as
"/opt/vpp-agent/dev/vpp/src/vnet/interface_stats.c:164:1:
internal compiler error: Segmentation fault"
Type: fix
Change-Id: Iaf9f80a6c203a7e5b6a40523f14a62bb37091c92
Signed-off-by: Jianlin Lv <[email protected]>
Nitin Saxena [Thu, 28 Mar 2019 09:12:31 +0000 (14:42 +0530)]
 
vppinfra: Update "show cpu" output for AArch64 chips
- Allow "Microarch model(family)" row to show PASS
revison as either string (like A0, B0) or number (like
1.0, 2.0).
- Fix part number for Marvell CN96XX
Change-Id: Ie01a3960c4e5e481be354dc8bb60f744e5c65737
Signed-off-by: Nitin Saxena <[email protected]>
Zhiyong Yang [Wed, 26 Jun 2019 02:41:55 +0000 (22:41 -0400)]
 
ip: leverage existing vlib_buffer_advance
The function ip4_rewrite_inline_with_gso can leverage
the existing vlib_buffer_advance to simplify code.
Type: fix
Change-Id: I25d943dc78aba2f67654385cf3f693eb01e0210e
Signed-off-by: Zhiyong Yang <[email protected]>
Zhiyong Yang [Wed, 24 Jul 2019 05:43:39 +0000 (01:43 -0400)]
 
nsh: rewrite nsh_output_inline
Type: style
Change-Id: I0c870eddb427efa26cd5b52daf12b13c3927976a
Signed-off-by: Zhiyong Yang <[email protected]>
Benoît Ganne [Mon, 12 Aug 2019 09:44:20 +0000 (11:44 +0200)]
 
rdma: add support for MAC changes
Type: feature
Change-Id: I5803b52d12e56f2ccc1316e89ece6f1c5898810a
Signed-off-by: Benoît Ganne <[email protected]>
Chenmin Sun [Wed, 17 Jul 2019 14:29:44 +0000 (22:29 +0800)]
 
dpdk: add TSO support in dpdk plugin.
Type: feature
You can enable tso in starup.conf like this:
dev 0000:86:00.0{
	tso on
}
TSO is disabled by default.
Change-Id: Ifdbaf5322f768c384aa54e532d7bf45e810ca01c
Signed-off-by: Chenmin Sun <[email protected]>
Jim Thompson [Mon, 12 Aug 2019 07:03:38 +0000 (02:03 -0500)]
 
dpdk: QAT devices update, add c4xxx and xeon d15xx
Type: feature
Change-Id: I21f8f4563f5545a684b2666f7410847e0f7bc403
Signed-off-by: Jim Thompson <[email protected]>
Steven Luong [Wed, 7 Aug 2019 04:51:34 +0000 (21:51 -0700)]
 
devices: skip checksum calculation if guest supports checksum offload
Set VNET_HW_INTERFACE_FLAG_SUPPORTS_TX_L4_CKSUM_OFFLOAD for the interface
to skip checksum calculation if guest supports checksum offload.
Type: fix
Signed-off-by: Steven Luong <[email protected]>
Change-Id: Ie933c3462394f07580ef7f2bec1d2eb3b075bd0c
Benoît Ganne [Wed, 7 Aug 2019 11:35:29 +0000 (13:35 +0200)]
 
rdma: add support for input feature arcs
Input feature arcs enable functions such as l2patch or bonding.
Type: feature
Change-Id: Ie333c9b8f7ea20f8a3a409a9a06367807e215a57
Signed-off-by: Benoît Ganne <[email protected]>
Florin Coras [Sat, 17 Aug 2019 00:48:44 +0000 (17:48 -0700)]
 
session: add explicit reset api
Type: feature
This can be used to forcefully close a session. It's only available to
builtin applications for now. Transports must support the reset api
otherwise normal close is used.
Change-Id: I5e6d681cbc4c8045385e293e0e9d86fa2bf45849
Signed-off-by: Florin Coras <[email protected]>
Florin Coras [Fri, 16 Aug 2019 16:44:00 +0000 (09:44 -0700)]
 
tcp: set cc_algo on connection alloc
Type: feature
Change-Id: Ie00329b11e26cab5db64b9c006171d283854c8ef
Signed-off-by: Florin Coras <[email protected]>
Florin Coras [Fri, 16 Aug 2019 17:33:49 +0000 (10:33 -0700)]
 
tcp: allow cc algos to set pacing rate
Type: feature
Change-Id: Ie7f0f5d2a476d401ede567e422abb953b2bb4a78
Signed-off-by: Florin Coras <[email protected]>
Mohsin Kazmi [Mon, 29 Jul 2019 09:39:26 +0000 (11:39 +0200)]
 
gso: fix l3 and l4 header offset in case of tagged interface
previously, PG and virtio interfaces calculate wrong l3 and l4
header offset. This patch fixes this issue.
Type: fix
Ticket: VPP-1739
Change-Id: I5ba978e464babeb65e0711e1027320d46b3b9932
Signed-off-by: Mohsin Kazmi <[email protected]>
Mohsin Kazmi [Tue, 13 Aug 2019 16:23:26 +0000 (18:23 +0200)]
 
gso: fix the segmentation to use current_data offset
Type: fix
Ticket: VPP-1740
Change-Id: If3e34b5b8260e4c50af338895066c2c96f4603af
Signed-off-by: Mohsin Kazmi <[email protected]>
Steven Luong [Mon, 5 Aug 2019 16:47:58 +0000 (09:47 -0700)]
 
bonding lacp: deleting virtual interface which was enslaved may cause crash
Virtual interfaces may be part of the bonding like physical interfaces. The
difference is virtual interfaces may disappear dynamically. As an example,
the following CLI sequence may crash the debug image
create vhost-user socket /tmp/sock1
create bond mode lacp
bond add BondEthernet0 VirtualEthernet0/0/0
delete vhost-user VirtualEhernet0/0/0
Notice the virtual interface is deleted without first doing bond delete.
The proper order is to first remove the slave interface from the bond prior
to deleting the virtual interface as shown below. But we should handle it
anyway.
create vhost-user socket /tmp/sock1
create bond mode lacp
bond add BondEthernet0 VirtualEthernet0/0/0
bond del VirtualEthernet0/0/0   <-----
delete vhost-user VirtualEhernet0/0/0
The fix is to register for VNET_SW_INTERFACE_ADD_DEL_FUNCTION and remove
the slave interface from the bond if the to-be-deleted interface is part of
the bond. We check the interface that it is actually up before we send
the lacp pdu. Up means both hw and sw admin up.
Type: fix
Signed-off-by: Steven Luong <[email protected]>
Change-Id: If4d2da074338b16aab0df54e00d719e55c45221a
Andrew Yourtchenko [Thu, 15 Aug 2019 12:26:17 +0000 (12:26 +0000)]
 
acl: fix stats-segment counters validation on acl update
The stats-segment validation/clear logic for acl counters was wrong,
fix it. Also add the code to the unittests to cover that case,
add a vat command to enable/disable counters, clean up
the unnecessary endian conversion and remove the stray clib_warning()
Change-Id: I421297a92e4aeb885c468c72a97cec25981df615
Type: fix
Ticket: VPP-1744
Fixes: 
f995c7122ba0d024b17bc3232e8edd18d5e25088
Signed-off-by: Andrew Yourtchenko <[email protected]>
(cherry picked from commit 
4c945dacb9ff9da731301feb26b1edb4ac00e8bd)
Steven Luong [Thu, 15 Aug 2019 21:30:16 +0000 (14:30 -0700)]
 
devices: vhost-user crashes displaying show trace for deleted interface
After the trace is collected and if the interface is then deleted, show
trace may crash for the debug image. This is due to the additional check
in pool_elt_at_index() to make sure that the block is not free.
The fix is to do the check in vhost format trace and return "interface deleted"
Type: fix
Signed-off-by: Steven Luong <[email protected]>
Change-Id: I0744f913ba6146609663443f408d784067880f93
Nathan Skrzypczak [Mon, 5 Aug 2019 11:43:31 +0000 (13:43 +0200)]
 
hsa: Refactor quic_echo to allow other protocols
Type: refactor
Change-Id: Iaef9091e1d057110530255e644fad1c298418966
Signed-off-by: Nathan Skrzypczak <[email protected]>
Florin Coras [Fri, 16 Aug 2019 02:55:03 +0000 (19:55 -0700)]
 
tcp: fix cc algo name parsing
Type: fix
The initial config parser passed a pointer to the field algo id field in
tcp main. Because the field is a u8 and it was interpreted as a uword,
it ended up overwrting other tcp configuration fields.
Change-Id: Ie9020051c8fca40e14cf42a9888daa87360e5038
Signed-off-by: Florin Coras <[email protected]>
Mathias Raoul [Tue, 6 Aug 2019 11:08:51 +0000 (13:08 +0200)]
 
quic: quic_app_rx_callback refactor.
Add quic_process_one_rx_packet() function
Type: refactor
Change-Id: Iecaec3f7fed9f95a25ea55d0251626beb79181fd
Signed-off-by: Mathias Raoul <[email protected]>
Mohsin Kazmi [Wed, 14 Aug 2019 14:23:17 +0000 (16:23 +0200)]
 
gso: remove the ip checksum flag in case of ipv6
Type: fix
Ticket: VPP-1727
Change-Id: Icfee35c5ab5e1c65079d1ca7bb514162319113e5
Signed-off-by: Mohsin Kazmi <[email protected]>
Dmitry Vakhrushev [Wed, 14 Aug 2019 04:12:33 +0000 (00:12 -0400)]
 
ipsec: fix missed IPSEC_INTEG_ALG_MD5_96
This algorithm was missed in last improvements.
Type:fix
Signed-off-by: Dmitry Vakhrushev <[email protected]>
Change-Id: Ib818cbdcdd1a6f298e8b0086dac4189cc201baa3
Dave Barach [Thu, 15 Aug 2019 19:14:14 +0000 (15:14 -0400)]
 
dhcp: resolver process node index in main_t
Remove the (unused) node_registration_t, don't try to use it to signal
resolution events.
Type: fix
Ticket: VPP-1746
Signed-off-by: Dave Barach <[email protected]>
Change-Id: Ice975e32152892ac4100b9e758412d48a43f09f1
John Lo [Tue, 13 Aug 2019 22:18:21 +0000 (18:18 -0400)]
 
vlib: copy trace_handle in vlib_buffer_copy/clone() functions
Since vlib_buffer_copy() and vlib_buffer_clone() both preserve
VLIB_BUFFER_IS_TRACED bit in flags field, it should also copy
trace_handle which would add minimal overhead. Thus, callers of
these functions do not have to call vlib_buffer_copy_trace_flags()
to copy trace_handle.
Type: refactor
Signed-off-by: John Lo <[email protected]>
Change-Id: Iff6a3f81660dd62b36a2966033eb380305340310
Matthew G Smith [Tue, 6 Aug 2019 13:43:50 +0000 (08:43 -0500)]
 
dpdk: ipsec tunnel support for ip6-in-ip4
Type: feature
If an attempt was made to send an IPv6 packet over an IPv4 tunnel,
the DPDK esp_encrypt did not complete setting up
the crypto operation for a buffer, but still queued the crypto
operations that were allocated. This results in a SEGV when
attempting to dequeue them in dpdk-crypto-input.
Allow IPv6 packets to be sent over a v4 tunnel when using the DPDK
plugin esp crypto nodes.
Change-Id: Ic9a4cd69b7fc06a17ab2f64ae806ec2ceacfef27
Signed-off-by: Matthew Smith <[email protected]>
Dave Barach [Wed, 14 Aug 2019 13:35:41 +0000 (09:35 -0400)]
 
stats: refactor header files
Performant stat segment scraping involves caching the results of
stat_segment_ls (...) and directly fishing counter data from the
shared-memory segment.
To do that, we need to publish several things previously hidden,
declared in stat_client.c:
o stat_client_main_t typedef
o stat_segment_access_t typedef
o stat_segment_access_start inline function
o stat_segment_access_end inline function
Type: refactor
Signed-off-by: Dave Barach <[email protected]>
Change-Id: I3175e3d1f1fd8ea816336a584565179d1972115c
Florin Coras [Mon, 12 Aug 2019 21:17:47 +0000 (14:17 -0700)]
 
tcp: extend protocol configuration
Type: feature
Expose more configuration parameters and refactor some of the existing
ones.
Change-Id: If44c31ff77ce3d7e8da67d39a4ff61346bdf5ccc
Signed-off-by: Florin Coras <[email protected]>
Benoît Ganne [Fri, 2 Aug 2019 15:57:08 +0000 (17:57 +0200)]
 
gbp: add local l3out redirect to local SEP unit test
Type: test
Change-Id: Ia6dad86d02f6f665a3e6960812b2527eaabb65f1
Signed-off-by: Benoît Ganne <[email protected]>
Benoît Ganne [Tue, 6 Aug 2019 11:47:21 +0000 (13:47 +0200)]
 
gbp: do not scan gbp bihash if not instantiated
Type: fix
Fixes: 
32dcd3b2f227dec638c39ade0c58d6741d83ec30
Change-Id: I42550fcc5b3fa486a05770d3e220d7a86315628e
Signed-off-by: Benoît Ganne <[email protected]>