summaryrefslogtreecommitdiffstats
path: root/arch/microblaze/kernel
diff options
context:
space:
mode:
authorRoland Dreier <roland@purestorage.com>2017-08-29 19:34:43 +0200
committerDoug Ledford <dledford@redhat.com>2017-08-31 14:35:07 +0200
commitc76161181193985087cd716fdf69b5cb6cf9ee85 (patch)
treeabc2e8648e24f498f3d768b8a9131866a32cb300 /arch/microblaze/kernel
parentIB/core: Add support to finalize objects in one transaction (diff)
downloadlinux-c76161181193985087cd716fdf69b5cb6cf9ee85.tar.xz
linux-c76161181193985087cd716fdf69b5cb6cf9ee85.zip
IB/cm: Fix sleeping in atomic when RoCE is used
A couple of places in the CM do spin_lock_irq(&cm_id_priv->lock); ... if (cm_alloc_response_msg(work->port, work->mad_recv_wc, &msg)) However when the underlying transport is RoCE, this leads to a sleeping function being called with the lock held - the callchain is cm_alloc_response_msg() -> ib_create_ah_from_wc() -> ib_init_ah_from_wc() -> rdma_addr_find_l2_eth_by_grh() -> rdma_resolve_ip() and rdma_resolve_ip() starts out by doing req = kzalloc(sizeof *req, GFP_KERNEL); not to mention rdma_addr_find_l2_eth_by_grh() doing wait_for_completion(&ctx.comp); to wait for the task that rdma_resolve_ip() queues up. Fix this by moving the AH creation out of the lock. Signed-off-by: Roland Dreier <roland@purestorage.com> Reviewed-by: Sean Hefty <sean.hefty@intel.com> Signed-off-by: Doug Ledford <dledford@redhat.com>
Diffstat (limited to 'arch/microblaze/kernel')
0 files changed, 0 insertions, 0 deletions