Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp5591299imu; Tue, 29 Jan 2019 23:41:45 -0800 (PST) X-Google-Smtp-Source: ALg8bN4OsppABDXjUiMwzP2k65sNmHoer8GsAYYEsWzNh5OOBoE9ZfEIls5I0q4Ihz29E/t0vpFN X-Received: by 2002:a17:902:a60f:: with SMTP id u15mr27905293plq.275.1548834105357; Tue, 29 Jan 2019 23:41:45 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1548834105; cv=none; d=google.com; s=arc-20160816; b=KbCntECjeaAB25Upnj2Qq8GRpcFGJScuhdmOvl8Tjx1cDlo8QtFfU6kdfPcFs9WVDk pWTHvT2C9a0KiJN3YFC85itrO+6fkC+K/vK4rKQgbt25Dc1J9XxPl5pB9U6/qrzAGcWd 5nUZJUAXt0HtvbK4I7uwvHRKdky5o14/sd5xBAeLZlpf/ALhMpCajatUbl0faza+gpxl Y4qLY6AFyu1g/zquTxn2rxQ4oe24jymn9FRlsz+UsOa3V0RprMawxm9TgJ8yB05JXbw8 EdHlioUldnxZ6ZpjzKIFeGrYsUsWtCZYn8En5sv7fYA1HmYplaQXIuOiio39vUeRdScu uUrg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=6OdpKyLpwzFqGlv0RqsmWvcbW6VtnXG2WDicXIJtMqc=; b=oX3mr1a1GgDRInTH3jwfWqRB6Awt1Jhxx05oDqCGcyN2BGgFBnyQCIvzOanQ3AGO4Z nb6xXQQmrlTn5KHraU5VdoHsYJg1mjrQSLmxIGcueeDwmHm2MQGJNHL8gAicrNRKc22g sUTiW8A3C41bOLJpnsU4hl62sv7BWQKH45EJfxz93oKujBxjXgXXBiKTbOdYwTJ59gWg wiW01PEKMxopI2CTS/JSoCJkgEQUu04CWx21bDuom3yiVBoqALTZ33WPkVZrn8aofN3R GSot5TkWFkqOzw/f1hL2jD6pn3MVF0PDd1rYxebVrAS1XMKvmZCJpAncBjdjfYlf1z4m iofA== 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 ay7si817836plb.410.2019.01.29.23.41.29; Tue, 29 Jan 2019 23:41:45 -0800 (PST) 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 S1730163AbfA3HlB (ORCPT + 99 others); Wed, 30 Jan 2019 02:41:01 -0500 Received: from verein.lst.de ([213.95.11.211]:50653 "EHLO newverein.lst.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725819AbfA3HlB (ORCPT ); Wed, 30 Jan 2019 02:41:01 -0500 Received: by newverein.lst.de (Postfix, from userid 2407) id 402C968CEC; Wed, 30 Jan 2019 08:40:59 +0100 (CET) Date: Wed, 30 Jan 2019 08:40:59 +0100 From: Christoph Hellwig To: Hanjun Guo Cc: Greg Kroah-Hartman , Robin Murphy , Lorenzo Pieralisi , "Rafael J. Wysocki" , Bjorn Helgaas , Christoph Hellwig , linux-usb@vger.kernel.org, linux-acpi@vger.kernel.org, linux-pci@vger.kernel.org, linux-kernel@vger.kernel.org, linuxarm@huawei.com, John Garry , Jonathan Cameron , anthony.jebson@huawei.com, Hanjun Guo Subject: Re: [RFC PATCH] USB: PCI: set 32bit DMA mask for PCI based USB controllers Message-ID: <20190130074059.GA29458@lst.de> References: <1548831714-3706-1-git-send-email-guohanjun@huawei.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1548831714-3706-1-git-send-email-guohanjun@huawei.com> User-Agent: Mutt/1.5.17 (2007-11-01) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Jan 30, 2019 at 03:01:54PM +0800, Hanjun Guo wrote: > This is the RFC version, I'm not sure this is the best solution, > comments are warmly welcomed. > > Thanks > Hanjun > > drivers/usb/core/hcd-pci.c | 4 ++++ > 1 file changed, 4 insertions(+) > > diff --git a/drivers/usb/core/hcd-pci.c b/drivers/usb/core/hcd-pci.c > index 0343246..a9c33e6 100644 > --- a/drivers/usb/core/hcd-pci.c > +++ b/drivers/usb/core/hcd-pci.c > @@ -188,6 +188,10 @@ int usb_hcd_pci_probe(struct pci_dev *dev, const struct pci_device_id *id) > if (pci_enable_device(dev) < 0) > return -ENODEV; > > + retval = dma_coerce_mask_and_coherent(&dev->dev, DMA_BIT_MASK(32)); > + if (retval) > + return retval; dma_coerce_mask_and_coherent is only for platform devices (and I'm not sure it is a good idea to start with, but that is a different story). PCI device should have the dma_mask pointer set already, so you should use dma_set_mask_and_coherent here.