IB/mlx5: Fix list_del of empty list
authorEli Cohen <eli@dev.mellanox.co.il>
Thu, 31 Oct 2013 13:26:33 +0000 (15:26 +0200)
committerRoland Dreier <roland@purestorage.com>
Fri, 15 Nov 2013 22:36:35 +0000 (14:36 -0800)
For archs with pages size of 4K, when the chunk is freed, fwp is not in the
list so avoid attempting to delete it.

Signed-off-by: Eli Cohen <eli@mellanox.com>
Signed-off-by: Roland Dreier <roland@purestorage.com>
drivers/net/ethernet/mellanox/mlx5/core/pagealloc.c

index ba816c25c5c11c29188281eee1f1f6be083d8c23..37b6ad1f9a1bf6697fb813d5e5c1ebd0bea48d15 100644 (file)
@@ -229,7 +229,8 @@ static void free_4k(struct mlx5_core_dev *dev, u64 addr)
        set_bit(n, &fwp->bitmask);
        if (fwp->free_count == MLX5_NUM_4K_IN_PAGE) {
                rb_erase(&fwp->rb_node, &dev->priv.page_root);
-               list_del(&fwp->list);
+               if (fwp->free_count != 1)
+                       list_del(&fwp->list);
                dma_unmap_page(&dev->pdev->dev, addr, PAGE_SIZE, DMA_BIDIRECTIONAL);
                __free_page(fwp->page);
                kfree(fwp);