Received: by 2002:a25:8b12:0:0:0:0:0 with SMTP id i18csp1648020ybl; Wed, 28 Aug 2019 18:49:27 -0700 (PDT) X-Google-Smtp-Source: APXvYqwIeFqctWGoEeS+0mwlXr5Haf4H7EmJ7dV7fmMsGhDnWbqQeLFEVso/EGZJf1DMxloYl7Bl X-Received: by 2002:a17:902:7c12:: with SMTP id x18mr7430432pll.123.1567043367810; Wed, 28 Aug 2019 18:49:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1567043367; cv=none; d=google.com; s=arc-20160816; b=jqEtO1PtfQnuyK7sm3T8b9abfrvzPPmhS5PlBCXHt0cmVX3/hnlA1w1+9hdSU4GH2U deOPeg2bIxFwWqYzAv4E75DkZgk0iZ7v0NyZRfVxrrCnmcaybzDIYU/U3FBgJ+s41kwV Bz4E4McgaYe9gM1IiizOxDYQCOvGS66bM5xhs1sA9zim0echcHh0DjzmBDgdll/7S0L1 coSEc+WF4FCC5EJQjTXG0/ucwwP14NV28B4AXWWm/22URMkY0w4Q9YfZYBFAKSucmQaT Qblm2PSLWub/TIYnLW91alJfa6AuYOALBeO84Us5dWdj1tor8+0A79FsB9XRe4oSx3Un i0sw== 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:date:subject:cc:to:from :dkim-signature; bh=+YooG/gsKARue5F8fzG4z9J/V6/qOmWpJ/qg5upQPNY=; b=ZYUCOw75raBfEw2ni0AUZdzEYlxTR05vPDqMFNctnmcAIG1yfA/EPDCcNz2uIIyVwy ao/cabQWWYx1ANrAHWcQIsHfv2CJmTHvW8iaXsAqUKvS4O0bA4ehGkBGgZT+nAniCJAQ vVL+S544EsabbCuu5rx72e9f4oD1/+ppQp0g9Cf8pag0TjwAJQZ20sIxZ9TPPL60xf90 1JpVebTh/V5abmgv7FWhZ5o4LOIplgQv1LBgirsZuLQczHyFeMRfCeAqNispmSNDRM9M cTcXL6n36zcxPEhFj7E3ipRNDYMW9f8pPQ6Gv2OclvvN18R6n0UiQnZ0hT309wpqK04+ 9C6A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=rGM6ZBGf; 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 r200si626147pgr.518.2019.08.28.18.49.12; Wed, 28 Aug 2019 18:49: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; dkim=pass header.i=@gmail.com header.s=20161025 header.b=rGM6ZBGf; 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 S1727318AbfH2Brk (ORCPT + 99 others); Wed, 28 Aug 2019 21:47:40 -0400 Received: from mail-pf1-f193.google.com ([209.85.210.193]:43549 "EHLO mail-pf1-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726971AbfH2Brj (ORCPT ); Wed, 28 Aug 2019 21:47:39 -0400 Received: by mail-pf1-f193.google.com with SMTP id v12so933285pfn.10; Wed, 28 Aug 2019 18:47:38 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=+YooG/gsKARue5F8fzG4z9J/V6/qOmWpJ/qg5upQPNY=; b=rGM6ZBGf7AwZnk5UPwR+TBnQBE6gLM8LicPUp6R0WPMCA8ow5XKV/qfAqVpvGJqzoW RvGjaaUHRXI/TGLHQwsq8Q/UwRmQT9z9/Z9jx9KL1jtiT1HgFAjog9zz1WezWSDgeXuC uypfzLOitDum972jn5iprQTYNWRMB9z/onbXB32+2I5MMU9h2S3DwxHAd7QVc5hT7FrA A3J1C0+cbDIvg07iSYDJ9QSYhB6OZGZoiKu9ZE7doNxyuc2fKXFmkk0vWeF2ej2favaW Hrchu2Oo+feAm6LHnUL3KVbA07giWp7PGSm5h8Y6XPWsJkLEGr2L6FQgAjIIEvkHpiS7 gQiw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=+YooG/gsKARue5F8fzG4z9J/V6/qOmWpJ/qg5upQPNY=; b=DXFXrPY/bO0pl5J3G+HOWmw1WRQ2WbHJS9+omeR8nqBNznyLikU6Mv6L//BmLVyNY9 gO6KRLjPMbXHv9EHMDTw9WPFduw65risIQQKIszSKWu1BXZsRGmEbZZLNf2bnbNldY5x dCgTzOo3OA/Ua2zd/d/2ibpzqfxEHmcXfKFt8zGWiKbCvfzUlk7HppJZCKZ+8d9rjuxN nc8wBXpi5mTiZm6YAtnXZQQUwsCvTCcYPfHUuYh23zjz5udGw7kWGtPwvixeFoBE6S7X jIZkZaC4mpJtP30gppUu6jl9AhS5iywEmxlyv4dyW1dLc/4etl4MJt49lbc6men89fWT lpyQ== X-Gm-Message-State: APjAAAXJWlCA7L6teBuc6Yf8HPa9z++dSkQrgAS3oP4FKApJQ3w0BlI/ P0FfIp7BAVK8udB8GWJT1nE= X-Received: by 2002:aa7:9533:: with SMTP id c19mr8186659pfp.153.1567043258491; Wed, 28 Aug 2019 18:47:38 -0700 (PDT) Received: from ubt.spreadtrum.com ([117.18.48.82]) by smtp.gmail.com with ESMTPSA id j10sm404548pjn.3.2019.08.28.18.47.35 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 28 Aug 2019 18:47:37 -0700 (PDT) From: Chunyan Zhang To: Ulf Hansson , Adrian Hunter , Orson Zhai , Baolin Wang Cc: linux-mmc@vger.kernel.org, linux-kernel@vger.kernel.org, Chunyan Zhang Subject: [RESEND PATCH v2 5/5] mmc: sdhci-sprd: clear the UHS-I modes read from registers Date: Thu, 29 Aug 2019 09:46:45 +0800 Message-Id: <20190829014645.4479-6-zhang.lyra@gmail.com> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20190829014645.4479-1-zhang.lyra@gmail.com> References: <20190829014645.4479-1-zhang.lyra@gmail.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Chunyan Zhang sprd's sd host controller supports SDR50/SDR104/DDR50 though, the UHS-I mode used by the specific card can be selected via devicetree only. Fixes: fb8bd90f83c4 ("mmc: sdhci-sprd: Add Spreadtrum's initial host controller") Signed-off-by: Chunyan Zhang Signed-off-by: Chunyan Zhang Reviewed-by: Baolin Wang Tested-by: Baolin Wang --- drivers/mmc/host/sdhci-sprd.c | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) diff --git a/drivers/mmc/host/sdhci-sprd.c b/drivers/mmc/host/sdhci-sprd.c index 1fecf055682c..d3c3e95676f0 100644 --- a/drivers/mmc/host/sdhci-sprd.c +++ b/drivers/mmc/host/sdhci-sprd.c @@ -509,7 +509,8 @@ static void sdhci_sprd_phy_param_parse(struct sdhci_sprd_host *sprd_host, static const struct sdhci_pltfm_data sdhci_sprd_pdata = { .quirks = SDHCI_QUIRK_BROKEN_CARD_DETECTION | - SDHCI_QUIRK_DATA_TIMEOUT_USES_SDCLK, + SDHCI_QUIRK_DATA_TIMEOUT_USES_SDCLK | + SDHCI_QUIRK_MISSING_CAPS, .quirks2 = SDHCI_QUIRK2_BROKEN_HS200 | SDHCI_QUIRK2_USE_32BIT_BLK_CNT | SDHCI_QUIRK2_PRESET_VALUE_BROKEN, @@ -614,6 +615,16 @@ static int sdhci_sprd_probe(struct platform_device *pdev) sdhci_enable_v4_mode(host); + /* + * Supply the existing CAPS, but clear the UHS-I modes. This + * will allow these modes to be specified only by device + * tree properties through mmc_of_parse(). + */ + host->caps = sdhci_readl(host, SDHCI_CAPABILITIES); + host->caps1 = sdhci_readl(host, SDHCI_CAPABILITIES_1); + host->caps1 &= ~(SDHCI_SUPPORT_SDR50 | SDHCI_SUPPORT_SDR104 | + SDHCI_SUPPORT_DDR50); + ret = sdhci_setup_host(host); if (ret) goto pm_runtime_disable; -- 2.20.1