> + spinlock_t sc_rw_ctxt_lock; > + struct list_head sc_rw_ctxts; It's a little sad that we always need a list and a spinlock when most requests should need a single context only. > + * Each WR chain handles a single contiguous server-side buffer, > + * because some registration modes (eg. FRWR) do not support a > + * discontiguous scatterlist. Both FRWR and FMR have no problem with a discontiguous page list, they only have a problem with any segment but the first not starting page aligned. For NFS you'll need vectored direct I/O to hit that case. > + spin_lock(&rdma->sc_rw_ctxt_lock); > + if (list_empty(&rdma->sc_rw_ctxts)) > + goto out_empty; > + > + ctxt = list_first_entry(&rdma->sc_rw_ctxts, > + struct svc_rdma_rw_ctxt, rw_list); Use list_first_entry_or_null? > + struct svc_rdma_rw_ctxt *ctxt; > + > + while (!list_empty(&rdma->sc_rw_ctxts)) { > + ctxt = list_first_entry(&rdma->sc_rw_ctxts, > + struct svc_rdma_rw_ctxt, rw_list); Same here. > + if (wc->status != IB_WC_SUCCESS) > + goto flush; > + > +out: > + rdma_rw_ctx_destroy(&ctxt->rw_ctx, rdma->sc_qp, rdma->sc_port_num, > + ctxt->rw_sg_table.sgl, ctxt->rw_nents, > + DMA_TO_DEVICE); > + svc_rdma_put_rw_ctxt(ctxt); > + return; > + > +flush: > + set_bit(XPT_CLOSE, &rdma->sc_xprt.xpt_flags); > + if (wc->status != IB_WC_WR_FLUSH_ERR) > + pr_err("svcrdma: write ctx: %s (%u/0x%x)\n", > + ib_wc_status_msg(wc->status), > + wc->status, wc->vendor_err); > + goto out; This would seem cleaner without the gotos (but maybe an unlikely for the if above). > + struct svc_xprt *xprt = &rdma->sc_xprt; > + struct ib_send_wr *bad_wr; > + int ret; > + > + do { > + if ((atomic_sub_return(num_wrs, &rdma->sc_sq_avail) > 0)) { No need for the inner braces. Except for these minor nitpicks the patch looks fine to me: Reviewed-by: Christoph Hellwig <hch@xxxxxx> -- To unsubscribe from this list: send the line "unsubscribe linux-nfs" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html