Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp1777657pxj; Fri, 18 Jun 2021 15:27:39 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxl1nN9dl2gK9B9C7l3fJbqcliu1Cq36UGkkm7wAcl3IgaJ//CLMp9YzWjGNvBJvgAJH/se X-Received: by 2002:a02:a710:: with SMTP id k16mr5304396jam.46.1624055259212; Fri, 18 Jun 2021 15:27:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1624055259; cv=none; d=google.com; s=arc-20160816; b=Ww2c7VSp6NxkJjB8Beo4cDNRDrJMS7aq7VtI0DQNGuAAN8ZGAhOD1/Eum6pZrGIV59 9U7B/wFykgNsKy7EJLiGSPp1yywyAjXT0vNn9vtLig5fhk3Rk12C0lT8KKYmqUFLUUat rt8eeDdu/9f/4UnzAhKQMcsZUGsBYEqx/L0e23TRivqiGl2iQRMRCLG3tzcgNF+K5HGY zWXhOn/nLru/PQSOj7Dn1gne2g/n+Dc8c9eBeTJMlxmKbWM7CNkW93tBHA27zOEbiueP NYa0JzEA80QxInRIxuHGQ9JzvevIih8t4+NSM3AO/b4ZbimbNW+dKFlCY6crsNC/6Fzv gOhA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-language:content-transfer-encoding :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject:dmarc-filter:sender:dkim-signature; bh=OxgVviWKxuFMj10LPSjFh3cD0WnhN3SYM98fOdw/uao=; b=RqKFqXFcOm9LCNFKphkmL5EQwBtPF1PaWDRXd2NtZxsg9cdDj0cwWrvIczV4sx/H5p cOlPfyfsccMwbhol0TGLR6SOq0PyLSEPXoiQcG5inwRI7dbtzBDIfHbLTJaH056amOtE uKwbnCXio6jvG0wSYkDOvI8dOBEZJiM87yPTHiUjLAlK9tMHvpUDNXLd5fMz+6p1Mi43 tFXt7EsKpjSKeB4RJgIpUth2fnFpYPltKx5kOEyY0aUlIn337MvnDs6cr1CY8EObPH8t D5NErQtbM1aLBJz9FXQnGjQRc6AUvLeFwCPh+amVt5E5Qbvpc0JhhUoAxQc73QPX5Wef l+5A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@mg.codeaurora.org header.s=smtp header.b=wNl4VSH4; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id i13si3513488ils.127.2021.06.18.15.27.27; Fri, 18 Jun 2021 15:27:39 -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=@mg.codeaurora.org header.s=smtp header.b=wNl4VSH4; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S235455AbhFRPd5 (ORCPT + 99 others); Fri, 18 Jun 2021 11:33:57 -0400 Received: from so254-9.mailgun.net ([198.61.254.9]:26050 "EHLO so254-9.mailgun.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235563AbhFRPdi (ORCPT ); Fri, 18 Jun 2021 11:33:38 -0400 DKIM-Signature: a=rsa-sha256; v=1; c=relaxed/relaxed; d=mg.codeaurora.org; q=dns/txt; s=smtp; t=1624030289; h=Content-Transfer-Encoding: Content-Type: In-Reply-To: MIME-Version: Date: Message-ID: From: References: Cc: To: Subject: Sender; bh=OxgVviWKxuFMj10LPSjFh3cD0WnhN3SYM98fOdw/uao=; b=wNl4VSH4gCyOhBQrC4oFfQC6Ib3tQWR3PwzcMi4fLhYronZx/bfRx+Blwaccq7FTVkXzbZO3 A4ZPkY/qruXwlpCXTlvb7VMe8jK37Y0vUAOo/KhkNtyXsoWle1aKijJNWv0N/hLE8KtImciY QhEZ3LyIJgdz1YRWfuUblaMiD1Q= X-Mailgun-Sending-Ip: 198.61.254.9 X-Mailgun-Sid: WyI0MWYwYSIsICJsaW51eC1rZXJuZWxAdmdlci5rZXJuZWwub3JnIiwgImJlOWU0YSJd Received: from smtp.codeaurora.org (ec2-35-166-182-171.us-west-2.compute.amazonaws.com [35.166.182.171]) by smtp-out-n05.prod.us-west-2.postgun.com with SMTP id 60ccbc35e570c056195867b9 (version=TLS1.2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256); Fri, 18 Jun 2021 15:31:01 GMT Sender: vbadigan=codeaurora.org@mg.codeaurora.org Received: by smtp.codeaurora.org (Postfix, from userid 1001) id 2DE9BC43217; Fri, 18 Jun 2021 15:31:01 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-caf-mail-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-3.1 required=2.0 tests=ALL_TRUSTED,BAYES_00, NICE_REPLY_A,SPF_FAIL,URIBL_BLOCKED autolearn=no autolearn_force=no version=3.4.0 Received: from [192.168.1.102] (unknown [49.205.245.243]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: vbadigan) by smtp.codeaurora.org (Postfix) with ESMTPSA id 667BBC433D3; Fri, 18 Jun 2021 15:30:55 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org 667BBC433D3 Authentication-Results: aws-us-west-2-caf-mail-1.web.codeaurora.org; dmarc=none (p=none dis=none) header.from=codeaurora.org Authentication-Results: aws-us-west-2-caf-mail-1.web.codeaurora.org; spf=fail smtp.mailfrom=vbadigan@codeaurora.org Subject: Re: [PATCH V1] mmc: sdhci: Update the software timeout value for sdhc To: Shaik Sajida Bhanu , adrian.hunter@intel.com, ulf.hansson@linaro.org Cc: asutoshd@codeaurora.org, stummala@codeaurora.org, rampraka@codeaurora.org, sayalil@codeaurora.org, sartgarg@codeaurora.org, rnayak@codeaurora.org, cang@codeaurora.org, pragalla@codeaurora.org, nitirawa@codeaurora.org, linux-mmc@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-msm@vger.kernel.org, agross@kernel.org, bjorn.andersson@linaro.org, robh+dt@kernel.org References: <1623835535-30871-1-git-send-email-sbhanu@codeaurora.org> From: Veerabhadrarao Badiganti Message-ID: <585e003c-0342-4691-ab6d-8c6a930f9404@codeaurora.org> Date: Fri, 18 Jun 2021 21:00:29 +0530 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:78.0) Gecko/20100101 Thunderbird/78.10.0 MIME-Version: 1.0 In-Reply-To: <1623835535-30871-1-git-send-email-sbhanu@codeaurora.org> Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 7bit Content-Language: en-US Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 6/16/2021 2:55 PM, Shaik Sajida Bhanu wrote: > Whenever SDHC run at clock rate 50MHZ or below, the hardware data > timeout value will be 21.47secs, which is approx. 22secs and we have > a current software timeout value as 10secs. We have to set software > timeout value more than the hardware data timeout value to avioid seeing > the below register dumps. > > [ 332.953670] mmc2: Timeout waiting for hardware interrupt. > [ 332.959608] mmc2: sdhci: ============ SDHCI REGISTER DUMP =========== > [ 332.966450] mmc2: sdhci: Sys addr: 0x00000000 | Version: 0x00007202 > [ 332.973256] mmc2: sdhci: Blk size: 0x00000200 | Blk cnt: 0x00000001 > [ 332.980054] mmc2: sdhci: Argument: 0x00000000 | Trn mode: 0x00000027 > [ 332.986864] mmc2: sdhci: Present: 0x01f801f6 | Host ctl: 0x0000001f > [ 332.993671] mmc2: sdhci: Power: 0x00000001 | Blk gap: 0x00000000 > [ 333.000583] mmc2: sdhci: Wake-up: 0x00000000 | Clock: 0x00000007 > [ 333.007386] mmc2: sdhci: Timeout: 0x0000000e | Int stat: 0x00000000 > [ 333.014182] mmc2: sdhci: Int enab: 0x03ff100b | Sig enab: 0x03ff100b > [ 333.020976] mmc2: sdhci: ACmd stat: 0x00000000 | Slot int: 0x00000000 > [ 333.027771] mmc2: sdhci: Caps: 0x322dc8b2 | Caps_1: 0x0000808f > [ 333.034561] mmc2: sdhci: Cmd: 0x0000183a | Max curr: 0x00000000 > [ 333.041359] mmc2: sdhci: Resp[0]: 0x00000900 | Resp[1]: 0x00000000 > [ 333.048157] mmc2: sdhci: Resp[2]: 0x00000000 | Resp[3]: 0x00000000 > [ 333.054945] mmc2: sdhci: Host ctl2: 0x00000000 > [ 333.059657] mmc2: sdhci: ADMA Err: 0x00000000 | ADMA Ptr: > 0x0000000ffffff218 > [ 333.067178] mmc2: sdhci_msm: ----------- VENDOR REGISTER DUMP > ----------- > [ 333.074343] mmc2: sdhci_msm: DLL sts: 0x00000000 | DLL cfg: > 0x6000642c | DLL cfg2: 0x0020a000 > [ 333.083417] mmc2: sdhci_msm: DLL cfg3: 0x00000000 | DLL usr ctl: > 0x00000000 | DDR cfg: 0x80040873 > [ 333.092850] mmc2: sdhci_msm: Vndr func: 0x00008a9c | Vndr func2 : > 0xf88218a8 Vndr func3: 0x02626040 > [ 333.102371] mmc2: sdhci: ============================================ > > So, set software timeout value more than hardware timeout value. > > Signed-off-by: Shaik Sajida Bhanu > --- > drivers/mmc/host/sdhci.c | 9 ++++++++- > 1 file changed, 8 insertions(+), 1 deletion(-) > > diff --git a/drivers/mmc/host/sdhci.c b/drivers/mmc/host/sdhci.c > index bf238ad..1386f7d 100644 > --- a/drivers/mmc/host/sdhci.c > +++ b/drivers/mmc/host/sdhci.c > @@ -1670,7 +1670,14 @@ static bool sdhci_send_command(struct sdhci_host *host, struct mmc_command *cmd) > else if (!cmd->data && cmd->busy_timeout > 9000) > timeout += DIV_ROUND_UP(cmd->busy_timeout, 1000) * HZ + HZ; > else > - timeout += 10 * HZ; > + /* > + * In some of the conditions hardware data timeout value could be > + * approx 21.5 seconds and driver is setting software data timeout > + * value less than the hardware data timeout value and software data > + * timeout value should be more than the hardware data timeout value. > + * So, set software data timeout value more than 21.5 sec i.e. 22sec. > + */ > + timeout += 22 * HZ; This timeout is qcom SDHC specific. I think right way is to, define your own set_timeout op and update host->data_timeout in that as per qcom SDHC requirements. > sdhci_mod_timer(host, cmd->mrq, timeout); > > if (host->use_external_dma)