Received: by 2002:a25:c593:0:0:0:0:0 with SMTP id v141csp1126792ybe; Mon, 2 Sep 2019 15:05:54 -0700 (PDT) X-Google-Smtp-Source: APXvYqxYoV741KHBF41JzrB+FB0Nba1TwvAIISRVtbUfOgR09lMg8DJuTMPwQBHg8XK1aRgw/HXR X-Received: by 2002:a17:902:b58f:: with SMTP id a15mr3804496pls.81.1567461954883; Mon, 02 Sep 2019 15:05:54 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1567461954; cv=none; d=google.com; s=arc-20160816; b=UkKY/aJEKz68IpdphDtNgUBH7JlRY8tBlTt3aBpLsql2Zh4SWbaIJAZ4olMYqlkpOC UpoJUQR4rOpnZ6OCg0rD1eB0eyi2ADOIoz+cCGru8TpHU4/uEYaLJwAUGHLCzKPgzYJq HTrMWz1sp+w7CR2/GndqZhSHV7vJ/1xrd0FefvLMbK9LI3Nglelr7IBzzbee1x9Dgd9R 8w0ekSyFpAkR9MZewn2xsZSGuZo05r9R9gY404bkyAGTVOmUbDg1KH8L1xTq/p0wMhRG dAx/N3gzObO2Dk/7f6swak92nV9so49gqtWIf7J99eXzE5GRRNXgPn5ybLnincNFybR1 2UEw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:dkim-signature; bh=IjxbbmbaScar5G9t17eQujGLEddpWeSgeOopYsl1QiQ=; b=YV7nLyXmaHB6XZjtaiNczm4e8e1cVzd4IHP+QUu2TQ/5Zj2FzF5KN3mAqp3hE5FWzk QF369RgqxKZwYgpLZzH/ke+kznTwLk+KTgLj0cF6F8iUwCcqhafyIRBJMDi5PaEIR0JT jyRw7xbRG9ZacW4/DU4waq/ViHZpW5CWo2AjCGKEY2oF1lstFEHvdE+YNXlg2bMMqhuk U393n2hPVWLmjzNk9fo7/RXFJ9obnVLcyVDtRXTzuIfgyeiCbtqWT/P13/tsbCeL9wx4 jp5DmsYRuCb3lrKOVA+P/gcFBgNZHWbGV7/HmNwJVNGj5ARc4bOqXUIU2gKNocLWsGks pFkA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@googlemail.com header.s=20161025 header.b=R41g14fk; 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=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=googlemail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id o2si7287548pgm.359.2019.09.02.15.05.38; Mon, 02 Sep 2019 15:05:54 -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 header.i=@googlemail.com header.s=20161025 header.b=R41g14fk; 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=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=googlemail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727731AbfIBWEv (ORCPT + 99 others); Mon, 2 Sep 2019 18:04:51 -0400 Received: from mail-ot1-f66.google.com ([209.85.210.66]:34014 "EHLO mail-ot1-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726933AbfIBWEu (ORCPT ); Mon, 2 Sep 2019 18:04:50 -0400 Received: by mail-ot1-f66.google.com with SMTP id c7so14818952otp.1; Mon, 02 Sep 2019 15:04:49 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=googlemail.com; s=20161025; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=IjxbbmbaScar5G9t17eQujGLEddpWeSgeOopYsl1QiQ=; b=R41g14fk+tfIZ4YZ+gauurcCP1l0El0uiYBkePlyv4gMb2bG/HXaSZ7hiMA+UxoT3H XcX/nVClCacfIE+vv9S+aaCk3R6/xch4OWaSIkDNXrLNg6+OImQmVne0BGkE1nsdqIZX +Ch035xSIQmgVuvhgc1uXGmbgTbwku8DUleNsnEh+BNB5kjIyD77gUBeXCqKu0oHkyuq zKt+gmRqf3sGSoTuHhPpBv4/wg9Rr44C9GHO6MgiqI9UH980uRIqJ1/LlX4YbXDhOHCQ O+HnEl7bbSH1lks9PmyrYcmNsPcSXclLglli5uA+2kPx0xrnaGkD7hHi02CS+1UY1F6Q 4Qvg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=IjxbbmbaScar5G9t17eQujGLEddpWeSgeOopYsl1QiQ=; b=SjZPInydCUy91uZb7lEXzs4LUzjmQ7RrpUFRPxm7bCy8ZcL/ktLyFp9EOg6koO1iGJ 0D9YJKpLwiAEHMIjcW0awkLrzfwu8fCB6tioGvp8fH8PuBwVbW+flBR9QWmb1xX45KeP Co72hr7+Tm4xo1PsPDcWQfut+bykdZCuVm41ymg+PZx1ZWAka9I5sDKegvqKQyB6nKcx VAHEhju5DT65w7qL7yIFJuzLpQotEH2lmpjyYaG1jDtuOJfHfi7v/rT279n9QyyWOqIr haD7GpshaIbEbDtn2ucGLafiXVodZpxF1hDWWRuNja7801ZshQlpRxWJA7biUp4MyZlx u2aw== X-Gm-Message-State: APjAAAWBjZIdHD8yhffio8oVOxip8DfET4V233ywaTENngeETWHMd3Pr qgYFqgX6x1LKzVYIAZx9A1gJ8ePZ4L6mMZvTG88= X-Received: by 2002:a9d:6c0e:: with SMTP id f14mr14868159otq.6.1567461888990; Mon, 02 Sep 2019 15:04:48 -0700 (PDT) MIME-Version: 1.0 References: <90cc600d6f7ded68f5a618b626bd9cffa5edf5c3.1566531960.git.eswara.kota@linux.intel.com> <20190824211158.5900-1-martin.blumenstingl@googlemail.com> <3813e658-1600-d878-61a4-29b4fe51b281@linux.intel.com> <48b90943-e23d-a27a-c743-f321345c9151@linux.intel.com> <19719490-178a-18fd-64f2-f77d955897f7@linux.intel.com> <34336c9a-8e87-8f84-2ae8-032b7967928f@linux.intel.com> <657d796d-cb1b-472d-fe67-f7b9bf12fd79@linux.intel.com> In-Reply-To: From: Martin Blumenstingl Date: Tue, 3 Sep 2019 00:04:37 +0200 Message-ID: Subject: Re: [PATCH v2 2/2] reset: Reset controller driver for Intel LGM SoC To: "Chuan Hua, Lei" Cc: eswara.kota@linux.intel.com, cheol.yong.kim@intel.com, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, p.zabel@pengutronix.de, qi-ming.wu@intel.com, robh@kernel.org, Hauke Mehrtens Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi, On Mon, Sep 2, 2019 at 11:45 AM Chuan Hua, Lei wrote: > > Hi Martin, > > > On 9/2/2019 5:38 AM, Martin Blumenstingl wrote: > > Hi, > > > > On Fri, Aug 30, 2019 at 5:02 AM Chuan Hua, Lei > > wrote: > >> Hi Martin, > >> > >> On 8/30/2019 5:40 AM, Martin Blumenstingl wrote: > >>> Hi, > >>> > >>> On Thu, Aug 29, 2019 at 4:51 AM Chuan Hua, Lei > >>> wrote: > >>> > >>>>> I'm not surprised that we got some of the IP block layout for the > >>>>> VRX200 RCU "wrong" - all "documentation" we have is the old Lantiq UGW > >>>>> (BSP). > >>>>> with proper documentation (as in a "public datasheet for the SoC") it > >>>>> would be easy to spot these mistakes (at least I assume that the > >>>>> quality of the Infineon / Lantiq datasheets is excellent). > >>>>> > >>>>> back to reset-intel-syscon: > >>>>> assigning only one job to the RCU hardware is a good idea (in my opinion). > >>>>> that brings up a question: why do we need the "syscon" compatible for > >>>>> the RCU node? > >>>>> this is typically used when registers are accessed by another IP block > >>>>> and the other driver has to access these registers as well. does this > >>>>> mean that there's more hidden in the RCU registers? > >>>> As I mentioned, some other misc registers are put into RCU even they > >>>> don't belong to reset functions. > >>> OK, just be aware that there are also rules for syscon compatible > >>> drivers, see for example: [0] > >>> if Rob (dt-bindings maintainer) is happy with the documentation in > >>> patch 1 then I'm fine with it as well. > >>> for my own education I would appreciate if you could describe these > >>> "other misc registers" with a few sentences (I assume that this can > >>> also help Rob) > >> For LGM, RCU is clean. There would be no MISC register after software's > >> feedback. These misc registers will be moved to chiptop/misc > >> groups(implemented by syscon). For legacy SoC, we do have a lot MISC > >> registers for different SoCs. > > OK, I think I understand now: chiptop != RCU > > so RCU really only has one purpose: handling resets > > while chiptop manages all the random bits > > > > does this means we don't need RCU to match "syscon"? > > If we don't support legacy SoC with the same driver, we don't need > syscon, just regmap. Regmap is a must for us since we will use regmap > proxy to implement secure rest via secure processor. I think we should drop the syscon compatible for LGM then even for the legacy SoCs the reset controller should not have a syscon compatible: instead it should have a syscon parent (as the current "lantiq,xrx200-reset" binding requires and as suggested by Rob for another IP block: [0]) keeping regmap is great in my opinion because it's a nice API and gets rid of some boilerplate even better if it makes things easier for accessing the secure processor > > > >>> [...] > >>>>>>>>>> 4. Code not optimized and intel internal review not assessed. > >>>>>>>>> insights from you (like the issue with the reset callback) are very > >>>>>>>>> valuable - this shows that we should focus on having one driver. > >>>>>>>>> > >>>>>>>>>> Based on the above findings, I would suggest reset-lantiq.c to move to > >>>>>>>>>> reset-intel-syscon.c > >>>>>>>>> my concern with having two separate drivers is that it will be hard to > >>>>>>>>> migrate from reset-lantiq to the "optimized" reset-intel-syscon > >>>>>>>>> driver. > >>>>>>>>> I don't have access to the datasheets for the any Lantiq/Intel SoC > >>>>>>>>> (VRX200 and even older). > >>>>>>>>> so debugging issues after switching from one driver to another is > >>>>>>>>> tedious because I cannot tell which part of the driver is causing a > >>>>>>>>> problem (it's either "all code from driver A" vs "all code from driver > >>>>>>>>> B", meaning it's hard to narrow it down). > >>>>>>>>> with separate commits/patches that are improving the reset-lantiq > >>>>>>>>> driver I can do git bisect to find the cause of a problem on the older > >>>>>>>>> SoCs (VRX200 for example) > >>>>>>>> Our internal version supports XRX350/XRX500/PRX300(MIPS based) and > >>>>>>>> latest Lighting Mountain(X86 based). Migration to reset-intel-syscon.c > >>>>>>>> should be straight forward. > >>>>>>> what about the _reset callback on the XRX350/XRX500/PRX300 SoCs - do > >>>>>>> they only use level resets (_assert and _deassert) or are some reset > >>>>>>> lines using reset pulses (_reset)? > >>>>>>> > >>>>>>> when we wanted to switch from reset-lantiq.c to reset-intel-syscon.c > >>>>>>> we still had to add support for the _reset callback as this is missing > >>>>>>> in reset-intel-syscon.c currently > >>>>>> Yes. We have reset pulse(assert, then check the reset status). > >>>>> only now I realized that the reset-intel-syscon driver does not seem > >>>>> to use the status registers (instead it's looking at the reset > >>>>> registers when checking the status). > >>>>> what happened to the status registers - do they still exist in newer > >>>>> SoCs (like LGM)? why are they not used? > >>>> Reset status check is there. regmap_read_poll_timeout to check status > >>>> big. Status register offset <4) from request register. For legacy, there > >>>> is one exception, we can add soc specific data to handle it. > >>> I see, thank you for the explanation > >>> this won't work on VRX200 for example because the status register is > >>> not always at (reset register - 0x4) > >> As I mentioned, VRX200 and all legacy SoCs (MIPS based) can be solved > >> with one soc data in the compatible array. > >> > >> For example(not same as upstream, but idea is similar) > >> > >> static u32 intel_stat_reg_off(struct intel_reset_data *data, u32 req_off) > >> { > >> if (data->soc_data->legacy && req_off == RCU_RST_REQ) > >> return RCU_RST_STAT; > >> else > >> return req_off + 0x4; > >> } > >> > >>>>> on VRX200 for example there seem to be some cases where the bits in > >>>>> the reset and status registers are different (for example: the first > >>>>> GPHY seems to use reset bit 31 but status bit 30) > >>>>> this is currently not supported in reset-intel-syscon > >>>> This is most tricky and ugly part for VRX200/Danube. Do you have any > >>>> idea to handle this nicely? > >>> with reset-lantiq we have the following register information: > >>> a) reset offset: first reg property > >>> b) status offset: second reg property > >>> c) reset bit: first #reset-cell > >>> d) status bit: second #reset-cell > >>> > >>> reset-intel-syscon derives half of this information from the two #reset-cells: > >>> a) reset offset: first #reset-cell > >>> b) status offset: reset offset - 0x4 > >>> c) reset bit: second #reset-cell > >>> d) status bit: same as reset bit > >>> > >>> I cannot make any suggestion (yet) how to handle VRX200 and LGM in one > >>> driver because I don't know enough about LGM (yet). > >>> on VRX200 my understanding is that we have 64 reset bits (2x 32bit > >>> registers) and 64 status bits (also 2x 32bit registers). each reset > >>> bit has a corresponding status bit but the numbering may be different > >>> it's not clear to me how many resets LGM supports and how they are > >>> organized. for example: I think it makes a difference if "there are 64 > >>> registers with each one reset bit" versus "there are two registers > >>> with 32 bits each" > >>> please share some details how it's organized internally, then I can > >>> try to come up with a suggestion. > >> LGM reset organization is more clean compared with legacy SoCs. We have > >> 8 x 32bit reset and status registers(more modules need to be reset, > >> overall ideas are similar without big change). Their request and status > >> bit is at the same register bit position. Hope this will help you. > > have you already discussed using only one reset cell? > > if there's only one big reset controller in RCU then why not let the > > reset controller driver do it's job of translating a reset line? also > > this represents the hardware best (dt-bindings should describe the > > hardware, drivers then translate that into the various subsystems > > offered by the kernel). > > > > we have to translate it into: > > - status register and bit > > - reset register and bit > > > > for LGM the implementation seems to be the easiest because the reset > > line can be mapped easily to the registers and bit offsets (for > > example like reset-meson.c does it, which also supports 256 reset > > lines together with for example > > include/dt-bindings/reset/amlogic,meson-g12a-reset.h. the latter is > > nice to have but optional) > When we implement this driver, we checked other drivers(hisilicon/*, > reset-berlin.c and etc). After evaluation, we think register offset and > register bit are easier for users to understand and use if they follow > the hardware spec. just so I know how the documentation looks like: does the hardware spec document 8 registers, each with (up to) the 32 reset lines in it? reset-meson.c does it like that, but the difference there is that the reset registers are continuous because there's no status register in between so your existing way of describing the reset line seems fine if Rob is happy with it as well > > we can then implement special translation logic (in other words: a > > separate of_xlate callback) for VRX200 which then has to do more > > "magic" (like you have shown in your example code above: "if the reset > > line belongs to the second set of 32 reset lines then use reset offset > > X and status offset Y" - or even use a translation table as > > reset-imx7.c does) > > > > the current binding is a mix of specifying reset register and bit in > > .dts but calculating the status register. > > I missed the calculation of the status register until you pointed it out earlier > But we still don't have a good solution for VRX200 status bit issues. > Before we solve this issue, it is very difficult to use one driver for OK, let me summarize what we have so far. all SoC have the following "shared" logic so far: - all reset_control_ops callbacks are the same on VRX200 and LGM (assuming we fix the issues you found in the reset-lantiq.c implementation) - internally we should use regmap (LGM for accessing the secure processor, earlier SoCs because the parent is a syscon) - each reset line consists of a reset register offset and bit as well as a status register offset and bit however, we have differences in: - how to map the registers (LGM maps the RCU registers directly while earlier SoCs fetch the parent syscon) - calculation of the status register - calculation of the status bit I see two ways to use one common driver for LGM and the earlier SoCs: 1) use a reset line mapping table as for example reset-imx7.c does. this would include reset register, reset bit, status register and status bit. LGM can use a macro to get rid of the duplication between status bit and reset bit (and the status register offset if you prefer) this case would use #reset-cells = <1> and we wouldn't need to implement the of_xlate callback 2) on VRX200 (and probably the older SoCs as well) we can encode the following information in one 32-bit value: - reset register (max value: 0x48) - status register (max value: 0x24) - reset bit (max value: 32) - status bit (max value: 32) if this also works for LGM we can determine all required information for a reset line in the of_xlate callback and translate it to one 32-bit value. LGM and earlier SoCs would each use it's own of_xlate implementation. the reset_control_ops callback would then unpack the 32-bit value ("unsigned long id") into the reset register and bit as well as status register and bit (as needed) both ways can work, but it depends on what the dt-bindings maintainers (like Rob) think of the binding itself. (dt-bindings follow what the hardware implements, the driver only does the translation between a vendor specific binding and a given subsystem) so we first need Rob's ACK on the binding, then we can figure out the best driver implementation for that binding Martin [0] https://lkml.org/lkml/2019/8/27/849