dma-mapping: allow EREMOTEIO return code for P2PDMA transfers
authorLogan Gunthorpe <logang@deltatee.com>
Fri, 8 Jul 2022 16:50:55 +0000 (10:50 -0600)
committerChristoph Hellwig <hch@lst.de>
Tue, 26 Jul 2022 11:27:47 +0000 (07:27 -0400)
Add EREMOTEIO error return to dma_map_sgtable() which will be used
by .map_sg() implementations that detect P2PDMA pages that the
underlying DMA device cannot access.

Signed-off-by: Logan Gunthorpe <logang@deltatee.com>
Reviewed-by: Jason Gunthorpe <jgg@nvidia.com>
Reviewed-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Christoph Hellwig <hch@lst.de>
kernel/dma/mapping.c

index 1bfe11b1edb6685b40c736f36175b2a82fbaa814..746d46825d08fe4a043d2ed05e13d95f96db5ec4 100644 (file)
@@ -197,7 +197,7 @@ static int __dma_map_sg_attrs(struct device *dev, struct scatterlist *sg,
        if (ents > 0)
                debug_dma_map_sg(dev, sg, nents, ents, dir, attrs);
        else if (WARN_ON_ONCE(ents != -EINVAL && ents != -ENOMEM &&
-                             ents != -EIO))
+                             ents != -EIO && ents != -EREMOTEIO))
                return -EIO;
 
        return ents;
@@ -255,6 +255,9 @@ EXPORT_SYMBOL(dma_map_sg_attrs);
  *             complete the mapping. Should succeed if retried later.
  *   -EIO      Legacy error code with an unknown meaning. eg. this is
  *             returned if a lower level call returned DMA_MAPPING_ERROR.
+ *   -EREMOTEIO        The DMA device cannot access P2PDMA memory specified in
+ *             the sg_table. This will not succeed if retried.
+ *
  */
 int dma_map_sgtable(struct device *dev, struct sg_table *sgt,
                    enum dma_data_direction dir, unsigned long attrs)