IB/mlx5: Fix warning about cast of wr_id back to pointer on 32 bits
authorRoland Dreier <roland@purestorage.com>
Wed, 28 May 2014 16:23:03 +0000 (09:23 -0700)
committerRoland Dreier <roland@purestorage.com>
Wed, 28 May 2014 16:23:03 +0000 (09:23 -0700)
We need to cast wr_id to unsigned long before casting to a pointer.
This fixes:

       drivers/infiniband/hw/mlx5/mr.c: In function 'mlx5_umr_cq_handler':
    >> drivers/infiniband/hw/mlx5/mr.c:724:13: warning: cast to pointer from integer of different size [-Wint-to-pointer-cast]
          context = (struct mlx5_ib_umr_context *)wc.wr_id;

Reported-by: kbuild test robot <fengguang.wu@intel.com>
Signed-off-by: Roland Dreier <roland@purestorage.com>
drivers/infiniband/hw/mlx5/mr.c

index 14ee4fdcf17210c1a35495756cd8441d286da428..afa873bd028ed5ad76f2348bbe9789b0b225b476 100644 (file)
@@ -721,7 +721,7 @@ void mlx5_umr_cq_handler(struct ib_cq *cq, void *cq_context)
                if (err == 0)
                        break;
 
-               context = (struct mlx5_ib_umr_context *)wc.wr_id;
+               context = (struct mlx5_ib_umr_context *) (unsigned long) wc.wr_id;
                context->status = wc.status;
                complete(&context->done);
        }