Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp2323871imu; Thu, 29 Nov 2018 03:13:42 -0800 (PST) X-Google-Smtp-Source: AFSGD/U8+1NdX2G/rJcxWqammT6A06qKuitHkvayvH6QQiRjKl+8g09eohcpQAJBzGNMyOTvV1gV X-Received: by 2002:a63:6ac5:: with SMTP id f188mr863216pgc.165.1543490021975; Thu, 29 Nov 2018 03:13:41 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1543490021; cv=none; d=google.com; s=arc-20160816; b=XbozSkQaG2fjRVUHI2T01Rz476tsADbZVGx6Q3uzGPAV0wEgEU4ehFNW1Ae785PBT1 VzajX9Xk8MdI/C2/bDqGVmsIl60ql5zNDfedCELTYdxdyDv/Np+8MwV+gNGpKGwUiW2b HqZfVg0p/8TqimxyIc/Q+AwPDGk/JlSYPcrqht/VPXBu6DgUSMBH7qvuUWUcNZzFXbh4 k1e+d321/aTLkXSJowBINlFQbyA/0WZQGOv7b5gJo9J1LRDI4wLGwNPMfgVpyJUjFhSd ObW1bMRRiV5TqlnMTxTC50B9yDdgccNG78n8kN2lyAoLDM7Kz9m/ohiXenCI44O5lB7o Ch5Q== 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:mime-version :references:in-reply-to:date:cc:to:from:subject:message-id; bh=ayscUWIc2A5m5ekeUVldQfzo19bA1CQyf9bcj6+Brsk=; b=mnXZLh3fbPRc3Zw3VL9VtvsFyIfht1CDUzwWCU/oKvc4RzzGjWwDcbI5A/mJTIFzAx vSkmPiM6QMN0AOgomQIyePadJLJgkKwdNajCzEgVwHMGJzIzAcNJtS2AptNpa7JqkdlO eEG4rAerT6zP14KpNgeub+2K2Sw/hDwyHHe5J/3jQiCrMyLr8KcoyqlHThT1wXxgvkmf TOYTjfYAMad5SvfFl7VVN9kSpo8bSCsj20mCFkdq0Vv1rA6LldeftCjSzkRg4ufEqBcU tJYtjomwBL2nQc1s7kxUetYxO/qNjj17asiEiTwFV3gzUGKC75qXn3AKrgaxUUIzJ4bN Rrcw== 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 u184si1633012pgd.262.2018.11.29.03.13.26; Thu, 29 Nov 2018 03:13:41 -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 S1728045AbeK2WRP (ORCPT + 99 others); Thu, 29 Nov 2018 17:17:15 -0500 Received: from metis.ext.pengutronix.de ([85.220.165.71]:42187 "EHLO metis.ext.pengutronix.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727114AbeK2WRO (ORCPT ); Thu, 29 Nov 2018 17:17:14 -0500 Received: from kresse.hi.pengutronix.de ([2001:67c:670:100:1d::2a]) by metis.ext.pengutronix.de with esmtp (Exim 4.89) (envelope-from ) id 1gSKEr-0008La-01; Thu, 29 Nov 2018 12:12:08 +0100 Message-ID: <1543489928.2507.59.camel@pengutronix.de> Subject: Re: [PATCH 3/3] PCI: imx: Add support for i.MX8MQ From: Lucas Stach To: Andrey Smirnov , Leonard Crestez Cc: Richard Zhu , linux-imx@nxp.com, Chris Healy , Dong Aisheng , linux-kernel , Rob Herring , "open list:OPEN FIRMWARE AND FLATTENED DEVICE TREE BINDINGS" , Fabio Estevam , Mark Rutland , linux-arm-kernel , Bjorn Helgaas , linux-pci@vger.kernel.org Date: Thu, 29 Nov 2018 12:12:08 +0100 In-Reply-To: References: <20181117181225.10737-1-andrew.smirnov@gmail.com> <20181117181225.10737-4-andrew.smirnov@gmail.com> <1543313169.2507.39.camel@pengutronix.de> Content-Type: text/plain; charset="UTF-8" X-Mailer: Evolution 3.22.6-1+deb9u1 Mime-Version: 1.0 Content-Transfer-Encoding: 8bit X-SA-Exim-Connect-IP: 2001:67c:670:100:1d::2a X-SA-Exim-Mail-From: l.stach@pengutronix.de X-SA-Exim-Scanned: No (on metis.ext.pengutronix.de); SAEximRunCond expanded to false X-PTX-Original-Recipient: linux-kernel@vger.kernel.org Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Am Dienstag, den 27.11.2018, 13:14 -0800 schrieb Andrey Smirnov: > On Tue, Nov 27, 2018 at 2:46 AM Leonard Crestez wrote: > > > > On 11/27/18 12:06 PM, Lucas Stach wrote: > > > Hi Andrey, > > > > > > Am Montag, den 26.11.2018, 10:24 -0800 schrieb Andrey Smirnov: > > > > On Tue, Nov 20, 2018 at 2:49 AM Leonard Crestez wrote: > > > > > > > > > > On Sat, 2018-11-17 at 10:12 -0800, Andrey Smirnov wrote: > > > > > > @@ -921,7 +1004,28 @@ static int imx6_pcie_probe(struct platform_device *pdev) > > > > > > -     case IMX7D: > > > > > > +     case IMX8MQ: > > > > > > +             if (of_property_read_u32(node, "fsl,iomux-gpr1x", > > > > > > +                                      &imx6_pcie->gpr1x)) { > > > > > > +                     dev_err(dev, "Failed to get GPR1x address\n"); > > > > > > +                     return -EINVAL; > > > > > > +             } > > > > > > > > > > This is for distinguishing multiple controllers on the SOC but other > > > > > registers and bits might differ. Isn't it preferable to have a property > > > > > for controller id instead of adding many registers to DT? > > > > > > > > I liked encoding necessary info in DT directly slightly better than > > > > encoding abstract ID and then decoding it further in the driver code. > > > > OTOH, I am not really attached to that path. Lucas, can you comment on > > > > this please? > > > > > > Yes, after rereading the patch with this in mind I agree that having > > > the GPR offset on DT directly is IMO the better approach than an > > > abstract ID. > > > > But it's not a single offset, for example the device_type (EP/RC) has > > bits for the two controllers side-by-side in GPR12. > > > > Playing devil's advocate for a bit: > > More specifically, currently the following per-controller bits need to > be configured: > > - Location of the "device type" field within GPR12 > - GPR register to use to control PCIn_CLKREQ_B_OVERRIDE_EN and > PCIn_CLKREQ_B_OVERRIDE_EN (GPR14 vs GPR16) > - Now that Philip spoke against PCIE_CTRL_APPS_CLK_REQ being exposed > via reset controller driver, we need to know which SRC register to use > to control that bit (SRC_PCIEPHY_RCR vs. SRC_PCIE2_RCR) If if we need a lot of different GPR offsets, I revise my earlier opinion. We certainly don't want lots of bit offsets and masks in the DT. The whole GPR thing is ugly, but I would rather hide this in the driver code, keyed by compatible and a controller id property, where we can change things without any worries about DT backward compatibility. Regards, Lucas