Commit c050def0 authored by Roland Dreier's avatar Roland Dreier

mlx4_core: Clean up mlx4_alloc_icm() a bit

Handle the allocation error case first, so that we don't have further
nested if for handling the common case of success.
Signed-off-by: default avatarRoland Dreier <rolandd@cisco.com>
parent c0dc72ba
...@@ -163,29 +163,30 @@ struct mlx4_icm *mlx4_alloc_icm(struct mlx4_dev *dev, int npages, ...@@ -163,29 +163,30 @@ struct mlx4_icm *mlx4_alloc_icm(struct mlx4_dev *dev, int npages,
ret = mlx4_alloc_icm_pages(&chunk->mem[chunk->npages], ret = mlx4_alloc_icm_pages(&chunk->mem[chunk->npages],
cur_order, gfp_mask); cur_order, gfp_mask);
if (!ret) { if (ret) {
++chunk->npages; if (--cur_order < 0)
goto fail;
if (coherent) else
++chunk->nsg; continue;
else if (chunk->npages == MLX4_ICM_CHUNK_LEN) { }
chunk->nsg = pci_map_sg(dev->pdev, chunk->mem,
chunk->npages,
PCI_DMA_BIDIRECTIONAL);
if (chunk->nsg <= 0)
goto fail;
}
if (chunk->npages == MLX4_ICM_CHUNK_LEN) ++chunk->npages;
chunk = NULL;
npages -= 1 << cur_order; if (coherent)
} else { ++chunk->nsg;
--cur_order; else if (chunk->npages == MLX4_ICM_CHUNK_LEN) {
if (cur_order < 0) chunk->nsg = pci_map_sg(dev->pdev, chunk->mem,
chunk->npages,
PCI_DMA_BIDIRECTIONAL);
if (chunk->nsg <= 0)
goto fail; goto fail;
} }
if (chunk->npages == MLX4_ICM_CHUNK_LEN)
chunk = NULL;
npages -= 1 << cur_order;
} }
if (!coherent && chunk) { if (!coherent && chunk) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment