ULPs such as iSER/NVMEoF can use memory regions that support arbitrary sg list mapping in order to allow the block layer to send us gappy bios and reduce the stack workload. Add an helper function to get IB_MR_TYPE_SG_GAPS mr_type if the device support this kind of mapping. Signed-off-by: Max Gurtovoy <maxg@xxxxxxxxxxxx> Reviewed-by: Leon Romanovsky <leon@xxxxxxxxxx> --- include/rdma/ib_verbs.h | 17 +++++++++++++++++ 1 files changed, 17 insertions(+), 0 deletions(-) diff --git a/include/rdma/ib_verbs.h b/include/rdma/ib_verbs.h index 99e4423..dd97169 100644 --- a/include/rdma/ib_verbs.h +++ b/include/rdma/ib_verbs.h @@ -3375,6 +3375,23 @@ int ib_map_mr_sg(struct ib_mr *mr, struct scatterlist *sg, int sg_nents, int ib_sg_to_pages(struct ib_mr *mr, struct scatterlist *sgl, int sg_nents, unsigned int *sg_offset, int (*set_page)(struct ib_mr *, u64)); +/** + * ib_get_sg_mr_type() - check if the device support arbitrary + * sg mapping and return a suitable mr type. + * @device: The device on which to check support. + * + * Return: IB_MR_TYPE_SG_GAPS if the device support. + * Otherwise, return IB_MR_TYPE_MEM_REG. + */ +static inline enum ib_mr_type ib_get_sg_mr_type(struct ib_device *device) +{ + if (device->attrs.device_cap_flags & IB_DEVICE_SG_GAPS_REG) + return IB_MR_TYPE_SG_GAPS; + else + return IB_MR_TYPE_MEM_REG; + +} + void ib_drain_rq(struct ib_qp *qp); void ib_drain_sq(struct ib_qp *qp); void ib_drain_qp(struct ib_qp *qp); -- 1.7.1 -- To unsubscribe from this list: send the line "unsubscribe linux-rdma" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html