Received: by 2002:ac0:a5a6:0:0:0:0:0 with SMTP id m35-v6csp5770524imm; Mon, 27 Aug 2018 04:06:09 -0700 (PDT) X-Google-Smtp-Source: ANB0VdbAlqaV86av7i2FI5F9SQsp/oWVoLb3E8oTpHkUznEL7nWr+soH1+dfZQum+QXRGxAA/MzW X-Received: by 2002:a17:902:4201:: with SMTP id g1-v6mr12861908pld.203.1535367969619; Mon, 27 Aug 2018 04:06:09 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1535367969; cv=none; d=google.com; s=arc-20160816; b=MNv/9v3Dypyr320hYBGuqAzg0St7243HAAhSXHq3ib0o5FqZPOuyeGY/e32DeBgkr1 nEaO09UF1hRKGYt3X9BeLVEI+9QkKQ6ve1MZr/D9zQH6YvbK5BrVUYUqmdVT6dVU305x TE6VOxycGVfGXf3ZqOF8yon4GIyNqlxVds22vQW77lPOHQLFIAYKpCnuIpodTLvdHc8+ hYJKZkdBAERdWp0p4ZETbus0gOJyKQHDE2mdpjKvgKTuwYeg8ibPNhG2mKFZKYEvTjtK BO329epHyvCWh1fN/X3LZAVY7dTDl2/6cXCINfl8l8VbbkqzrkyJBJ5LHAbCZ4gWiNJs RRrQ== 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=v1JEqXnQ1BhT0K81hsdmA9CNAQdTEh3+cQk8cJo90IU=; b=oxf4petnLMZIw6g1fPqDXaZtx3z5MzhB58RuG7JfTFZCaYpJ/h+4qqUa1C9ISJ+kwD U5qEjii24YvnGhEXKCOjUAQk1zQqq02yzAwKptO6Ap/5eCy9KMBTty0Vnhtqkl0WL7A0 6OBmtHCkaTu7JhLdfkKD3Ru2+TS1UxTJN+XgACD7FBaiJ/ymCiJUkW5hcFMWRAcOwVRo 6wLwqux15b+4wUmvnkjxVKyjLHJh9hZdoC8jpNdkHDwY3Do3de8W5kbZkOlp9b0PNlsC YSe4csTLqVBP6ktd7U72NmYrcIkgl0Gcs0dh3n5hWTQqc0qP4Azr7Fw22JQejEMUWNCs khzQ== 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 p21-v6si12658999plq.338.2018.08.27.04.05.53; Mon, 27 Aug 2018 04:06:09 -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 S1727374AbeH0Otu (ORCPT + 99 others); Mon, 27 Aug 2018 10:49:50 -0400 Received: from mga18.intel.com ([134.134.136.126]:33931 "EHLO mga18.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726902AbeH0Otu (ORCPT ); Mon, 27 Aug 2018 10:49:50 -0400 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga008.fm.intel.com ([10.253.24.58]) by orsmga106.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 27 Aug 2018 04:03:38 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.53,295,1531810800"; d="scan'208";a="66281277" Received: from ahunter-desktop.fi.intel.com (HELO [10.237.72.137]) ([10.237.72.137]) by fmsmga008.fm.intel.com with ESMTP; 27 Aug 2018 04:03:35 -0700 Subject: Re: [PATCH v2 11/40] mmc: sdhci: Add a quirk to skip clearing the transfer mode register on tuning To: Aapo Vienamo , Rob Herring , Mark Rutland , Thierry Reding , Jonathan Hunter , Ulf Hansson , Mikko Perttunen , Stefan Agner Cc: devicetree@vger.kernel.org, linux-tegra@vger.kernel.org, linux-kernel@vger.kernel.org, linux-mmc@vger.kernel.org References: <1533924522-1037-1-git-send-email-avienamo@nvidia.com> <1533924522-1037-12-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: Date: Mon, 27 Aug 2018 14:01:52 +0300 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.9.1 MIME-Version: 1.0 In-Reply-To: <1533924522-1037-12-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 10/08/18 21:08, Aapo Vienamo wrote: > Add SDHCI_QUIRK2_TUNE_SKIP_XFERRMODE_REG_PROG to skip programming the > SDHCI_TRANSFER_MODE in sdhci_set_transfer_mode() if tuning command is > being sent. > > On Tegra210 and Tegra186 the tuning sequence hangs if the SDHCI > transfer mode register is touched. > > Signed-off-by: Aapo Vienamo > --- > drivers/mmc/host/sdhci.c | 6 ++++++ > drivers/mmc/host/sdhci.h | 2 ++ > 2 files changed, 8 insertions(+) > > diff --git a/drivers/mmc/host/sdhci.c b/drivers/mmc/host/sdhci.c > index a7b5602..04dc443 100644 > --- a/drivers/mmc/host/sdhci.c > +++ b/drivers/mmc/host/sdhci.c > @@ -1028,6 +1028,12 @@ static void sdhci_set_transfer_mode(struct sdhci_host *host, > > if (data == NULL) { > if (host->quirks2 & > + SDHCI_QUIRK2_TUNE_SKIP_XFERMODE_REG_PROG && > + (cmd->opcode == MMC_SEND_TUNING_BLOCK || > + cmd->opcode == MMC_SEND_TUNING_BLOCK_HS200)) { > + return; > + } Rather than introduce a quirk, can't we just dodge the unnecessary write e.g. diff --git a/drivers/mmc/host/sdhci.c b/drivers/mmc/host/sdhci.c index 1b3fbd9bd5c5..68af6a67e397 100644 --- a/drivers/mmc/host/sdhci.c +++ b/drivers/mmc/host/sdhci.c @@ -1033,10 +1033,19 @@ static void sdhci_set_transfer_mode(struct sdhci_host *host, if (cmd->opcode != MMC_SEND_TUNING_BLOCK_HS200) sdhci_writew(host, 0x0, SDHCI_TRANSFER_MODE); } else { - /* clear Auto CMD settings for no data CMDs */ + u16 orig; + + /* clear Auto CMD settings for no data CMDs */ mode = sdhci_readw(host, SDHCI_TRANSFER_MODE); - sdhci_writew(host, mode & ~(SDHCI_TRNS_AUTO_CMD12 | - SDHCI_TRNS_AUTO_CMD23), SDHCI_TRANSFER_MODE); + orig = mode; + mode &= ~(SDHCI_TRNS_AUTO_CMD12 | SDHCI_TRNS_AUTO_CMD23); + /* + * Do not write transfer mode unnecessarily because it + * can upset some host controllers (e.g. sdhci-tregra) + * during tuning. + */ + if (mode != orig) + sdhci_writew(host, new_mode, SDHCI_TRANSFER_MODE); } return; } Alternatively > + if (host->quirks2 & > SDHCI_QUIRK2_CLEAR_TRANSFERMODE_REG_BEFORE_CMD) { > sdhci_writew(host, 0x0, SDHCI_TRANSFER_MODE); > } else { > diff --git a/drivers/mmc/host/sdhci.h b/drivers/mmc/host/sdhci.h > index 23966f8..0a99008 100644 > --- a/drivers/mmc/host/sdhci.h > +++ b/drivers/mmc/host/sdhci.h > @@ -450,6 +450,8 @@ struct sdhci_host { > * obtainable timeout. > */ > #define SDHCI_QUIRK2_DISABLE_HW_TIMEOUT (1<<17) > +/* Don't clear the SDHCI_TRANSFER_MODE register on tuning commands */ > +#define SDHCI_QUIRK2_TUNE_SKIP_XFERMODE_REG_PROG (1<<18) > > int irq; /* Device IRQ */ > void __iomem *ioaddr; /* Mapped address */ >