1. 10 Jun, 2021 40 commits
    • Tan Zhongjun's avatar
      soc: qcom: ipa: Remove superfluous error message around platform_get_irq() · 950fd045
      Tan Zhongjun authored
      The platform_get_irq() prints error message telling that interrupt is
      missing,hence there is no need to duplicated that message in the
      drivers.
      Signed-off-by: default avatarTan Zhongjun <tanzhongjun@yulong.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      950fd045
    • Baokun Li's avatar
      dccp: tfrc: fix doc warnings in tfrc_equation.c · cb8e2e43
      Baokun Li authored
      Add description for `tfrc_invert_loss_event_rate` to fix the W=1 warnings:
      
       net/dccp/ccids/lib/tfrc_equation.c:695: warning: Function parameter or
        member 'loss_event_rate' not described in 'tfrc_invert_loss_event_rate'
      Signed-off-by: default avatarBaokun Li <libaokun1@huawei.com>
      Reviewed-by: default avatarRichard Sailer <richard_siegfried@systemli.org>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      cb8e2e43
    • Wang Hai's avatar
      atm: Use list_for_each_entry() to simplify code in resources.c · 73e42909
      Wang Hai authored
      Convert list_for_each() to list_for_each_entry() where
      applicable. This simplifies the code.
      Reported-by: default avatarHulk Robot <hulkci@huawei.com>
      Signed-off-by: default avatarWang Hai <wanghai38@huawei.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      73e42909
    • Wang Hai's avatar
      ibmvnic: Use list_for_each_entry() to simplify code in ibmvnic.c · 3e98ae00
      Wang Hai authored
      Convert list_for_each() to list_for_each_entry() where
      applicable. This simplifies the code.
      Reported-by: default avatarHulk Robot <hulkci@huawei.com>
      Signed-off-by: default avatarWang Hai <wanghai38@huawei.com>
      Acked-by: default avatarLijun Pan <lijunp213@gmail.com>
      Reviewed-by: default avatarDany Madden <drt@linux.ibm.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      3e98ae00
    • Wang Hai's avatar
      net: x25: Use list_for_each_entry() to simplify code in x25_route.c · bc831fac
      Wang Hai authored
      Convert list_for_each() to list_for_each_entry() where
      applicable. This simplifies the code.
      Reported-by: default avatarHulk Robot <hulkci@huawei.com>
      Signed-off-by: default avatarWang Hai <wanghai38@huawei.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      bc831fac
    • Yang Yingliang's avatar
      mt76: mt7615: Use devm_platform_get_and_ioremap_resource() · 9e2b7b04
      Yang Yingliang authored
      Use devm_platform_get_and_ioremap_resource() to simplify
      code.
      Signed-off-by: default avatarYang Yingliang <yangyingliang@huawei.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      9e2b7b04
    • Yang Yingliang's avatar
      net: mido: mdio-mux-bcm-iproc: Use devm_platform_get_and_ioremap_resource() · 8a55a734
      Yang Yingliang authored
      Use devm_platform_get_and_ioremap_resource() to simplify
      code and avoid a null-ptr-deref by checking 'res' in it.
      Signed-off-by: default avatarYang Yingliang <yangyingliang@huawei.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      8a55a734
    • Wong Vee Khee's avatar
      net: stmmac: Fix mixed enum type warning · 1f7096f0
      Wong Vee Khee authored
      The commit 5a558611 ("net: stmmac: support FPE link partner
      hand-shaking procedure") introduced the following coverity warning:
      
        "Parse warning (PW.MIXED_ENUM_TYPE)"
        "1. mixed_enum_type: enumerated type mixed with another type"
      
      This is due to both "lo_state" and "lp_sate" which their datatype are
      enum stmmac_fpe_state type, and being assigned with "FPE_EVENT_UNKNOWN"
      which is a macro-defined of 0. Fixed this by assigned both these
      variables with the correct enum value.
      
      Fixes: 5a558611 ("net: stmmac: support FPE link partner hand-shaking procedure")
      Signed-off-by: default avatarWong Vee Khee <vee.khee.wong@linux.intel.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      1f7096f0
    • Yang Yingliang's avatar
      fjes: check return value after calling platform_get_resource() · f18c1181
      Yang Yingliang authored
      It will cause null-ptr-deref if platform_get_resource() returns NULL,
      we need check the return value.
      Signed-off-by: default avatarYang Yingliang <yangyingliang@huawei.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      f18c1181
    • Yang Yingliang's avatar
      net: axienet: Use devm_platform_get_and_ioremap_resource() · 47651c51
      Yang Yingliang authored
      Use devm_platform_get_and_ioremap_resource() to simplify
      code.
      Signed-off-by: default avatarYang Yingliang <yangyingliang@huawei.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      47651c51
    • Yang Yingliang's avatar
      net: w5100: Use devm_platform_get_and_ioremap_resource() · 0b462d01
      Yang Yingliang authored
      Use devm_platform_get_and_ioremap_resource() to simplify
      code.
      Signed-off-by: default avatarYang Yingliang <yangyingliang@huawei.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      0b462d01
    • David S. Miller's avatar
      Merge branch 'ixp4xxx_hss-cleanups' · d2ca24ee
      David S. Miller authored
      Peng Li says:
      
      ====================
      net: ixp4xx_hss: clean up some code style issues
      
      This patchset clean up some code style issues.
      ====================
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      d2ca24ee
    • Peng Li's avatar
      net: ixp4xx_hss: add braces {} to all arms of the statement · e0bd2764
      Peng Li authored
      Braces {} should be used on all arms of this statement.
      Signed-off-by: default avatarPeng Li <lipeng321@huawei.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      e0bd2764
    • Peng Li's avatar
      net: ixp4xx_hss: fix the comments style issue · 17ce9764
      Peng Li authored
      Networking block comments don't use an empty /* line,
      use /* Comment...
      
      Block comments use * on subsequent lines.
      Block comments use a trailing */ on a separate line.
      
      This patch fixes the comments style issues.
      Signed-off-by: default avatarPeng Li <lipeng321@huawei.com>
      Signed-off-by: default avatarGuangbin Huang <huangguangbin2@huawei.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      17ce9764
    • Peng Li's avatar
      net: ixp4xx_hss: remove redundant spaces · 137d5672
      Peng Li authored
      According to the chackpatch.pl,
      space prohibited after that open parenthesis '('.
      Signed-off-by: default avatarPeng Li <lipeng321@huawei.com>
      Signed-off-by: default avatarGuangbin Huang <huangguangbin2@huawei.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      137d5672
    • Peng Li's avatar
      net: ixp4xx_hss: add some required spaces · dee01456
      Peng Li authored
      Add space required before the open parenthesis '('.
      Add space required after that close brace '}'.
      Signed-off-by: default avatarPeng Li <lipeng321@huawei.com>
      Signed-off-by: default avatarGuangbin Huang <huangguangbin2@huawei.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      dee01456
    • Peng Li's avatar
      net: ixp4xx_hss: move out assignment in if condition · 99ebe65e
      Peng Li authored
      Should not use assignment in if condition.
      Signed-off-by: default avatarPeng Li <lipeng321@huawei.com>
      Signed-off-by: default avatarGuangbin Huang <huangguangbin2@huawei.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      99ebe65e
    • Peng Li's avatar
      net: ixp4xx_hss: fix the code style issue about "foo* bar" · 6487fab0
      Peng Li authored
      Fix the checkpatch error as "foo* bar" and should be "foo *bar",
      and "(foo*)" should be "(foo *)".
      Signed-off-by: default avatarPeng Li <lipeng321@huawei.com>
      Signed-off-by: default avatarGuangbin Huang <huangguangbin2@huawei.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      6487fab0
    • Peng Li's avatar
      net: ixp4xx_hss: add blank line after declarations · 6f2016ed
      Peng Li authored
      This patch fixes the checkpatch error about missing a blank line
      after declarations.
      Signed-off-by: default avatarPeng Li <lipeng321@huawei.com>
      Signed-off-by: default avatarGuangbin Huang <huangguangbin2@huawei.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      6f2016ed
    • Peng Li's avatar
      net: ixp4xx_hss: remove redundant blank lines · 5c32fdbb
      Peng Li authored
      This patch removes some redundant blank lines.
      Signed-off-by: default avatarPeng Li <lipeng321@huawei.com>
      Signed-off-by: default avatarGuangbin Huang <huangguangbin2@huawei.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      5c32fdbb
    • gushengxian's avatar
      tipc:subscr.c: fix a spelling mistake · f1dcdc07
      gushengxian authored
      Fix a spelling mistake.
      Signed-off-by: default avatargushengxian <gushengxian@yulong.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      f1dcdc07
    • gushengxian's avatar
      tipc: socket.c: fix the use of copular verb · 326af505
      gushengxian authored
      Fix the use of copular verb.
      Signed-off-by: default avatargushengxian <gushengxian@yulong.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      326af505
    • gushengxian's avatar
      node.c: fix the use of indefinite article · 15139bcb
      gushengxian authored
      Fix the use of indefinite article.
      Signed-off-by: default avatargushengxian <gushengxian@yulong.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      15139bcb
    • gushengxian's avatar
      af_unix: remove the repeated word "and" · 4e03d073
      gushengxian authored
      Remove the repeated word "and".
      Signed-off-by: default avatargushengxian <gushengxian@yulong.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      4e03d073
    • gushengxian's avatar
      vsock/vmci: remove the repeated word "be" · 26855150
      gushengxian authored
      Remove the repeated word "be".
      Signed-off-by: default avatargushengxian <gushengxian@yulong.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      26855150
    • David S. Miller's avatar
      Merge tag 'mlx5-updates-2021-06-09' of git://git.kernel.org/pub/scm/linux/kernel/git/saeed/linux · 2027e13f
      David S. Miller authored
      Saeed Mahameed says:
      
      ====================
      mlx5-updates-2021-06-09
      
      Introduce steering header insert/remove and switchdev bridge offloads
      
      1) From Yevgeny, Steering header insert/remove support
      
      ConnectX supports offloading of various encapsulations and decapsulations
      (e.g. VXLAN), which are performed by 'Packet Reformat' action.
      Starting with ConnectX-6 DX, a new reformat type is supported - INSERT_HEADER.
      This reformat allows inserting an arbitrary size buffer at a selected location
      in the packet on RX flows.
      
      The insert/remove header support are needed as a prerequisite for the
      bridge offloads vlan pop/push supprt, see below.
      
      2) From Vlad, Support for bridge offloads for switchdev mode
      
      This change implements bridge offloads with VLAN-support that works on top
      of mlx5 representors in switchdev mode.
      
      HIGH-LEVEL OVERVIEW
      
      Hardware supported by mlx5 driver doesn't provide dynamic learning or aging
      functionality and requires the driver to emulate all switch-like behavior
      in software. As such, all packets by default go through miss path, appear
      on representor and get to software bridge, if it is the upper device of the
      representor. This causes bridge to process packet in software, learn the
      MAC address to FDB and send SWITCHDEV_FDB_ADD_TO_DEVICE event to all
      subscribers. Upon reception of SWITCHDEV_FDB_ADD_TO_DEVICE notification
      mlx5 bridge offloads the FDB to hardware and sends back
      SWITCHDEV_FDB_ADD_TO_BRIDGE notification to prevent such entries from being
      aged out by kernel bridge. Leaving aging to kernel bridge would result
      deletion of offloaded dynamic FDB entries every aging_time period due to
      packets being processed by hardware and, consecutively, 'used' timestamp
      for FDB entry not being updated. Hardware aging is emulated in driver by
      running periodic workqueue task that manually updates the rules according
      to their hardware counter:
      
      - If hardware counter has changed since last update, the handler updates
      'used' timestamp in kernel bridge dynamic entry by sending
      SWITCHDEV_FDB_ADD_TO_BRIDGE notification for the entry.
      
      - If FDB entry wasn't updated for user-controllable aging_time period,
      then the FDB entry is unoffloaded from hardware and corresponding
      SWITCHDEV_FDB_DEL_TO_BRIDGE notification is sent to kernel bridge.
      
      The mlx5 bridge offload implementation fully supports port VLAN objects,
      including PVID (vlan push) and "Egress Untagged" (vlan pop).
      
      SOFTWARE ARCHITECTURE
      
      Mlx5_eswitch is extended with pointer to new mlx5_esw_bridge_offloads
      structure which has a linked list of mlx5_esw_bridge objects. Struct
      mlx5_esw_bridge is the main switch object in mlx5 that holds all data for
      offloaded FDB entries and metadata for bridge ports and their vlans. The
      mlx5_esw_bridge object is created when first representor of eswitch vport
      is added to bridge and deleted when the last representor is detached from
      it. Bridge FDB entries are saved in linked list (to iterate over all FDB
      entries in aging workqueue task) and also in hashtable for quick lookup by
      MAC+VLAN tuple. Bridge FDB entries are saved in linked list (to iterate
      over all FDB entries in aging workqueue task) and in hashtable for quick
      lookup by MAC+VLAN tuple. Port metadata is stored in struct
      mlx5_esw_bridge_port that is saved in xarray to allow quick lookup by vport
      number. Part of the port metadata is the set of port vlans that are
      represented by mlx5_esw_bridge_vlan structure. The vlan structure points to
      all FDBs on vlan/port via fdb_list linked list.
      
      Simplified diagram of mlx5 bridge objects:
      
                            +------------------+
                            |  mxl5_eswitch    |
                            |                  |
                            |  br_offloads     |
                            +--------+---------+
                                     |
                            +--------v-------------------+
                            |  mlx5_esw_bridge_offloads  |
                            |                            |
                         +-->  bridges                   |
                         |  +-------+--------------------+
                         |          |
                         |          |
                         |      +---v---------------+
                         |      | mlx5_esw_bridge   |
                         |      |                   |
                         |      | vports            |
                         |      |                   |
                         |      | fdb_ht            |
                         |      +---+---------------+
                         |          |
                         |      +---v---------------+
                         +------+ mlx5_esw_bridge   |
                                |                   |
      +-------------------------+ vports            |
      |                         |                   |
      |                         | fdb_ht            +------------------------------------------+
      |                         +-------------------+                                          |
      |                                                                                        |
      |                                                                                        |
      | +----------------------+                                 +---------------------------+ |
      +-> mlx5_esw_bridge_port |                              +--> mlx5_esw_bridge_fdb_entry <-+
      | |                      |    +----------------------+  |  +--+------------------------+ |
      | | vlans                +--+-> mlx5_esw_bridge_vlan |  |     |                          |
      | |                      |  | |                      |  |  +--v------------------------+ |
      | +----------------------+  | | fdb_list             +--+  | mlx5_esw_bridge_fdb_entry <-+
      |                           | +-------^--------------+     +--+------------------------+ |
      | +----------------------+  |         |                       |                          |
      +-> mlx5_esw_bridge_port |  |         +-----------------------+                          |
        |                      |  |                                                            |
        | vlans                |  | -----------------------+                                   |
        |                      |  +-> mlx5_esw_bridge_vlan |                                   |
        +----------------------+    |                      |     +---------------------------+ |
                                    | fdb_list             +-----> mlx5_esw_bridge_fdb_entry <-+
                                    +-------^--------------+     +--+------------------------+
                                            |                       |
                                            +-----------------------+
      
      HARDWARE REPRESENTATION
      
      In order to adhere to kernel software datapath model bridge offloads must
      come after TC and NF FDBs. However, since netfilter offload in mlx5 is
      implemented with unmanaged tables, its miss path is not automatically
      connected to next priority and requires the code to manually connect with
      slow table. To keep bridge offloads encapsulated and not mix it with
      eswitch offloads new FDB_TC_MISS priority is created between FDB_FT_OFFLOAD
      and FDB_SLOW_PATH which allows bridge offloads to be created without
      exposing its internal tables to any other modules since miss path of
      managed TC-miss table is automatically wired to next priority.
      
      The bridge tables are created with new priority FDB_BR_OFFLOAD in FDB
      namespace. The new priority is between tc-miss and slow path priorities.
      Priority consist of two levels: the ingress table that is global per
      eswitch and matches incoming packets by src_mac/vid and redirects them to
      next level (egress table) that is chosen according to ingress port bridge
      membership and matches on dst_mac/vid in order to redirect packet to vport
      according to the following diagram:
      
                      +
                      |
            +---------v----------+
            |                    |
            |   FDB_TC_OFFLOAD   |
            |                    |
            +---------+----------+
                      |
                      |
            +---------v----------+
            |                    |
            |   FDB_FT_OFFLOAD   |
            |                    |
            +---------+----------+
                      |
                      |
            +---------v----------+
            |                    |
            |    FDB_TC_MISS     |
            |                    |
            +---------+----------+
                      |
      +--------------------------------------+
      |               |                      |
      |        +------+                      |
      |        |                             |
      | +------v--------+   FDB_BR_OFFLOAD   |
      | | INGRESS_TABLE |                    |
      | +------+---+----+                    |
      |        |   |      match              |
      |        |   +---------+               |
      |        |             |               |    +-------+
      |        |     +-------v-------+ match |    |       |
      |        |     | EGRESS_TABLE  +------------> vport |
      |        |     +-------+-------+       |    |       |
      |        |             |               |    +-------+
      |        |    miss     |               |
      |        +------+------+               |
      |               |                      |
      +--------------------------------------+
                      |
                      |
            +---------v----------+
            |                    |
            |   FDB_SLOW_PATH    |
            |                    |
            +---------+----------+
                      |
                      v
      
      PATCHES OVERVIEW
      
      1-3 - Miscellaneous refactorings and infrastructure changes.
      
      4 - Mlx5 bridge offload infrastructure and dedicated fs_core
      namespace/tables implementation.
      
      5 - FDB entry offload.
      
      6 - Dynamic FDB entry aging.
      
      7-10 - VLAN filtering offload.
      
      11 - Tracepoints for main mlx5 bridge offload events (FDB entry
      offload/unoffload, VLAN add/delete, etc.)
      ====================
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      
      --
      2027e13f
    • Yang Yingliang's avatar
      net: davinci_emac: Use devm_platform_get_and_ioremap_resource() · 06990739
      Yang Yingliang authored
      Use devm_platform_get_and_ioremap_resource() to simplify
      code and avoid a null-ptr-deref by checking 'res' in it.
      Signed-off-by: default avatarYang Yingliang <yangyingliang@huawei.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      06990739
    • Yang Yingliang's avatar
      net: ethernet: ti: cpsw: Use devm_platform_get_and_ioremap_resource() · aced6d37
      Yang Yingliang authored
      Use devm_platform_get_and_ioremap_resource() to simplify
      code.
      Signed-off-by: default avatarYang Yingliang <yangyingliang@huawei.com>
      Reviewed-by: default avatarGrygorii Strashko <grygorii.strashko@ti.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      aced6d37
    • Wong Vee Khee's avatar
      net: phy: probe for C45 PHYs that return PHY ID of zero in C22 space · b040aab7
      Wong Vee Khee authored
      PHY devices such as the Marvell Alaska 88E2110 does not return a valid
      PHY ID when probed using Clause-22. The current implementation treats
      PHY ID of zero as a non-error and valid PHY ID, and causing the PHY
      device failed to bind to the Marvell driver.
      
      For such devices, we do an additional probe in the Clause-45 space,
      if a valid PHY ID is returned, we then proceed to attach the PHY
      device to the matching PHY ID driver.
      Signed-off-by: default avatarWong Vee Khee <vee.khee.wong@linux.intel.com>
      Reviewed-by: default avatarAndrew Lunn <andrew@lunn.ch>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      b040aab7
    • Chen Li's avatar
      netlink: simplify NLMSG_DATA with NLMSG_HDRLEN · d409989b
      Chen Li authored
      The NLMSG_LENGTH(0) may confuse the API users,
      NLMSG_HDRLEN is much more clear.
      
      Besides, some code style problems are also fixed.
      Signed-off-by: default avatarChen Li <chenli@uniontech.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      d409989b
    • Vlad Buslov's avatar
      net/mlx5: Bridge, add tracepoints · 9724fd5d
      Vlad Buslov authored
      Move private bridge structures to dedicated headers that is accessible to
      bridge tracepoint header. Implemented following tracepoints:
      
      - Initialize FDB entry.
      - Refresh FDB entry.
      - Cleanup FDB entry.
      - Create VLAN.
      - Cleanup VLAN.
      - Attach port to bridge.
      - Detach port from bridge.
      
      Usage example:
      
      ># cd /sys/kernel/debug/tracing
      ># echo mlx5:mlx5_esw_bridge_fdb_entry_init >> set_event
      ># cat trace
      ...
         kworker/u20:1-96      [001] ....   231.892503: mlx5_esw_bridge_fdb_entry_init: net_device=enp8s0f0_0 addr=e4:fd:05:08:00:02 vid=3 flags=0 lastuse=4294895695
      Signed-off-by: default avatarVlad Buslov <vladbu@nvidia.com>
      Reviewed-by: default avatarJianbo Liu <jianbol@nvidia.com>
      Signed-off-by: default avatarSaeed Mahameed <saeedm@nvidia.com>
      9724fd5d
    • Vlad Buslov's avatar
      net/mlx5: Bridge, filter tagged packets that didn't match tagged fg · cc2987c4
      Vlad Buslov authored
      With support for pvid vlans in mlx5 bridge it is possible to have rules in
      untagged flow group when vlan filtering is enabled. However, such rules can
      also match tagged packets that didn't match anything in tagged flow group.
      Filter such packets by introducing additional flow group between tagged and
      untagged groups. When filtering is enabled on the bridge create additional
      flow in vlan filtering flow group and matches tagged packets with specified
      source MAC address and redirects them to new "skip" table. The skip table
      is new lowest-level empty table that is used to skip all further processing
      on packet in bridge priority.
      Signed-off-by: default avatarVlad Buslov <vladbu@nvidia.com>
      Reviewed-by: default avatarJianbo Liu <jianbol@nvidia.com>
      Signed-off-by: default avatarSaeed Mahameed <saeedm@nvidia.com>
      cc2987c4
    • Vlad Buslov's avatar
      net/mlx5: Bridge, support pvid and untagged vlan configurations · 36e55079
      Vlad Buslov authored
      Implement support for pushing vlan header into untagged packet on ingress
      of port that has pvid configured and support for popping vlan on egress of
      port that has the matching vlan configured as untagged. To support such
      configurations packet reformat contexts of {INSERT|REMOVE}_HEADER types are
      created per such vlan and saved to struct mlx5_esw_bridge_vlan which allows
      all FDB entries on particular vlan to share single packet reformat
      instance. When initializing FDB entries with pvid or untagged vlan type set
      its mlx5_flow_act->pkt_reformat action accordingly.
      
      Flush all flows when removing vlan from port. This is necessary because
      even though software bridge removes all FDB entries before removing their
      vlan, mlx5 bridge implementation deletes their corresponding flow entries
      from hardware in asynchronous workqueue task, which will cause firmware
      error if vlan packet reformat context is deleted before all flows that
      point to it.
      Signed-off-by: default avatarVlad Buslov <vladbu@nvidia.com>
      Reviewed-by: default avatarJianbo Liu <jianbol@nvidia.com>
      Signed-off-by: default avatarSaeed Mahameed <saeedm@nvidia.com>
      36e55079
    • Vlad Buslov's avatar
      net/mlx5: Bridge, match FDB entry vlan tag · ffc89ee5
      Vlad Buslov authored
      Add support for FDB vlan-tagged entries. Extend ingress and egress flow
      tables with flow groups to match packet vlan tag. Modify the flow creation
      code to include vlan tag, if vlan is configured on port and vlan
      configuration is supported for offload.
      Signed-off-by: default avatarVlad Buslov <vladbu@nvidia.com>
      Reviewed-by: default avatarJianbo Liu <jianbol@nvidia.com>
      Signed-off-by: default avatarSaeed Mahameed <saeedm@nvidia.com>
      ffc89ee5
    • Vlad Buslov's avatar
      net/mlx5: Bridge, implement infrastructure for vlans · d75b9e80
      Vlad Buslov authored
      Establish all the necessary infrastructure for implementing vlan matching
      and vlan push/pop in following patches:
      
      - Add new per-vport struct mlx5_esw_bridge_port that is used to store
      metadata for all port vlans. Initialize and cleanup the instance of the
      structure when port representor is linked/unliked to bridge. Use xarray to
      allow quick vport metadata lookup by vport number.
      
      - Add new per-port-vlan struct mlx5_esw_bridge_vlan that is used to store
      vlan-specific data (vid, flags). Handle SWITCHDEV_PORT_OBJ_{ADD|DEL}
      switchdev blocking event for SWITCHDEV_OBJ_ID_PORT_VLAN object by
      creating/deleting the vlan structure and saving it in per-vport xarray for
      quick lookup.
      
      - Implement support for SWITCHDEV_ATTR_ID_BRIDGE_VLAN_FILTERING object
      attribute that is used to toggle vlan filtering. Remove all FDB entries
      from hardware when vlan filtering state is changed.
      Signed-off-by: default avatarVlad Buslov <vladbu@nvidia.com>
      Reviewed-by: default avatarJianbo Liu <jianbol@nvidia.com>
      Signed-off-by: default avatarSaeed Mahameed <saeedm@nvidia.com>
      d75b9e80
    • Vlad Buslov's avatar
      net/mlx5: Bridge, dynamic entry ageing · c636a0f0
      Vlad Buslov authored
      Dynamic FDB entries require capability to age out unused entries. Such
      entries are either aged out by kernel software bridge implementation or by
      hardware switch that offloaded them (and notified the kernel to mark them
      as SWITCHDEV_FDB_ADD_TO_BRIDGE). Leaving ageing to kernel bridge would
      result it deleting offloaded dynamic FDB entries every ageing_time period
      due to packets being processed by hardware and, consecutively, 'used'
      timestamp for FDB entry not being updated. However, since hardware doesn't
      support ageing, software solution inside the driver is required.
      
      In order to emulate hardware ageing in driver, extend bridge FDB ingress
      flows with counter and create delayed br_offloads->update_work task on
      bridge offloads workqueue. Run the task every second, update 'used'
      timestamp in software bridge dynamic entry by sending
      SWITCHDEV_FDB_ADD_TO_BRIDGE for the entry, if it flow hardware counter
      lastuse field was changed since last update. If lastuse wasn't changed for
      ageing_time period, then delete the FDB entry and notify kernel bridge by
      sending SWITCHDEV_FDB_DEL_TO_BRIDGE notification.
      
      Register blocking switchdev notifier callback and handle attribute set
      SWITCHDEV_ATTR_ID_BRIDGE_AGEING_TIME event to allow user to dynamically
      configure bridge FDB entry ageing timeout. Save the value per-bridge in
      struct mlx5_esw_bridge. Silently ignore
      SWITCHDEV_ATTR_ID_PORT_{PRE_}BRIDGE_FLAGS switchdev event since mlx5 bridge
      implementation relies on software bridge for implementing necessary
      behavior for all of these flags.
      Signed-off-by: default avatarVlad Buslov <vladbu@nvidia.com>
      Reviewed-by: default avatarJianbo Liu <jianbol@nvidia.com>
      Signed-off-by: default avatarSaeed Mahameed <saeedm@nvidia.com>
      c636a0f0
    • Vlad Buslov's avatar
      net/mlx5: Bridge, handle FDB events · 7cd6a54a
      Vlad Buslov authored
      Hardware supported by mlx5 driver doesn't provide learning and requires the
      driver to emulate all switch-like behavior in software. As such, all
      packets by default go through miss path, appear on representor and get to
      software bridge, if it is the upper device of the representor. This causes
      bridge to process packet in software, learn the MAC address to FDB and send
      SWITCHDEV_FDB_ADD_TO_DEVICE event to all subscribers.
      
      In order to offload FDB entries in mlx5, register switchdev notifier
      callback and implement support for both 'added_by_user' and dynamic FDB
      entry SWITCHDEV_FDB_ADD_TO_DEVICE events asynchronously using new
      mlx5_esw_bridge_offloads->wq ordered workqueue. In workqueue callback
      offload the ingress rule (matching FDB entry MAC as packet source MAC) and
      egress table rule (matching FDB entry MAC as destination MAC). For ingress
      table rule also match source vport to ensure that only traffic coming from
      expected bridge port is matched by offloaded rule. Save all the relevant
      FDB entry data in struct mlx5_esw_bridge_fdb_entry instance and insert the
      instance in new mlx5_esw_bridge->fdb_list list (for traversing all entries
      by software ageing implementation in following patch) and in new
      mlx5_esw_bridge->fdb_ht hash table for fast retrieval. Notify the bridge
      that FDB entry has been offloaded by sending SWITCHDEV_FDB_OFFLOADED
      notification.
      
      Delete FDB entry on reception of SWITCHDEV_FDB_DEL_TO_DEVICE event.
      Signed-off-by: default avatarVlad Buslov <vladbu@nvidia.com>
      Reviewed-by: default avatarJianbo Liu <jianbol@nvidia.com>
      Signed-off-by: default avatarSaeed Mahameed <saeedm@nvidia.com>
      7cd6a54a
    • Vlad Buslov's avatar
      net/mlx5: Bridge, add offload infrastructure · 19e9bfa0
      Vlad Buslov authored
      Create new files bridge.{c|h} in en/rep directory that implement bridge
      interaction with representor netdevices and handle required
      events/notifications, bridge.{c|h} in esw directory that implement all
      necessary eswitch offloading infrastructure and works on vport/eswitch
      level. Provide new kconfig MLX5_BRIDGE which is automatically selected when
      both kernel bridge and mlx5 eswitch configs are enabled.
      
      Provide basic infrastructure for bridge offloads:
      
      - struct mlx5_esw_bridge_offloads - per-eswitch bridge offload structure
      that encapsulates generic bridge-offloads data (notifier blocks, ingress
      flow table/group, etc.) that is created/deleted on enable/disable eswitch
      offloads.
      
      - struct mlx5_esw_bridge - per-bridge structure that encapsulates
      per-bridge data (reference counter, FDB, egress flow table/group, etc.)
      that is created when first eswitch represetor is attached to new bridge and
      deleted when last representor is removed from the bridge as a result of
      NETDEV_CHANGEUPPER event.
      
      The bridge tables are created with new priority FDB_BR_OFFLOAD in FDB
      namespace. The new priority is between tc-miss and slow path priorities.
      Priority consist of two levels: the ingress table that is global per
      eswitch and matches incoming packets by src_mac/vid and redirects them to
      next level (egress table) that is chosen according to ingress port bridge
      membership and matches on dst_mac/vid in order to redirect packet to vport
      according to the following diagram:
      
                      +
                      |
            +---------v----------+
            |                    |
            |   FDB_TC_OFFLOAD   |
            |                    |
            +---------+----------+
                      |
                      |
            +---------v----------+
            |                    |
            |   FDB_FT_OFFLOAD   |
            |                    |
            +---------+----------+
                      |
                      |
            +---------v----------+
            |                    |
            |    FDB_TC_MISS     |
            |                    |
            +---------+----------+
                      |
      +--------------------------------------+
      |               |                      |
      |        +------+                      |
      |        |                             |
      | +------v--------+   FDB_BR_OFFLOAD   |
      | | INGRESS_TABLE |                    |
      | +------+---+----+                    |
      |        |   |      match              |
      |        |   +---------+               |
      |        |             |               |    +-------+
      |        |     +-------v-------+ match |    |       |
      |        |     | EGRESS_TABLE  +------------> vport |
      |        |     +-------+-------+       |    |       |
      |        |             |               |    +-------+
      |        |    miss     |               |
      |        +------+------+               |
      |               |                      |
      +--------------------------------------+
                      |
                      |
            +---------v----------+
            |                    |
            |   FDB_SLOW_PATH    |
            |                    |
            +---------+----------+
                      |
                      v
      Signed-off-by: default avatarVlad Buslov <vladbu@nvidia.com>
      Reviewed-by: default avatarJianbo Liu <jianbol@nvidia.com>
      Signed-off-by: default avatarSaeed Mahameed <saeedm@nvidia.com>
      19e9bfa0
    • Vlad Buslov's avatar
      net/mlx5e: Refactor mlx5e_eswitch_{*}rep() helpers · 07810152
      Vlad Buslov authored
      Change the helper to functions to accept constant pointer to struct
      net_device. This is necessary for following patches in series that pass
      mlx5e_eswitch_rep() as a callback to kernel bridge infrastructure code.
      Signed-off-by: default avatarVlad Buslov <vladbu@nvidia.com>
      Reviewed-by: default avatarJianbo Liu <jianbol@nvidia.com>
      Signed-off-by: default avatarSaeed Mahameed <saeedm@nvidia.com>
      07810152
    • Vlad Buslov's avatar
      net/mlx5: Create TC-miss priority and table · ec3be887
      Vlad Buslov authored
      In order to adhere to kernel software datapath model bridge offloads must
      come after TC and NF FDBs. Following patches in this series add new FDB
      priority for bridge after FDB_FT_OFFLOAD. However, since netfilter offload
      is implemented with unmanaged tables, its miss path is not automatically
      connected to next priority and requires the code to manually connect with
      slow table. To keep bridge offloads encapsulated and not mix it with
      eswitch offloads, create a new FDB_TC_MISS priority between FDB_FT_OFFLOAD
      and FDB_SLOW_PATH:
      
                +
                |
      +---------v----------+
      |                    |
      |   FDB_TC_OFFLOAD   |
      |                    |
      +---------+----------+
                |
                |
                |
      +---------v----------+
      |                    |
      |   FDB_FT_OFFLOAD   |
      |                    |
      +---------+----------+
                |
                |
                |
      +---------v----------+
      |                    |
      |    FDB_TC_MISS     |
      |                    |
      +---------+----------+
                |
                |
                |
      +---------v----------+
      |                    |
      |   FDB_SLOW_PATH    |
      |                    |
      +---------+----------+
                |
                v
      
      Initialize the new priority with single default empty managed table and use
      the table as TC/NF miss patch instead of slow table. This approach allows
      bridge offloads to be created as new FDB namespace priority between
      FDB_TC_MISS and FDB_SLOW_PATH without exposing its internal tables to any
      other modules since miss path of managed TC-miss table is automatically
      wired to next priority.
      Signed-off-by: default avatarVlad Buslov <vladbu@nvidia.com>
      Reviewed-by: default avatarJianbo Liu <jianbol@nvidia.com>
      Signed-off-by: default avatarSaeed Mahameed <saeedm@nvidia.com>
      ec3be887