1. 13 Feb, 2021 36 commits
    • David S. Miller's avatar
      Merge branch 'brport-flags' · 4098ced4
      David S. Miller authored
      Vladimir Oltean says:
      
      ====================
      Cleanup in brport flags switchdev offload for DSA
      
      The initial goal of this series was to have better support for
      standalone ports mode on the DSA drivers like ocelot/felix and sja1105.
      This turned out to require some API adjustments in both directions:
      to the information presented to and by the switchdev notifier, and to
      the API presented to the switch drivers by the DSA layer.
      ====================
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      4098ced4
    • Vladimir Oltean's avatar
      net: dsa: sja1105: offload bridge port flags to device · 4d942354
      Vladimir Oltean authored
      The chip can configure unicast flooding, broadcast flooding and learning.
      Learning is per port, while flooding is per {ingress, egress} port pair
      and we need to configure the same value for all possible ingress ports
      towards the requested one.
      
      While multicast flooding is not officially supported, we can hack it by
      using a feature of the second generation (P/Q/R/S) devices, which is that
      FDB entries are maskable, and multicast addresses always have an odd
      first octet. So by putting a match-all for 00:01:00:00:00:00 addr and
      00:01:00:00:00:00 mask at the end of the FDB, we make sure that it is
      always checked last, and does not take precedence in front of any other
      MDB. So it behaves effectively as an unknown multicast entry.
      
      For the first generation switches, this feature is not available, so
      unknown multicast will always be treated the same as unknown unicast.
      So the only thing we can do is request the user to offload the settings
      for these 2 flags in tandem, i.e.
      
      ip link set swp2 type bridge_slave flood off
      Error: sja1105: This chip cannot configure multicast flooding independently of unicast.
      ip link set swp2 type bridge_slave flood off mcast_flood off
      ip link set swp2 type bridge_slave mcast_flood on
      Error: sja1105: This chip cannot configure multicast flooding independently of unicast.
      Signed-off-by: default avatarVladimir Oltean <vladimir.oltean@nxp.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      4d942354
    • Vladimir Oltean's avatar
      net: mscc: ocelot: offload bridge port flags to device · 421741ea
      Vladimir Oltean authored
      We should not be unconditionally enabling address learning, since doing
      that is actively detrimential when a port is standalone and not offloading
      a bridge. Namely, if a port in the switch is standalone and others are
      offloading the bridge, then we could enter a situation where we learn an
      address towards the standalone port, but the bridged ports could not
      forward the packet there, because the CPU is the only path between the
      standalone and the bridged ports. The solution of course is to not
      enable address learning unless the bridge asks for it.
      
      We need to set up the initial port flags for no learning and flooding
      everything, and also when the port joins and leaves the bridge.
      The flood configuration was already configured ok for standalone mode
      in ocelot_init, we just need to disable learning in ocelot_init_port.
      Signed-off-by: default avatarVladimir Oltean <vladimir.oltean@nxp.com>
      Reviewed-by: default avatarAlexandre Belloni <alexandre.belloni@bootlin.com>
      Reviewed-by: default avatarFlorian Fainelli <f.fainelli@gmail.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      421741ea
    • Vladimir Oltean's avatar
      net: mscc: ocelot: use separate flooding PGID for broadcast · b360d94f
      Vladimir Oltean authored
      In preparation of offloading the bridge port flags which have
      independent settings for unknown multicast and for broadcast, we should
      also start reserving one destination Port Group ID for the flooding of
      broadcast packets, to allow configuring it individually.
      Signed-off-by: default avatarVladimir Oltean <vladimir.oltean@nxp.com>
      Reviewed-by: default avatarFlorian Fainelli <f.fainelli@gmail.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      b360d94f
    • Vladimir Oltean's avatar
      net: dsa: felix: restore multicast flood to CPU when NPI tagger reinitializes · 6edb9e8d
      Vladimir Oltean authored
      ocelot_init sets up PGID_MC to include the CPU port module, and that is
      fine, but the ocelot-8021q tagger removes the CPU port module from the
      unknown multicast replicator. So after a transition from the default
      ocelot tagger towards ocelot-8021q and then again towards ocelot,
      multicast flooding towards the CPU port module will be disabled.
      
      Fixes: e21268ef ("net: dsa: felix: perform switch setup for tag_8021q")
      Signed-off-by: default avatarVladimir Oltean <vladimir.oltean@nxp.com>
      Reviewed-by: default avatarFlorian Fainelli <f.fainelli@gmail.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      6edb9e8d
    • Vladimir Oltean's avatar
      net: dsa: act as passthrough for bridge port flags · a8b659e7
      Vladimir Oltean authored
      There are multiple ways in which a PORT_BRIDGE_FLAGS attribute can be
      expressed by the bridge through switchdev, and not all of them can be
      emulated by DSA mid-layer API at the same time.
      
      One possible configuration is when the bridge offloads the port flags
      using a mask that has a single bit set - therefore only one feature
      should change. However, DSA currently groups together unicast and
      multicast flooding in the .port_egress_floods method, which limits our
      options when we try to add support for turning off broadcast flooding:
      do we extend .port_egress_floods with a third parameter which b53 and
      mv88e6xxx will ignore? But that means that the DSA layer, which
      currently implements the PRE_BRIDGE_FLAGS attribute all by itself, will
      see that .port_egress_floods is implemented, and will report that all 3
      types of flooding are supported - not necessarily true.
      
      Another configuration is when the user specifies more than one flag at
      the same time, in the same netlink message. If we were to create one
      individual function per offloadable bridge port flag, we would limit the
      expressiveness of the switch driver of refusing certain combinations of
      flag values. For example, a switch may not have an explicit knob for
      flooding of unknown multicast, just for flooding in general. In that
      case, the only correct thing to do is to allow changes to BR_FLOOD and
      BR_MCAST_FLOOD in tandem, and never allow mismatched values. But having
      a separate .port_set_unicast_flood and .port_set_multicast_flood would
      not allow the driver to possibly reject that.
      
      Also, DSA doesn't consider it necessary to inform the driver that a
      SWITCHDEV_ATTR_ID_BRIDGE_MROUTER attribute was offloaded, because it
      just calls .port_egress_floods for the CPU port. When we'll add support
      for the plain SWITCHDEV_ATTR_ID_PORT_MROUTER, that will become a real
      problem because the flood settings will need to be held statefully in
      the DSA middle layer, otherwise changing the mrouter port attribute will
      impact the flooding attribute. And that's _assuming_ that the underlying
      hardware doesn't have anything else to do when a multicast router
      attaches to a port than flood unknown traffic to it.  If it does, there
      will need to be a dedicated .port_set_mrouter anyway.
      
      So we need to let the DSA drivers see the exact form that the bridge
      passes this switchdev attribute in, otherwise we are standing in the
      way. Therefore we also need to use this form of language when
      communicating to the driver that it needs to configure its initial
      (before bridge join) and final (after bridge leave) port flags.
      
      The b53 and mv88e6xxx drivers are converted to the passthrough API and
      their implementation of .port_egress_floods is split into two: a
      function that configures unicast flooding and another for multicast.
      The mv88e6xxx implementation is quite hairy, and it turns out that
      the implementations of unknown unicast flooding are actually the same
      for 6185 and for 6352:
      
      behind the confusing names actually lie two individual bits:
      NO_UNKNOWN_MC -> FLOOD_UC = 0x4 = BIT(2)
      NO_UNKNOWN_UC -> FLOOD_MC = 0x8 = BIT(3)
      
      so there was no reason to entangle them in the first place.
      
      Whereas the 6185 writes to MV88E6185_PORT_CTL0_FORWARD_UNKNOWN of
      PORT_CTL0, which has the exact same bit index. I have left the
      implementations separate though, for the only reason that the names are
      different enough to confuse me, since I am not able to double-check with
      a user manual. The multicast flooding setting for 6185 is in a different
      register than for 6352 though.
      Signed-off-by: default avatarVladimir Oltean <vladimir.oltean@nxp.com>
      Reviewed-by: default avatarFlorian Fainelli <f.fainelli@gmail.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      a8b659e7
    • Vladimir Oltean's avatar
      net: switchdev: pass flags and mask to both {PRE_,}BRIDGE_FLAGS attributes · e18f4c18
      Vladimir Oltean authored
      This switchdev attribute offers a counterproductive API for a driver
      writer, because although br_switchdev_set_port_flag gets passed a
      "flags" and a "mask", those are passed piecemeal to the driver, so while
      the PRE_BRIDGE_FLAGS listener knows what changed because it has the
      "mask", the BRIDGE_FLAGS listener doesn't, because it only has the final
      value. But certain drivers can offload only certain combinations of
      settings, like for example they cannot change unicast flooding
      independently of multicast flooding - they must be both on or both off.
      The way the information is passed to switchdev makes drivers not
      expressive enough, and unable to reject this request ahead of time, in
      the PRE_BRIDGE_FLAGS notifier, so they are forced to reject it during
      the deferred BRIDGE_FLAGS attribute, where the rejection is currently
      ignored.
      
      This patch also changes drivers to make use of the "mask" field for edge
      detection when possible.
      Signed-off-by: default avatarVladimir Oltean <vladimir.oltean@nxp.com>
      Reviewed-by: default avatarGrygorii Strashko <grygorii.strashko@ti.com>
      Reviewed-by: default avatarFlorian Fainelli <f.fainelli@gmail.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      e18f4c18
    • Vladimir Oltean's avatar
      net: dsa: configure better brport flags when ports leave the bridge · 5e38c158
      Vladimir Oltean authored
      For a DSA switch port operating in standalone mode, address learning
      doesn't make much sense since that is a bridge function. In fact,
      address learning even breaks setups such as this one:
      
         +---------------------------------------------+
         |                                             |
         | +-------------------+                       |
         | |        br0        |    send      receive  |
         | +--------+-+--------+ +--------+ +--------+ |
         | |        | |        | |        | |        | |
         | |  swp0  | |  swp1  | |  swp2  | |  swp3  | |
         | |        | |        | |        | |        | |
         +-+--------+-+--------+-+--------+-+--------+-+
                |         ^           |          ^
                |         |           |          |
                |         +-----------+          |
                |                                |
                +--------------------------------+
      
      because if the switch has a single FDB (can offload a single bridge)
      then source address learning on swp3 can "steal" the source MAC address
      of swp2 from br0's FDB, because learning frames coming from swp2 will be
      done twice: first on the swp1 ingress port, second on the swp3 ingress
      port. So the hardware FDB will become out of sync with the software
      bridge, and when swp2 tries to send one more packet towards swp1, the
      ASIC will attempt to short-circuit the forwarding path and send it
      directly to swp3 (since that's the last port it learned that address on),
      which it obviously can't, because swp3 operates in standalone mode.
      
      So DSA drivers operating in standalone mode should still configure a
      list of bridge port flags even when they are standalone. Currently DSA
      attempts to call dsa_port_bridge_flags with 0, which disables egress
      flooding of unknown unicast and multicast, something which doesn't make
      much sense. For the switches that implement .port_egress_floods - b53
      and mv88e6xxx, it probably doesn't matter too much either, since they
      can possibly inject traffic from the CPU into a standalone port,
      regardless of MAC DA, even if egress flooding is turned off for that
      port, but certainly not all DSA switches can do that - sja1105, for
      example, can't. So it makes sense to use a better common default there,
      such as "flood everything".
      
      It should also be noted that what DSA calls "dsa_port_bridge_flags()"
      is a degenerate name for just calling .port_egress_floods(), since
      nothing else is implemented - not learning, in particular. But disabling
      address learning, something that this driver is also coding up for, will
      be supported by individual drivers once .port_egress_floods is replaced
      with a more generic .port_bridge_flags.
      
      Previous attempts to code up this logic have been in the common bridge
      layer, but as pointed out by Ido Schimmel, there are corner cases that
      are missed when doing that:
      https://patchwork.kernel.org/project/netdevbpf/patch/20210209151936.97382-5-olteanv@gmail.com/
      
      So, at least for now, let's leave DSA in charge of setting port flags
      before and after the bridge join and leave.
      Signed-off-by: default avatarVladimir Oltean <vladimir.oltean@nxp.com>
      Reviewed-by: default avatarFlorian Fainelli <f.fainelli@gmail.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      5e38c158
    • Vladimir Oltean's avatar
      net: bridge: don't print in br_switchdev_set_port_flag · 078bbb85
      Vladimir Oltean authored
      For the netlink interface, propagate errors through extack rather than
      simply printing them to the console. For the sysfs interface, we still
      print to the console, but at least that's one layer higher than in
      switchdev, which also allows us to silently ignore the offloading of
      flags if that is ever needed in the future.
      Signed-off-by: default avatarVladimir Oltean <vladimir.oltean@nxp.com>
      Acked-by: default avatarNikolay Aleksandrov <nikolay@nvidia.com>
      Reviewed-by: default avatarFlorian Fainelli <f.fainelli@gmail.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      078bbb85
    • Vladimir Oltean's avatar
      net: bridge: offload all port flags at once in br_setport · 304ae3bf
      Vladimir Oltean authored
      If for example this command:
      
      ip link set swp0 type bridge_slave flood off mcast_flood off learning off
      
      succeeded at configuring BR_FLOOD and BR_MCAST_FLOOD but not at
      BR_LEARNING, there would be no attempt to revert the partial state in
      any way. Arguably, if the user changes more than one flag through the
      same netlink command, this one _should_ be all or nothing, which means
      it should be passed through switchdev as all or nothing.
      Signed-off-by: default avatarVladimir Oltean <vladimir.oltean@nxp.com>
      Acked-by: default avatarNikolay Aleksandrov <nikolay@nvidia.com>
      Reviewed-by: default avatarFlorian Fainelli <f.fainelli@gmail.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      304ae3bf
    • Vladimir Oltean's avatar
      net: switchdev: propagate extack to port attributes · 4c08c586
      Vladimir Oltean authored
      When a struct switchdev_attr is notified through switchdev, there is no
      way to report informational messages, unlike for struct switchdev_obj.
      Signed-off-by: default avatarVladimir Oltean <vladimir.oltean@nxp.com>
      Reviewed-by: default avatarIdo Schimmel <idosch@nvidia.com>
      Reviewed-by: default avatarFlorian Fainelli <f.fainelli@gmail.com>
      Reviewed-by: default avatarNikolay Aleksandrov <nikolay@nvidia.com>
      Reviewed-by: default avatarGrygorii Strashko <grygorii.strashko@ti.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      4c08c586
    • David S. Miller's avatar
      octeontx2: Fix condition. · b0aae0bd
      David S. Miller authored
      Fixes: 93efb0c6 ("octeontx2-pf: Fix out-of-bounds read in otx2_get_fecparam()")
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      b0aae0bd
    • David S. Miller's avatar
      Merge branch 'ipa-cleanups' · 4b47ad00
      David S. Miller authored
      Alex Elder says:
      
      ====================
      net: ipa: some more cleanup
      
      Version 3 of this series uses dev_err_probe() in the second patch,
      as suggested by Heiner Kallweit.
      
      Version 2 was sent to ensure the series was based on current
      net-next/master, and added copyright updates to files touched.
      
      The original introduction is below.
      
      This is another fairly innocuous set of cleanup patches.
      
      The first was motivated by a bug found that would affect IPA v4.5.
      It maintain a new GSI address pointer; one is the "raw" (original
      mapped) address, and the other will have been adjusted if necessary
      for use on newer platforms.
      
      The second just quiets some unnecessary noise during early probe.
      
      The third fixes some errors that show up when IPA_VALIDATION is
      enabled.
      
      The last two just create helper functions to improve readability.
      
      ====================
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      4b47ad00
    • Alex Elder's avatar
      net: ipa: introduce gsi_channel_initialized() · 6170b6da
      Alex Elder authored
      Create a simple helper function that indicates whether a channel has
      been initialized.  This abstacts/hides the details of how this is
      determined.
      Signed-off-by: default avatarAlex Elder <elder@linaro.org>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      6170b6da
    • Alex Elder's avatar
      net: ipa: introduce ipa_table_hash_support() · a266ad6b
      Alex Elder authored
      Introduce a new function to abstract the knowledge of whether hashed
      routing and filter tables are supported for a given IPA instance.
      
      IPA v4.2 is the only one that doesn't support hashed tables (now
      and for the foreseeable future), but the name of the helper function
      is better for explaining what's going on.
      Signed-off-by: default avatarAlex Elder <elder@linaro.org>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      a266ad6b
    • Alex Elder's avatar
      net: ipa: fix register write command validation · 2d65ed76
      Alex Elder authored
      In ipa_cmd_register_write_valid() we verify that values we will
      supply to a REGISTER_WRITE IPA immediate command will fit in
      the fields that need to hold them.  This patch fixes some issues
      in that function and ipa_cmd_register_write_offset_valid().
      
      The dev_err() call in ipa_cmd_register_write_offset_valid() has
      some printf format errors:
        - The name of the register (corresponding to the string format
          specifier) was not supplied.
        - The IPA base offset and offset need to be supplied separately to
          match the other format specifiers.
      Also make the ~0 constant used there to compute the maximum
      supported offset value explicitly unsigned.
      
      There are two other issues in ipa_cmd_register_write_valid():
        - There's no need to check the hash flush register for platforms
          (like IPA v4.2) that do not support hashed tables
        - The highest possible endpoint number, whose status register
          offset is computed, is COUNT - 1, not COUNT.
      
      Fix these problems, and add some additional commentary.
      Signed-off-by: default avatarAlex Elder <elder@linaro.org>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      2d65ed76
    • Alex Elder's avatar
      net: ipa: use dev_err_probe() in ipa_clock.c · 4c7ccfcd
      Alex Elder authored
      When initializing the IPA core clock and interconnects, it's
      possible we'll get an EPROBE_DEFER error.  This isn't really an
      error, it's just means we need to be re-probed later.
      
      Use dev_err_probe() to report the error rather than dev_err().
      This avoids polluting the log with these "error" messages.
      Signed-off-by: default avatarAlex Elder <elder@linaro.org>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      4c7ccfcd
    • Alex Elder's avatar
      net: ipa: use a separate pointer for adjusted GSI memory · 571b1e7e
      Alex Elder authored
      This patch actually fixes a bug, though it doesn't affect the two
      platforms supported currently.  The fix implements GSI memory
      pointers a bit differently.
      
      For IPA version 4.5 and above, the address space for almost all GSI
      registers is adjusted downward by a fixed amount.  This is currently
      handled by adjusting the I/O virtual address pointer after it has
      been mapped.  The bug is that the pointer is not "de-adjusted" as it
      should be when it's unmapped.
      
      This patch fixes that error, but it does so by maintaining one "raw"
      pointer for the mapped memory range.  This is assigned when the
      memory is mapped and used to unmap the memory.  This pointer is also
      used to access the two registers that do *not* sit in the "adjusted"
      memory space.
      
      Rather than adjusting *that* pointer, we maintain a separate pointer
      that's an adjusted copy of the "raw" pointer, and that is used for
      most GSI register accesses.
      Signed-off-by: default avatarAlex Elder <elder@linaro.org>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      571b1e7e
    • David S. Miller's avatar
      Merge tag 'mac80211-next-for-net-next-2021-02-12' of... · 21cc70c7
      David S. Miller authored
      Merge tag 'mac80211-next-for-net-next-2021-02-12' of git://git.kernel.org/pub/scm/linux/kernel/git/jberg/mac80211-next
      
      Johannes Berg says:
      
      ====================
      Last set of updates:
       * more minstrel work from Felix to reduce the
         probing overhead
       * QoS for nl80211 control port frames
       * STBC injection support
       * and a couple of small fixes
      ====================
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      21cc70c7
    • Gustavo A. R. Silva's avatar
      octeontx2-pf: Fix out-of-bounds read in otx2_get_fecparam() · 93efb0c6
      Gustavo A. R. Silva authored
      Code at line 967 implies that rsp->fwdata.supported_fec may be up to 4:
      
       967: if (rsp->fwdata.supported_fec <= FEC_MAX_INDEX)
      
      If rsp->fwdata.supported_fec evaluates to 4, then there is an
      out-of-bounds read at line 971 because fec is an array with
      a maximum of 4 elements:
      
       954         const int fec[] = {
       955                 ETHTOOL_FEC_OFF,
       956                 ETHTOOL_FEC_BASER,
       957                 ETHTOOL_FEC_RS,
       958                 ETHTOOL_FEC_BASER | ETHTOOL_FEC_RS};
       959 #define FEC_MAX_INDEX 4
      
       971: fecparam->fec = fec[rsp->fwdata.supported_fec];
      
      Fix this by properly indexing fec[] with rsp->fwdata.supported_fec - 1.
      In this case the proper indexes 0 to 3 are used when
      rsp->fwdata.supported_fec evaluates to a range of 1 to 4, correspondingly.
      
      Fixes: d0cf9503 ("octeontx2-pf: ethtool fec mode support")
      Addresses-Coverity-ID: 1501722 ("Out-of-bounds read")
      Signed-off-by: default avatarGustavo A. R. Silva <gustavoars@kernel.org>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      93efb0c6
    • Colin Ian King's avatar
      octeontx2-af: Fix spelling mistake "recievd" -> "received" · a6e0ee35
      Colin Ian King authored
      There is a spelling mistake in the text in array rpm_rx_stats_fields,
      fix it.
      Signed-off-by: default avatarColin Ian King <colin.king@canonical.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      a6e0ee35
    • David S. Miller's avatar
      Merge tag 'wireless-drivers-next-2021-02-12' of... · 79201f35
      David S. Miller authored
      Merge tag 'wireless-drivers-next-2021-02-12' of git://git.kernel.org/pub/scm/linux/kernel/git/kvalo/wireless-drivers-next
      
      Kalle Valo says:
      ====================
      wireless-drivers-next patches for v5.12
      
      Second set of patches for v5.12. Last time there was a smaller pull
      request so unsurprisingly this time we have a big one. mt76 has new
      hardware support and lots of new features, iwlwifi getting new
      features and rtw88 got NAPI support. And the usual cleanups and fixes
      all over.
      
      Major changes:
      
      ath10k
      
      * support setting SAR limits via nl80211
      
      rtw88
      
      * support 8821 RFE type2 devices
      
      * NAPI support
      
      iwlwifi
      
      * add new FW API support
      
      * support for new So devices
      
      * support for RF interference mitigation (RFI)
      
      * support for PNVM (Platform Non-Volatile Memory, a firmware data
        file) from BIOS
      
      mt76
      
      * add new mt7921e driver
      
      * 802.11 encap offload support
      
      * support for multiple pcie gen1 host interfaces on 7915
      
      * 7915 testmode support
      
      * 7915 txbf support
      
      brcmfmac
      
      * support for CQM RSSI notifications
      
      wil6210
      
      * support for extended DMG MCS 12.1 rate
      ====================
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      79201f35
    • Vadim Fedorenko's avatar
      rxrpc: Fix dependency on IPv6 in udp tunnel config · 295f830e
      Vadim Fedorenko authored
      As udp_port_cfg struct changes its members with dependency on IPv6
      configuration, the code in rxrpc should also check for IPv6.
      
      Fixes: 1a9b86c9 ("rxrpc: use udp tunnel APIs instead of open code in rxrpc_open_socket")
      Reported-by: default avatarkernel test robot <lkp@intel.com>
      Signed-off-by: default avatarVadim Fedorenko <vfedorenko@novek.ru>
      Acked-by: default avatarDavid Howells <dhowells@redhat.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      295f830e
    • David S. Miller's avatar
      Merge branch 'mptcp-genl-events' · 0a2f6b32
      David S. Miller authored
      Mat Martineau says:
      
      ====================
      mptcp: Add genl events for connection info
      
      This series from the MPTCP tree adds genl multicast events that are
      important for implementing a userspace path manager. In MPTCP, a path
      manager is responsible for adding or removing additional subflows on
      each MPTCP connection. The in-kernel path manager (already part of the
      kernel) is a better fit for many server use cases, but the additional
      flexibility of userspace path managers is often useful for client
      devices.
      
      Patches 1, 2, 4, 5, and 6 do some refactoring to streamline the netlink
      event implementation in the final patch.
      
      Patch 3 improves the timeliness of subflow destruction to ensure the
      'subflow closed' event will be sent soon enough.
      
      Patch 7 allows use of the GENL_UNS_ADMIN_PERM flag on genl mcast groups
      to mandate CAP_NET_ADMIN, which is important to protect token information
      in the MPTCP events. This is a genetlink change.
      
      Patch 8 adds the MPTCP netlink events.
      ====================
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      0a2f6b32
    • Florian Westphal's avatar
      mptcp: add netlink event support · b911c97c
      Florian Westphal authored
      Allow userspace (mptcpd) to subscribe to mptcp genl multicast events.
      This implementation reuses the same event API as the mptcp kernel fork
      to ease integration of existing tools, e.g. mptcpd.
      
      Supported events include:
      1. start and close of an mptcp connection
      2. start and close of subflows (joins)
      3. announce and withdrawals of addresses
      4. subflow priority (backup/non-backup) change.
      Reviewed-by: default avatarMatthieu Baerts <matthieu.baerts@tessares.net>
      Signed-off-by: default avatarFlorian Westphal <fw@strlen.de>
      Signed-off-by: default avatarMat Martineau <mathew.j.martineau@linux.intel.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      b911c97c
    • Florian Westphal's avatar
      mptcp: avoid lock_fast usage in accept path · 4d54cc32
      Florian Westphal authored
      Once event support is added this may need to allocate memory while msk
      lock is held with softirqs disabled.
      
      Not using lock_fast also allows to do the allocation with GFP_KERNEL.
      Signed-off-by: default avatarFlorian Westphal <fw@strlen.de>
      Signed-off-by: default avatarMat Martineau <mathew.j.martineau@linux.intel.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      4d54cc32
    • Florian Westphal's avatar
      mptcp: pass subflow socket to a few helpers · 6c714f1b
      Florian Westphal authored
      Pass the first/initial subflow to the existing functions so they can
      pass this on to the notification handler that is added later in the
      series.
      Signed-off-by: default avatarFlorian Westphal <fw@strlen.de>
      Signed-off-by: default avatarMat Martineau <mathew.j.martineau@linux.intel.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      6c714f1b
    • Florian Westphal's avatar
      mptcp: move subflow close loop after sk close check · b263b0d7
      Florian Westphal authored
      In case mptcp socket is already dead the entire mptcp socket
      will be freed. We can avoid the close check in this case.
      Signed-off-by: default avatarFlorian Westphal <fw@strlen.de>
      Signed-off-by: default avatarMat Martineau <mathew.j.martineau@linux.intel.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      b263b0d7
    • Florian Westphal's avatar
      mptcp: schedule worker when subflow is closed · 40947e13
      Florian Westphal authored
      When remote side closes a subflow we should schedule the worker to
      dispose of the subflow in a timely manner.
      
      Otherwise, SF_CLOSED event won't be generated until the mptcp
      socket itself is closing or local side is closing another subflow.
      Signed-off-by: default avatarFlorian Westphal <fw@strlen.de>
      Signed-off-by: default avatarMat Martineau <mathew.j.martineau@linux.intel.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      40947e13
    • Florian Westphal's avatar
      mptcp: split __mptcp_close_ssk helper · a141e02e
      Florian Westphal authored
      Prepare for subflow close events:
      
      When mptcp connection is torn down its enough to send the mptcp socket
      close notification rather than a subflow close event for all of the
      subflows followed by the mptcp close event.
      
      This splits the helper: mptcp_close_ssk() will emit the close
      notification, __mptcp_close_ssk will not.
      Signed-off-by: default avatarFlorian Westphal <fw@strlen.de>
      Signed-off-by: default avatarMat Martineau <mathew.j.martineau@linux.intel.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      a141e02e
    • Florian Westphal's avatar
      mptcp: move pm netlink work into pm_netlink · e9801430
      Florian Westphal authored
      Allows to make some functions static and avoids acquire of the pm
      spinlock in protocol.c.
      Signed-off-by: default avatarFlorian Westphal <fw@strlen.de>
      Signed-off-by: default avatarMat Martineau <mathew.j.martineau@linux.intel.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      e9801430
    • David S. Miller's avatar
      Merge branch 'mptcp-selftests' · 0a82c37e
      David S. Miller authored
      Mat Martineau says:
      
      ====================
      mptcp: Selftest enhancement and fixes
      
      This is a collection of selftest updates from the MPTCP tree.
      
      Patch 1 uses additional 'ss' command line parameters and 'nstat' to
      improve output when certain MPTCP tests fail.
      
      Patches 2 & 3 fix a copy/paste error and some output formatting.
      
      Patch 4 makes sure tests still pass if certain connection-related
      packets are retransmitted.
      ====================
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      0a82c37e
    • Matthieu Baerts's avatar
      selftests: mptcp: fail if not enough SYN/3rd ACK · 5f88117f
      Matthieu Baerts authored
      If we receive less MPCapable SYN or 3rd ACK than expected, we now mark
      the test as failed.
      
      On the other hand, if we receive more, we keep the warning but we add a
      hint that it is probably due to retransmissions and that's why we don't
      mark the test as failed.
      
      Closes: https://github.com/multipath-tcp/mptcp_net-next/issues/148Signed-off-by: default avatarMatthieu Baerts <matthieu.baerts@tessares.net>
      Signed-off-by: default avatarMat Martineau <mathew.j.martineau@linux.intel.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      5f88117f
    • Matthieu Baerts's avatar
      selftests: mptcp: display warnings on one line · 45759a87
      Matthieu Baerts authored
      Before we had this in case of SYN retransmissions:
      
        (...)
        # ns4 MPTCP -> ns2 (10.0.1.2:10034      ) MPTCP	(duration  1201ms) [ OK ]
        # ns4 MPTCP -> ns2 (dead:beef:1::2:10035) MPTCP	(duration  1242ms) [ OK ]
        # ns4 MPTCP -> ns2 (10.0.2.1:10036      ) MPTCP	ns2-60143c00-cDZWo4 SYNRX: MPTCP -> MPTCP: expect 11, got
        # 13
        # (duration  6221ms) [ OK ]
        # ns4 MPTCP -> ns2 (dead:beef:2::1:10037) MPTCP	(duration  1427ms) [ OK ]
        # ns4 MPTCP -> ns3 (10.0.2.2:10038      ) MPTCP	(duration   881ms) [ OK ]
        (...)
      
      Now we have:
      
        (...)
        # ns4 MPTCP -> ns2 (10.0.1.2:10034      ) MPTCP	(duration  1201ms) [ OK ]
        # ns4 MPTCP -> ns2 (dead:beef:1::2:10035) MPTCP	(duration  1242ms) [ OK ]
        # ns4 MPTCP -> ns2 (10.0.2.1:10036      ) MPTCP	(duration  6221ms) [ OK ] WARN: SYNRX: expect 11, got 13
        # ns4 MPTCP -> ns2 (dead:beef:2::1:10037) MPTCP	(duration  1427ms) [ OK ]
        # ns4 MPTCP -> ns3 (10.0.2.2:10038      ) MPTCP	(duration   881ms) [ OK ]
        (...)
      
      So we put everything on one line, keep the durations and "OK" aligned
      and removed duplicated info to short the warning.
      Signed-off-by: default avatarMatthieu Baerts <matthieu.baerts@tessares.net>
      Signed-off-by: default avatarMat Martineau <mathew.j.martineau@linux.intel.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      45759a87
    • Matthieu Baerts's avatar
      selftests: mptcp: fix ACKRX debug message · f384221a
      Matthieu Baerts authored
      Info from received MPCapable SYN were printed instead of the ones from
      received MPCapable 3rd ACK.
      
      Fixes: fed61c4b ("selftests: mptcp: make 2nd net namespace use tcp syn cookies unconditionally")
      Signed-off-by: default avatarMatthieu Baerts <matthieu.baerts@tessares.net>
      Signed-off-by: default avatarMat Martineau <mathew.j.martineau@linux.intel.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      f384221a
    • Paolo Abeni's avatar
      selftests: mptcp: dump more info on errors · 767389c8
      Paolo Abeni authored
      Even if that may sound completely unlikely, the mptcp implementation
      is not perfect, yet.
      
      When the self-tests report an error we usually need more information
      of what the scripts currently report. iproute allow provides
      some additional goodies since a few releases, let's dump them.
      Signed-off-by: default avatarPaolo Abeni <pabeni@redhat.com>
      Signed-off-by: default avatarMat Martineau <mathew.j.martineau@linux.intel.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      767389c8
  2. 12 Feb, 2021 4 commits