Received: by 2002:ac0:bc90:0:0:0:0:0 with SMTP id a16csp620426img; Fri, 22 Mar 2019 05:18:32 -0700 (PDT) X-Google-Smtp-Source: APXvYqxBCE8CQpskJHzjnPRnXwQ3L0L7P+mp0q6fMlPI0ZFcv0SIGIOxCyVoq2odZUmBuSAA6maq X-Received: by 2002:a63:bd51:: with SMTP id d17mr8578104pgp.117.1553257112089; Fri, 22 Mar 2019 05:18:32 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1553257112; cv=none; d=google.com; s=arc-20160816; b=L2u2zSxYTHvTo9SSkihZJarKGmMDQjfpmLA+gUj8QaUr1uVqEbUtatENO+ywRaFkH4 qfy2Ux0cVunCEn4fkGxxFXhgSOVQC/6HqEB73ZjUmDoOAh9lCiftc2EVgi18SgaZKNPa D9HxompTYZ6bFlGc7Syt+f0XqAabffMxVoDlpyusJB7IB5OwVCVf1tqzvP+tOwGIdLEg Xll9vJUsuUeWpYB3azxJKnmIed4Sig2CMTnHq5+NiP99pFS1DS1cUYcGDzmr//fODves Ld29VM1IcuQs88rVtLAxLKAIr/Fq6Wd53yA5ud4HhzWIvEX6Wv3b8GHkQZM5DbtcIkhE vBIg== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=6O1Xb99WrEdTodAJ4f/rLTvrNR3lU+jvqlfRQWSveAI=; b=vWKwdfygmLd0mX8jWXuv83AIo3CKOCsic0Odfl4c0u05ajy+XDJjMiJNBBeYW73R9b GtPm1Um4xm9A3LiQ0Apnztv/GeTLJGaePa/4j2lI5zjq8N5x0fjywNQ5vKeAXivJW7Wr tlV6P1m+31POcbVYN5EJ0jrXsb7wgEMbdTxO+4d7np/yv9C+lTqbOnnwXnZ7iPUoBxF3 lhQPHMq5Po74GkH0AztKT1yJrEZBFMKdlkOpJfyfsfM7gRQyrksqk0DHATmctXYjUSdM jzukSwIWDL6l5vjSfKyp1aGnl1cC3WhB5A0OUhnS+5rrId3O5xw+1Kh5Ire6m7PBN7v7 GpBw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=gyDIXwEU; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id n66si6679770pfb.62.2019.03.22.05.18.17; Fri, 22 Mar 2019 05:18:32 -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=@kernel.org header.s=default header.b=gyDIXwEU; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2390191AbfCVMQT (ORCPT + 99 others); Fri, 22 Mar 2019 08:16:19 -0400 Received: from mail.kernel.org ([198.145.29.99]:54910 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2389935AbfCVMQR (ORCPT ); Fri, 22 Mar 2019 08:16:17 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 06BF92083D; Fri, 22 Mar 2019 12:16:15 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1553256976; bh=fcZl3fKBQoVlxAFlmvZRIW+fWoEIR2Fgbh9kbs/JBRA=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=gyDIXwEUhfdOIEclQJpL9TSr9Yj2/yyeljvPaupqzBo7WIiEfiPL1/2QNTHF2LfMm NRCsiMff412qP7HeNhBnG3PpGRil8NYO2h2JKKLeA5s9EvTygksFhwc4f5SMdzEOiC /lnaCRHCOTbc3pUT0GHw8BGrlutVIcxYSTHRXE1E= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Takeshi Saito , Marek Vasut , =?UTF-8?q?Niklas=20S=C3=B6derlund?= , Simon Horman , Wolfram Sang , Ulf Hansson Subject: [PATCH 5.0 063/238] mmc: renesas_sdhi: Fix card initialization failure in high speed mode Date: Fri, 22 Mar 2019 12:14:42 +0100 Message-Id: <20190322111302.294363058@linuxfoundation.org> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20190322111258.383569278@linuxfoundation.org> References: <20190322111258.383569278@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review X-Patchwork-Hint: ignore MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 5.0-stable review patch. If anyone has any objections, please let me know. ------------------ From: Takeshi Saito commit d30ae056adb81e1d2b8b953efa74735a020b8e3b upstream. This fixes card initialization failure in high speed mode. If U-Boot uses SDR or HS200/400 mode before starting Linux and Linux DT does not enable SDR/HS200/HS400 mode, card initialization fails in high speed mode. It is necessary to initialize SCC registers during card initialization phase. HW reset function is registered only for a port with either of SDR/HS200/HS400 properties in device tree. If SDR/HS200/HS400 properties are not present in device tree, SCC registers will not be reset. In SoC that support SCC registers, HW reset function should be registered regardless of the configuration of device tree. Reproduction procedure: - Use U-Boot that support MMC HS200/400 mode. - Delete HS200/HS400 properties in device tree. (Delete mmc-hs200-1_8v and mmc-hs400-1_8v) - MMC port works high speed mode and all commands fail. Signed-off-by: Takeshi Saito Signed-off-by: Marek Vasut Cc: Niklas Söderlund Cc: Simon Horman Reviewed-by: Wolfram Sang Cc: stable@vger.kernel.org Signed-off-by: Ulf Hansson Signed-off-by: Greg Kroah-Hartman --- drivers/mmc/host/renesas_sdhi_core.c | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) --- a/drivers/mmc/host/renesas_sdhi_core.c +++ b/drivers/mmc/host/renesas_sdhi_core.c @@ -723,6 +723,13 @@ int renesas_sdhi_probe(struct platform_d host->ops.start_signal_voltage_switch = renesas_sdhi_start_signal_voltage_switch; host->sdcard_irq_setbit_mask = TMIO_STAT_ALWAYS_SET_27; + + /* SDR and HS200/400 registers requires HW reset */ + if (of_data && of_data->scc_offset) { + priv->scc_ctl = host->ctl + of_data->scc_offset; + host->mmc->caps |= MMC_CAP_HW_RESET; + host->hw_reset = renesas_sdhi_hw_reset; + } } /* Orginally registers were 16 bit apart, could be 32 or 64 nowadays */ @@ -775,8 +782,6 @@ int renesas_sdhi_probe(struct platform_d const struct renesas_sdhi_scc *taps = of_data->taps; bool hit = false; - host->mmc->caps |= MMC_CAP_HW_RESET; - for (i = 0; i < of_data->taps_num; i++) { if (taps[i].clk_rate == 0 || taps[i].clk_rate == host->mmc->f_max) { @@ -789,12 +794,10 @@ int renesas_sdhi_probe(struct platform_d if (!hit) dev_warn(&host->pdev->dev, "Unknown clock rate for SDR104\n"); - priv->scc_ctl = host->ctl + of_data->scc_offset; host->init_tuning = renesas_sdhi_init_tuning; host->prepare_tuning = renesas_sdhi_prepare_tuning; host->select_tuning = renesas_sdhi_select_tuning; host->check_scc_error = renesas_sdhi_check_scc_error; - host->hw_reset = renesas_sdhi_hw_reset; host->prepare_hs400_tuning = renesas_sdhi_prepare_hs400_tuning; host->hs400_downgrade = renesas_sdhi_disable_scc;