Clean up, based on code audit: Remove the possibility that the
chunk list XDR encoders can return zero, which would be interpreted
as a NULL.
Signed-off-by: Chuck Lever <chuck.lever@oracle.com>
Tested-by: Steve Wise <swise@opengridcomputing.com>
Signed-off-by: Anna Schumaker <Anna.Schumaker@Netapp.com>
        }
        mw->mw_nents = i;
        mw->mw_dir = rpcrdma_data_dir(writing);
+       if (i == 0)
+               goto out_dmamap_err;
 
        if (!ib_dma_map_sg(r_xprt->rx_ia.ri_device,
                           mw->mw_sg, mw->mw_nents, mw->mw_dir))
 
        }
        mw->mw_nents = i;
        mw->mw_dir = rpcrdma_data_dir(writing);
+       if (i == 0)
+               goto out_dmamap_err;
 
        dma_nents = ib_dma_map_sg(ia->ri_device,
                                  mw->mw_sg, mw->mw_nents, mw->mw_dir);
 
 
        do {
                n = r_xprt->rx_ia.ri_ops->ro_map(r_xprt, seg, nsegs, false);
-               if (n <= 0)
+               if (n < 0)
                        return ERR_PTR(n);
 
                *iptr++ = xdr_one;      /* item present */
        nchunks = 0;
        do {
                n = r_xprt->rx_ia.ri_ops->ro_map(r_xprt, seg, nsegs, true);
-               if (n <= 0)
+               if (n < 0)
                        return ERR_PTR(n);
 
                iptr = xdr_encode_rdma_segment(iptr, seg);
        nchunks = 0;
        do {
                n = r_xprt->rx_ia.ri_ops->ro_map(r_xprt, seg, nsegs, true);
-               if (n <= 0)
+               if (n < 0)
                        return ERR_PTR(n);
 
                iptr = xdr_encode_rdma_segment(iptr, seg);