diff options
author | Simon Arlott <simon@fire.lp0.eu> | 2010-05-10 05:31:11 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2010-05-16 02:10:15 -0400 |
commit | e0f43752a942b7be1bc06b9fd74e20ae337c1cca (patch) | |
tree | 892d0fbc2ecae39f2e5c4a7b711cbb988c8dc3f1 /net/bridge/br_private.h | |
parent | 28a16c97963d3bc36a2c192859f6d8025ef2967a (diff) |
bridge: update sysfs link names if port device names have changed
Links for each port are created in sysfs using the device
name, but this could be changed after being added to the
bridge.
As well as being unable to remove interfaces after this
occurs (because userspace tools don't recognise the new
name, and the kernel won't recognise the old name), adding
another interface with the old name to the bridge will
cause an error trying to create the sysfs link.
This fixes the problem by listening for NETDEV_CHANGENAME
notifications and renaming the link.
https://bugzilla.kernel.org/show_bug.cgi?id=12743
Signed-off-by: Simon Arlott <simon@fire.lp0.eu>
Acked-by: Stephen Hemminger <shemminger@vyatta.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/bridge/br_private.h')
-rw-r--r-- | net/bridge/br_private.h | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/net/bridge/br_private.h b/net/bridge/br_private.h index 79a13d1c2573..0f4a74bc6a9b 100644 --- a/net/bridge/br_private.h +++ b/net/bridge/br_private.h | |||
@@ -139,6 +139,10 @@ struct net_bridge_port | |||
139 | struct hlist_head mglist; | 139 | struct hlist_head mglist; |
140 | struct hlist_node rlist; | 140 | struct hlist_node rlist; |
141 | #endif | 141 | #endif |
142 | |||
143 | #ifdef CONFIG_SYSFS | ||
144 | char sysfs_name[IFNAMSIZ]; | ||
145 | #endif | ||
142 | }; | 146 | }; |
143 | 147 | ||
144 | struct br_cpu_netstats { | 148 | struct br_cpu_netstats { |
@@ -480,6 +484,7 @@ extern void br_ifinfo_notify(int event, struct net_bridge_port *port); | |||
480 | /* br_sysfs_if.c */ | 484 | /* br_sysfs_if.c */ |
481 | extern const struct sysfs_ops brport_sysfs_ops; | 485 | extern const struct sysfs_ops brport_sysfs_ops; |
482 | extern int br_sysfs_addif(struct net_bridge_port *p); | 486 | extern int br_sysfs_addif(struct net_bridge_port *p); |
487 | extern int br_sysfs_renameif(struct net_bridge_port *p); | ||
483 | 488 | ||
484 | /* br_sysfs_br.c */ | 489 | /* br_sysfs_br.c */ |
485 | extern int br_sysfs_addbr(struct net_device *dev); | 490 | extern int br_sysfs_addbr(struct net_device *dev); |
@@ -488,6 +493,7 @@ extern void br_sysfs_delbr(struct net_device *dev); | |||
488 | #else | 493 | #else |
489 | 494 | ||
490 | #define br_sysfs_addif(p) (0) | 495 | #define br_sysfs_addif(p) (0) |
496 | #define br_sysfs_renameif(p) (0) | ||
491 | #define br_sysfs_addbr(dev) (0) | 497 | #define br_sysfs_addbr(dev) (0) |
492 | #define br_sysfs_delbr(dev) do { } while(0) | 498 | #define br_sysfs_delbr(dev) do { } while(0) |
493 | #endif /* CONFIG_SYSFS */ | 499 | #endif /* CONFIG_SYSFS */ |