Received: by 10.213.65.68 with SMTP id h4csp2723355imn; Mon, 2 Apr 2018 12:47:20 -0700 (PDT) X-Google-Smtp-Source: AIpwx49YXIKjhjnD35OPlYl0Leoo5dmJFByFPGfZYIvplpZf+MubIvLEcpR3UgHAnh5YaHKE6KND X-Received: by 2002:a17:902:8287:: with SMTP id y7-v6mr11076967pln.85.1522698439877; Mon, 02 Apr 2018 12:47:19 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1522698439; cv=none; d=google.com; s=arc-20160816; b=JaD/mDHMalrYdBpxjvGjFnc5fChXGJbIzZmkYywuSZgi/TQ8nvVgR9KpCZlOgJqcAk HoOB5VRc1M0Tbqq0vPGd7UgwwP9cpernjGNSK446TeE/T2JxQTU3MZJVDpi0hDXJUp3F NsyVyFwA885SuWuuDWc0jUGJy3DsatHLpaonqCRtTvpBO8EDf7oe2A9r+Gvd2HUFn4Ca Rt4bNXkII7GqcDLMEvqPn3nqC/pE3KfhqLMXohLAkCa2Kdr1oh1mBKBJXJHl9O/FmIZ5 edFwMtbQD8YdCNPg3hGs0XKWqtpsfVcWx/XJ0aaS4W/CaV3LJ7l4eVT/dA9ai4RIw17c xMbA== 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:dkim-signature:arc-authentication-results; bh=sSUN+8EnUsQI1Kittd/Cly/zh+tdP8KY+k1toBJCAus=; b=bdFbfH4MYfzMQTJw7kMhvsr33SZGTARltj51b0fl3uR7J75v6otBz7IF8dRKF6Vhzq ixtNDwVYL7S6OCxcbXivTx9GOLEHFk9i2Kma3q8TeG42J7eplrfRXYhbV37mFFO4n775 T0ljhl+jQnd7tVo0OZhzQlUng1WoozMiNX2tLdQVA8ij359BrL/tB09nRSFMYUNcAsWf Hh3P+KvVRPuuLOxiKxd/lll9/UDFOYyKuJlEPLXz+gG4ckGQrG9IH2cHKMM5hslAZf+n fvQyONOhQJT7tJKYkOqLDMrmxXpQo/S1j7BGR+Yo955knZnGjQ0X9L0IZ9eabF2mjQoR 7emA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass (test mode) header.i=@flawful.org header.s=mail header.b=ArA3aJJQ; 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 c23si680826pgn.186.2018.04.02.12.47.05; Mon, 02 Apr 2018 12:47:19 -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; dkim=pass (test mode) header.i=@flawful.org header.s=mail header.b=ArA3aJJQ; 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 S1756820AbeDBThJ (ORCPT + 99 others); Mon, 2 Apr 2018 15:37:09 -0400 Received: from ste-pvt-msa2.bahnhof.se ([213.80.101.71]:3357 "EHLO ste-pvt-msa2.bahnhof.se" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754655AbeDBThH (ORCPT ); Mon, 2 Apr 2018 15:37:07 -0400 Received: from localhost (localhost [127.0.0.1]) by ste-pvt-msa2.bahnhof.se (Postfix) with ESMTP id A96E33F41C; Mon, 2 Apr 2018 21:37:05 +0200 (CEST) X-Virus-Scanned: Debian amavisd-new at bahnhof.se Authentication-Results: ste-ftg-msa2.bahnhof.se (amavisd-new); dkim=pass (1024-bit key) header.d=flawful.org Received: from ste-pvt-msa2.bahnhof.se ([127.0.0.1]) by localhost (ste-ftg-msa2.bahnhof.se [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id o8CaYqcwc4PC; Mon, 2 Apr 2018 21:37:05 +0200 (CEST) Received: from flawful.org (h-184-10.A323.priv.bahnhof.se [155.4.184.10]) (Authenticated sender: mb274189) by ste-pvt-msa2.bahnhof.se (Postfix) with ESMTPA id 5440A3F3B0; Mon, 2 Apr 2018 21:37:04 +0200 (CEST) Received: by flawful.org (Postfix, from userid 1001) id 9DC21C996; Mon, 2 Apr 2018 21:37:03 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=flawful.org; s=mail; t=1522697823; bh=sSUN+8EnUsQI1Kittd/Cly/zh+tdP8KY+k1toBJCAus=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=ArA3aJJQVfqcZchY4YsJ2eTwHXUiioTq0cEtpv8BSDwPq2T2cYKU9s2zSyUbRCDXG /TaZRk68DTjSgNYPA9ULfs4H31QCX4rZ35aSh4GIgGCLlSOcWG6zGUQKbIoopPQH/l sseqaLdzEAdX7cqo9QJY+uFYhgKeZ49u57eTqmG0= Date: Mon, 2 Apr 2018 21:37:03 +0200 From: Niklas Cassel To: Kishon Vijay Abraham I Cc: Niklas Cassel , cyrille.pitchen@free-electrons.com, Jingoo Han , Joao Pinto , Lorenzo Pieralisi , Bjorn Helgaas , Niklas Cassel , linux-pci@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH v5 06/12] PCI: designware-ep: Make dw_pcie_ep_set_bar() handle 64-bit BARs properly Message-ID: <20180402193703.GB23587@flawful.org> References: <20180328115018.31921-1-niklas.cassel@axis.com> <20180328115018.31921-7-niklas.cassel@axis.com> <45971780-3a46-061d-bb76-2f450401c797@ti.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <45971780-3a46-061d-bb76-2f450401c797@ti.com> User-Agent: Mutt/1.5.23 (2014-03-12) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Mar 29, 2018 at 03:17:11PM +0530, Kishon Vijay Abraham I wrote: > Hi, > > On Wednesday 28 March 2018 05:20 PM, Niklas Cassel wrote: > > Since a 64-bit BAR consists of a BAR pair, we need to write to both > > BARs in the BAR pair to setup the BAR properly. > > > > Signed-off-by: Niklas Cassel > > --- > > drivers/pci/dwc/pcie-designware-ep.c | 11 +++++++++-- > > 1 file changed, 9 insertions(+), 2 deletions(-) > > > > diff --git a/drivers/pci/dwc/pcie-designware-ep.c b/drivers/pci/dwc/pcie-designware-ep.c > > index 5a0bb53c795c..571b90f88d84 100644 > > --- a/drivers/pci/dwc/pcie-designware-ep.c > > +++ b/drivers/pci/dwc/pcie-designware-ep.c > > @@ -138,8 +138,15 @@ static int dw_pcie_ep_set_bar(struct pci_epc *epc, u8 func_no, > > return ret; > > > > dw_pcie_dbi_ro_wr_en(pci); > > - dw_pcie_writel_dbi2(pci, reg, size - 1); > > - dw_pcie_writel_dbi(pci, reg, flags); > > + if (flags & PCI_BASE_ADDRESS_MEM_TYPE_64) { > > + dw_pcie_writel_dbi2(pci, reg, lower_32_bits(size - 1)); > > + dw_pcie_writel_dbi(pci, reg, flags); > > + dw_pcie_writel_dbi2(pci, reg + 4, upper_32_bits(size - 1)); > > + dw_pcie_writel_dbi(pci, reg + 4, 0); > > + } else { > > + dw_pcie_writel_dbi2(pci, reg, size - 1); > > + dw_pcie_writel_dbi(pci, reg, flags); > > + } > > > I think this should work too? > dw_pcie_writel_dbi2(pci, reg, lower_32_bits(size - 1)); > dw_pcie_writel_dbi(pci, reg, flags); > > if (flags & PCI_BASE_ADDRESS_MEM_TYPE_64) { > dw_pcie_writel_dbi2(pci, reg + 4, upper_32_bits(size - 1)); > dw_pcie_writel_dbi(pci, reg + 4, 0); > } > Hello Kishon, I agree, your suggestion is more neat. Kishon, please tell me if you insist that the long if-statement in pci_epc_set_bar() should be split, since there are 5 different conditions. Because imho, having 5 succeeding if-statements isn't clearer than having 1 long if-statement. If Kishon agrees with me, then the review comment in this mail seems to be the only review comment. And in that case, perhaps Lorenzo wouldn't mind fixing this up. Or perhaps Lorenzo prefers if I reroll the whole patch series? Kind regards, Niklas