Received: by 2002:ac0:a5a6:0:0:0:0:0 with SMTP id m35-v6csp21703imm; Wed, 12 Sep 2018 17:14:23 -0700 (PDT) X-Google-Smtp-Source: ANB0VdYy8QOI0vyxxmzNrrKbeNC5OFfojutwaj0R/fC2t9GX6zYaRf6Xlvaw/MeoOmu2WVkM+WkJ X-Received: by 2002:a17:902:8a97:: with SMTP id p23-v6mr4619781plo.21.1536797663722; Wed, 12 Sep 2018 17:14:23 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1536797663; cv=none; d=google.com; s=arc-20160816; b=l5Igcgt6mS5Vj94+nBX7IFBRe7SijoiAy/BIZ2NGoUyS5lS1r+MEZzvtd3lXSGNo6M IbTjEOl/TwRPGJS3GcGSSacvbPP9PUBcckP+txnNdwGRBsxJ83GBm8CbhsXzQbs2vlIE usjRwCKY7dclACqHIl8VooC1lJVer96VLnic2V8G/iLS/ItuD2DyxkV4//kUqahtSi/y 0iaW6DFmHqeZdLFQmDdiVCcAoYb70Ms05bKyn3W8R8KZCL3kUALyvDRqbZuOW56bfGSR yW1YkG8WaT2pAH2WghHgkUF8eG0p+1f52IwydxK1KgKKtCZuSDysNJ3pg9zL2ILF3x7C Ca7Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:subject:content-transfer-encoding :mime-version:references:in-reply-to:message-id:date:cc:to:from; bh=KIQTmMX9o3Aei9QtQuyS1K9aIZW4GDiLMdPcT64Sl+s=; b=bGdVVV9hoC5Ixw+JOmeSdaa2Q2LY82GkqXhMcmt00AL6lzcyTxDZMuABMP53HDVhp/ 0jfLNfS+XmmlAjGqu/fQXPrnOYyo4P67T3WWL13DtjJXTI9Q7D60TGsWl+84i0LCei9b o8is51Mdcl3woyzWyc24H0w4BkxPoBKnR14bFnKfNJk9Wg8xxK+7q297fyc53lon6R/Y mNefmpv8RRFhgSKagP3cWJQ1ckJzRlSEo0oAwmnKUFUERjOHZiVSOK9LiCi8J1i8FkJE hQVMI4ckQ1jrGabBtzCPWUuWqsYLdLwc4JniB9TGCDXdk0o2RN9TktAyQOltKxMEKCib yqoA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id x188-v6si2423665pfx.19.2018.09.12.17.14.09; Wed, 12 Sep 2018 17:14:23 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728185AbeIMFUE (ORCPT + 99 others); Thu, 13 Sep 2018 01:20:04 -0400 Received: from ale.deltatee.com ([207.54.116.67]:38584 "EHLO ale.deltatee.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727246AbeIMFTA (ORCPT ); Thu, 13 Sep 2018 01:19:00 -0400 Received: from cgy1-donard.priv.deltatee.com ([172.16.1.31]) by ale.deltatee.com with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.89) (envelope-from ) id 1g0FEl-0006bI-TM; Wed, 12 Sep 2018 18:12:03 -0600 Received: from gunthorp by cgy1-donard.priv.deltatee.com with local (Exim 4.89) (envelope-from ) id 1g0FEl-00015f-Nu; Wed, 12 Sep 2018 18:11:59 -0600 From: Logan Gunthorpe To: linux-kernel@vger.kernel.org, linux-pci@vger.kernel.org, linux-nvme@lists.infradead.org, linux-rdma@vger.kernel.org, linux-nvdimm@lists.01.org, linux-block@vger.kernel.org Cc: Stephen Bates , Christoph Hellwig , Keith Busch , Sagi Grimberg , Bjorn Helgaas , Jason Gunthorpe , Max Gurtovoy , Dan Williams , =?UTF-8?q?J=C3=A9r=C3=B4me=20Glisse?= , Benjamin Herrenschmidt , Alex Williamson , =?UTF-8?q?Christian=20K=C3=B6nig?= , Jens Axboe , Logan Gunthorpe Date: Wed, 12 Sep 2018 18:11:51 -0600 Message-Id: <20180913001156.4115-9-logang@deltatee.com> X-Mailer: git-send-email 2.19.0 In-Reply-To: <20180913001156.4115-1-logang@deltatee.com> References: <20180913001156.4115-1-logang@deltatee.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-SA-Exim-Connect-IP: 172.16.1.31 X-SA-Exim-Rcpt-To: linux-nvme@lists.infradead.org, linux-nvdimm@lists.01.org, linux-kernel@vger.kernel.org, linux-pci@vger.kernel.org, linux-rdma@vger.kernel.org, linux-block@vger.kernel.org, sbates@raithlin.com, hch@lst.de, sagi@grimberg.me, bhelgaas@google.com, jgg@mellanox.com, maxg@mellanox.com, keith.busch@intel.com, dan.j.williams@intel.com, benh@kernel.crashing.org, jglisse@redhat.com, alex.williamson@redhat.com, christian.koenig@amd.com, axboe@kernel.dk, logang@deltatee.com X-SA-Exim-Mail-From: gunthorp@deltatee.com X-Spam-Checker-Version: SpamAssassin 3.4.1 (2015-04-28) on ale.deltatee.com X-Spam-Level: X-Spam-Status: No, score=-8.7 required=5.0 tests=ALL_TRUSTED,BAYES_00, GREYLIST_ISWHITE,MYRULES_NO_TEXT autolearn=ham autolearn_force=no version=3.4.1 Subject: [PATCH v6 08/13] IB/core: Ensure we map P2P memory correctly in rdma_rw_ctx_[init|destroy]() X-SA-Exim-Version: 4.2.1 (built Tue, 02 Aug 2016 21:08:31 +0000) X-SA-Exim-Scanned: Yes (on ale.deltatee.com) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org In order to use PCI P2P memory the pci_p2pmem_map_sg() function must be called to map the correct PCI bus address. To do this, check the first page in the scatter list to see if it is P2P memory or not. At the moment, scatter lists that contain P2P memory must be homogeneous so if the first page is P2P the entire SGL should be P2P. Signed-off-by: Logan Gunthorpe Reviewed-by: Christoph Hellwig Reviewed-by: Sagi Grimberg --- drivers/infiniband/core/rw.c | 11 +++++++++-- 1 file changed, 9 insertions(+), 2 deletions(-) diff --git a/drivers/infiniband/core/rw.c b/drivers/infiniband/core/rw.c index 683e6d11a564..d22c4a2ebac6 100644 --- a/drivers/infiniband/core/rw.c +++ b/drivers/infiniband/core/rw.c @@ -12,6 +12,7 @@ */ #include #include +#include #include #include @@ -280,7 +281,11 @@ int rdma_rw_ctx_init(struct rdma_rw_ctx *ctx, struct ib_qp *qp, u8 port_num, struct ib_device *dev = qp->pd->device; int ret; - ret = ib_dma_map_sg(dev, sg, sg_cnt, dir); + if (is_pci_p2pdma_page(sg_page(sg))) + ret = pci_p2pdma_map_sg(dev->dma_device, sg, sg_cnt, dir); + else + ret = ib_dma_map_sg(dev, sg, sg_cnt, dir); + if (!ret) return -ENOMEM; sg_cnt = ret; @@ -602,7 +607,9 @@ void rdma_rw_ctx_destroy(struct rdma_rw_ctx *ctx, struct ib_qp *qp, u8 port_num, break; } - ib_dma_unmap_sg(qp->pd->device, sg, sg_cnt, dir); + /* P2PDMA contexts do not need to be unmapped */ + if (!is_pci_p2pdma_page(sg_page(sg))) + ib_dma_unmap_sg(qp->pd->device, sg, sg_cnt, dir); } EXPORT_SYMBOL(rdma_rw_ctx_destroy); -- 2.19.0