Received: by 2002:a25:f815:0:0:0:0:0 with SMTP id u21csp4029281ybd; Tue, 25 Jun 2019 12:45:09 -0700 (PDT) X-Google-Smtp-Source: APXvYqwrQNS7WD1Pa4wbaW8pVIp02DzZfTZX9BxGfcAmvecMP7cxKitsQAx0CWJtjYNJUOuk/B2q X-Received: by 2002:a65:51cb:: with SMTP id i11mr39329106pgq.390.1561491909418; Tue, 25 Jun 2019 12:45:09 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1561491909; cv=none; d=google.com; s=arc-20160816; b=PEDJUbQxS9G0kn3IHbF8AE2jkxcxz4Yz+1nf2ImZrwA4P3C48/rJ4Z2ndevCF3M7Q5 HhB2JOzkcc07FKDpExagZLlXPXmyQwNwega3xI0c1oaw+XaZUiJ4xKpKzkk/D2hLCZUr aR4HW1l5ltPMm0ITm0Ut1Tw9wiC/+O/Egaq1FdKhDBaYFlu5YcVJ4n2Sk+DevKvxlhQi vvXtfkDnSG3hCkZuLOHKKRrZtwfB8Y+hJhpnqdgCsrfC5mvihk2S4kiW46ih7q+2MkPY 6S/Y8g+AmvGxNL2BS3oTpthLQ0Wwp5uP8ShdgZwYo1t94tpsTNhwxTfpRfsAV3PuuG1Z Zstg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:to:subject; bh=/gdY49FUVHocxbz7LBXn5sNpERjwuvk9A6H7M8LrInk=; b=aIFX/K7fKvFfkoesZ1VVzaYbemnXx1UPPoje7VaDGxvNtwQbCI/NClsI1fpkgx4bJi LGM3Uhduj1UcnlFg6y/CrqVl7PjIRq2Yta1If2JtTotaMEtszy9vHHZJO40vjH1EE5JV b75VOa6ZYyoYfksSVU1WoocmGT+Dtuto2buUcSkXwLMAgSoMqJGUHI7PO2r71Dt3Xdtf bkO+Ea+kshkxlmBwLGvrqhjZkeoZlEQPDn2bZnV77a80ocWfx2edRLqtA4vfZ0c1pKUn ebczr2kIZHilcB6NvAZr2C0lPXXVAZzBtRNObsevGadfLYp7vmMwMTenN2G2OPX1MK1t EMiw== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id f72si15937183pfa.67.2019.06.25.12.44.54; Tue, 25 Jun 2019 12:45:09 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731169AbfFYRKg (ORCPT + 99 others); Tue, 25 Jun 2019 13:10:36 -0400 Received: from mga12.intel.com ([192.55.52.136]:21632 "EHLO mga12.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727039AbfFYRKg (ORCPT ); Tue, 25 Jun 2019 13:10:36 -0400 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga008.jf.intel.com ([10.7.209.65]) by fmsmga106.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 25 Jun 2019 10:10:22 -0700 X-IronPort-AV: E=Sophos;i="5.63,416,1557212400"; d="scan'208";a="155572110" Received: from unknown (HELO [10.232.112.175]) ([10.232.112.175]) by orsmga008-auth.jf.intel.com with ESMTP/TLS/AES256-SHA; 25 Jun 2019 10:10:22 -0700 Subject: Re: [PATCH] nvme-pci: Avoid leak if pci_p2pmem_virt_to_bus() returns null To: Alan Mikhak , linux-nvme@lists.infradead.org, linux-kernel@vger.kernel.org, keith.busch@intel.com, axboe@fb.com, hch@lst.de, sagi@grimberg.me, palmer@sifive.com, paul.walmsley@sifive.com References: <1561420642-21186-1-git-send-email-alan.mikhak@sifive.com> From: "Heitke, Kenneth" Message-ID: <39cc44bb-28b8-0daf-b059-b78791c77eb1@intel.com> Date: Tue, 25 Jun 2019 11:10:21 -0600 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:60.0) Gecko/20100101 Thunderbird/60.7.2 MIME-Version: 1.0 In-Reply-To: <1561420642-21186-1-git-send-email-alan.mikhak@sifive.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 6/24/2019 5:57 PM, Alan Mikhak wrote: > Modify nvme_alloc_sq_cmds() to call pci_free_p2pmem() > to free the memory it allocated using pci_alloc_p2pmem() > in case pci_p2pmem_virt_to_bus() returns null. > > Make sure not to call pci_free_p2pmem() if pci_alloc_p2pmem() > returned null which can happen if CONFIG_PCI_P2PDMA is not > configured. > > Signed-off-by: Alan Mikhak > --- > drivers/nvme/host/pci.c | 14 +++++++++----- > 1 file changed, 9 insertions(+), 5 deletions(-) > > diff --git a/drivers/nvme/host/pci.c b/drivers/nvme/host/pci.c > index 524d6bd6d095..5dfa067f6506 100644 > --- a/drivers/nvme/host/pci.c > +++ b/drivers/nvme/host/pci.c > @@ -1456,11 +1456,15 @@ static int nvme_alloc_sq_cmds(struct nvme_dev *dev, struct nvme_queue *nvmeq, > > if (qid && dev->cmb_use_sqes && (dev->cmbsz & NVME_CMBSZ_SQS)) { > nvmeq->sq_cmds = pci_alloc_p2pmem(pdev, SQ_SIZE(depth)); > - nvmeq->sq_dma_addr = pci_p2pmem_virt_to_bus(pdev, > - nvmeq->sq_cmds); > - if (nvmeq->sq_dma_addr) { > - set_bit(NVMEQ_SQ_CMB, &nvmeq->flags); > - return 0; > + if (nvmeq->sq_cmds) { > + nvmeq->sq_dma_addr = pci_p2pmem_virt_to_bus(pdev, > + nvmeq->sq_cmds); > + if (nvmeq->sq_dma_addr) { > + set_bit(NVMEQ_SQ_CMB, &nvmeq->flags); > + return 0; > + } > + > + pci_free_p2pmem(pdev, nvmeq->sq_cmds, SQ_SIZE(depth)); Should the pointer be set to NULL here, just in case? > } > } > >