1. 12 5月, 2022 8 次提交
    • P
      net: enetc: count the tc-taprio window drops · 285e8ded
      Po Liu 提交于
      The enetc scheduler for IEEE 802.1Qbv has 2 options (depending on
      PTGCR[TG_DROP_DISABLE]) when we attempt to send an oversized packet
      which will never fit in its allotted time slot for its traffic class:
      either block the entire port due to head-of-line blocking, or drop the
      packet and set a bit in the writeback format of the transmit buffer
      descriptor, allowing other packets to be sent.
      
      We obviously choose the second option in the driver, but we do not
      detect the drop condition, so from the perspective of the network stack,
      the packet is sent and no error counter is incremented.
      
      This change checks the writeback of the TX BD when tc-taprio is enabled,
      and increments a specific ethtool statistics counter and a generic
      "tx_dropped" counter in ndo_get_stats64.
      Signed-off-by: NPo Liu <Po.Liu@nxp.com>
      Signed-off-by: NVladimir Oltean <vladimir.oltean@nxp.com>
      Reviewed-by: NClaudiu Manoil <claudiu.manoil@nxp.com>
      Signed-off-by: NJakub Kicinski <kuba@kernel.org>
      285e8ded
    • V
      net: enetc: manage ENETC_F_QBV in priv->active_offloads only when enabled · 32bf8e1f
      Vladimir Oltean 提交于
      Future work in this driver would like to look at priv->active_offloads &
      ENETC_F_QBV to determine whether a tc-taprio qdisc offload was
      installed, but this does not produce the intended effect.
      
      All the other flags in priv->active_offloads are managed dynamically,
      except ENETC_F_QBV which is set statically based on the probed SI capability.
      
      This change makes priv->active_offloads & ENETC_F_QBV really track the
      presence of a tc-taprio schedule on the port.
      
      Some existing users, like the enetc_sched_speed_set() call from
      phylink_mac_link_up(), are best kept using the old logic: the tc-taprio
      offload does not re-trigger another link mode resolve, so the scheduler
      needs to be functional from the get go, as long as Qbv is supported at
      all on the port. So to preserve functionality there, look at the static
      station interface capability from pf->si->hw_features instead.
      Signed-off-by: NVladimir Oltean <vladimir.oltean@nxp.com>
      Reviewed-by: NClaudiu Manoil <claudiu.manoil@nxp.com>
      Signed-off-by: NJakub Kicinski <kuba@kernel.org>
      32bf8e1f
    • J
      Merge branch 'macb-napi-improvements' · d7722973
      Jakub Kicinski 提交于
      Robert Hancock says:
      
      ====================
      MACB NAPI improvements
      
      Simplify the logic in the Cadence MACB/GEM driver for determining
      when to reschedule NAPI processing, and update it to use NAPI for the
      TX path as well as the RX path.
      
      Changes since v1: Changed to use separate TX and RX NAPI instances and
      poll functions to avoid unnecessary checks of the other ring (TX/RX)
      states during polling and to use budget handling for both RX and TX.
      Fixed locking to protect against concurrent access to TX ring on
      TX transmit and TX poll paths.
      ====================
      
      Link: https://lore.kernel.org/r/20220509194635.3094080-1-robert.hancock@calian.comSigned-off-by: NJakub Kicinski <kuba@kernel.org>
      d7722973
    • R
      net: macb: use NAPI for TX completion path · 138badbc
      Robert Hancock 提交于
      This driver was using the TX IRQ handler to perform all TX completion
      tasks. Under heavy TX network load, this can cause significant irqs-off
      latencies (found to be in the hundreds of microseconds using ftrace).
      This can cause other issues, such as overrunning serial UART FIFOs when
      using high baud rates with limited UART FIFO sizes.
      
      Switch to using a NAPI poll handler to perform the TX completion work
      to get this out of hard IRQ context and avoid the IRQ latency impact. A
      separate NAPI instance is used for TX and RX to avoid checking the other
      ring's state unnecessarily when doing the poll, and so that the NAPI
      budget handling can work for both TX and RX packets.
      
      A new per-queue tx_ptr_lock spinlock has been added to avoid using the
      main device lock (with IRQs needing to be disabled) across the entire TX
      mapping operation, and also to protect the TX queue pointers from
      concurrent access between the TX start and TX poll operations.
      
      The TX Used Bit Read interrupt (TXUBR) handling also needs to be moved into
      the TX NAPI poll handler to maintain the proper order of operations. A flag
      is used to notify the poll handler that a UBR condition needs to be
      handled. The macb_tx_restart handler has had some locking added for global
      register access, since this could now potentially happen concurrently on
      different queues.
      Signed-off-by: NRobert Hancock <robert.hancock@calian.com>
      Signed-off-by: NJakub Kicinski <kuba@kernel.org>
      138badbc
    • R
      net: macb: simplify/cleanup NAPI reschedule checking · 1900e30d
      Robert Hancock 提交于
      Previously the macb_poll method was checking the RSR register after
      completing its RX receive work to see if additional packets had been
      received since IRQs were disabled, since this controller does not
      maintain the pending IRQ status across IRQ disable. It also had to
      double-check the register after re-enabling IRQs to detect if packets
      were received after the first check but before IRQs were enabled.
      
      Using the RSR register for this purpose is problematic since it reflects
      the global device state rather than the per-queue state, so if packets
      are being received on multiple queues it may end up retriggering receive
      on a queue where the packets did not actually arrive and not on the one
      where they did arrive. This will also cause problems with an upcoming
      change to use NAPI for the TX path where use of multiple queues is more
      likely.
      
      Add a macb_rx_pending function to check the RX ring to see if more
      packets have arrived in the queue, and use that to check if NAPI should
      be rescheduled rather than the RSR register. By doing this, we can just
      ignore the global RSR register entirely, and thus save some extra device
      register accesses at the same time.
      
      This also makes the previous first check for pending packets rather
      redundant, since it would be checking the RX ring state which was just
      checked in the receive work function. Therefore we can get rid of it and
      just check after enabling interrupts whether packets are already
      pending.
      Signed-off-by: NRobert Hancock <robert.hancock@calian.com>
      Signed-off-by: NJakub Kicinski <kuba@kernel.org>
      1900e30d
    • V
      net: dsa: ocelot: accept 1000base-X for VSC9959 and VSC9953 · 11ecf341
      Vladimir Oltean 提交于
      Switches using the Lynx PCS driver support 1000base-X optical SFP
      modules. Accept this interface type on a port.
      Signed-off-by: NVladimir Oltean <vladimir.oltean@nxp.com>
      Link: https://lore.kernel.org/r/20220510164320.10313-1-vladimir.oltean@nxp.comSigned-off-by: NJakub Kicinski <kuba@kernel.org>
      11ecf341
    • V
      selftests: forwarding: tc_actions: allow mirred egress test to run on non-offloaded h2 · b57c7e8b
      Vladimir Oltean 提交于
      The host interfaces $h1 and $h2 don't have to be switchdev interfaces,
      but due to the fact that we pass $tcflags which may have the value of
      "skip_sw", we force $h2 to offload a drop rule for dst_ip, something
      which it may not be able to do.
      
      The selftest only wants to verify the hit count of this rule as a means
      of figuring out whether the packet was received, so remove the $tcflags
      for it and let it be done in software.
      Signed-off-by: NVladimir Oltean <vladimir.oltean@nxp.com>
      Reviewed-by: NIdo Schimmel <idosch@nvidia.com>
      Tested-by: NIdo Schimmel <idosch@nvidia.com>
      Link: https://lore.kernel.org/r/20220510220904.284552-1-vladimir.oltean@nxp.comSigned-off-by: NJakub Kicinski <kuba@kernel.org>
      b57c7e8b
    • J
      Merge branch '1GbE' of git://git.kernel.org/pub/scm/linux/kernel/git/tnguy/next-queue · ddae9bc4
      Jakub Kicinski 提交于
      Tony Nguyen says:
      
      ====================
      1GbE Intel Wired LAN Driver Updates 2022-05-10
      
      This series contains updates to igc driver only.
      
      Sasha cleans up the code by removing an unused function and removing an
      enum for PHY type as there is only one PHY. The return type for
      igc_check_downshift() is changed to void as it always returns success.
      
      * '1GbE' of git://git.kernel.org/pub/scm/linux/kernel/git/tnguy/next-queue:
        igc: Change type of the 'igc_check_downshift' method
        igc: Remove unused phy_type enum
        igc: Remove igc_set_spd_dplx method
      ====================
      
      Link: https://lore.kernel.org/r/20220510210656.2168393-1-anthony.l.nguyen@intel.comSigned-off-by: NJakub Kicinski <kuba@kernel.org>
      ddae9bc4
  2. 11 5月, 2022 32 次提交