Received: by 2002:ac0:a5b6:0:0:0:0:0 with SMTP id m51-v6csp4522330imm; Mon, 11 Jun 2018 13:55:46 -0700 (PDT) X-Google-Smtp-Source: ADUXVKKpYKmJQ8jDL4s1pq2HfFQXfhdLUgH2DRvDaoSuCYdGIjvSVviE/pRvrzMpRchrDgrlIlbu X-Received: by 2002:a17:902:7c83:: with SMTP id y3-v6mr736622pll.51.1528750546744; Mon, 11 Jun 2018 13:55:46 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1528750546; cv=none; d=google.com; s=arc-20160816; b=DLgo5G40wgw/iv95Ayw4aKi+UqugxT0YAp+S1lYgDvSvrzkAh6y4GpFal7YIEqcQgl BxOYVDpHiJyX0cDwmCFXHbkBetfgIUDLyf1tZouCQVHTQ8f/m7kgS1Fnf10wPocEcLI3 Qb0IHe5OvCK5sHb1eNS3ilQfRuIlMqZqo1yTWCHl2AlNidhu57YrOrIs3g/PyC3AOo77 mVPA7JLv+txTYQbNKlD0/LLczUrrQ41iZo6tRTczHYs79mD1oMbp2MAe1W166cqXpZ49 MnsLptIF1B/gk9DjzzCXQtVOOaPIjn4HJklX8KxhDgWRheqv/D37o3QRFmbCnhTqFapj y4Ww== 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:cc:to:subject:arc-authentication-results; bh=k3IQmr0ghz2dTY4xmRE8v4DzEVROQapeOHsVOkjaRdw=; b=04t0oVKj5+ONnIItVoqjPZoaEr0qm4+teijkKBd8rfJz1RmihJboQyh05CN6r2P19A zTkJVRF+uP8/q8UQlEnbB6OSh1FPn2NcJpBDzR7WzQEpgVopdZq871ulqG1ybT4xmu9L /gYBZe9UqVFM0h/NkN6mApM9Shh1YVhE22Fhz6Axd/ImLeLBuzOmJ5hK5yH1d4uorHxR fZ/fGMjaUEwJoiktscdKJBNi54VohurrpoftirVuzbDF0q1nMBqNfrB4QrCDE4Y6GsCl VtHeG+sGs+2/RLPnBSZYto4Zp8+A54qymXe2F8atK/9TJa86gmfW+H6keMv7u+hCOAI9 /DcA== 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 t23-v6si65185977plo.508.2018.06.11.13.55.32; Mon, 11 Jun 2018 13:55:46 -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 S934513AbeFKUvu (ORCPT + 99 others); Mon, 11 Jun 2018 16:51:50 -0400 Received: from mga02.intel.com ([134.134.136.20]:22630 "EHLO mga02.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S933366AbeFKUvt (ORCPT ); Mon, 11 Jun 2018 16:51:49 -0400 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga004.fm.intel.com ([10.253.24.48]) by orsmga101.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 11 Jun 2018 13:51:49 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.51,211,1526367600"; d="scan'208";a="62279502" Received: from djiang5-desk3.ch.intel.com ([143.182.136.93]) by fmsmga004.fm.intel.com with ESMTP; 11 Jun 2018 13:51:48 -0700 Subject: Re: [PATCH 2/8] NTB: Setup the DMA mask globally for all drivers To: Logan Gunthorpe , linux-kernel@vger.kernel.org, linux-ntb@googlegroups.com Cc: Jon Mason , Allen Hubbe , Serge Semin , Shyam Sundar S K , Shuah Khan References: <20180609000819.13883-1-logang@deltatee.com> <20180609000819.13883-3-logang@deltatee.com> From: Dave Jiang Message-ID: <25c67d72-9cb0-6a13-3614-b549906e222c@intel.com> Date: Mon, 11 Jun 2018 13:51:48 -0700 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.7.0 MIME-Version: 1.0 In-Reply-To: <20180609000819.13883-3-logang@deltatee.com> Content-Type: text/plain; charset=utf-8 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 06/08/2018 05:08 PM, Logan Gunthorpe wrote: > Commit 417cf39cfea9 ("NTB: Set dma mask and dma coherent mask to NTB > devices") added code to set the DMA mask for the NTB device > to each driver individually. However, it neglected to set it for the > Switchtec driver. So when the monolithic commit 7f46c8b3a552 ("NTB: > ntb_tool: Add full multi-port NTB API support") started allocating > DMA memory against the NTB device it broke the Switchtec driver. > > Seeing this is setting up a property of the NTB device, it should be > done by the common NTB code (inside ntb_register_device()) so we can be > sure it's done properly for all drivers. This avoids each driver needing > to duplicate the code and helps prevent us from inadvertently breaking > one of the drivers in the future if we have to make changes in this area. > > Fixes: 7f46c8b3a552 ("NTB: ntb_tool: Add full multi-port NTB API support") > Signed-off-by: Logan Gunthorpe Acked-by: Dave Jiang for the Intel parts and the generic parts > --- > drivers/ntb/hw/amd/ntb_hw_amd.c | 4 ---- > drivers/ntb/hw/idt/ntb_hw_idt.c | 6 ------ > drivers/ntb/hw/intel/ntb_hw_intel.c | 4 ---- > drivers/ntb/ntb.c | 13 ++++++++++++- > 4 files changed, 12 insertions(+), 15 deletions(-) > > diff --git a/drivers/ntb/hw/amd/ntb_hw_amd.c b/drivers/ntb/hw/amd/ntb_hw_amd.c > index 3cfa46876239..f0788aae05c9 100644 > --- a/drivers/ntb/hw/amd/ntb_hw_amd.c > +++ b/drivers/ntb/hw/amd/ntb_hw_amd.c > @@ -1020,10 +1020,6 @@ static int amd_ntb_init_pci(struct amd_ntb_dev *ndev, > goto err_dma_mask; > dev_warn(&pdev->dev, "Cannot DMA consistent highmem\n"); > } > - rc = dma_coerce_mask_and_coherent(&ndev->ntb.dev, > - dma_get_mask(&pdev->dev)); > - if (rc) > - goto err_dma_mask; > > ndev->self_mmio = pci_iomap(pdev, 0, 0); > if (!ndev->self_mmio) { > diff --git a/drivers/ntb/hw/idt/ntb_hw_idt.c b/drivers/ntb/hw/idt/ntb_hw_idt.c > index 8d98872d0983..1918a2db1c43 100644 > --- a/drivers/ntb/hw/idt/ntb_hw_idt.c > +++ b/drivers/ntb/hw/idt/ntb_hw_idt.c > @@ -2447,12 +2447,6 @@ static int idt_init_pci(struct idt_ntb_dev *ndev) > dev_warn(&pdev->dev, > "Cannot set consistent DMA highmem bit mask\n"); > } > - ret = dma_coerce_mask_and_coherent(&ndev->ntb.dev, > - dma_get_mask(&pdev->dev)); > - if (ret != 0) { > - dev_err(&pdev->dev, "Failed to set NTB device DMA bit mask\n"); > - return ret; > - } > > /* > * Enable the device advanced error reporting. It's not critical to > diff --git a/drivers/ntb/hw/intel/ntb_hw_intel.c b/drivers/ntb/hw/intel/ntb_hw_intel.c > index 156b45cd4a19..341a3d5baa3f 100644 > --- a/drivers/ntb/hw/intel/ntb_hw_intel.c > +++ b/drivers/ntb/hw/intel/ntb_hw_intel.c > @@ -2334,10 +2334,6 @@ static int intel_ntb_init_pci(struct intel_ntb_dev *ndev, struct pci_dev *pdev) > goto err_dma_mask; > dev_warn(&pdev->dev, "Cannot DMA consistent highmem\n"); > } > - rc = dma_coerce_mask_and_coherent(&ndev->ntb.dev, > - dma_get_mask(&pdev->dev)); > - if (rc) > - goto err_dma_mask; > > ndev->self_mmio = pci_iomap(pdev, 0, 0); > if (!ndev->self_mmio) { > diff --git a/drivers/ntb/ntb.c b/drivers/ntb/ntb.c > index 2581ab724c34..93f24440d11d 100644 > --- a/drivers/ntb/ntb.c > +++ b/drivers/ntb/ntb.c > @@ -100,6 +100,8 @@ EXPORT_SYMBOL(ntb_unregister_client); > > int ntb_register_device(struct ntb_dev *ntb) > { > + int ret; > + > if (!ntb) > return -EINVAL; > if (!ntb->pdev) > @@ -120,7 +122,16 @@ int ntb_register_device(struct ntb_dev *ntb) > ntb->ctx_ops = NULL; > spin_lock_init(&ntb->ctx_lock); > > - return device_register(&ntb->dev); > + device_initialize(&ntb->dev); > + > + ret = dma_coerce_mask_and_coherent(&ntb->dev, > + dma_get_mask(&ntb->pdev->dev)); > + if (ret != 0) { > + dev_err(&ntb->dev, "Failed to set NTB device DMA bit mask\n"); > + return ret; > + } > + > + return device_add(&ntb->dev); > } > EXPORT_SYMBOL(ntb_register_device); > >