Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp883277ybz; Wed, 22 Apr 2020 09:36:33 -0700 (PDT) X-Google-Smtp-Source: APiQypJhv6VTpNuu/bwiN6iUur4hxcIzMgkr1SLXtcwV7z1+KZiY8MGQM+nEdwsK7e9dVS+DfyiK X-Received: by 2002:a05:6402:1422:: with SMTP id c2mr18652499edx.179.1587573393160; Wed, 22 Apr 2020 09:36:33 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1587573393; cv=none; d=google.com; s=arc-20160816; b=JGqsH0qasVY2y0UGscAu4xzUmWs5mF3ojnnUU5z+cFeIpGFhVaLhTg/gVamsdras1c bhGAaoDko9t5mEM3Ihlh7A3SVyZlTa0Cqo1+IuGJ/hxf0uerSZEPdVmvdZ3/CJGjwkzn xc5s+wfb7iPXYT4ekhe7fZlcnIuXuBQyQoeetec1XTzVxAaRGiZ4Bgzy7keJwGNTO1ss i6/p/wbau1n2b7UKPrN5hPvENN0HcJbHdMXvmXubUlNnTdcJ5fSgF7wVU3EZ06pVraqr ddrJKIQiID9Ch8bzz7eD26V7zaegjDCNY1UsmzztyN1srqJC4Dm6I4BD2UJpMkf/cqZm ecaQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:dkim-signature:mime-version:references :in-reply-to:message-id:date:subject:cc:to:from; bh=kYhxxXI3LV4oeArlKvtdIWzgGCgrp9TkYQa4roEyFZw=; b=0khYJansyr4fH+wHPyPFOSWLClXlNkNZvS1vQQIHwVjvnp6dNDQ2GodJ0o1xL355Kv RLYJBhHxcrP5wTMw5LBNsxCskOHXWHXv1tz3Ek6J3Xn4wup4yUe6xZEO4Uds1qnMK5K6 xz0wzaX43EUjX58blhUyljDdt2QKACrJrAGtOQ6qoBaFS1+GpxTQxFto1wA5YEnMl7Dy k/MW7h6CTsb7LVxmQUYC49cMdBzfDJ9GQ5fzMRt5tLWpvX1/zfJ81M1ls9QW02GF+KX5 ozX58+TDrOf9iaJQFKmsqhVEF65Ch7e34YUMS9scuFhFWl0Jzf2cLKH2p54PGoaY8R4d ungQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@nvidia.com header.s=n1 header.b=ZIBBWpNS; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=nvidia.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id u10si3680251ejt.145.2020.04.22.09.36.07; Wed, 22 Apr 2020 09:36:33 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@nvidia.com header.s=n1 header.b=ZIBBWpNS; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=nvidia.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726006AbgDVQcf (ORCPT + 99 others); Wed, 22 Apr 2020 12:32:35 -0400 Received: from hqnvemgate25.nvidia.com ([216.228.121.64]:19873 "EHLO hqnvemgate25.nvidia.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726582AbgDVQcd (ORCPT ); Wed, 22 Apr 2020 12:32:33 -0400 Received: from hqpgpgate101.nvidia.com (Not Verified[216.228.121.13]) by hqnvemgate25.nvidia.com (using TLS: TLSv1.2, DES-CBC3-SHA) id ; Wed, 22 Apr 2020 09:31:30 -0700 Received: from hqmail.nvidia.com ([172.20.161.6]) by hqpgpgate101.nvidia.com (PGP Universal service); Wed, 22 Apr 2020 09:32:32 -0700 X-PGP-Universal: processed; by hqpgpgate101.nvidia.com on Wed, 22 Apr 2020 09:32:32 -0700 Received: from HQMAIL107.nvidia.com (172.20.187.13) by HQMAIL101.nvidia.com (172.20.187.10) with Microsoft SMTP Server (TLS) id 15.0.1473.3; Wed, 22 Apr 2020 16:32:32 +0000 Received: from hqnvemgw03.nvidia.com (10.124.88.68) by HQMAIL107.nvidia.com (172.20.187.13) with Microsoft SMTP Server (TLS) id 15.0.1473.3 via Frontend Transport; Wed, 22 Apr 2020 16:32:32 +0000 Received: from skomatineni-linux.nvidia.com (Not Verified[10.2.165.49]) by hqnvemgw03.nvidia.com with Trustwave SEG (v7,5,8,10121) id ; Wed, 22 Apr 2020 09:32:32 -0700 From: Sowjanya Komatineni To: , , , , , , , , , CC: , , , Subject: [PATCH 5.4.33 1/2] sdhci: tegra: Implement Tegra specific set_timeout callback Date: Wed, 22 Apr 2020 09:32:28 -0700 Message-ID: <1587573149-30269-2-git-send-email-skomatineni@nvidia.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1587573149-30269-1-git-send-email-skomatineni@nvidia.com> References: <1587573149-30269-1-git-send-email-skomatineni@nvidia.com> X-NVConfidentiality: public MIME-Version: 1.0 Content-Type: text/plain DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=nvidia.com; s=n1; t=1587573090; bh=kYhxxXI3LV4oeArlKvtdIWzgGCgrp9TkYQa4roEyFZw=; h=X-PGP-Universal:From:To:CC:Subject:Date:Message-ID:X-Mailer: In-Reply-To:References:X-NVConfidentiality:MIME-Version: Content-Type; b=ZIBBWpNS8T3rNedF9IGJF+a/2IIHbW8Pk/EMmgsdH3W0/TGaJmJkHzZaFBDRlqWnY M5U4vPtx2NFS2sIG4IeRR4G8yJXB0JiXjnT5oxUhdXyvJqIUOz8dHfIrVk5o9py3PI KDzaJeKDg36SP8qbvSIq4lXIQiLhCM5AdxVsD/047/EadO525wt5o6TOVk28G66y9v 9DkqOHkSmFr3XI5TDNOJfJdS6/WeMhV5Jx5wAbA4swlL6GznfdpfVPXdM4/m8ZiXTz c4lpOBJ8QdX/tScB8o3lPUyPCiMLmH/VXVAyXdO7A0NvGS0Oulr8zetdpiwtrFHV6+ S8nlIY+FnGaeQ== Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org commit 5e958e4aacf4 ("sdhci: tegra: Implement Tegra specific set_timeout callback") Tegra host supports HW busy detection and timeouts based on the count programmed in SDHCI_TIMEOUT_CONTROL register and max busy timeout it supports is 11s in finite busy wait mode. Some operations like SLEEP_AWAKE, ERASE and flush cache through SWITCH commands take longer than 11s and Tegra host supports infinite HW busy wait mode where HW waits forever till the card is busy without HW timeout. This patch implements Tegra specific set_timeout sdhci_ops to allow switching between finite and infinite HW busy detection wait modes based on the device command expected operation time. Cc: Signed-off-by: Sowjanya Komatineni --- drivers/mmc/host/sdhci-tegra.c | 31 +++++++++++++++++++++++++++++++ 1 file changed, 31 insertions(+) diff --git a/drivers/mmc/host/sdhci-tegra.c b/drivers/mmc/host/sdhci-tegra.c index a25c3a4..fa8f6a4 100644 --- a/drivers/mmc/host/sdhci-tegra.c +++ b/drivers/mmc/host/sdhci-tegra.c @@ -45,6 +45,7 @@ #define SDHCI_TEGRA_CAP_OVERRIDES_DQS_TRIM_SHIFT 8 #define SDHCI_TEGRA_VENDOR_MISC_CTRL 0x120 +#define SDHCI_MISC_CTRL_ERASE_TIMEOUT_LIMIT BIT(0) #define SDHCI_MISC_CTRL_ENABLE_SDR104 0x8 #define SDHCI_MISC_CTRL_ENABLE_SDR50 0x10 #define SDHCI_MISC_CTRL_ENABLE_SDHCI_SPEC_300 0x20 @@ -1227,6 +1228,34 @@ static u32 sdhci_tegra_cqhci_irq(struct sdhci_host *host, u32 intmask) return 0; } +static void tegra_sdhci_set_timeout(struct sdhci_host *host, + struct mmc_command *cmd) +{ + u32 val; + + /* + * HW busy detection timeout is based on programmed data timeout + * counter and maximum supported timeout is 11s which may not be + * enough for long operations like cache flush, sleep awake, erase. + * + * ERASE_TIMEOUT_LIMIT bit of VENDOR_MISC_CTRL register allows + * host controller to wait for busy state until the card is busy + * without HW timeout. + * + * So, use infinite busy wait mode for operations that may take + * more than maximum HW busy timeout of 11s otherwise use finite + * busy wait mode. + */ + val = sdhci_readl(host, SDHCI_TEGRA_VENDOR_MISC_CTRL); + if (cmd && cmd->busy_timeout >= 11 * HZ) + val |= SDHCI_MISC_CTRL_ERASE_TIMEOUT_LIMIT; + else + val &= ~SDHCI_MISC_CTRL_ERASE_TIMEOUT_LIMIT; + sdhci_writel(host, val, SDHCI_TEGRA_VENDOR_MISC_CTRL); + + __sdhci_set_timeout(host, cmd); +} + static const struct cqhci_host_ops sdhci_tegra_cqhci_ops = { .write_l = tegra_cqhci_writel, .enable = sdhci_tegra_cqe_enable, @@ -1366,6 +1395,7 @@ static const struct sdhci_ops tegra210_sdhci_ops = { .set_uhs_signaling = tegra_sdhci_set_uhs_signaling, .voltage_switch = tegra_sdhci_voltage_switch, .get_max_clock = tegra_sdhci_get_max_clock, + .set_timeout = tegra_sdhci_set_timeout, }; static const struct sdhci_pltfm_data sdhci_tegra210_pdata = { @@ -1403,6 +1433,7 @@ static const struct sdhci_ops tegra186_sdhci_ops = { .voltage_switch = tegra_sdhci_voltage_switch, .get_max_clock = tegra_sdhci_get_max_clock, .irq = sdhci_tegra_cqhci_irq, + .set_timeout = tegra_sdhci_set_timeout, }; static const struct sdhci_pltfm_data sdhci_tegra186_pdata = { -- 2.7.4