1. 05 Jul, 2022 2 commits
    • Kuniyuki Iwashima's avatar
      selftests: net: af_unix: Test connect() with different netns. · e95ab1d8
      Kuniyuki Iwashima authored
      This patch add a test that checks connect()ivity between two sockets:
      
          unnamed socket -> bound socket
                            * SOCK_STREAM or SOCK_DGRAM
                            * pathname or abstract
                            * same or different netns
      Signed-off-by: default avatarKuniyuki Iwashima <kuniyu@amazon.com>
      Signed-off-by: default avatarPaolo Abeni <pabeni@redhat.com>
      e95ab1d8
    • Kuniyuki Iwashima's avatar
      af_unix: Put pathname sockets in the global hash table. · 51bae889
      Kuniyuki Iwashima authored
      Commit cf2f225e ("af_unix: Put a socket into a per-netns hash table.")
      accidentally broke user API for pathname sockets.  A socket was able to
      connect() to a pathname socket whose file was visible even if they were in
      different network namespaces.
      
      The commit puts all sockets into a per-netns hash table.  As a result,
      connect() to a pathname socket in a different netns fails to find it in the
      caller's per-netns hash table and returns -ECONNREFUSED even when the task
      can view the peer socket file.
      
      We can reproduce this issue by:
      
        Console A:
      
          # python3
          >>> from socket import *
          >>> s = socket(AF_UNIX, SOCK_STREAM, 0)
          >>> s.bind('test')
          >>> s.listen(32)
      
        Console B:
      
          # ip netns add test
          # ip netns exec test sh
          # python3
          >>> from socket import *
          >>> s = socket(AF_UNIX, SOCK_STREAM, 0)
          >>> s.connect('test')
      
      Note when dumping sockets by sock_diag, procfs, and bpf_iter, they are
      filtered only by netns.  In other words, even if they are visible and
      connect()able, all sockets in different netns are skipped while iterating
      sockets.  Thus, we need a fix only for finding a peer pathname socket.
      
      This patch adds a global hash table for pathname sockets, links them with
      sk_bind_node, and uses it in unix_find_socket_byinode().  By doing so, we
      can keep sockets in per-netns hash tables and dump them easily.
      
      Thanks to Sachin Sant and Leonard Crestez for reports, logs and a reproducer.
      
      Fixes: cf2f225e ("af_unix: Put a socket into a per-netns hash table.")
      Reported-by: default avatarSachin Sant <sachinp@linux.ibm.com>
      Reported-by: default avatarLeonard Crestez <cdleonard@gmail.com>
      Tested-by: default avatarSachin Sant <sachinp@linux.ibm.com>
      Tested-by: default avatarNathan Chancellor <nathan@kernel.org>
      Signed-off-by: default avatarKuniyuki Iwashima <kuniyu@amazon.com>
      Tested-by: default avatarLeonard Crestez <cdleonard@gmail.com>
      Signed-off-by: default avatarPaolo Abeni <pabeni@redhat.com>
      51bae889
  2. 04 Jul, 2022 26 commits
    • Zhang Jiaming's avatar
      net: hns: Fix spelling mistakes in comments. · 874bdbfe
      Zhang Jiaming authored
      Fix spelling of 'waitting' in comments.
      remove unnecessary space of 'MDIO_COMMAND_REG 's'.
      Signed-off-by: default avatarZhang Jiaming <jiaming@nfschina.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      874bdbfe
    • David S. Miller's avatar
      Merge branch 'nfp-vlan-strip-and-insert' · fd4b96c4
      David S. Miller authored
      Simon Horman says:
      
      ====================
      nfp: support VLAN strip and insert
      
      this series adds support to the NFP driver for HW offload of both:
      
      * RX VLAN ctag/stag strip
      * TX VLAN ctag insert
      ====================
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      fd4b96c4
    • Diana Wang's avatar
      nfp: support TX VLAN ctag insert · d80702ff
      Diana Wang authored
      Add support for TX VLAN ctag insert
      which may be configured via ethtool.
      
      e.g.
           # ethtool -K $DEV tx-vlan-offload on
      
      The NIC supplies VLAN insert information as packet metadata.
      The fields of this VLAN metadata are gotten from sk_buff, including
      vlan_proto and vlan tag.
      
      Configuration control bit NFP_NET_CFG_CTRL_TXVLAN_V2 is to
      signal availability of ctag-insert features of the firmware.
      
      NFDK is used to communicate via PCIE to NFP-3800 based NICs
      while NFD3 is used for other NICs supported by the NFP driver.
      The metadata format on tx side of NFD3 is different from NFDK.
      This feature is not currently implemented for NFDK.
      Signed-off-by: default avatarDiana Wang <na.wang@corigine.com>
      Reviewed-by: default avatarLouis Peens <louis.peens@corigine.com>
      Signed-off-by: default avatarSimon Horman <simon.horman@corigine.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      d80702ff
    • Diana Wang's avatar
      nfp: support RX VLAN ctag/stag strip · 67d2656b
      Diana Wang authored
      Add support for RX VLAN ctag/stag strip
      which may be configured via ethtool.
      
      e.g.
           # ethtool -K $DEV rx-vlan-offload on
           # ethtool -K $DEV rx-vlan-stag-hw-parse on
      
      Ctag-stripped and stag-stripped cannot be enabled at the same time
      because currently the kernel supports only one layer of VLAN stripping.
      
      The NIC supplies VLAN strip information as packet metadata.
      The fields of this VLAN metadata are:
      
      * strip flag: 1 for stripped; 0 for unstripped
      * tci: VLAN TCI ID
      * tpid: 1 for ETH_P_8021AD; 0 for ETH_P_8021Q
      
      Configuration control bits NFP_NET_CFG_CTRL_RXVLAN_V2 and
      NFP_NET_CFG_CTRL_RXQINQ are to signal availability of
      ctag-strip and stag-strip features of the firmware.
      Signed-off-by: default avatarDiana Wang <na.wang@corigine.com>
      Reviewed-by: default avatarLouis Peens <louis.peens@corigine.com>
      Signed-off-by: default avatarSimon Horman <simon.horman@corigine.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      67d2656b
    • David S. Miller's avatar
      Merge branch 'smsc95xx-deadlock' · 5ee4bba2
      David S. Miller authored
      Lukas Wunner says:
      
      ====================
      Deadlock no more in LAN95xx
      
      Second attempt at fixing a runtime resume deadlock in the LAN95xx USB driver:
      
      In short, the driver isn't using the "nopm" register accessors in portions
      of its runtime resume path, causing a deadlock.  I'm fixing that by
      auto-detecting whether nopm accessors shall be used, instead of
      having to explicitly call them wherever it's necessary.
      As a byproduct, code size shrinks significantly (see diffstat below).
      
      Back in April I submitted a first attempt which was rejected by Alan Stern:
      https://lore.kernel.org/all/6710d8c18ff54139cdc538763ba544187c5a0cee.1651041411.git.lukas@wunner.de/
      
      That approach only detected whether a PM callback is running concurrently,
      not whether the access is performed by the PM callback.  I've come up with
      a different approach which should resolve the objection (see patch [1/3]).
      ====================
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      5ee4bba2
    • Lukas Wunner's avatar
      usbnet: smsc95xx: Clean up unnecessary BUG_ON() upon register access · 03b3df43
      Lukas Wunner authored
      smsc95xx_read_reg() and smsc95xx_write_reg() call BUG_ON() if the
      struct usbnet pointer passed in is NULL.
      
      The functions have just been amended to dereference the pointer on
      entry.  So the kernel now oopses if the pointer is NULL, eliminating
      the need for an explicit BUG_ON().
      Signed-off-by: default avatarLukas Wunner <lukas@wunner.de>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      03b3df43
    • Lukas Wunner's avatar
      usbnet: smsc95xx: Clean up nopm handling · 31472429
      Lukas Wunner authored
      The LAN95xx driver has just been amended to auto-detect whether the
      _nopm variant of usbnet_read_cmd() / usbnet_write_cmd() shall be used.
      
      Drop all the now unnecessary open coding of that distinction.
      Signed-off-by: default avatarLukas Wunner <lukas@wunner.de>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      31472429
    • Lukas Wunner's avatar
      usbnet: smsc95xx: Fix deadlock on runtime resume · 7b960c96
      Lukas Wunner authored
      Commit 05b35e7e ("smsc95xx: add phylib support") amended
      smsc95xx_resume() to call phy_init_hw().  That function waits for the
      device to runtime resume even though it is placed in the runtime resume
      path, causing a deadlock.
      
      The problem is that phy_init_hw() calls down to smsc95xx_mdiobus_read(),
      which never uses the _nopm variant of usbnet_read_cmd().
      
      Commit b4df480f ("usbnet: smsc95xx: add reset_resume function with
      reset operation") causes a similar deadlock on resume if the device was
      already runtime suspended when entering system sleep:
      
      That's because the commit introduced smsc95xx_reset_resume(), which
      calls down to smsc95xx_reset(), which neglects to use _nopm accessors.
      
      Fix by auto-detecting whether a device access is performed by the
      suspend/resume task_struct and use the _nopm variant if so.  This works
      because the PM core guarantees that suspend/resume callbacks are run in
      task context.
      
      Stacktrace for posterity:
      
        INFO: task kworker/2:1:49 blocked for more than 122 seconds.
        Workqueue: usb_hub_wq hub_event
        schedule
        rpm_resume
        __pm_runtime_resume
        usb_autopm_get_interface
        usbnet_read_cmd
        __smsc95xx_read_reg
        __smsc95xx_phy_wait_not_busy
        __smsc95xx_mdio_read
        smsc95xx_mdiobus_read
        __mdiobus_read
        mdiobus_read
        smsc_phy_reset
        phy_init_hw
        smsc95xx_resume
        usb_resume_interface
        usb_resume_both
        usb_runtime_resume
        __rpm_callback
        rpm_callback
        rpm_resume
        __pm_runtime_resume
        usb_autoresume_device
        hub_event
        process_one_work
      
      Fixes: b4df480f ("usbnet: smsc95xx: add reset_resume function with reset operation")
      Signed-off-by: default avatarLukas Wunner <lukas@wunner.de>
      Cc: stable@vger.kernel.org # v3.16+
      Cc: Andre Edich <andre.edich@microchip.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      7b960c96
    • Kurt Kanzenbach's avatar
      net: phy: broadcom: Add support for BCM53128 internal PHYs · 39bfb3c1
      Kurt Kanzenbach authored
      Add support for BCM53128 internal PHYs. These support interrupts as well as
      statistics. Therefore, enable the Broadcom PHY driver for them.
      
      Tested on BCM53128 switch using the mainline b53 DSA driver.
      Signed-off-by: Kurt Kanzenbach's avatarKurt Kanzenbach <kurt@linutronix.de>
      Reviewed-by: default avatarFlorian Fainelli <f.fainelli@gmail.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      39bfb3c1
    • Clément Léger's avatar
      dt-bindings: net: dsa: renesas,rzn1-a5psw: add interrupts description · 326569cc
      Clément Léger authored
      Describe the switch interrupts (dlr, switch, prp, hub, pattern) which
      are connected to the GIC.
      Signed-off-by: default avatarClément Léger <clement.leger@bootlin.com>
      Reviewed-by: default avatarRob Herring <robh@kernel.org>
      Reviewed-by: default avatarGeert Uytterhoeven <geert+renesas@glider.be>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      326569cc
    • Casper Andersson's avatar
      selftest: net: bridge mdb add/del entry to port that is down · 0d153dd2
      Casper Andersson authored
      Tests that permanent mdb entries can be added/deleted on ports with state down.
      Signed-off-by: default avatarCasper Andersson <casper.casan@gmail.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      0d153dd2
    • XueBing Chen's avatar
      net: ipconfig: use strscpy to replace strlcpy · 634b215b
      XueBing Chen authored
      The strlcpy should not be used because it doesn't limit the source
      length. Preferred is strscpy.
      Signed-off-by: default avatarXueBing Chen <chenxuebing@jari.cn>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      634b215b
    • David S. Miller's avatar
      Merge branch 'mlxsw-unified-bridge-conversion-part-6' · 798661c7
      David S. Miller authored
      Ido Schimmel says:
      
      ====================
      mlxsw: Unified bridge conversion - part 6/6
      
      This is the sixth and final part of the conversion of mlxsw to the
      unified bridge model. It transitions the last bits of functionality that
      were under firmware's responsibility in the legacy model to the driver.
      The last patches flip the driver to the unified bridge model and clean
      up code that was used to make the conversion easier to review.
      
      Patchset overview:
      
      Patch #1 sets the egress VID for known unicast packets. For multicast
      packets, the egress VID is configured using the MPE table. See commit
      8c2da081 ("mlxsw: spectrum_fid: Configure egress VID classification
      for multicast").
      
      Patch #2 configures the VNI to FID classification that is used during
      decapsulation.
      
      Patch #3 configures ingress router interface (RIF) in FID classification
      records, so that when a packet reaches the router block, its ingress RIF
      is known. Care is taken to configure this in all the different flows
      (e.g., RIF set on a FID, {Port, VID} joins a FID that already has a RIF
      etc.).
      
      Patch #4 configures the egress VID for routed packets. For such packets,
      the egress VID is not set by the MPE table or by an FDB record at the
      egress bridge, but instead by a dedicated table that maps {Egress RIF,
      Egress port} to a VID.
      
      Patch #5 removes VID configuration from RIF creation as in the unified
      bridge model firmware no longer needs it.
      
      Patch #6 sets the egress FID to use in RIF configuration so that the
      device knows using which FID to bridge the packet after routing.
      
      Patches #7-#9 add a new 802.1Q family and associated VLAN RIFs. In the
      unified bridge model, we no longer need to emulate 802.1Q FIDs using
      802.1D FIDs as VNI can be associated with both.
      
      Patches #10-#11 finally flip the driver to the unified bridge model.
      
      Patches #12-#13 clean up code that was used to make the conversion
      easier to review.
      
      v2:
      * Fix build failure [1] in patch #1.
      
      [1] https://lore.kernel.org/netdev/20220630201709.6e66a1bb@kernel.org/
      ====================
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      798661c7
    • Amit Cohen's avatar
      mlxsw: spectrum_fid: Remove '_ub_' indication from structures and defines · 88840d69
      Amit Cohen authored
      Some structures and defines were added with '_ub_' indication, as there
      were equivalent objects for the legacy model.
      
      Now when the legacy model is not used anymore, remove the '_ub_'
      indication.
      Signed-off-by: default avatarAmit Cohen <amcohen@nvidia.com>
      Reviewed-by: default avatarPetr Machata <petrm@nvidia.com>
      Signed-off-by: default avatarIdo Schimmel <idosch@nvidia.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      88840d69
    • Amit Cohen's avatar
      mlxsw: spectrum_fid: Remove flood_index() from FID operation structure · 8928fd47
      Amit Cohen authored
      The flood_index() function is not needed anymore, as in the unified
      bridge model the flood index is calculated using 'mid_base' and
      'fid_offset'.
      
      Remove this function.
      Signed-off-by: default avatarAmit Cohen <amcohen@nvidia.com>
      Reviewed-by: default avatarPetr Machata <petrm@nvidia.com>
      Signed-off-by: default avatarIdo Schimmel <idosch@nvidia.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      8928fd47
    • Amit Cohen's avatar
      mlxsw: Enable unified bridge model · 77b7f83d
      Amit Cohen authored
      After all the preparations for unified bridge model, finally flip mlxsw
      driver to use the new model.
      
      Change config profile, set 'ubridge' to true and remove the configurations
      that are relevant only for the legacy model. Set 'flood_mode' to
      'controlled' as the current mode is not supported with unified bridge
      model.
      
      Remove all the code which is dedicated to the legacy model. Remove
      'struct mlxsw_sp.ubridge' variable which was temporarily added to separate
      configurations between the models.
      Signed-off-by: default avatarAmit Cohen <amcohen@nvidia.com>
      Reviewed-by: default avatarPetr Machata <petrm@nvidia.com>
      Signed-off-by: default avatarIdo Schimmel <idosch@nvidia.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      77b7f83d
    • Amit Cohen's avatar
      mlxsw: Add ubridge to config profile · e9cf8990
      Amit Cohen authored
      The unified bridge model is enabled via the CONFIG_PROFILE command
      during driver initialization. Add the definition of the relevant fields
      to the command's payload in preparation for unified bridge enablement.
      Signed-off-by: default avatarAmit Cohen <amcohen@nvidia.com>
      Reviewed-by: default avatarPetr Machata <petrm@nvidia.com>
      Signed-off-by: default avatarIdo Schimmel <idosch@nvidia.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      e9cf8990
    • Amit Cohen's avatar
      mlxsw: Add support for 802.1Q FID family · bf73904f
      Amit Cohen authored
      Using the legacy bridge model, there is no VID classification at egress
      for 802.1Q FIDs, which means that the VID is maintained.
      
      This behavior cause the limitation that 802.1Q FIDs cannot work with VXLAN.
      This limitation stems from the fact that a decapsulated VXLAN packet should
      not contain a VLAN tag. If such a packet was to egress from a local port
      using a 802.1Q FID, it would "maintain" its VLAN on egress, which is no
      VLAN at all.
      
      Currently 802.1Q FIDs are emulated in mlxsw driver using 802.1D FIDs. Using
      unified bridge model, there is a FID->VID mapping, so it is possible to
      stop emulating 802.1Q FIDs.
      
      The main changes are:
      1. Use 'SFGC.bridge_type' = 0, to separate between 802.1Q FIDs and
         802.1D FIDs.
      2. Use VLAN RIF instead of the emulated one (VLAN_EMU which is emulated
         using FID RIF).
      3. Create VID->FID mapping when the FID is created. Then when a new port
         is mapped to the FID, if it not in virtual mode, no new mapping is
         needed. Save the new port in 'port_vid_list', to be able to update a
         RIF in all {Port, VID}->FID mappings in case that the port will be in
         virtual mode later.
      4. Add a dedicated operation function per FID family to update RIF for
         VID->FID mappings. For 802.1d and rFID families, just return. For
         802.1q family, handle the global mapping which is created for new 802.1q
         FID.
      Signed-off-by: default avatarAmit Cohen <amcohen@nvidia.com>
      Reviewed-by: default avatarPetr Machata <petrm@nvidia.com>
      Signed-off-by: default avatarIdo Schimmel <idosch@nvidia.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      bf73904f
    • Amit Cohen's avatar
      mlxsw: Add new FID families for unified bridge model · d4324e31
      Amit Cohen authored
      In the unified bridge model, mlxsw will no longer emulate 802.1Q FIDs
      using 802.1D FIDs. The new FID table will look as follows:
      
           +---------------+
           | 802.1q FIDs   | 4K entries
           | [1..4094]     |
           +---------------+
           | 802.1d FIDs   | 1K entries
           | [4095..5118]  |
           +---------------+
           | Dummy FIDs    | 1 entry
           | [5119..5119]  |
           +---------------+
           | rFIDs         | 11K entries
           | [5120..16383] |
           +---------------+
      
      In order to make the change easier to review, four new temporary FID
      families will be added (e.g., MLXSW_SP_FID_TYPE_8021D_UB) and will not
      be registered with the FID core until mlxsw is flipped to use the unified
      bridge model.
      
      Add .1d, rfid and dummy FID families for unified bridge, the next patch
      will add .1q family separately as it requires more changes.
      
      The following changes are required:
      1. Add 'smpe_index_valid' field to 'struct mlxsw_sp_fid_family' and set
         SFMR.smpe accordingly. SMPE index is reserved for rFIDs, as their
         flooding is handled by firmware, and always reserved in Spectrum-1,
         as it is configured as part of PGT table.
      
      2. Add 'ubridge' field to 'struct mlxsw_sp_fid_family'. This field will
         be removed later, use it in mlxsw_sp_fid_family_{register,unregister}()
         to skip the registration / unregistration of the new families when the
         legacy model is used.
      
      3. Indexes - the start and end indexes of each FID family will need to be
         changed according to the above diagram.
      
      4. Add flood tables for unified bridge model, use 'fid_offset' as table
         type, as in the new model the access to flood tables will be using
         'fid_offset' calculation.
      
      5. FID family operation changes:
         a. rFID supposed to be created using SFMR, as it is not created by
            firmware using unified bridge model.
         b. port_vid_map() should perform SVFA for rFID, as the mapping is not
            created by firmware using unified bridge model.
         c. flood_index() is not aligned to the new model, as this function will
            be removed later.
      Signed-off-by: default avatarAmit Cohen <amcohen@nvidia.com>
      Reviewed-by: default avatarPetr Machata <petrm@nvidia.com>
      Signed-off-by: default avatarIdo Schimmel <idosch@nvidia.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      d4324e31
    • Amit Cohen's avatar
      mlxsw: Add support for VLAN RIFs · 662761d8
      Amit Cohen authored
      Router interfaces (RIFs) constructed on top of VLAN-aware bridges are of
      'VLAN' type, whereas RIFs constructed on top of VLAN-unaware bridges are of
      'FID' type.
      
      Currently 802.1Q FIDs are emulated using 802.1D FIDs, therefore VLAN RIFs
      are emulated using FID RIFs. As part of converting the driver to use
      unified bridge model, 802.1Q FIDs and VLAN RIFs will be used.
      
      The egress FID is required for VLAN RIFs in Spectrum-2 and above, but not
      in Spectrum-1, as in Spectrum-1 the mapping for VLAN RIFs is VID->FID,
      while in other ASICs it is FID->FID. The reason for the change is that it
      is more scalable to reuse the FID->FID entry than creating multiple
      {Port, VID}->FID entries for the router port. Use the existing operation
      structure to separate the configuration between different ASICs.
      
      Add support for VLAN RIFs, most of the configurations are same to FID
      RIFs.
      Signed-off-by: default avatarAmit Cohen <amcohen@nvidia.com>
      Reviewed-by: default avatarPetr Machata <petrm@nvidia.com>
      Signed-off-by: default avatarIdo Schimmel <idosch@nvidia.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      662761d8
    • Amit Cohen's avatar
      mlxsw: Configure egress FID classification after routing · 058de325
      Amit Cohen authored
      After routing, a packet needs to perform an L2 lookup using the DMAC it got
      from the routing and a FID. In unified bridge model, the egress FID
      configuration needs to be performed by software.
      
      It is configured by RITR for both sub-port RIFs and FID RIFs. Currently
      FID RIFs already configure eFID. Add eFID configuration for sub-port RIFs.
      Signed-off-by: default avatarAmit Cohen <amcohen@nvidia.com>
      Reviewed-by: default avatarPetr Machata <petrm@nvidia.com>
      Signed-off-by: default avatarIdo Schimmel <idosch@nvidia.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      058de325
    • Amit Cohen's avatar
      mlxsw: spectrum_router: Do not configure VID for sub-port RIFs · 2c3ae763
      Amit Cohen authored
      The field 'vid' in RITR is reserved when unified bridge model is used
      and the RIF's type is sub-port RIF. Instead, ingress VID is configured via
      SVFA and egress VID is configured via REIV.
      
      Set 'vid' to zero in RITR register for sub-port RIF when unified bridge
      model is used.
      Signed-off-by: default avatarAmit Cohen <amcohen@nvidia.com>
      Reviewed-by: default avatarPetr Machata <petrm@nvidia.com>
      Signed-off-by: default avatarIdo Schimmel <idosch@nvidia.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      2c3ae763
    • Amit Cohen's avatar
      mlxsw: spectrum_fid: Configure layer 3 egress VID classification · d4b464d2
      Amit Cohen authored
      After routing, the device always consults a table that determines the
      packet's egress VID based on {egress RIF, egress local port}. In the
      unified bridge model, it is up to software to maintain this table via REIV
      register.
      
      The table needs to be updated in the following flows:
      1. When a RIF is set on a FID, need to iterate over the FID's {Port, VID}
         list and issue REIV write to map the {RIF, Port} to the given VID.
      2. When a {Port, VID} is mapped to a FID and the FID already has a RIF,
         need to issue REIV write with a single record to map the {RIF, Port}
         to the given VID.
      
      REIV register supports a simultaneous update of 256 ports, so use this
      capability for the first flow.
      
      Handle the two above mentioned flows.
      
      Add mlxsw_sp_fid_evid_map() function to handle egress VID classification
      for both unicast and multicast. Layer 2 multicast configuration is already
      done in the driver, just move it to the new function.
      Signed-off-by: default avatarAmit Cohen <amcohen@nvidia.com>
      Reviewed-by: default avatarPetr Machata <petrm@nvidia.com>
      Signed-off-by: default avatarIdo Schimmel <idosch@nvidia.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      d4b464d2
    • Amit Cohen's avatar
      mlxsw: Configure ingress RIF classification · fea20547
      Amit Cohen authored
      Before layer 2 forwarding, the device classifies an incoming packet to
      a FID. The classification is done based on one of the following keys:
      
      1. FID
      2. VNI (after decapsulation)
      3. VID / {Port, VID}
      
      After classification, the FID is known, but also all the attributes of
      the FID, such as the router interface (RIF) via which a packet that
      needs to be routed will ingress the router block.
      
      In the legacy model, when a RIF was created / destroyed, it was
      firmware's responsibility to update it in the previously mentioned FID
      classification records. In the unified bridge model, this responsibility
      moved to software.
      
      The third classification requires to iterate over the FID's {Port, VID}
      list and issue SVFA write with the correct mapping table according to the
      port's mode (virtual or not). We never map multiple VLANs to the same FID
      using VID->FID mapping, so such a mapping needs to be performed once.
      
      When a new FID classification entry is configured and the FID already has
      a RIF, set the RIF as part of SVFA configuration.
      
      The reverse needs to be done when clearing a RIF from a FID. Currently,
      clearing is done by issuing mlxsw_sp_fid_rif_set() with a NULL RIF pointer.
      Instead, introduce mlxsw_sp_fid_rif_unset().
      
      Note that mlxsw_sp_fid_rif_set() is called after the RIF is fully
      operational, so it conforms to the internal requirement regarding
      SVFA.irif_v: "Must not be set for a non-enabled RIF".
      
      Do not set the ingress RIF for rFIDs, as the {Port, VID}->rFID entry is
      configured by firmware when legacy model is used, a next patch will
      handle this configuration for rFIDs and unified bridge model.
      Signed-off-by: default avatarAmit Cohen <amcohen@nvidia.com>
      Reviewed-by: default avatarPetr Machata <petrm@nvidia.com>
      Signed-off-by: default avatarIdo Schimmel <idosch@nvidia.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      fea20547
    • Amit Cohen's avatar
      mlxsw: spectrum_fid: Configure VNI to FID classification · 8cfc7f77
      Amit Cohen authored
      In the new model, SFMR no longer configures both VNI->FID and FID->VNI
      classifications, but only the later. The former needs to be configured via
      SVFA.
      
      Add SVFA configuration as part of vni_set() and vni_clear().
      Signed-off-by: default avatarAmit Cohen <amcohen@nvidia.com>
      Reviewed-by: default avatarPetr Machata <petrm@nvidia.com>
      Signed-off-by: default avatarIdo Schimmel <idosch@nvidia.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      8cfc7f77
    • Amit Cohen's avatar
      mlxsw: Configure egress VID for unicast FDB entries · 53d7ae53
      Amit Cohen authored
      Using unified bridge model, firmware no longer configures the egress VID
      "under the hood" and moves this responsibility to software.
      
      For layer 2, this means that software needs to determine the egress VID
      for both unicast (i.e., FDB) and multicast (i.e., MDB and flooding) flows.
      
      Unicast FDB records and unicast LAG FDB records have new fields - "set_vid"
      and "vid", set them. For records which point to router port, do not set
      these fields.
      Signed-off-by: default avatarAmit Cohen <amcohen@nvidia.com>
      Reviewed-by: default avatarPetr Machata <petrm@nvidia.com>
      Signed-off-by: default avatarIdo Schimmel <idosch@nvidia.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      53d7ae53
  3. 03 Jul, 2022 12 commits
    • Li kunyu's avatar
      net: usb: Remove unnecessary '0' values from hasdata · d0bf1fe6
      Li kunyu authored
      hasdata does not need to be initialized to zero. It will be assigned a
      value in the following judgment conditions.
      Signed-off-by: default avatarLi kunyu <kunyu@nfschina.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      d0bf1fe6
    • David S. Miller's avatar
      Merge tag 'linux-can-next-for-5.20-20220703' of... · a48e789d
      David S. Miller authored
      Merge tag 'linux-can-next-for-5.20-20220703' of git://git.kernel.org/pub/scm/linux/kernel/git/mkl/linux-can-next
      
      Marc Kleine-Budde says:
      
      ====================
      pull-request: can-next 2022-07-03
      
      this is a pull request of 15 patches for net-next/master.
      
      The first 2 patches are by Max Staudt and add the can327 serial CAN
      driver along with a new line discipline ID.
      
      The next patch is by me an fixes a typo in the ctucanfd driver.
      
      The last 12 patches are by Dario Binacchi and integrate slcan CAN
      serial driver better into the existing CAN driver API.
      ====================
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      a48e789d
    • David S. Miller's avatar
      Merge tag 'mlx5-updates-2022-06-29' of git://git.kernel.org/pub/scm/linux/kernel/git/saeed/linux · c67289e0
      David S. Miller authored
      mlx5-updates-2022-06-29
      
      Chris Mi Says:
      ==============
      Remove dependency between sriov and eswitch mode
      
      Currently, there are three eswitch modes, none, legacy and
      switchdev. None is the default mode. And when disabling sriov,
      current eswitch mode will be changed to none. This patchset
      removes eswitch mode none and also removes dependency between
      sriov and eswitch mode. With this patchset, there are two
      behavior changes:
      
      Original behavior
      -----------------
       - When driver is loaded without sriov enabled, none is the default
         mode. But actually eswitch mode should be either legacy or
         switchdev, so devlink will return unsupported when showing
         eswitch mode.
       - When disabling sriov in either legacy or switchdev mode, eswitch
         mode will be changed to none.
      
      New behavior
      ------------
       - When driver is loaded, legacy will be the default mode.
       - When disabling sriov in either legacy or switchdev mode, eswitch
         mode will not be changed.
      
      Jianbo Liu Says:
      ================
      Add support offloading police action
      
      This patchset supports offloading police action by flow meter ASO
      object in hardware.
      
      The first part is to add interfaces to create and destroy flow meter
      ASO object, and modify meter parameters by ACCESS_ASO WQE. As multiple
      objects are created at a time, and two meters are in one object,
      bitmaps are used manage these meters in one creation.
      
      Then the police action can be mapped to a meter by the action index.
      After mlx5e tc action refactoring was merged and post_act table was
      added, a simple tc flow with one police action is broken down into two
      rules in hardware. One rule with the original match in the original
      table, which performs a metadata rewrite and do metering, then jumps
      to post_meter table. The second rule is placed in the post_act table
      with all the actions left.
      
      The rules in post_meter table match on the meter outcome. If the
      outcome is GREEN, we merely jump back to the post_act table for
      further processing. Otherwise, the outcome is RED, and we drop the
      packet.
      
      The last part is to support flow meter ASO object in sw steering.
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      c67289e0
    • Marc Kleine-Budde's avatar
      Merge branch 'can-slcan-extend-supported-features' · 0ebd5529
      Marc Kleine-Budde authored
      Dario Binacchi says:
      ====================
      This series originated as a result of CAN communication tests for an
      application using the USBtin adapter (https://www.fischl.de/usbtin/).
      The tests showed some errors but for the driver everything was ok.
      Also, being the first time I used the slcan driver, I was amazed that
      it was not possible to configure the bitrate via the ip tool.
      For these two reasons, I started looking at the driver code and realized
      that it didn't use the CAN network device driver interface.
      
      Starting from these assumptions, I tried to:
      - Use the CAN network device driver interface.
      - Set the bitrate via the ip tool.
      - Send the open/close command to the adapter from the driver.
      - Add ethtool support to reset the adapter errors.
      - Extend the protocol to forward the adapter CAN communication
        errors and the CAN state changes to the netdev upper layers.
      
      Except for the protocol extension patches (i. e. forward the adapter CAN
      communication errors and the CAN state changes to the netdev upper
      layers), the whole series has been tested under QEMU with Linux 4.19.208
      using the USBtin adapter.
      Testing the extension protocol patches requires updating the adapter
      firmware. Before modifying the firmware I think it makes sense to know if
      these extensions can be considered useful.
      
      Before applying the series I used these commands:
      
      slcan_attach -f -s6 -o /dev/ttyACM0
      slcand ttyACM0 can0
      ip link set can0 up
      
      After applying the series I am using these commands:
      
      slcan_attach /dev/ttyACM0
      slcand ttyACM0 can0
      ip link set dev can0 down
      ip link set can0 type can bitrate 500000
      ethtool --set-priv-flags can0 err-rst-on-open on
      ip link set dev can0 up
      
      Now there is a clearer separation between serial line and CAN,
      but above all, it is possible to use the ip and ethtool commands
      as it happens for any CAN device driver. The changes are backward
      compatible, you can continue to use the slcand and slcan_attach
      command options.
      
      Changes in v5:
      - Update the commit message.
      - Restore the use of rtnl_lock() and rtnl_unlock().
      
      Changes in v4:
      - Move the patch in front of the patch "[v3,04/13] can: slcan: use CAN network device driver API".
      - Add the CAN_BITRATE_UNSET (0) and CAN_BITRATE_UNKNOWN (-1U) macros.
      - Simplify the bitrate check to dump it.
      - Update the commit description.
      - Update the commit description.
      - Use the CAN_BITRATE_UNKNOWN macro.
      - Use kfree_skb() instead of can_put_echo_skb() in the slc_xmit().
      - Remove the `if (slcan_devs)' check in the slc_dealloc().
      - Replace `sl->tty == NULL' with `!sl->tty'.
      - Use CAN_BITRATE_UNSET (0) and CAN_BITRATE_UNKNOWN (-1U) macros.
      - Don't reset the bitrate in ndo_stop() if it has been configured.
      - Squashed to the patch [v3,09/13] can: slcan: send the close command to the adapter.
      - Use the CAN_BITRATE_UNKNOWN macro.
      - Add description of slc_bump_err() function.
      - Remove check for the 'e' character at the beggining of the function.
        It was already checked by the caller function.
      - Protect decoding against the case the len value is longer than the
        received data.
      - Some small changes to make the decoding more readable.
      - Increment all the error counters at the end of the function.
      - Add description of slc_bump_state() function.
      - Remove check for the 's' character at the beggining of the function.
        It was already checked by the caller function.
      - Protect decoding against the case the frame len is longer than the
        received data (add SLC_STATE_FRAME_LEN macro).
      - Set cf to NULL in case of alloc_can_err_skb() failure.
      - Some small changes to make the decoding more readable.
      - Use the character 'b' instead of 'f' for bus-off state.
      
      Changes in v3:
      - Increment the error counter in case of decoding failure.
      - Replace (-1) with (-1U) in the commit description.
      - Update the commit description.
      - Remove the slc_do_set_bittiming().
      - Set the bitrate in the ndo_open().
      - Replace -1UL with -1U in setting a fake value for the bitrate.
      - Drop the patch "can: slcan: simplify the device de-allocation".
      - Add the patch "can: netlink: dump bitrate 0 if can_priv::bittiming.bitrate is -1U".
      
      Changes in v2:
      - Put the data into the allocated skb directly instead of first
        filling the "cf" on the stack and then doing a memcpy().
      - Move CAN_SLCAN Kconfig option inside CAN_DEV scope.
      - Improve the commit message.
      - Use the CAN framework support for setting fixed bit rates.
      - Improve the commit message.
      - Protect decoding against the case the len value is longer than the
        received data.
      - Continue error handling even if no skb can be allocated.
      - Continue error handling even if no skb can be allocated.
      ====================
      
      Link: https://lore.kernel.org/all/20220628163137.413025-1-dario.binacchi@amarulasolutions.com/Signed-off-by: default avatarMarc Kleine-Budde <mkl@pengutronix.de>
      0ebd5529
    • Dario Binacchi's avatar
      can: slcan: extend the protocol with CAN state info · 0a9cdcf0
      Dario Binacchi authored
      It extends the protocol to receive the adapter CAN state changes
      (warning, busoff, etc.) and forward them to the netdev upper levels.
      
      Link: https://lore.kernel.org/all/20220628163137.413025-13-dario.binacchi@amarulasolutions.comSigned-off-by: default avatarDario Binacchi <dario.binacchi@amarulasolutions.com>
      Signed-off-by: default avatarMarc Kleine-Budde <mkl@pengutronix.de>
      0a9cdcf0
    • Dario Binacchi's avatar
      can: slcan: extend the protocol with error info · b32ff466
      Dario Binacchi authored
      It extends the protocol to receive the adapter CAN communication errors
      and forward them to the netdev upper levels.
      
      Link: https://lore.kernel.org/all/20220628163137.413025-12-dario.binacchi@amarulasolutions.comSigned-off-by: default avatarDario Binacchi <dario.binacchi@amarulasolutions.com>
      Signed-off-by: default avatarMarc Kleine-Budde <mkl@pengutronix.de>
      b32ff466
    • Dario Binacchi's avatar
      can: slcan: add ethtool support to reset adapter errors · 4de0e8ef
      Dario Binacchi authored
      This patch adds a private flag to the slcan driver to switch the
      "err-rst-on-open" setting on and off.
      
      "err-rst-on-open" on  - Reset error states on opening command
      
      "err-rst-on-open" off - Don't reset error states on opening command
                              (default)
      
      The setting can only be changed if the interface is down:
      
          ip link set dev can0 down
          ethtool --set-priv-flags can0 err-rst-on-open {off|on}
          ip link set dev can0 up
      
      Link: https://lore.kernel.org/all/20220628163137.413025-11-dario.binacchi@amarulasolutions.comSigned-off-by: default avatarDario Binacchi <dario.binacchi@amarulasolutions.com>
      Signed-off-by: default avatarMarc Kleine-Budde <mkl@pengutronix.de>
      4de0e8ef
    • Dario Binacchi's avatar
      can: slcan: move driver into separate sub directory · 98b12064
      Dario Binacchi authored
      This patch moves the slcan driver into a separate directory, a later
      patch will add more files.
      
      Link: https://lore.kernel.org/all/20220628163137.413025-10-dario.binacchi@amarulasolutions.comSigned-off-by: default avatarDario Binacchi <dario.binacchi@amarulasolutions.com>
      Signed-off-by: default avatarMarc Kleine-Budde <mkl@pengutronix.de>
      98b12064
    • Dario Binacchi's avatar
      can: slcan: send the open/close commands to the adapter · 5bac315b
      Dario Binacchi authored
      In case the bitrate has been set via ip tool, this patch changes the
      driver to send the open ("O\r") and close ("C\r) commands to the
      adapter.
      
      Link: https://lore.kernel.org/all/20220628163137.413025-9-dario.binacchi@amarulasolutions.comSigned-off-by: default avatarDario Binacchi <dario.binacchi@amarulasolutions.com>
      Tested-by: default avatarJeroen Hofstee <jhofstee@victronenergy.com>
      Signed-off-by: default avatarMarc Kleine-Budde <mkl@pengutronix.de>
      5bac315b
    • Dario Binacchi's avatar
      can: slcan: set bitrate by CAN device driver API · dca79629
      Dario Binacchi authored
      It allows to set the bitrate via ip tool, as it happens for the other
      CAN device drivers. It still remains possible to set the bitrate via
      slcand or slcan_attach utilities. In case the ip tool is used, the
      driver will send the serial command to the adapter.
      
      Link: https://lore.kernel.org/all/20220628163137.413025-8-dario.binacchi@amarulasolutions.comSigned-off-by: default avatarDario Binacchi <dario.binacchi@amarulasolutions.com>
      Tested-by: default avatarJeroen Hofstee <jhofstee@victronenergy.com>
      Signed-off-by: default avatarMarc Kleine-Budde <mkl@pengutronix.de>
      dca79629
    • Dario Binacchi's avatar
      can: slcan: allow to send commands to the adapter · 52f9ac85
      Dario Binacchi authored
      This is a preparation patch for the upcoming support to change the
      bitrate via ip tool, reset the adapter error states via the ethtool API
      and, more generally, send commands to the adapter.
      
      Since the close command (i. e. "C\r") will be sent in the ndo_stop()
      where netif_running() returns false, a new flag bit (i. e. SLF_XCMD) for
      serial transmission has to be added.
      
      Link: https://lore.kernel.org/all/20220628163137.413025-7-dario.binacchi@amarulasolutions.comSigned-off-by: default avatarDario Binacchi <dario.binacchi@amarulasolutions.com>
      Tested-by: default avatarJeroen Hofstee <jhofstee@victronenergy.com>
      Signed-off-by: default avatarMarc Kleine-Budde <mkl@pengutronix.de>
      52f9ac85
    • Dario Binacchi's avatar
      can: slcan: use CAN network device driver API · c4e54b06
      Dario Binacchi authored
      As suggested by commit [1], now the driver uses the functions and the
      data structures provided by the CAN network device driver interface.
      
      Currently the driver doesn't implement a way to set bitrate for SLCAN
      based devices via ip tool, so you'll have to do this by slcand or
      slcan_attach invocation through the -sX parameter:
      
      - slcan_attach -f -s6 -o /dev/ttyACM0
      - slcand -f -s8 -o /dev/ttyUSB0
      
      where -s6 in will set adapter's bitrate to 500 Kbit/s and -s8 to
      1Mbit/s.
      See the table below for further CAN bitrates:
      - s0 ->   10 Kbit/s
      - s1 ->   20 Kbit/s
      - s2 ->   50 Kbit/s
      - s3 ->  100 Kbit/s
      - s4 ->  125 Kbit/s
      - s5 ->  250 Kbit/s
      - s6 ->  500 Kbit/s
      - s7 ->  800 Kbit/s
      - s8 -> 1000 Kbit/s
      
      In doing so, the struct can_priv::bittiming.bitrate of the driver is not
      set and since the open_candev() checks that the bitrate has been set, it
      must be a non-zero value, the bitrate is set to a fake value (-1U)
      before it is called.
      
      Using the rtnl_lock()/rtnl_unlock() functions has become a bit more
      tricky as the register_candev() function indirectly calls rtnl_lock()
      via register_netdev(). To avoid a deadlock it is therefore necessary to
      call rtnl_unlock() before calling register_candev(). The same goes for
      the unregister_candev() function.
      
      [1] commit 39549eef ("can: CAN Network device driver and Netlink interface")
      
      Link: https://lore.kernel.org/all/20220628163137.413025-6-dario.binacchi@amarulasolutions.comSigned-off-by: default avatarDario Binacchi <dario.binacchi@amarulasolutions.com>
      Tested-by: default avatarJeroen Hofstee <jhofstee@victronenergy.com>
      Signed-off-by: default avatarMarc Kleine-Budde <mkl@pengutronix.de>
      c4e54b06