1. 27 4月, 2018 1 次提交
  2. 13 4月, 2018 1 次提交
    • R
      net: dsa: mv88e6xxx: Fix receive time stamp race condition. · 22904823
      Richard Cochran 提交于
      The DSA stack passes received PTP frames to this driver via
      mv88e6xxx_port_rxtstamp() for deferred delivery.  The driver then
      queues the frame and kicks the worker thread.  The work callback reads
      out the latched receive time stamp and then works through the queue,
      delivering any non-matching frames without a time stamp.
      
      If a new frame arrives after the worker thread has read out the time
      stamp register but enters the queue before the worker finishes
      processing the queue, that frame will be delivered without a time
      stamp.
      
      This patch fixes the race by moving the queue onto a list on the stack
      before reading out the latched time stamp value.
      
      Fixes: c6fe0ad2 ("net: dsa: mv88e6xxx: add rx/tx timestamping support")
      Signed-off-by: NRichard Cochran <richardcochran@gmail.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      22904823
  3. 04 4月, 2018 2 次提交
  4. 30 3月, 2018 2 次提交
  5. 27 3月, 2018 2 次提交
  6. 26 3月, 2018 2 次提交
  7. 23 3月, 2018 1 次提交
  8. 21 3月, 2018 3 次提交
  9. 19 3月, 2018 4 次提交
    • A
      net: dsa: mv88e6xxx: Add MDIO interrupts for internal PHYs · 6f88284f
      Andrew Lunn 提交于
      When registering an MDIO bus, it is possible to pass an array of
      interrupts, one per address on the bus. phylib will then associate the
      interrupt to the PHY device, if no other interrupt is provided.
      
      Some of the global2 interrupts are PHY interrupts. Place them into the
      MDIO bus structure.
      Signed-off-by: NAndrew Lunn <andrew@lunn.ch>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      6f88284f
    • A
      net: dsa: mv88e6xxx: Add number of internal PHYs · bc393155
      Andrew Lunn 提交于
      Add to the info structure the number of internal PHYs, if they generate
      interrupts. Some of the older generations of switches have internal
      PHYs, but no interrupt registers. In this case, set the count to zero.
      Signed-off-by: NAndrew Lunn <andrew@lunn.ch>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      bc393155
    • A
      net: dsa: mv88e6xxx: Add missing g1 IRQ numbers · adfccf11
      Andrew Lunn 提交于
      With the recent change to polling for interrupts, it is important that
      the number of global 1 interrupts is listed. Without it, the driver
      requests an interrupt domain for zero interrupts, which returns
      EINVAL, and the probe fails.
      
      Add two missing entries.
      Signed-off-by: NAndrew Lunn <andrew@lunn.ch>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      adfccf11
    • F
      net: dsa: mv88e6xxx: Fix missing register lock in serdes_get_stats · ef44d78d
      Florian Fainelli 提交于
      We can hit the register lock not held assertion with the following path:
      
      [   34.170631] mv88e6085 0.1:00: Switch registers lock not held!
      [   34.176510] CPU: 0 PID: 950 Comm: ethtool Not tainted 4.16.0-rc4 #143
      [   34.182985] Hardware name: Freescale Vybrid VF5xx/VF6xx (Device Tree)
      [   34.189519] Backtrace:
      [   34.192033] [<8010c4b4>] (dump_backtrace) from [<8010c788>] (show_stack+0x20/0x24)
      [   34.199680]  r6:9f5dc010 r5:00000011 r4:9f5dc010 r3:00000000
      [   34.205434] [<8010c768>] (show_stack) from [<80679d38>] (dump_stack+0x24/0x28)
      [   34.212719] [<80679d14>] (dump_stack) from [<804844a8>] (mv88e6xxx_read+0x70/0x7c)
      [   34.220376] [<80484438>] (mv88e6xxx_read) from [<804870dc>] (mv88e6xxx_port_get_cmode+0x34/0x4c)
      [   34.229257]  r5:a09cd128 r4:9ee31d07
      [   34.232880] [<804870a8>] (mv88e6xxx_port_get_cmode) from [<80487e6c>] (mv88e6352_port_has_serdes+0x24/0x64)
      [   34.242690]  r4:9f5dc010
      [   34.245309] [<80487e48>] (mv88e6352_port_has_serdes) from [<804880b8>] (mv88e6352_serdes_get_stats+0x28/0x12c)
      [   34.255389]  r4:00000001
      [   34.257973] [<80488090>] (mv88e6352_serdes_get_stats) from [<804811e8>] (mv88e6xxx_get_ethtool_stats+0xb0/0xc0)
      [   34.268156]  r10:00000000 r9:00000000 r8:00000000 r7:a09cd020 r6:00000001 r5:9f5dc01c
      [   34.276052]  r4:9f5dc010
      [   34.278631] [<80481138>] (mv88e6xxx_get_ethtool_stats) from [<8064f740>] (dsa_slave_get_ethtool_stats+0xbc/0xc4)
      
      mv88e6xxx_get_ethtool_stats() calls mv88e6xxx_get_stats() which calls both
      chip->info->ops->stats_get_stats(), which holds the register lock, and
      chip->info->ops->serdes_get_stats() which does not. Have
      chip->info->ops->serdes_get_stats() be running with the register lock held to
      avoid such assertions.
      
      Fixes: 436fe17d ("net: dsa: mv88e6xxx: Allow the SERDES interfaces to have statistics")
      Signed-off-by: NFlorian Fainelli <f.fainelli@gmail.com>
      Reviewed-by: NAndrew Lunn <andrew@lunn.ch>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      ef44d78d
  10. 18 3月, 2018 1 次提交
  11. 10 3月, 2018 1 次提交
  12. 08 3月, 2018 1 次提交
  13. 07 3月, 2018 1 次提交
  14. 05 3月, 2018 5 次提交
  15. 27 2月, 2018 1 次提交
    • A
      net: dsa: mv88e6xxx: Poll when no interrupt defined · 294d711e
      Andrew Lunn 提交于
      Not all boards have the interrupt output from the switch connected to
      a GPIO line. In such cases, phylib has to poll the internal PHYs,
      rather than receive an interrupt when there is a change in the link
      state. phylib polls once per second, and per PHY reads around 4
      words. With a switch typically having 4 internal PHYs, this means 16
      MDIO transactions per second.
      
      Rather than performing this phylib level polling, have the driver poll
      the interrupt status register. If the status register indicates an
      interrupt condition processing of interrupts in the same way as if a
      GPIO was used.
      
      Polling 10 times a second places less load on the MDIO bus. But rather
      than taking on average 0.5s to detect a link change, it takes less
      than 0.05s. Additionally, other interrupts, such as the watchdog, ATU
      and VTU violations will be reported.
      Signed-off-by: NAndrew Lunn <andrew@lunn.ch>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      294d711e
  16. 23 2月, 2018 2 次提交
    • A
      dsa: ptp: mark dummy helpers as 'inline' · 46182452
      Arnd Bergmann 提交于
      Declaring a static function in a header leads to a warning every
      time that header gets included without the function being used:
      
      In file included from drivers/net/dsa/mv88e6xxx/chip.c:42:
      drivers/net/dsa/mv88e6xxx/ptp.h:92:13: error: 'mv88e6xxx_hwtstamp_work' defined but not used [-Werror=unused-function]
       static long mv88e6xxx_hwtstamp_work(struct ptp_clock_info *ptp)
      In file included from drivers/net/dsa/mv88e6xxx/chip.c:38:
      drivers/net/dsa/mv88e6xxx/global2.h:355:12: error: 'mv88e6xxx_g2_wait' defined but not used [-Werror=unused-function]
       static int mv88e6xxx_g2_wait(struct mv88e6xxx_chip *chip, int reg, u16 mask)
                  ^~~~~~~~~~~~~~~~~
      drivers/net/dsa/mv88e6xxx/global2.h:350:12: error: 'mv88e6xxx_g2_update' defined but not used [-Werror=unused-function]
       static int mv88e6xxx_g2_update(struct mv88e6xxx_chip *chip, int reg, u16 update)
                  ^~~~~~~~~~~~~~~~~~~
      drivers/net/dsa/mv88e6xxx/global2.h:345:12: error: 'mv88e6xxx_g2_write' defined but not used [-Werror=unused-function]
       static int mv88e6xxx_g2_write(struct mv88e6xxx_chip *chip, int reg, u16 val)
                  ^~~~~~~~~~~~~~~~~~
      drivers/net/dsa/mv88e6xxx/global2.h:340:12: error: 'mv88e6xxx_g2_read' defined but not used [-Werror=unused-function]
       static int mv88e6xxx_g2_read(struct mv88e6xxx_chip *chip, int reg, u16 *val)
      
      This marks all such functions in dsa inline to make sure we don't warn
      about them.
      
      Fixes: c6fe0ad2 ("net: dsa: mv88e6xxx: add rx/tx timestamping support")
      Fixes: 0d632c3d ("net: dsa: mv88e6xxx: add accessors for PTP/TAI registers")
      Signed-off-by: NArnd Bergmann <arnd@arndb.de>
      Reviewed-by: NAndrew Lunn <andrew@lunn.ch>
      Acked-by: NRichard Cochran <richardcochran@gmail.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      46182452
    • A
      net: dsa: mv88e6xxx: scratch registers and external MDIO pins · 2510babc
      Andrew Lunn 提交于
      MV88E6352 and later switches support GPIO control through the "Scratch
      & Misc" global2 register. Two of the pins controlled this way on the
      mv88e6390 family are the external MDIO pins. They can either by used
      as part of the MII interface for port 0, GPIOs, or MDIO. Add a
      function to configure them for MDIO, if possible, and call it when
      registering the external MDIO bus.
      Suggested-by: NRussell King <rmk@armlinux.org.uk>
      Signed-off-by: NAndrew Lunn <andrew@lunn.ch>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      2510babc
  17. 20 2月, 2018 1 次提交
  18. 17 2月, 2018 3 次提交
  19. 15 2月, 2018 6 次提交