diff options
author | Guenter Roeck <linux@roeck-us.net> | 2015-02-24 16:15:32 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2015-02-25 17:03:38 -0500 |
commit | d87d6f44d7c1254fd9560a5191659cb00882db56 (patch) | |
tree | edc80a71daf91645aa2e74a798f97a9fd836a35a /net/dsa/dsa.c | |
parent | 92bf200881d978bc3c6a290991ae1f9ddc7b5411 (diff) |
net: dsa: Ensure that port array elements are initialized before being used
A network device notifier can be called for one or more of the created
slave devices before all slave devices have been registered. This can
result in a mismatch between ds->phys_port_mask and the registered devices
by the time the call is made, and it can result in a slave device being
added to a bridge before its entry in ds->ports[] has been initialized.
Rework the initialization code to initialize entries in ds->ports[] in
dsa_slave_create. With this change, dsa_slave_create no longer needs
to return slave_dev but can return an error code instead.
Signed-off-by: Guenter Roeck <linux@roeck-us.net>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/dsa/dsa.c')
-rw-r--r-- | net/dsa/dsa.c | 10 |
1 files changed, 3 insertions, 7 deletions
diff --git a/net/dsa/dsa.c b/net/dsa/dsa.c index 2173402d87e0..fc1813140be6 100644 --- a/net/dsa/dsa.c +++ b/net/dsa/dsa.c | |||
@@ -314,19 +314,15 @@ dsa_switch_setup(struct dsa_switch_tree *dst, int index, | |||
314 | * Create network devices for physical switch ports. | 314 | * Create network devices for physical switch ports. |
315 | */ | 315 | */ |
316 | for (i = 0; i < DSA_MAX_PORTS; i++) { | 316 | for (i = 0; i < DSA_MAX_PORTS; i++) { |
317 | struct net_device *slave_dev; | ||
318 | |||
319 | if (!(ds->phys_port_mask & (1 << i))) | 317 | if (!(ds->phys_port_mask & (1 << i))) |
320 | continue; | 318 | continue; |
321 | 319 | ||
322 | slave_dev = dsa_slave_create(ds, parent, i, pd->port_names[i]); | 320 | ret = dsa_slave_create(ds, parent, i, pd->port_names[i]); |
323 | if (slave_dev == NULL) { | 321 | if (ret < 0) { |
324 | netdev_err(dst->master_netdev, "[%d]: can't create dsa slave device for port %d(%s)\n", | 322 | netdev_err(dst->master_netdev, "[%d]: can't create dsa slave device for port %d(%s)\n", |
325 | index, i, pd->port_names[i]); | 323 | index, i, pd->port_names[i]); |
326 | continue; | 324 | ret = 0; |
327 | } | 325 | } |
328 | |||
329 | ds->ports[i] = slave_dev; | ||
330 | } | 326 | } |
331 | 327 | ||
332 | #ifdef CONFIG_NET_DSA_HWMON | 328 | #ifdef CONFIG_NET_DSA_HWMON |