Received: by 2002:a25:ab43:0:0:0:0:0 with SMTP id u61csp6855326ybi; Wed, 29 May 2019 14:29:08 -0700 (PDT) X-Google-Smtp-Source: APXvYqz4rWyhNueDNEVtqzL3J2KDYI+KY4dwRrdOhbecCZg6PKmrl29okicHe7/wqMlbsSEyiK0Q X-Received: by 2002:a62:7995:: with SMTP id u143mr152811936pfc.61.1559165348003; Wed, 29 May 2019 14:29:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1559165347; cv=none; d=google.com; s=arc-20160816; b=cIRDgMT/OQ4jcSt3D/Wsoz6BITorr/Lt5gwJIo55Pp61xquJ8XHc3peJsbEvA3h000 YeH+m3SEaGB3/xdlgStI0Z9z3B6IFl2GZLYB/3B8VuUO1MMR1pw1vEJDaprI/sjFkBCH oeH95vjGwVMkU/st6YgcirQ90944me0ZkMuesc0oKML6NqqVfsvIIwk92PTYTPtT8r3N aZiVryE35O9egIE7SHeHENzFYhfgoeYni1f1nOJg+RS/5MOAhl+hZ8EJu9NNzFZT3xQ2 80Og10f2t6VG9D8gIYaph1ldDTwnSGFUqgeQ5T/H1STzl0Shv7lrcTcYP8mLbDYtmmu/ L9yw== 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:dkim-signature; bh=AHJUi6ywWg40R8ywUQxkqT+6QFkJHA8t+9/PSoqzOfw=; b=waw6033PMmCIaU03ocb0UzQngsPsa/9w+y4F6dPJmXhgU0AAL36KKXFz1A2gDT3Va9 VfumiA2/VF1KZV+PIjbqedZ+SDFIwpayyAw8Z4/zURy5iqGq9CSRFuG6ip9mcsBj8pOf +GvP18Y1niwXAHtFFmJL624+xTQs4HatuEG/tD9cvTWg2BDek8obamgK/MRCVkAh9jbA ketFLSJFdLtxfPFMrINwfSRj7enbTPP0KvrlRg/6IK2Ir4Rx1i1MENTn678O1EnU8jwe T6eiB4PR01OHqQCz5GifPORkxYYdbKhZ6N0eeIWfoB3sVxvaijYjYzZPWJSB+GJHzC3f G1WQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=A1ReYKqi; 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=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 15si922931pgk.227.2019.05.29.14.28.47; Wed, 29 May 2019 14:29:07 -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=@gmail.com header.s=20161025 header.b=A1ReYKqi; 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=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726724AbfE2VZr (ORCPT + 99 others); Wed, 29 May 2019 17:25:47 -0400 Received: from mail-lf1-f68.google.com ([209.85.167.68]:40635 "EHLO mail-lf1-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726189AbfE2VZr (ORCPT ); Wed, 29 May 2019 17:25:47 -0400 Received: by mail-lf1-f68.google.com with SMTP id a9so1860499lff.7; Wed, 29 May 2019 14:25:44 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-language:content-transfer-encoding; bh=AHJUi6ywWg40R8ywUQxkqT+6QFkJHA8t+9/PSoqzOfw=; b=A1ReYKqiHPO7CPdK/Qtmknka0d817WjVlxF5Og4nGKuBmZJx58JiO437luVA0iPlAI jLo1Yct6MkVoS/qTZ5hv6OOamQ0Rg2N80GI1RpZKqfQ3/Dts5yffjy1jtAnPLzTp9was 3nkRud5bsUZ7hMtOf/Q0Uvz/gaPg5zXIKK5QSTvVvTBScaPX76iQJuOLHjIdf917V2gq uuNMVRUK8Yj1RCp8tZWLleaS0tmGBTtqPXEN864x9q/0JrgdbjwwSydVTFvzrN9mhx8a 9eJ6eU3Xyv6hLlkbb15tXDaNvBOHPe247G+am4Bt+mVGsVZ1Ik2c5f3GYUm0q5/rmcwr BDxQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=AHJUi6ywWg40R8ywUQxkqT+6QFkJHA8t+9/PSoqzOfw=; b=uFDUKOqHjk24sUPvz+QZ4YuzcxX7hQ3pd61ZTBAgdKElzoBjkzexkJQLJKZcJ3ELZM zvaBp9u7BleEc7Pts6jlSVeQOV81gt5VToQhcrhGwMq+DtF9vLDilAibY8lefg/B8PIa iO5Cd7Ic2jba6MvVDf78WPB6c5RKQmfcXwCGea543V5z+uyw3kyfRZA0hbvkmoiNvZi0 E7ovtYpuUJ0RhV4E+o4ZXUTlxqpI6EVQG1pqMMD3ReLgVqH4bPoPQydtzfc9iLXYxwx5 4tZnVZhjVUO0HkAc/ehHvnufJ+IUIfZOTQ1kf9dJj7V82j76gXVqWqacY+ZZPAD6iOJn YO2g== X-Gm-Message-State: APjAAAUfoQ3l141WijwhRr5/PTTsY7pCaSJfBoO4h8I+5ZEp6movU1bF 5n+YJRiT/3FFOrYamfLPB30stnoK X-Received: by 2002:a19:c512:: with SMTP id w18mr38609lfe.81.1559165143018; Wed, 29 May 2019 14:25:43 -0700 (PDT) Received: from [192.168.2.145] ([94.29.35.141]) by smtp.googlemail.com with ESMTPSA id n10sm129059lfk.39.2019.05.29.14.25.41 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Wed, 29 May 2019 14:25:42 -0700 (PDT) Subject: Re: [PATCH V2 02/12] pinctrl: tegra: add suspend and resume support To: Sowjanya Komatineni , thierry.reding@gmail.com, jonathanh@nvidia.com, tglx@linutronix.de, jason@lakedaemon.net, marc.zyngier@arm.com, linus.walleij@linaro.org, stefan@agner.ch, mark.rutland@arm.com Cc: pdeschrijver@nvidia.com, pgaikwad@nvidia.com, sboyd@kernel.org, linux-clk@vger.kernel.org, linux-gpio@vger.kernel.org, jckuo@nvidia.com, josephl@nvidia.com, talho@nvidia.com, linux-tegra@vger.kernel.org, linux-kernel@vger.kernel.org, mperttunen@nvidia.com, spatra@nvidia.com, robh+dt@kernel.org, devicetree@vger.kernel.org References: <1559084936-4610-1-git-send-email-skomatineni@nvidia.com> <1559084936-4610-3-git-send-email-skomatineni@nvidia.com> <6273a790-d4b7-c501-3fec-d9816288b139@gmail.com> <11fe4d9a-6d8e-bc4f-b764-a849571fb6b0@gmail.com> <0f087659-cdde-9f89-55a2-d399ee539431@nvidia.com> <34480b14-48da-2745-086d-6a8900c5a049@gmail.com> From: Dmitry Osipenko Message-ID: <5e074715-fd8c-908a-b880-9f1fd03a244f@gmail.com> Date: Thu, 30 May 2019 00:25:41 +0300 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.6.1 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 29.05.2019 23:56, Sowjanya Komatineni пишет: > > On 5/29/19 1:47 PM, Dmitry Osipenko wrote: >> 29.05.2019 23:11, Sowjanya Komatineni пишет: >>> On 5/29/19 12:32 PM, Dmitry Osipenko wrote: >>>> 29.05.2019 21:14, Sowjanya Komatineni пишет: >>>>> On 5/29/19 8:29 AM, Dmitry Osipenko wrote: >>>>>> 29.05.2019 2:08, Sowjanya Komatineni пишет: >>>>>>> This patch adds suspend and resume support for Tegra pinctrl driver >>>>>>> and registers them to syscore so the pinmux settings are restored >>>>>>> before the devices resume. >>>>>>> >>>>>>> Signed-off-by: Sowjanya Komatineni >>>>>>> --- >>>>>>>     drivers/pinctrl/tegra/pinctrl-tegra.c    | 68 >>>>>>> +++++++++++++++++++++++++++++++- >>>>>>>     drivers/pinctrl/tegra/pinctrl-tegra.h    |  3 ++ >>>>>>>     drivers/pinctrl/tegra/pinctrl-tegra114.c |  1 + >>>>>>>     drivers/pinctrl/tegra/pinctrl-tegra124.c |  1 + >>>>>>>     drivers/pinctrl/tegra/pinctrl-tegra20.c  |  1 + >>>>>>>     drivers/pinctrl/tegra/pinctrl-tegra210.c |  1 + >>>>>>>     drivers/pinctrl/tegra/pinctrl-tegra30.c  |  1 + >>>>>>>     7 files changed, 75 insertions(+), 1 deletion(-) >>>>>>> >>>>>>> diff --git a/drivers/pinctrl/tegra/pinctrl-tegra.c >>>>>>> b/drivers/pinctrl/tegra/pinctrl-tegra.c >>>>>>> index a5008c066bac..bdc47e62c457 100644 >>>>>>> --- a/drivers/pinctrl/tegra/pinctrl-tegra.c >>>>>>> +++ b/drivers/pinctrl/tegra/pinctrl-tegra.c >>>>>>> @@ -28,11 +28,18 @@ >>>>>>>     #include >>>>>>>     #include >>>>>>>     #include >>>>>>> +#include >>>>>>>       #include "../core.h" >>>>>>>     #include "../pinctrl-utils.h" >>>>>>>     #include "pinctrl-tegra.h" >>>>>>>     +#define EMMC2_PAD_CFGPADCTRL_0            0x1c8 >>>>>>> +#define EMMC4_PAD_CFGPADCTRL_0            0x1e0 >>>>>>> +#define EMMC_DPD_PARKING            (0x1fff << 14) >>>>>>> + >>>>>>> +static struct tegra_pmx *pmx; >>>>>>> + >>>>>>>     static inline u32 pmx_readl(struct tegra_pmx *pmx, u32 bank, u32 >>>>>>> reg) >>>>>>>     { >>>>>>>         return readl(pmx->regs[bank] + reg); >>>>>>> @@ -629,6 +636,50 @@ static void >>>>>>> tegra_pinctrl_clear_parked_bits(struct tegra_pmx *pmx) >>>>>>>         } >>>>>>>     } >>>>>>>     +static int __maybe_unused tegra_pinctrl_suspend(void) >>>>>>> +{ >>>>>>> +    u32 *backup_regs = pmx->backup_regs; >>>>>>> +    u32 *regs; >>>>>>> +    int i, j; >>>>>>> + >>>>>>> +    for (i = 0; i < pmx->nbanks; i++) { >>>>>>> +        regs = pmx->regs[i]; >>>>>>> +        for (j = 0; j < pmx->reg_bank_size[i] / 4; j++) >>>>>>> +            *backup_regs++ = readl(regs++); >>>>>>> +    } >>>>>>> + >>>>>>> +    return pinctrl_force_sleep(pmx->pctl); >>>>>>> +} >>>>>>> + >>>>>>> +static void __maybe_unused tegra_pinctrl_resume(void) >>>>>>> +{ >>>>>>> +    u32 *backup_regs = pmx->backup_regs; >>>>>>> +    u32 *regs; >>>>>>> +    u32 val; >>>>>>> +    int i, j; >>>>>>> + >>>>>>> +    for (i = 0; i < pmx->nbanks; i++) { >>>>>>> +        regs = pmx->regs[i]; >>>>>>> +        for (j = 0; j < pmx->reg_bank_size[i] / 4; j++) >>>>>>> +            writel(*backup_regs++, regs++); >>>>>>> +    } >>>>>>> + >>>>>>> +    if (pmx->soc->has_park_padcfg) { >>>>>>> +        val = pmx_readl(pmx, 0, EMMC2_PAD_CFGPADCTRL_0); >>>>>>> +        val &= ~EMMC_DPD_PARKING; >>>>>>> +        pmx_writel(pmx, val, 0, EMMC2_PAD_CFGPADCTRL_0); >>>>>>> + >>>>>>> +        val = pmx_readl(pmx, 0, EMMC4_PAD_CFGPADCTRL_0); >>>>>>> +        val &= ~EMMC_DPD_PARKING; >>>>>>> +        pmx_writel(pmx, val, 0, EMMC4_PAD_CFGPADCTRL_0); >>>>>>> +    } >>>>>>> +} >>>>>>> >>>>>> But the CFGPADCTRL registers are already programmed by restoring the >>>>>> backup_regs and hence the relevant EMMC's are already unparked. Hence >>>>>> why do you need to force-unpark both of the EMMC's? What if EMMC is >>>>>> unpopulated on a board, why do you need to unpark it then? >>>>> PARK bit for EMMC2/EMMC4 (EMMC2_PAD_CFGPADCTRL and >>>>> EMMC4_PAD_CFGPADCTRL) >>>>> are not part of pinmux. >>>>> >>>>> They are part of CFGPADCTRL register so pinctrl driver pingroup >>>>> doesn't >>>>> include these registers. >>>> I'm looking at the tegra210_groups and it clearly has these both >>>> registers as a part of pinctrl setup because the rest of the bits >>>> configure drive of the pads. >>>> >>>>   From pinctrl-tegra210.c: >>>> >>>> #define DRV_PINGROUP_REG_A        0x8d4    /* bank 0 */ >>>> >>>> DRV_PINGROUP(sdmmc2, 0xa9c, 2,  6,  8,  6,  28, 2,  30, 2), >>>> DRV_PINGROUP(sdmmc4, 0xab4, 2,  6,  8,  6,  28, 2,  30, 2), >>>> >>>> ... >>>> >>>> 0xa9c - 0x8d4 = 0x1c8 >>>> 0xab4 - 0x8d4 = 0x1e0 >>>> >>>> Hence the PARK bits are already getting unset by restoring the >>>> backup_regs because the CFGPADCTRL registers are a part of the "bank 0" >>>> registers. >>>> >>>> Am I still missing something? >>> DRV_PINGROUP parked_bit is -1 and will not be programmed so store and >>> restore will not take care of it. >>> >>> Also EMMC PADCFG is the only padcfg register which has parked bit and >>> for other IO pads its part of pinmux >> You're storing raw values of all of the PINCTRL registers and then >> restoring the raw values (if I'm not misreading that part on the patch), >> it's absolutely meaningless that DRV_PINGROUP doesn't define the PARK >> bits. >> >> In a result, the backup_regs array contains raw CFGPADCTRL value with >> the PARK bits being unset on store, that value is written out on the >> restore as-is and hence the PARK bits are getting unset as well. >> >> And why DRV_PINGROUP misses PARK bits for the EMMC's? Looks like a >> driver's drawback that need to be addressed. > > Parked bits from padcfg are available only for couple of EMMC registers. > > default PARK bits are set so stored value contains park bit set. on > resume, after restoring park bit is cleared. TRM says that the PARK bits are set on HW reset (and on DPD IIUC) and then SW should unset the bits. I assume that the PARK bits of the EMMC pads are unset by bootloader and that's why it doesn't cause problems for kernel, in oppose to PARK bits of the rest of pinmux that are unset by the driver in tegra_pinctrl_clear_parked_bits() on driver's probe. > on subsequence DPD entry, stored value contains park bit 0 and HW clamps > park bit to logic 1 during DPD entry and cleared again on resume. I assume that EMMC won't work properly if pads are "parked" and the PARK bits should be in unset state on kernel boot-up as I wrote above, hence stored value should always contain 0 for the EMMC PARK bits. No?