Received: by 2002:a25:8b12:0:0:0:0:0 with SMTP id i18csp236945ybl; Tue, 27 Aug 2019 19:22:35 -0700 (PDT) X-Google-Smtp-Source: APXvYqxzgwrZaxqiUGMkON/EbcUhxwxHRBVfKGo7oHufX5wPB9U7Cs9M+PJtb8dHMIa59g9wrHqc X-Received: by 2002:a63:c009:: with SMTP id h9mr1395479pgg.166.1566958954945; Tue, 27 Aug 2019 19:22:34 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1566958954; cv=none; d=google.com; s=arc-20160816; b=gzAKs1zyGJu6j4YyQ8Ydkg4/hOlnZ1ZyAyjTqgY04XDp9g8Kt0JoOc2Nv78b9RAh9L OB7LIhZ1tm3K/dKCVeJ/HVQwAbPFnw+aTvbtiIqfrk9vPK65D62x1lNRHbFKuGSY2Bye LzCEF47aSJxElNYX7Oo45CaIJKt/r2ktaJ/WSPQ44earaNNps6RDH5v3q3rnyo8jlaYD 0mssV4UMLgb2PIKq5DXc0d7uoc+C5WZwCCF+yeeij08EToVr6FEdq9HJQ0+Qr4pdeDBc HbOOiy6f+8FOvTsSbW/eIkYJKgJw98gv453SMC+RWPG4rV12hPlQULsuvBR+aTHuvNIg SQpg== 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=0+dMjTeRnTWUOUtY5Y5qEbJRKkaqMUR9i5xBsX8C6EU=; b=kOCYwQclEcJRwgI/ihiYjzIyM33mLFD/EzREZjxpY61mnr4MGn5Pwj9+vyxSohfQq5 nfgWlYEySTq4TA48zOEK+RJsknAlkOId26yuuMRYIPSf9Unk7/j8uINh872/LvbTPKoB XrXpOYMTsw8HccN5o8uZrhIsPriH3GX4W3RBNOuvKRw7YRHS0C6XDWreSACuaT3yrHHs rVM/YFKMldbMpXJrkxYk1pgXTY444J5F66BSHLSg5t6R4GCLEAix/TuaHtDMW6IfilDp ajg+v7jPxpMjUmUWPHoKdxXV1pMwSLJK1mWnbpKpnSISuzPaQjZE27RUyvXcjqw5lE3n mbqQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=vG3b+7nE; 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 h19si676812pfn.55.2019.08.27.19.22.19; Tue, 27 Aug 2019 19:22:34 -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=vG3b+7nE; 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 S1726541AbfH1CT2 (ORCPT + 99 others); Tue, 27 Aug 2019 22:19:28 -0400 Received: from mail-pf1-f195.google.com ([209.85.210.195]:36343 "EHLO mail-pf1-f195.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726096AbfH1CTZ (ORCPT ); Tue, 27 Aug 2019 22:19:25 -0400 Received: by mail-pf1-f195.google.com with SMTP id w2so634434pfi.3; Tue, 27 Aug 2019 19:19:24 -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=0+dMjTeRnTWUOUtY5Y5qEbJRKkaqMUR9i5xBsX8C6EU=; b=vG3b+7nEBa/2elBzxkm+2aN/qwQlm39sFkNYCsGRiQHJvviHVDTfq2gKtzJe2mFGh4 wRjwkrFQTjSNDu77sQC0VSqY7QmOccDZG4qjjoA+j5lH7nWFG2SvEgdIPurVzB1OlB5H A3TcDWabVdo7KnTh2Yz0lm7iqvmmEp5qoJ1qhCJHjsS9mM+bato28oVcWqQLxPK1krR3 bcKdrbCTEUZSgRdRzyNb2zv0NT2tcIW5CngtiK39733QK3ULteT2cXjyNBUVPqFWv9/J LH8JwPnrQ0IfQidOPSi364OVLZoGNkUjEUsj6hLmp1XEbgwaPuWw4xO0YIrsnWklJ2L/ mGNA== 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=0+dMjTeRnTWUOUtY5Y5qEbJRKkaqMUR9i5xBsX8C6EU=; b=B8gu74jLzzqCZud+zWUyjVN4VmXElb3bBluvinUi/7gs+1bSDbJPHYowU8DvQdOG9z nYY+ahbZjiHkxNk1j+JD2EsXcYGoOP4bI/SB9KlyWohQCG4qwvbjGah08WWhciBmqa+z 4fDLwMbu6lT7drWDdJNV1hLCOIV+ZOr2oKq+EXFOVUUxsvHLpNCTCcwG83/edNpnppkA fQE5yqpYOxV5AFZlxUZsOmy/sKsySd4peR+AI9k7U+H5yAG/gk7lfk17Zm5PX1rnD2Rj 5vXq+hpAgT236fLpQl4P/DoAHIBcOgY3WD+isVjFMaeDqAwKQDqLcz8pYIyCe8uyYIZg AHUQ== X-Gm-Message-State: APjAAAWAJDX4WHIwlbYdZ9822Rnc0yHiBwFHypDzjuU4z4tteGgD08be KvlzqtwbWWZM4nemhWpUVzs= X-Received: by 2002:aa7:9e04:: with SMTP id y4mr1950076pfq.18.1566958764704; Tue, 27 Aug 2019 19:19:24 -0700 (PDT) Received: from ubt.spreadtrum.com ([117.18.48.82]) by smtp.gmail.com with ESMTPSA id b18sm673249pfi.160.2019.08.27.19.19.21 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 27 Aug 2019 19:19:24 -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: [PATCH v2 5/5] mmc: sdhci-sprd: clear the UHS-I modes read from registers Date: Wed, 28 Aug 2019 10:17:36 +0800 Message-Id: <20190828021736.22049-6-zhang.lyra@gmail.com> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20190828021736.22049-1-zhang.lyra@gmail.com> References: <20190828021736.22049-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