diff options
| author | Roland Dreier <roland@purestorage.com> | 2011-10-06 12:33:11 -0400 |
|---|---|---|
| committer | Roland Dreier <roland@purestorage.com> | 2011-10-06 12:33:11 -0400 |
| commit | 0f6740c7c455693f719580f34bb8afa8a298ea36 (patch) | |
| tree | 1302916de0b8d3ae3734156582b9fe0c81d50690 | |
| parent | 976d167615b64e14bc1491ca51d424e2ba9a5e84 (diff) | |
mlx4_core: Clean up error flow in mlx4_register_mac()
Fix a leak of entry if radix_tree_insert() fails.
Also, reduce the indentation and make the flow easier to read by
sticking to the conventional
err = do_something();
if (err)
return err;
err = do_another();
if (err)
return err;
rather than mixing the direction of the test as
err = do_something();
if (!err) {
err = do_another();
if (err)
return err;
} else
return err;
Signed-off-by: Roland Dreier <roland@purestorage.com>
| -rw-r--r-- | drivers/net/mlx4/port.c | 30 |
1 files changed, 17 insertions, 13 deletions
diff --git a/drivers/net/mlx4/port.c b/drivers/net/mlx4/port.c index 609e0ec14cee..ef10113da356 100644 --- a/drivers/net/mlx4/port.c +++ b/drivers/net/mlx4/port.c | |||
| @@ -148,22 +148,26 @@ int mlx4_register_mac(struct mlx4_dev *dev, u8 port, u64 mac, int *qpn, u8 wrap) | |||
| 148 | 148 | ||
| 149 | if (dev->caps.flags & MLX4_DEV_CAP_FLAG_VEP_UC_STEER) { | 149 | if (dev->caps.flags & MLX4_DEV_CAP_FLAG_VEP_UC_STEER) { |
| 150 | err = mlx4_uc_steer_add(dev, port, mac, qpn, 1); | 150 | err = mlx4_uc_steer_add(dev, port, mac, qpn, 1); |
| 151 | if (!err) { | 151 | if (err) |
| 152 | entry = kmalloc(sizeof *entry, GFP_KERNEL); | ||
| 153 | if (!entry) { | ||
| 154 | mlx4_uc_steer_release(dev, port, mac, *qpn, 1); | ||
| 155 | return -ENOMEM; | ||
| 156 | } | ||
| 157 | entry->mac = mac; | ||
| 158 | err = radix_tree_insert(&info->mac_tree, *qpn, entry); | ||
| 159 | if (err) { | ||
| 160 | mlx4_uc_steer_release(dev, port, mac, *qpn, 1); | ||
| 161 | return err; | ||
| 162 | } | ||
| 163 | } else | ||
| 164 | return err; | 152 | return err; |
| 153 | |||
| 154 | entry = kmalloc(sizeof *entry, GFP_KERNEL); | ||
| 155 | if (!entry) { | ||
| 156 | mlx4_uc_steer_release(dev, port, mac, *qpn, 1); | ||
| 157 | return -ENOMEM; | ||
| 158 | } | ||
| 159 | |||
| 160 | entry->mac = mac; | ||
| 161 | err = radix_tree_insert(&info->mac_tree, *qpn, entry); | ||
| 162 | if (err) { | ||
| 163 | kfree(entry); | ||
| 164 | mlx4_uc_steer_release(dev, port, mac, *qpn, 1); | ||
| 165 | return err; | ||
| 166 | } | ||
| 165 | } | 167 | } |
| 168 | |||
| 166 | mlx4_dbg(dev, "Registering MAC: 0x%llx\n", (unsigned long long) mac); | 169 | mlx4_dbg(dev, "Registering MAC: 0x%llx\n", (unsigned long long) mac); |
| 170 | |||
| 167 | mutex_lock(&table->mutex); | 171 | mutex_lock(&table->mutex); |
| 168 | for (i = 0; i < MLX4_MAX_MAC_NUM - 1; i++) { | 172 | for (i = 0; i < MLX4_MAX_MAC_NUM - 1; i++) { |
| 169 | if (free < 0 && !table->refs[i]) { | 173 | if (free < 0 && !table->refs[i]) { |
