aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/mlx4/port.c
diff options
context:
space:
mode:
authorRoland Dreier <roland@purestorage.com>2011-10-06 12:33:11 -0400
committerRoland Dreier <roland@purestorage.com>2011-10-06 12:33:11 -0400
commit0f6740c7c455693f719580f34bb8afa8a298ea36 (patch)
tree1302916de0b8d3ae3734156582b9fe0c81d50690 /drivers/net/mlx4/port.c
parent976d167615b64e14bc1491ca51d424e2ba9a5e84 (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>
Diffstat (limited to 'drivers/net/mlx4/port.c')
-rw-r--r--drivers/net/mlx4/port.c30
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]) {