1. 16 2月, 2022 19 次提交
  2. 15 2月, 2022 7 次提交
  3. 11 2月, 2022 14 次提交
    • D
      Merge tag 'wireless-next-2022-02-11' of... · b96a7925
      David S. Miller 提交于
      Merge tag 'wireless-next-2022-02-11' of git://git.kernel.org/pub/scm/linux/kernel/git/wireless/wireless-next
      
      wireless-next patches for v5.18
      
      First set of patches for v5.18, with both wireless and stack patches.
      rtw89 now has AP mode support and wcn36xx has survey support. But
      otherwise pretty normal.
      
      Major changes:
      
      ath11k
      
      * add LDPC FEC type in 802.11 radiotap header
      
      * enable RX PPDU stats in monitor co-exist mode
      
      wcn36xx
      
      * implement survey reporting
      
      brcmfmac
      
      * add CYW43570 PCIE device
      
      rtw88
      
      * rtw8821c: enable RFE 6 devices
      
      rtw89
      
      * AP mode support
      
      mt76
      
      * mt7916 support
      
      * background radar detection support
      b96a7925
    • D
      Merge branch 'ipv6-loopback' · c002496b
      David S. Miller 提交于
      Eric Dumazet says:
      
      ====================
      ipv6: remove addrconf reliance on loopback
      
      Second patch in this series removes IPv6 requirement about the netns
      loopback device being the last device being dismantled.
      
      This was needed because rt6_uncached_list_flush_dev()
      and ip6_dst_ifdown() had to switch dst dev to a known
      device (loopback).
      
      Instead of loopback, we can use the (hidden) blackhole_netdev
      which is also always there.
      
      This will allow future simplfications of netdev_run_to()
      and other parts of the stack like default_device_exit_batch().
      
      Last two patches are optimizations for both IP families.
      ====================
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      c002496b
    • E
      ipv4: add (struct uncached_list)->quarantine list · 29e5375d
      Eric Dumazet 提交于
      This is an optimization to keep the per-cpu lists as short as possible:
      
      Whenever rt_flush_dev() changes one rtable dst.dev
      matching the disappearing device, it can can transfer the object
      to a quarantine list, waiting for a final rt_del_uncached_list().
      Signed-off-by: NEric Dumazet <edumazet@google.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      29e5375d
    • E
      ipv6: add (struct uncached_list)->quarantine list · ba55ef81
      Eric Dumazet 提交于
      This is an optimization to keep the per-cpu lists as short as possible:
      
      Whenever rt6_uncached_list_flush_dev() changes one rt6_info
      matching the disappearing device, it can can transfer the object
      to a quarantine list, waiting for a final rt6_uncached_list_del().
      Signed-off-by: NEric Dumazet <edumazet@google.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      ba55ef81
    • E
      ipv6: give an IPv6 dev to blackhole_netdev · e5f80fcf
      Eric Dumazet 提交于
      IPv6 addrconf notifiers wants the loopback device to
      be the last device being dismantled at netns deletion.
      
      This caused many limitations and work arounds.
      
      Back in linux-5.3, Mahesh added a per host blackhole_netdev
      that can be used whenever we need to make sure objects no longer
      refer to a disappearing device.
      
      If we attach to blackhole_netdev an ip6_ptr (allocate an idev),
      then we can use this special device (which is never freed)
      in place of the loopback_dev (which can be freed).
      
      This will permit improvements in netdev_run_todo() and other parts
      of the stack where had steps to make sure loopback_dev was
      the last device to disappear.
      Signed-off-by: NEric Dumazet <edumazet@google.com>
      Cc: Mahesh Bandewar <maheshb@google.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      e5f80fcf
    • E
      ipv6: get rid of net->ipv6.rt6_stats->fib_rt_uncache · 2d4feb2c
      Eric Dumazet 提交于
      This counter has never been visible, there is little point
      trying to maintain it.
      Signed-off-by: NEric Dumazet <edumazet@google.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      2d4feb2c
    • H
      dsa: mv88e6xxx: make serdes SGMII/Fiber tx amplitude configurable · 926eae60
      Holger Brunck 提交于
      The mv88e6352, mv88e6240 and mv88e6176  have a serdes interface. This patch
      allows to configure the output swing to a desired value in the
      phy-handle of the port. The value which is peak to peak has to be
      specified in microvolts. As the chips only supports eight dedicated
      values we return EINVAL if the value in the DTS does not match one of
      these values.
      Signed-off-by: NHolger Brunck <holger.brunck@hitachienergy.com>
      Reviewed-by: NAndrew Lunn <andrew@lunn.ch>
      Reviewed-by: NMarek Behún <kabel@kernel.org>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      926eae60
    • M
      dt-bindings: phy: Add `tx-p2p-microvolt` property binding · 066c4b6b
      Marek Behún 提交于
      Common PHYs and network PCSes often have the possibility to specify
      peak-to-peak voltage on the differential pair - the default voltage
      sometimes needs to be changed for a particular board.
      
      Add properties `tx-p2p-microvolt` and `tx-p2p-microvolt-names` for this
      purpose. The second property is needed to specify the mode for the
      corresponding voltage in the `tx-p2p-microvolt` property, if the voltage
      is to be used only for speficic mode. More voltage-mode pairs can be
      specified.
      
      Example usage with only one voltage (it will be used for all supported
      PHY modes, the `tx-p2p-microvolt-names` property is not needed in this
      case):
      
        tx-p2p-microvolt = <915000>;
      
      Example usage with voltages for multiple modes:
      
        tx-p2p-microvolt = <915000>, <1100000>, <1200000>;
        tx-p2p-microvolt-names = "2500base-x", "usb", "pcie";
      
      Add these properties into a separate file phy/transmit-amplitude.yaml,
      which should be referenced by any binding that uses it.
      Signed-off-by: NMarek Behún <kabel@kernel.org>
      Reviewed-by: NRob Herring <robh@kernel.org>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      066c4b6b
    • G
      ipv6: Reject routes configurations that specify dsfield (tos) · b9605161
      Guillaume Nault 提交于
      The ->rtm_tos option is normally used to route packets based on both
      the destination address and the DS field. However it's ignored for
      IPv6 routes. Setting ->rtm_tos for IPv6 is thus invalid as the route
      is going to work only on the destination address anyway, so it won't
      behave as specified.
      Suggested-by: NToke Høiland-Jørgensen <toke@redhat.com>
      Signed-off-by: NGuillaume Nault <gnault@redhat.com>
      Reviewed-by: NDavid Ahern <dsahern@kernel.org>
      Reviewed-by: NShuah Khan <skhan@linuxfoundation.org>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      b9605161
    • D
      Merge branch 'dsa-cleanup' · 12a8f37f
      David S. Miller 提交于
      Vladimir Oltean says:
      
      ====================
      More aggressive DSA cleanup
      
      This series deletes some code which is apparently not needed.
      
      I've had these patches in my tree for a while, and testing on my boards
      didn't reveal any issues.
      
      Compared to the RFC v1 series, the only change is the addition of patch 3.
      https://patchwork.kernel.org/project/netdevbpf/cover/20220107184842.550334-1-vladimir.oltean@nxp.com/
      ====================
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      12a8f37f
    • V
      net: dsa: remove lockdep class for DSA slave address list · ddb44bdc
      Vladimir Oltean 提交于
      Since commit 2f1e8ea7 ("net: dsa: link interfaces with the DSA
      master to get rid of lockdep warnings"), suggested by Cong Wang, the
      DSA interfaces and their master have different dev->nested_level, which
      makes netif_addr_lock() stop complaining about potentially recursive
      locking on the same lock class.
      
      So we no longer need DSA slave interfaces to have their own lockdep
      class.
      
      Cc: Cong Wang <xiyou.wangcong@gmail.com>
      Signed-off-by: NVladimir Oltean <vladimir.oltean@nxp.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      ddb44bdc
    • V
      net: dsa: remove lockdep class for DSA master address list · 8db2bc79
      Vladimir Oltean 提交于
      Since commit 2f1e8ea7 ("net: dsa: link interfaces with the DSA
      master to get rid of lockdep warnings"), suggested by Cong Wang, the
      DSA interfaces and their master have different dev->nested_level, which
      makes netif_addr_lock() stop complaining about potentially recursive
      locking on the same lock class.
      
      So we no longer need DSA masters to have their own lockdep class.
      
      Cc: Cong Wang <xiyou.wangcong@gmail.com>
      Signed-off-by: NVladimir Oltean <vladimir.oltean@nxp.com>
      Reviewed-by: NFlorian Fainelli <f.fainelli@gmail.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      8db2bc79
    • V
      net: dsa: remove ndo_get_phys_port_name and ndo_get_port_parent_id · 45b987d5
      Vladimir Oltean 提交于
      There are no legacy ports, DSA registers a devlink instance with ports
      unconditionally for all switch drivers. Therefore, delete the old-style
      ndo operations used for determining bridge forwarding domains.
      Signed-off-by: NVladimir Oltean <vladimir.oltean@nxp.com>
      Reviewed-by: NFlorian Fainelli <f.fainelli@gmail.com>
      Tested-by: NFlorian Fainelli <f.fainelli@gmail.com>
      Reviewed-by: NIdo Schimmel <idosch@nvidia.com>
      Reviewed-by: NJiri Pirko <jiri@nvidia.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      45b987d5
    • D
      Merge branch 'smc-optimizations' · 1ea59b5e
      David S. Miller 提交于
      D. Wythe says:
      
      ====================
      net/smc: Optimizing performance in short-lived scenarios
      
      This patch set aims to optimizing performance of SMC in short-lived
      links scenarios, which is quite unsatisfactory right now.
      
      In our benchmark, we test it with follow scripts:
      
      ./wrk -c 10000 -t 4 -H 'Connection: Close' -d 20 http://smc-server
      
      Current performance figures like that:
      
      Running 20s test @ http://11.213.45.6
        4 threads and 10000 connections
        4956 requests in 20.06s, 3.24MB read
        Socket errors: connect 0, read 0, write 672, timeout 0
      Requests/sec:    247.07
      Transfer/sec:    165.28KB
      
      There are many reasons for this phenomenon, this patch set doesn't
      solve it all though, but it can be well alleviated with it in.
      
      Patch 1/5  (Make smc_tcp_listen_work() independent) :
      
      Separate smc_tcp_listen_work() from smc_listen_work(), make them
      independent of each other, the busy SMC handshake can not affect new TCP
      connections visit any more. Avoid discarding a large number of TCP
      connections after being overstock, which is undoubtedly raise the
      connection establishment time.
      
      Patch 2/5 (Limit SMC backlog connections):
      
      Since patch 1 has separated smc_tcp_listen_work() from
      smc_listen_work(), an unrestricted TCP accept have come into being. This
      patch try to put a limit on SMC backlog connections refers to
      implementation of TCP.
      
      Patch 3/5 (Limit SMC visits when handshake workqueue congested):
      
      Considering the complexity of SMC handshake right now, in short-lived
      links scenarios, this may not be the main scenario of SMC though, it's
      performance is still quite poor. This patch try to provide constraint on
      SMC handshake when handshake workqueue congested, which is the sign of
      SMC handshake stacking in our opinion.
      
      Patch 4/5 (Dynamic control handshake limitation by socket options)
      
      This patch allow applications dynamically control the ability of SMC
      handshake limitation. Since SMC don't support set SMC socket option
      before,
      this patch also have to support SMC's owns socket options.
      
      Patch 5/5 (Add global configure for handshake limitation by netlink)
      
      This patch provides a way to get benefit of handshake limitation
      without
      modifying any code for applications, which is quite useful for most
      existing applications.
      
      After this patch set, performance figures like that:
      
      Running 20s test @ http://11.213.45.6
        4 threads and 10000 connections
        693253 requests in 20.10s, 452.88MB read
      Requests/sec:  34488.13
      Transfer/sec:     22.53MB
      
      That's a quite well performance improvement, about to 6 to 7 times in my
      environment.
      ---
      changelog:
      v1 -> v2:
      - fix compile warning
      - fix invalid dependencies in kconfig
      v2 -> v3:
      - correct spelling mistakes
      - fix useless variable declare
      v3 -> v4
      - make smc_tcp_ls_wq be static
      v4 -> v5
      - add dynamic control for SMC auto fallback by socket options
      - add global configure for SMC auto fallback through netlink
      v5 -> v6
      - move auto fallback to net namespace scope
      - remove auto fallback attribute in SMC_GEN_SYS_INFO
      - add independent attributes for auto fallback
      v6 -> v7
      - fix wording and the naming issues, rename 'auto fallback' to handshake
        limitation.
      ====================
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      1ea59b5e