IB/mlx4: Optimize do_slave_init
authorDoug Ledford <dledford@redhat.com>
Thu, 9 Jul 2015 14:21:08 +0000 (10:21 -0400)
committerDoug Ledford <dledford@redhat.com>
Tue, 14 Jul 2015 17:20:15 +0000 (13:20 -0400)
commitd9a047aeffcef5755952d18f2901d8777d84019d
tree2167b6bb6832d31bb7ba86ea4c4140ef4cd50bf6
parent9bbf282da87294e1bda0ccb4e351bfdf5fc076cd
IB/mlx4: Optimize do_slave_init

There is little chance our memory allocation will fail, so we can
combine initializing the work structs with allocating them instead of
looping through all of them once to allocate and again to initialize.
Then when we need to actually find out if our device is up or in the
process of going down, have all of our work structs batched up, take the
spin_lock once and only once, and do all of the batch under the one
spin_lock invocation instead of incurring all of the locked memory cycles
we would otherwise incur to take/release the spin_lock over and over
again.

Signed-off-by: Doug Ledford <dledford@redhat.com>
drivers/infiniband/hw/mlx4/main.c