Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp134724ybz; Fri, 24 Apr 2020 13:08:49 -0700 (PDT) X-Google-Smtp-Source: APiQypLJqGSvEzOl5/71f/VvnJC817TIoEvkM7wchBJ/kHCwbTicsPXq8koO7qewwi8T0Y5UsnsJ X-Received: by 2002:a17:907:20a2:: with SMTP id pw2mr8993779ejb.252.1587758929625; Fri, 24 Apr 2020 13:08:49 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1587758929; cv=none; d=google.com; s=arc-20160816; b=K3vNXP1snz+CYxeMKse/+4JCOgRv3FefRGlGuwYBhmqDd4prc01kAlQU34S51kIWdI 6NEVCAw5a7J2Rvb8pOIqzFksPEHeTpyGccHC7KMmLltEjEChWtD5+pPU91hgrLltet7Z FfkXfFi3SDL774JXrpBmEVLsJftMovyYQ/P8FeXeYWky06TWJ1o7qljRa0wmVQWrFud5 ZN2N2PVvngBIIikLCHC4MBhwp927kMzWwbFhWdQimsLt8ezL6VqfzX7wZdrEKfYjX/3D hzxtVQmvbxnMBUWPWxCH+KtuGocx2a2L9OHjSFFBUPNwajksAXB1z2+l9jQesnkp141P NVxw== 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=Z4lZoTve4p6wovayco1GhskwVYDIfOL0C/VNA7v7SK4=; b=ptOeg/tyFlkzLtca96+jLMqQFjbYMsGGAJdHIwrXniC021BSjxIoeb+/wdPkIl8i6g wd/PdMlmo5jGKMnW3pykczKzADWGdQZYgZrjmBbyl/kaVvIuqOJQhnejk8s38ljYscwo LuL9GfLJFd/skIudf+sNGjwVKDxiQuYYuMV0Q0F0O9Z7yn/gkwRcq3FiDAh7qKr6SyW9 N75s1jGFMVb5H8UKLxG2pooTVBwqH5jCZuhaXZZJF7YHp2jzYxOMpgP40SXkEQFS0DaH uRE0I2evNnHi/M8WoyoyTBxj0L1t/E8yvZJwcWMAwlx+Yfrc8GmvktjDsY1GrFXMIckL n7mQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@nvidia.com header.s=n1 header.b=MRu1kO0Q; 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 w7si3530231edr.309.2020.04.24.13.08.26; Fri, 24 Apr 2020 13:08:49 -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=MRu1kO0Q; 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 S1729469AbgDXUG5 (ORCPT + 99 others); Fri, 24 Apr 2020 16:06:57 -0400 Received: from hqnvemgate24.nvidia.com ([216.228.121.143]:3494 "EHLO hqnvemgate24.nvidia.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727021AbgDXUG4 (ORCPT ); Fri, 24 Apr 2020 16:06:56 -0400 Received: from hqpgpgate101.nvidia.com (Not Verified[216.228.121.13]) by hqnvemgate24.nvidia.com (using TLS: TLSv1.2, DES-CBC3-SHA) id ; Fri, 24 Apr 2020 13:04:58 -0700 Received: from hqmail.nvidia.com ([172.20.161.6]) by hqpgpgate101.nvidia.com (PGP Universal service); Fri, 24 Apr 2020 13:06:56 -0700 X-PGP-Universal: processed; by hqpgpgate101.nvidia.com on Fri, 24 Apr 2020 13:06:56 -0700 Received: from HQMAIL107.nvidia.com (172.20.187.13) by HQMAIL105.nvidia.com (172.20.187.12) with Microsoft SMTP Server (TLS) id 15.0.1473.3; Fri, 24 Apr 2020 20:06:55 +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; Fri, 24 Apr 2020 20:06:55 +0000 Received: from skomatineni-linux.nvidia.com (Not Verified[10.2.165.152]) by hqnvemgw03.nvidia.com with Trustwave SEG (v7,5,8,10121) id ; Fri, 24 Apr 2020 13:06:55 -0700 From: Sowjanya Komatineni To: , , , , , , , , , CC: , , , , Subject: [PATCH 4.19.113 2/3] sdhci: tegra: Implement Tegra specific set_timeout callback Date: Fri, 24 Apr 2020 13:06:51 -0700 Message-ID: <1587758812-3331-3-git-send-email-skomatineni@nvidia.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1587758812-3331-1-git-send-email-skomatineni@nvidia.com> References: <1587758812-3331-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=1587758698; bh=Z4lZoTve4p6wovayco1GhskwVYDIfOL0C/VNA7v7SK4=; h=X-PGP-Universal:From:To:CC:Subject:Date:Message-ID:X-Mailer: In-Reply-To:References:X-NVConfidentiality:MIME-Version: Content-Type; b=MRu1kO0QTjK1hs5YjtErTtNtkr3MY2GEsifdyL558k2E4OFRVvDP385VrszFNPrBA Jgo6YjOl9vKhK/wJ1OPDqU3QcmaGtkmnisFrLONHHAOD40oI2/V1CKgpINvChe67aj rhWhRsSEKkL0vUgu05zbdbXMeK4dWpDoowDpW43NSvLTwOzTB/mvLeVONrz0hTbJkh T+Z6+vwpo5H1feK2waFgMrralNbBtcSgbni3cZDFEaC/yKW9L/wEdhJOrqE9tqBoAA 0DfyvqJ5ZQyaAWMsu2kEcSrn6peXXNq4Caw1J1LSzIRDpwRoxwiU9i0Y/uJA48hesF SVHFieOYrnp5g== 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 | 30 ++++++++++++++++++++++++++++++ 1 file changed, 30 insertions(+) diff --git a/drivers/mmc/host/sdhci-tegra.c b/drivers/mmc/host/sdhci-tegra.c index 27bdf6d..0f4de73 100644 --- a/drivers/mmc/host/sdhci-tegra.c +++ b/drivers/mmc/host/sdhci-tegra.c @@ -39,6 +39,7 @@ #define SDHCI_CLOCK_CTRL_SPI_MODE_CLKEN_OVERRIDE BIT(2) #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 @@ -301,6 +302,34 @@ static int tegra_sdhci_execute_tuning(struct sdhci_host *host, u32 opcode) return mmc_send_tuning(host->mmc, opcode, NULL); } +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 void tegra_sdhci_voltage_switch(struct sdhci_host *host) { struct sdhci_pltfm_host *pltfm_host = sdhci_priv(host); @@ -379,6 +408,7 @@ static const struct sdhci_ops tegra114_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_tegra114_pdata = { -- 2.7.4