Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp606314imm; Wed, 25 Jul 2018 03:01:27 -0700 (PDT) X-Google-Smtp-Source: AAOMgpf3xlaQBaGGkic1d7i8te0Lm1kTqtezjmTfZRFV5uKediFx9xM3qDjXfwtGhTzqQH4YV3o2 X-Received: by 2002:a17:902:a613:: with SMTP id u19-v6mr20161382plq.234.1532512887254; Wed, 25 Jul 2018 03:01:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1532512887; cv=none; d=google.com; s=arc-20160816; b=BwDU8T9w3pphTGHOYMYglRk+xI7/o+fWqksMSq6+1WGlrlsb3a7uLdQNhLqWp3EpUz SUTkN+B1DluS8GdGbvnkQRzyMV76ovWHAafV2FELED6HruWrhjmx/bITLC9ElsLYEBlY /MqipB2SEzZUMC++NhEgM7t3ySmn5/Q4k35raPj94aUtXhq1VmtsU39dzWPuZ602DYex qcpeXBSajtJ9KcbyB3DQjnOtrM0GVxKtH9j12UC+S9MMoXaMzab2S8IkwiYOjwGikghG XhEWrJUvmsqgEiSborL2+fULP3pAofg4bqTfoVUst+ucNFXfDvoE3Hp/aud3e7X907Py 5sTw== 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:message-id:subject:cc:to:from:date :arc-authentication-results; bh=TBnevAy4akuQ2/n67XLyBPBGdWwbBcKqzJCwM9/Ikfg=; b=QSJGXti6Mi5qt2JHUZIa20V2Vdo32rkBxausqlMDZguujmISEDJX1Yqe5MGuHE1XUK pTkSmzan2lcf1IxofU2p3n7HxCn7qGu4oAzP25HN2RqxyosqzufLC8xOkDGwu44oRbun zedBWWjeXkmTRRATazymEBnLXBFLa+CX3L5+B0Vnl7CuPipeFjy6w0LOBIYQijGlzy8z 3ubDwgRF5GGBphXOPRZ8uGLhYlgGfBUtQQBATsqUxmZbPpqqw3AuY5B3g/3fSRVwg9Y0 e8g3de30rVxNFwOpcH7I0n7Ub9CquN3idZFuvau6ovtDWAtejbYhysTljmSJN6g/y0HA P7Eg== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=nvidia.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id i6-v6si13635182pgt.352.2018.07.25.03.01.12; Wed, 25 Jul 2018 03:01:27 -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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=nvidia.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728759AbeGYLLU (ORCPT + 99 others); Wed, 25 Jul 2018 07:11:20 -0400 Received: from hqemgate14.nvidia.com ([216.228.121.143]:2578 "EHLO hqemgate14.nvidia.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728672AbeGYLLU (ORCPT ); Wed, 25 Jul 2018 07:11:20 -0400 Received: from hqpgpgate101.nvidia.com (Not Verified[216.228.121.13]) by hqemgate14.nvidia.com (using TLS: TLSv1, AES128-SHA) id ; Wed, 25 Jul 2018 03:00:14 -0700 Received: from HQMAIL101.nvidia.com ([172.20.161.6]) by hqpgpgate101.nvidia.com (PGP Universal service); Wed, 25 Jul 2018 03:00:23 -0700 X-PGP-Universal: processed; by hqpgpgate101.nvidia.com on Wed, 25 Jul 2018 03:00:23 -0700 Received: from dhcp-10-21-25-168 (10.21.25.201) by HQMAIL101.nvidia.com (172.20.187.10) with Microsoft SMTP Server (TLS) id 15.0.1347.2; Wed, 25 Jul 2018 10:00:19 +0000 Date: Wed, 25 Jul 2018 13:00:13 +0300 From: Aapo Vienamo To: Mikko Perttunen CC: Ulf Hansson , Rob Herring , Mark Rutland , Thierry Reding , Jonathan Hunter , "Adrian Hunter" , Mikko Perttunen , , , , Subject: Re: [PATCH 02/10] mmc: tegra: Set calibration pad voltage reference Message-ID: <20180725130013.7c86bfea@dhcp-10-21-25-168> In-Reply-To: References: <1532442591-5640-1-git-send-email-avienamo@nvidia.com> <1532442865-6391-1-git-send-email-avienamo@nvidia.com> X-NVConfidentiality: public MIME-Version: 1.0 Content-Type: text/plain; charset="US-ASCII" Content-Transfer-Encoding: 7bit X-Originating-IP: [10.21.25.201] X-ClientProxiedBy: UKMAIL101.nvidia.com (10.26.138.13) To HQMAIL101.nvidia.com (172.20.187.10) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, 25 Jul 2018 10:08:46 +0300 Mikko Perttunen wrote: > On 24.07.2018 17:34, Aapo Vienamo wrote: > > Configure the voltage reference used by the automatic pad drive strength > > calibration procedure. The value is a magic number from the TRM. > > > > Signed-off-by: Aapo Vienamo > > --- > > drivers/mmc/host/sdhci-tegra.c | 14 ++++++++++++-- > > 1 file changed, 12 insertions(+), 2 deletions(-) > > > > diff --git a/drivers/mmc/host/sdhci-tegra.c b/drivers/mmc/host/sdhci-tegra.c > > index e40ca43..6008e2f 100644 > > --- a/drivers/mmc/host/sdhci-tegra.c > > +++ b/drivers/mmc/host/sdhci-tegra.c > > @@ -49,6 +49,10 @@ > > #define SDHCI_AUTO_CAL_START BIT(31) > > #define SDHCI_AUTO_CAL_ENABLE BIT(29) > > > > +#define SDHCI_TEGRA_SDMEM_COMP_PADCTRL 0x1e0 > > +#define SDHCI_TEGRA_SDMEM_COMP_PADCTRL_VREF_SEL_MASK 0x0000000f > > +#define SDHCI_TEGRA_SDMEM_COMP_PADCTRL_VREF_SEL_VAL 0x7 > > + > > #define SDHCI_TEGRA_AUTO_CAL_STATUS 0x1ec > > #define SDHCI_TEGRA_AUTO_CAL_ACTIVE BIT(31) > > > > @@ -152,7 +156,7 @@ static void tegra_sdhci_reset(struct sdhci_host *host, u8 mask) > > struct sdhci_pltfm_host *pltfm_host = sdhci_priv(host); > > struct sdhci_tegra *tegra_host = sdhci_pltfm_priv(pltfm_host); > > const struct sdhci_tegra_soc_data *soc_data = tegra_host->soc_data; > > - u32 misc_ctrl, clk_ctrl; > > + u32 misc_ctrl, clk_ctrl, pad_ctrl; > > > > sdhci_reset(host, mask); > > > > @@ -193,8 +197,14 @@ static void tegra_sdhci_reset(struct sdhci_host *host, u8 mask) > > sdhci_writel(host, misc_ctrl, SDHCI_TEGRA_VENDOR_MISC_CTRL); > > sdhci_writel(host, clk_ctrl, SDHCI_TEGRA_VENDOR_CLOCK_CTRL); > > > > - if (soc_data->nvquirks & NVQUIRK_HAS_PADCALIB) > > + if (soc_data->nvquirks & NVQUIRK_HAS_PADCALIB) { > > + pad_ctrl = sdhci_readl(host, SDHCI_TEGRA_SDMEM_COMP_PADCTRL); > > + pad_ctrl &= ~SDHCI_TEGRA_SDMEM_COMP_PADCTRL_VREF_SEL_MASK; > > + pad_ctrl |= SDHCI_TEGRA_SDMEM_COMP_PADCTRL_VREF_SEL_VAL; > > + sdhci_writel(host, pad_ctrl, SDHCI_TEGRA_SDMEM_COMP_PADCTRL); > > + > > Will this happen to only eMMC controllers or for all controllers? My > docs are saying this should be set to 0x7 for SDMMC2/4 and 0x1 or 0x2 > for SDMMC1/3 depending on voltage. Not sure how downstream is > programming it, though. The Tegra210 TRM specifies that VREF_SEL should be set 0x7 for all of the controllers, there's no mention of this depending on the mode. The same value is also programmed by the downstream kernels for Tegra210 and Tegra186. -Aapo