1. 18 Jun, 2021 7 commits
    • David S. Miller's avatar
      Merge branch 'seg6.end.dt6' · e7f3863c
      David S. Miller authored
      Andrea Mayer says:
      
      ====================
      seg6: add support for SRv6 End.DT46 Behavior
      
      SRv6 End.DT46 Behavior is defined in the IETF RFC 8986 [1] along with SRv6
      End.DT4 and End.DT6 Behaviors.
      
      The proposed End.DT46 implementation is meant to support the decapsulation
      of both IPv4 and IPv6 traffic coming from a *single* SRv6 tunnel.
      The SRv6 End.DT46 Behavior greatly simplifies the setup and operations of
      SRv6 VPNs in the Linux kernel.
      
       - patch 1/2 is the core patch that adds support for the SRv6 End.DT46
         Behavior;
      
       - patch 2/2 adds the selftest for SRv6 End.DT46 Behavior.
      
      The patch introducing the new SRv6 End.DT46 Behavior in iproute2 will
      follow shortly.
      
      Comments, suggestions and improvements are very welcome as always!
      ====================
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      e7f3863c
    • Andrea Mayer's avatar
      selftests: seg6: add selftest for SRv6 End.DT46 Behavior · 03a0b567
      Andrea Mayer authored
      this selftest is designed for evaluating the new SRv6 End.DT46 Behavior
      used, in this example, for implementing IPv4/IPv6 L3 VPN use cases.
      Signed-off-by: default avatarAndrea Mayer <andrea.mayer@uniroma2.it>
      Signed-off-by: default avatarPaolo Lungaroni <paolo.lungaroni@uniroma2.it>
      Acked-by: default avatarDavid Ahern <dsahern@kernel.org>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      03a0b567
    • Andrea Mayer's avatar
      seg6: add support for SRv6 End.DT46 Behavior · 8b532109
      Andrea Mayer authored
      IETF RFC 8986 [1] includes the definition of SRv6 End.DT4, End.DT6, and
      End.DT46 Behaviors.
      
      The current SRv6 code in the Linux kernel only implements End.DT4 and
      End.DT6 which can be used respectively to support IPv4-in-IPv6 and
      IPv6-in-IPv6 VPNs. With End.DT4 and End.DT6 it is not possible to create a
      single SRv6 VPN tunnel to carry both IPv4 and IPv6 traffic.
      
      The proposed End.DT46 implementation is meant to support the decapsulation
      of IPv4 and IPv6 traffic coming from a single SRv6 tunnel.
      The implementation of the SRv6 End.DT46 Behavior in the Linux kernel
      greatly simplifies the setup and operations of SRv6 VPNs.
      
      The SRv6 End.DT46 Behavior leverages the infrastructure of SRv6 End.DT{4,6}
      Behaviors implemented so far, because it makes use of a VRF device in
      order to force the routing lookup into the associated routing table.
      
      To make the End.DT46 work properly, it must be guaranteed that the routing
      table used for routing lookup operations is bound to one and only one VRF
      during the tunnel creation. Such constraint has to be enforced by enabling
      the VRF strict_mode sysctl parameter, i.e.:
      
       $ sysctl -wq net.vrf.strict_mode=1
      
      Note that the same approach is used for the SRv6 End.DT4 Behavior and for
      the End.DT6 Behavior in VRF mode.
      
      The command used to instantiate an SRv6 End.DT46 Behavior is
      straightforward, i.e.:
      
       $ ip -6 route add 2001:db8::1 encap seg6local action End.DT46 vrftable 100 dev vrf100.
      
      [1] https://www.rfc-editor.org/rfc/rfc8986.html#name-enddt46-decapsulation-and-s
      
      ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
      
      Performance and impact of SRv6 End.DT46 Behavior on the SRv6 Networking
      =======================================================================
      
      This patch aims to add the SRv6 End.DT46 Behavior with minimal impact on
      the performance of SRv6 End.DT4 and End.DT6 Behaviors.
      In order to verify this, we tested the performance of the newly introduced
      SRv6 End.DT46 Behavior and compared it with the performance of SRv6
      End.DT{4,6} Behaviors, considering both the patched kernel and the kernel
      before applying the End.DT46 patch (referred to as vanilla kernel).
      
      In details, the following decapsulation scenarios were considered:
      
       1.a) IPv6 traffic in SRv6 End.DT46 Behavior on patched kernel;
       1.b) IPv4 traffic in SRv6 End.DT46 Behavior on patched kernel;
       2.a) SRv6 End.DT6 Behavior (VRF mode) on patched kernel;
       2.b) SRv6 End.DT4 Behavior on patched kernel;
       3.a) SRv6 End.DT6 Behavior (VRF mode) on vanilla kernel (without the
            End.DT46 patch);
       3.b) SRv6 End.DT4 Behavior on vanilla kernel (without the End.DT46 patch).
      
      All tests were performed on a testbed deployed on the CloudLab [2]
      facilities. We considered IPv{4,6} traffic handled by a single core (at 2.4
      GHz on a Xeon(R) CPU E5-2630 v3) on kernel 5.13-rc1 using packets of size
      ~ 100 bytes.
      
      Scenario (1.a): average 684.70 kpps; std. dev. 0.7 kpps;
      Scenario (1.b): average 711.69 kpps; std. dev. 1.2 kpps;
      Scenario (2.a): average 690.70 kpps; std. dev. 1.2 kpps;
      Scenario (2.b): average 722.22 kpps; std. dev. 1.7 kpps;
      Scenario (3.a): average 690.02 kpps; std. dev. 2.6 kpps;
      Scenario (3.b): average 721.91 kpps; std. dev. 1.2 kpps;
      
      Considering the results for the patched kernel (1.a, 1.b, 2.a, 2.b) we
      observe that the performance degradation incurred in using End.DT46 rather
      than End.DT6 and End.DT4 respectively for IPv6 and IPv4 traffic is minimal,
      around 0.9% and 1.5%. Such very minimal performance degradation is the
      price to be paid if one prefers to use a single tunnel capable of handling
      both types of traffic (IPv4 and IPv6).
      
      Comparing the results for End.DT4 and End.DT6 under the patched and the
      vanilla kernel (2.a, 2.b, 3.a, 3.b) we observe that the introduction of the
      End.DT46 patch has no impact on the performance of End.DT4 and End.DT6.
      
      [2] https://www.cloudlab.usSigned-off-by: default avatarAndrea Mayer <andrea.mayer@uniroma2.it>
      Reviewed-by: default avatarDavid Ahern <dsahern@kernel.org>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      8b532109
    • Ioana Ciornei's avatar
      Documentation: ACPI: DSD: fix block code comments · 5a336f97
      Ioana Ciornei authored
      Use the '.. code-block:: none' to properly highlight the documented DSDT
      entries. This also fixes warnings in the documentation build process.
      
      Fixes: e71305ac ("Documentation: ACPI: DSD: Document MDIO PHY")
      Reported-by: default avatarStephen Rothwell <sfr@canb.auug.org.au>
      Signed-off-by: default avatarIoana Ciornei <ioana.ciornei@nxp.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      5a336f97
    • Ioana Ciornei's avatar
      Documentation: ACPI: DSD: include phy.rst in the toctree · 79ab2b37
      Ioana Ciornei authored
      Include the new phy.rst into the index of the ACPI support
      documentation.
      
      Fixes: e71305ac ("Documentation: ACPI: DSD: Document MDIO PHY")
      Reported-by: default avatarStephen Rothwell <sfr@canb.auug.org.au>
      Signed-off-by: default avatarIoana Ciornei <ioana.ciornei@nxp.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      79ab2b37
    • Colin Ian King's avatar
      net: neterion: vxge: remove redundant continue statement · d1434cf5
      Colin Ian King authored
      The continue statement at the end of a for-loop has no effect,
      invert the if expression and remove the continue.
      Signed-off-by: default avatarColin Ian King <colin.king@canonical.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      d1434cf5
    • Oleksandr Mazur's avatar
      drivers: net: netdevsim: fix devlink_trap selftests failing · 275b51c2
      Oleksandr Mazur authored
      devlink_trap tests for the netdevsim fail due to misspelled
      debugfs file name. Change this name, as well as name of callback
      function, to match the naming as in the devlink itself - 'trap_drop_counter'.
      
      Test-results:
      selftests: drivers/net/netdevsim: devlink_trap.sh
      TEST: Initialization                                                [ OK ]
      TEST: Trap action                                                   [ OK ]
      TEST: Trap metadata                                                 [ OK ]
      TEST: Non-existing trap                                             [ OK ]
      TEST: Non-existing trap action                                      [ OK ]
      TEST: Trap statistics                                               [ OK ]
      TEST: Trap group action                                             [ OK ]
      TEST: Non-existing trap group                                       [ OK ]
      TEST: Trap group statistics                                         [ OK ]
      TEST: Trap policer                                                  [ OK ]
      TEST: Trap policer binding                                          [ OK ]
      TEST: Port delete                                                   [ OK ]
      TEST: Device delete                                                 [ OK ]
      
      Fixes: a7b3527a ("drivers: net: netdevsim: add devlink trap_drop_counter_get implementation")
      Signed-off-by: default avatarOleksandr Mazur <oleksandr.mazur@plvision.eu>
      Reviewed-by: default avatarIdo Schimmel <idosch@nvidia.com>
      Tested-by: default avatarIdo Schimmel <idosch@nvidia.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      275b51c2
  2. 17 Jun, 2021 33 commits