]> git.baikalelectronics.ru Git - kernel.git/commit
r8169: Avoid duplicate sysfs entry creation error
authorSayanta Pattanayak <sayanta.pattanayak@arm.com>
Tue, 20 Jul 2021 16:17:40 +0000 (17:17 +0100)
committerDavid S. Miller <davem@davemloft.net>
Wed, 21 Jul 2021 14:54:30 +0000 (07:54 -0700)
commita9e6529586026caa221f40373540aa5fbac1179b
tree2b235dcaccaaebf5464fc822ee4ce36168212aea
parent62d51cfb3cd8c46306fb729dd0a785855b83fa0a
r8169: Avoid duplicate sysfs entry creation error

When registering the MDIO bus for a r8169 device, we use the PCI
bus/device specifier as a (seemingly) unique device identifier.
However the very same BDF number can be used on another PCI segment,
which makes the driver fail probing:

[ 27.544136] r8169 0002:07:00.0: enabling device (0000 -> 0003)
[ 27.559734] sysfs: cannot create duplicate filename '/class/mdio_bus/r8169-700'
....
[ 27.684858] libphy: mii_bus r8169-700 failed to register
[ 27.695602] r8169: probe of 0002:07:00.0 failed with error -22

Add the segment number to the device name to make it more unique.

This fixes operation on ARM N1SDP boards, with two boards connected
together to form an SMP system, and all on-board devices showing up
twice, just on different PCI segments. A similar issue would occur on
large systems with many PCI slots and multiple RTL8169 NICs.

Fixes: 224b054928bc7 ("r8169: add basic phylib support")
Signed-off-by: Sayanta Pattanayak <sayanta.pattanayak@arm.com>
[Andre: expand commit message, use pci_domain_nr()]
Signed-off-by: Andre Przywara <andre.przywara@arm.com>
Acked-by: Heiner Kallweit <hkallweit1@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/realtek/r8169_main.c