1. 02 2月, 2021 1 次提交
  2. 24 1月, 2021 1 次提交
  3. 21 1月, 2021 2 次提交
  4. 20 1月, 2021 1 次提交
  5. 19 1月, 2021 1 次提交
  6. 08 1月, 2021 1 次提交
  7. 07 1月, 2021 1 次提交
  8. 05 1月, 2021 2 次提交
  9. 17 12月, 2020 1 次提交
    • O
      net: dsa: qca: ar9331: fix sleeping function called from invalid context bug · 3e47495f
      Oleksij Rempel 提交于
      With lockdep enabled, we will get following warning:
      
       ar9331_switch ethernet.1:10 lan0 (uninitialized): PHY [!ahb!ethernet@1a000000!mdio!switch@10:00] driver [Qualcomm Atheros AR9331 built-in PHY] (irq=13)
       BUG: sleeping function called from invalid context at kernel/locking/mutex.c:935
       in_atomic(): 1, irqs_disabled(): 1, non_block: 0, pid: 18, name: kworker/0:1
       INFO: lockdep is turned off.
       irq event stamp: 602
       hardirqs last  enabled at (601): [<8073fde0>] _raw_spin_unlock_irq+0x3c/0x80
       hardirqs last disabled at (602): [<8073a4f4>] __schedule+0x184/0x800
       softirqs last  enabled at (0): [<80080f60>] copy_process+0x578/0x14c8
       softirqs last disabled at (0): [<00000000>] 0x0
       CPU: 0 PID: 18 Comm: kworker/0:1 Not tainted 5.10.0-rc3-ar9331-00734-g7d644991df0c #31
       Workqueue: events deferred_probe_work_func
       Stack : 80980000 80980000 8089ef70 80890000 804b5414 80980000 00000002 80b53728
               00000000 800d1268 804b5414 ffffffde 00000017 800afe08 81943860 0f5bfc32
               00000000 00000000 8089ef70 819436c0 ffffffea 00000000 00000000 00000000
               8194390c 808e353c 0000000f 66657272 80980000 00000000 00000000 80890000
               804b5414 80980000 00000002 80b53728 00000000 00000000 00000000 80d40000
               ...
       Call Trace:
       [<80069ce0>] show_stack+0x9c/0x140
       [<800afe08>] ___might_sleep+0x220/0x244
       [<8073bfb0>] __mutex_lock+0x70/0x374
       [<8073c2e0>] mutex_lock_nested+0x2c/0x38
       [<804b5414>] regmap_update_bits_base+0x38/0x8c
       [<804ee584>] regmap_update_bits+0x1c/0x28
       [<804ee714>] ar9331_sw_unmask_irq+0x34/0x60
       [<800d91f0>] unmask_irq+0x48/0x70
       [<800d93d4>] irq_startup+0x114/0x11c
       [<800d65b4>] __setup_irq+0x4f4/0x6d0
       [<800d68a0>] request_threaded_irq+0x110/0x190
       [<804e3ef0>] phy_request_interrupt+0x4c/0xe4
       [<804df508>] phylink_bringup_phy+0x2c0/0x37c
       [<804df7bc>] phylink_of_phy_connect+0x118/0x130
       [<806c1a64>] dsa_slave_create+0x3d0/0x578
       [<806bc4ec>] dsa_register_switch+0x934/0xa20
       [<804eef98>] ar9331_sw_probe+0x34c/0x364
       [<804eb48c>] mdio_probe+0x44/0x70
       [<8049e3b4>] really_probe+0x30c/0x4f4
       [<8049ea10>] driver_probe_device+0x264/0x26c
       [<8049bc10>] bus_for_each_drv+0xb4/0xd8
       [<8049e684>] __device_attach+0xe8/0x18c
       [<8049ce58>] bus_probe_device+0x48/0xc4
       [<8049db70>] deferred_probe_work_func+0xdc/0xf8
       [<8009ff64>] process_one_work+0x2e4/0x4a0
       [<800a0770>] worker_thread+0x2a8/0x354
       [<800a774c>] kthread+0x16c/0x174
       [<8006306c>] ret_from_kernel_thread+0x14/0x1c
      
       ar9331_switch ethernet.1:10 lan1 (uninitialized): PHY [!ahb!ethernet@1a000000!mdio!switch@10:02] driver [Qualcomm Atheros AR9331 built-in PHY] (irq=13)
       DSA: tree 0 setup
      
      To fix it, it is better to move access to MDIO register to the .irq_bus_sync_unlock
      call back.
      
      Fixes: ec6698c2 ("net: dsa: add support for Atheros AR9331 built-in switch")
      Signed-off-by: NOleksij Rempel <o.rempel@pengutronix.de>
      Reviewed-by: NVladimir Oltean <olteanv@gmail.com>
      Link: https://lore.kernel.org/r/20201211110317.17061-1-o.rempel@pengutronix.deSigned-off-by: NJakub Kicinski <kuba@kernel.org>
      3e47495f
  10. 15 12月, 2020 1 次提交
  11. 13 12月, 2020 1 次提交
  12. 10 12月, 2020 2 次提交
  13. 09 12月, 2020 1 次提交
  14. 06 12月, 2020 1 次提交
    • V
      net: mscc: ocelot: fix dropping of unknown IPv4 multicast on Seville · edd2410b
      Vladimir Oltean 提交于
      The current assumption is that the felix DSA driver has flooding knobs
      per traffic class, while ocelot switchdev has a single flooding knob.
      This was correct for felix VSC9959 and ocelot VSC7514, but with the
      introduction of seville VSC9953, we see a switch driven by felix.c which
      has a single flooding knob.
      
      So it is clear that we must do what should have been done from the
      beginning, which is not to overwrite the configuration done by ocelot.c
      in felix, but instead to teach the common ocelot library about the
      differences in our switches, and set up the flooding PGIDs centrally.
      
      The effect that the bogus iteration through FELIX_NUM_TC has upon
      seville is quite dramatic. ANA_FLOODING is located at 0x00b548, and
      ANA_FLOODING_IPMC is located at 0x00b54c. So the bogus iteration will
      actually overwrite ANA_FLOODING_IPMC when attempting to write
      ANA_FLOODING[1]. There is no ANA_FLOODING[1] in sevile, just ANA_FLOODING.
      
      And when ANA_FLOODING_IPMC is overwritten with a bogus value, the effect
      is that ANA_FLOODING_IPMC gets the value of 0x0003CF7D:
      	MC6_DATA = 61,
      	MC6_CTRL = 61,
      	MC4_DATA = 60,
      	MC4_CTRL = 0.
      Because MC4_CTRL is zero, this means that IPv4 multicast control packets
      are not flooded, but dropped. An invalid configuration, and this is how
      the issue was actually spotted.
      Reported-by: NEldar Gasanov <eldargasanov2@gmail.com>
      Reported-by: NMaxim Kochetkov <fido_max@inbox.ru>
      Tested-by: NEldar Gasanov <eldargasanov2@gmail.com>
      Fixes: 84705fc1 ("net: dsa: felix: introduce support for Seville VSC9953 switch")
      Fixes: 3c7b51bd ("net: dsa: felix: allow flooding for all traffic classes")
      Signed-off-by: NVladimir Oltean <vladimir.oltean@nxp.com>
      Reviewed-by: NAlexandre Belloni <alexandre.belloni@bootlin.com>
      Link: https://lore.kernel.org/r/20201204175416.1445937-1-vladimir.oltean@nxp.comSigned-off-by: NJakub Kicinski <kuba@kernel.org>
      edd2410b
  15. 03 12月, 2020 11 次提交
  16. 26 11月, 2020 7 次提交
  17. 24 11月, 2020 1 次提交
  18. 19 11月, 2020 1 次提交
  19. 17 11月, 2020 1 次提交
    • M
      net: lantiq: Wait for the GPHY firmware to be ready · 2a1828e3
      Martin Blumenstingl 提交于
      A user reports (slightly shortened from the original message):
        libphy: lantiq,xrx200-mdio: probed
        mdio_bus 1e108000.switch-mii: MDIO device at address 17 is missing.
        gswip 1e108000.switch lan: no phy at 2
        gswip 1e108000.switch lan: failed to connect to port 2: -19
        lantiq,xrx200-net 1e10b308.eth eth0: error -19 setting up slave phy
      
      This is a single-port board using the internal Fast Ethernet PHY. The
      user reports that switching to PHY scanning instead of configuring the
      PHY within device-tree works around this issue.
      
      The documentation for the standalone variant of the PHY11G (which is
      probably very similar to what is used inside the xRX200 SoCs but having
      the firmware burnt onto that standalone chip in the factory) states that
      the PHY needs 300ms to be ready for MDIO communication after releasing
      the reset.
      
      Add a 300ms delay after initializing all GPHYs to ensure that the GPHY
      firmware had enough time to initialize and to appear on the MDIO bus.
      Unfortunately there is no (known) documentation on what the minimum time
      to wait after releasing the reset on an internal PHY so play safe and
      take the one for the external variant. Only wait after the last GPHY
      firmware is loaded to not slow down the initialization too much (
      xRX200 has two GPHYs but newer SoCs have at least three GPHYs).
      
      Fixes: 14fceff4 ("net: dsa: Add Lantiq / Intel DSA driver for vrx200")
      Reviewed-by: NAndrew Lunn <andrew@lunn.ch>
      Signed-off-by: NMartin Blumenstingl <martin.blumenstingl@googlemail.com>
      Acked-by: NHauke Mehrtens <hauke@hauke-m.de>
      Reviewed-by: NFlorian Fainelli <f.fainelli@gmail.com>
      Link: https://lore.kernel.org/r/20201115165757.552641-1-martin.blumenstingl@googlemail.comSigned-off-by: NJakub Kicinski <kuba@kernel.org>
      2a1828e3
  20. 15 11月, 2020 1 次提交
    • T
      net: dsa: mv88e6xxx: Avoid VTU corruption on 6097 · 92307069
      Tobias Waldekranz 提交于
      As soon as you add the second port to a VLAN, all other port
      membership configuration is overwritten with zeroes. The HW interprets
      this as all ports being "unmodified members" of the VLAN.
      
      In the simple case when all ports belong to the same VLAN, switching
      will still work. But using multiple VLANs or trying to set multiple
      ports as tagged members will not work.
      
      On the 6352, doing a VTU GetNext op, followed by an STU GetNext op
      will leave you with both the member- and state- data in the VTU/STU
      data registers. But on the 6097 (which uses the same implementation),
      the STU GetNext will override the information gathered from the VTU
      GetNext.
      
      Separate the two stages, parsing the result of the VTU GetNext before
      doing the STU GetNext.
      
      We opt to update the existing implementation for all applicable chips,
      as opposed to creating a separate callback for 6097, because although
      the previous implementation did work for (at least) 6352, the
      datasheet does not mention the masking behavior.
      
      Fixes: ef6fcea3 ("net: dsa: mv88e6xxx: get STU entry on VTU GetNext")
      Signed-off-by: NTobias Waldekranz <tobias@waldekranz.com>
      Link: https://lore.kernel.org/r/20201112114335.27371-1-tobias@waldekranz.comSigned-off-by: NJakub Kicinski <kuba@kernel.org>
      92307069
  21. 12 11月, 2020 1 次提交