Received: by 2002:a25:8b12:0:0:0:0:0 with SMTP id i18csp235992ybl; Tue, 27 Aug 2019 19:21:22 -0700 (PDT) X-Google-Smtp-Source: APXvYqxBaEDFm2Yz2DgYfiGVK6E9QA+KykFFfB5yQ6q741LCigVf8X5JJ7glaqwWYcQlUfEE3v8s X-Received: by 2002:a63:4e60:: with SMTP id o32mr1441868pgl.68.1566958881933; Tue, 27 Aug 2019 19:21:21 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1566958881; cv=none; d=google.com; s=arc-20160816; b=IrGXFm3K1TR5311pNqn+n5ky83hhnKjaUeGw8MTJlhkMPGU0BBAv7+Ijs7rodxYCXP FaQ024Z9HR1ZhQdxlDXl7v8D7ROfjYI2hffFVUoQSbECz5qtQIii7UZgsjX1KFY5F6Io VV/TaUSG5Yv7E7l4oanS8pzxyAeZaez+AzdBuMvrQxhFEngcPcYNB8lJQtbmG7B75r4t FNUFbLRAS0lel5UN5EWku7EUEiT7Oy+pavoGlrEhBH1B8bId8ISD5zLpTtF0NZc4dcO8 X2zj09Su5JPJY+qb8AjSPKCULB9L1+1pTjOKxfyefbDkW/wxd4Gp9m0BwpwESkPUHTGh E2vA== 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=R1Q7WwmlwNOy5BbyDBo69OlcwTbVn9JVSGBQ2CRv1xY=; b=OpsyN7R9kmp1BAxp7QG6VmiHNt6gRzFSkXIs0m9rAzeXsFnd8pcdJzjF1kIVzwO0O4 bJt5NPZgsiXXFL0WPAegDw1tmDQnDsWJINyEUQV0DFivTiSS0IomlXzkrHE3xDpe12I8 YnF5pwJsWa5SRixvUk5XI2R6TXlsQuFxv+3lRxBAGFDWRY+4/IRpGhXR56GUy6SkqyfV /QZT6J7lV4/B4TGrLUbux3UNY1jWZLDDsK+WaSUYK+Uw0yPKSAJXMdR92aZXp4gAEXHQ X+ypY4eES/zXUHOfojuQpAa8Dc4wPV+Vl45VGYi1FL4HsuhnvWhX757nA65mN2PAWLa6 /SVA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=aQm8I160; 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 q10si1099554pfc.85.2019.08.27.19.21.06; Tue, 27 Aug 2019 19:21:21 -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=aQm8I160; 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 S1726342AbfH1CS4 (ORCPT + 99 others); Tue, 27 Aug 2019 22:18:56 -0400 Received: from mail-pf1-f193.google.com ([209.85.210.193]:44892 "EHLO mail-pf1-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726096AbfH1CS4 (ORCPT ); Tue, 27 Aug 2019 22:18:56 -0400 Received: by mail-pf1-f193.google.com with SMTP id c81so608891pfc.11; Tue, 27 Aug 2019 19:18:56 -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=R1Q7WwmlwNOy5BbyDBo69OlcwTbVn9JVSGBQ2CRv1xY=; b=aQm8I160NpiG2BuIcCpq8UahmWPQvTZzKjN9zrQ0jzRbH6HUq52W548WtFOzn0a+fo Isf5fr6FJdMVV8P+J9phqkDfS19TnxGkdGE8LGhSBxsyzI8GQ8o6gt1Cif/Qg7Rbjy4O q0+wwzgSaFnRm6uCUEXZxe/BEUZSBvHdqlMBWSuSB5NSyQuUP/l8godEiYhhwo9ibqPa oYPukSNAbpUEc1HJ/UrfbauDxvm7mJmIMaCqUFFVWmOAvL4bjvAe66KxK4HzZxifv8ps nfQ2M69X+kyhxUcU0MF3JeLHYceRF9nsozqZXLJhBsTSTZ1xU+qPG1dPwq0gx/Z9XTVw drgQ== 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=R1Q7WwmlwNOy5BbyDBo69OlcwTbVn9JVSGBQ2CRv1xY=; b=aiagS+JTaTHIzVdx7eqOn9JhhTYNhzhaE1zf8TZQbMN1VXBJ5NodkZ73yUo26zHOzO 1pQVDzlChgcM2qLegxURjbiqZkCTMe9JE4DdOTIY8pzBfEF4A3QQdsOScfKF7uVw/KDH XhWs8CZGY3VAF5ixUxY/fYl7RYnmpx3U1rkX9QGRQIzuZ71ukLUae2fFnJXab3UQEIWW LFgNK2VWfBFhITFRpf9y1WYB1DvsetPkaYYqY4TKDGSYPcjznWvTCTDEBI8Us9xTqMfM egD4l21/4MIvnhVwHFzZhbEWO+L1NW1/rNqmprLbL+pr9AD8qkRnNwbR34eJXJ94c8Aq FeBA== X-Gm-Message-State: APjAAAXo6U+kjRTwaMlTMKLifl5t6GGaqyuBWBSF6SsjuiRi3XRlkGdp jMs80SyZ0fYezwGLC60AVKY= X-Received: by 2002:a62:e401:: with SMTP id r1mr1949847pfh.193.1566958735868; Tue, 27 Aug 2019 19:18:55 -0700 (PDT) Received: from ubt.spreadtrum.com ([117.18.48.82]) by smtp.gmail.com with ESMTPSA id b18sm673249pfi.160.2019.08.27.19.18.52 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 27 Aug 2019 19:18:55 -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 1/5] mmc: sdhci-sprd: fixed incorrect clock divider Date: Wed, 28 Aug 2019 10:17:32 +0800 Message-Id: <20190828021736.22049-2-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 The register SDHCI_CLOCK_CONTROL should be cleared before config clock divider, otherwise the frequency configured maybe lower than we expected. 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 | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/drivers/mmc/host/sdhci-sprd.c b/drivers/mmc/host/sdhci-sprd.c index 6ee340a3fb3a..d5871865a1e9 100644 --- a/drivers/mmc/host/sdhci-sprd.c +++ b/drivers/mmc/host/sdhci-sprd.c @@ -217,10 +217,11 @@ static inline void _sdhci_sprd_set_clock(struct sdhci_host *host, struct sdhci_sprd_host *sprd_host = TO_SPRD_HOST(host); u32 div, val, mask; - div = sdhci_sprd_calc_div(sprd_host->base_rate, clk); + sdhci_writew(host, 0, SDHCI_CLOCK_CONTROL); - clk |= ((div & 0x300) >> 2) | ((div & 0xFF) << 8); - sdhci_enable_clk(host, clk); + div = sdhci_sprd_calc_div(sprd_host->base_rate, clk); + div = ((div & 0x300) >> 2) | ((div & 0xFF) << 8); + sdhci_enable_clk(host, div); /* enable auto gate sdhc_enable_auto_gate */ val = sdhci_readl(host, SDHCI_SPRD_REG_32_BUSY_POSI); -- 2.20.1