Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp3355279imm; Tue, 17 Jul 2018 03:29:56 -0700 (PDT) X-Google-Smtp-Source: AAOMgpe7I7zAur4ApyO7UdlQR1VsI4R+KVdFEgxOjKs797SB07Vh/HVj+SpdBTLQ9fZFlprcBtXZ X-Received: by 2002:a65:60cf:: with SMTP id r15-v6mr1031571pgv.41.1531823396659; Tue, 17 Jul 2018 03:29:56 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1531823396; cv=none; d=google.com; s=arc-20160816; b=sANSNEgNYvytYFjjlvHvbRVBvefCMCV8FIjTJpRwHrjjMheFh7t1yCiwquUQHhiST9 xGVgDJG5OoNDohwZB/V3HtrHPRh6vRsWFgYn5MJykfXmjEPA/WjglY80gw/9YbG5lfu6 ScGElCnrR8ZkbAbwk8AFVX4j+GiepXlATh2pYEwwNuUbUcP8OkH8R4tc9HhI+V4tTjoC wsNi2lggyj93t1AkqXQfG3n2DqRTFOiWrOsRo2eY4rMBBmkeFkdHLYc0CSaSomQwr9kF 66n5IOtm8QY8QPzOxgZzcY9xQ0pTKciVFqp2/Zsl+tTtGUSQ3jYZR0D9I8JTzRgCtboH SD8Q== 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:organization:from:references:cc:to:subject :arc-authentication-results; bh=tAhF16NuA4Fm7uJa0z/efOZYuQLW2svzSkhPCL2nOQY=; b=O6Ed+ii6e4BE6LINsdbED4KD3HUpLPXFKl+Z4k1FdJTn3XBC2J7Euiiu3JnKLzZA9R qPuTWI20ek0f/5h09NmxcgCYoXthtAIqY4HmvPbEGa09G1ZtgcKK/g8joa3jsFvZ7LZY jQaiCc9tOWeNY8hQUbCcVN8YlfGSrdsbQVbD/KhZsuRJf5oxg1uqF0YuFmlk9wb7IK9t x0wI0ZcTVQGsBdTd4wCPYO8y5fK2DgUTNPDg3ONdURxnL6Mtm17TeNYWr3s+/O2ctw+7 OvpTuxYLmc/oG1kVsu0IQAqFfVG94qe91ArUFkxqBsj8ssus1XJ7NNMZSA1+E7ZgPRMP UmZg== 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=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id x19-v6si604030pgl.660.2018.07.17.03.29.41; Tue, 17 Jul 2018 03:29:56 -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=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730598AbeGQLBD (ORCPT + 99 others); Tue, 17 Jul 2018 07:01:03 -0400 Received: from mga09.intel.com ([134.134.136.24]:36971 "EHLO mga09.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729718AbeGQLBD (ORCPT ); Tue, 17 Jul 2018 07:01:03 -0400 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga001.fm.intel.com ([10.253.24.23]) by orsmga102.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 17 Jul 2018 03:28:35 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.51,365,1526367600"; d="scan'208";a="73015709" Received: from ahunter-desktop.fi.intel.com (HELO [10.237.72.168]) ([10.237.72.168]) by fmsmga001.fm.intel.com with ESMTP; 17 Jul 2018 03:28:33 -0700 Subject: Re: [PATCH] mmc: tegra: Force correct divider calculation on DDR50/52 To: Aapo Vienamo , Ulf Hansson , Thierry Reding , Jonathan Hunter , Marcel Ziswiler , Stefan Agner Cc: linux-mmc@vger.kernel.org, linux-tegra@vger.kernel.org, linux-kernel@vger.kernel.org References: <1531751669-26584-1-git-send-email-avienamo@nvidia.com> From: Adrian Hunter Organization: Intel Finland Oy, Registered Address: PL 281, 00181 Helsinki, Business Identity Code: 0357606 - 4, Domiciled in Helsinki Message-ID: <875ad3f9-81b9-2c50-be1d-4550fd9e3b44@intel.com> Date: Tue, 17 Jul 2018 13:26:58 +0300 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.9.0 MIME-Version: 1.0 In-Reply-To: <1531751669-26584-1-git-send-email-avienamo@nvidia.com> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 16/07/18 17:34, Aapo Vienamo wrote: > Tegra SDHCI controllers require the SDHCI clock divider to be configured > to divide the clock by two in DDR50/52 modes. Incorrectly configured > clock divider results in corrupted data. > > Prevent the possibility of incorrectly calculating the divider value due > to clock rate rounding or low parent clock frequency by not assigning > host->max_clk to clk_get_rate() on tegra_sdhci_set_clock(). > > See the comments for further details. > > Fixes: a8e326a ("mmc: tegra: implement module external clock change") > Signed-off-by: Aapo Vienamo Acked-by: Adrian Hunter > --- > drivers/mmc/host/sdhci-tegra.c | 17 ++++++++++++++++- > 1 file changed, 16 insertions(+), 1 deletion(-) > > diff --git a/drivers/mmc/host/sdhci-tegra.c b/drivers/mmc/host/sdhci-tegra.c > index ddf00166..908b23e 100644 > --- a/drivers/mmc/host/sdhci-tegra.c > +++ b/drivers/mmc/host/sdhci-tegra.c > @@ -210,9 +210,24 @@ static void tegra_sdhci_set_clock(struct sdhci_host *host, unsigned int clock) > if (!clock) > return sdhci_set_clock(host, clock); > > + /* > + * In DDR50/52 modes the Tegra SDHCI controllers require the SDHCI > + * divider to be configured to divided the host clock by two. The SDHCI > + * clock divider is calculated as part of sdhci_set_clock() by > + * sdhci_calc_clk(). The divider is calculated from host->max_clk and > + * the requested clock rate. > + * > + * By setting the host->max_clk to clock * 2 the divider calculation > + * will always result in the correct value for DDR50/52 modes, > + * regardless of clock rate rounding, which may happen if the value > + * from clk_get_rate() is used. > + */ > host_clk = tegra_host->ddr_signaling ? clock * 2 : clock; > clk_set_rate(pltfm_host->clk, host_clk); > - host->max_clk = clk_get_rate(pltfm_host->clk); > + if (tegra_host->ddr_signaling) > + host->max_clk = host_clk; > + else > + host->max_clk = clk_get_rate(pltfm_host->clk); > > sdhci_set_clock(host, clock); > >