Received: by 2002:a05:6a10:a852:0:0:0:0 with SMTP id d18csp23301pxy; Thu, 6 May 2021 19:14:28 -0700 (PDT) X-Google-Smtp-Source: ABdhPJw2kW/9dt6VqNbo7QX1RxQt8V56+Q5KzgexTEumafOsX+ya77LyFIezoogs3+m0pqeBVHWq X-Received: by 2002:aa7:8b0f:0:b029:20d:1b60:e823 with SMTP id f15-20020aa78b0f0000b029020d1b60e823mr7845144pfd.16.1620353668012; Thu, 06 May 2021 19:14:28 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620353668; cv=none; d=google.com; s=arc-20160816; b=lnVDTBCsX+nG1sHARcQUyffKiucA9uUlwmyh6TyxdV0ITteI4ZInoba2/aDRHA+6YU c7zyJVN4BHSZMLUceIslMEF6VihQL6+BHvLSnUnnAC9rEg3RcU6jkp2jpJZ3A5HLao6O MjrILFYVeYwdFosbeigHPsAi7F9/cuiD7M83cFQOPiLuJ441FJ4nUICGghXWTA76+Zfy rkG9FdhY4vIjBttlycSXmZIdri/BN/w73b93QiOz+chm/NM5ayevdRVaIJvoSsjKtA66 fSGo/BU6f4K7EbTWK5w44pMWmblhA8TZ35rRa2Svlb8s3+foZrpKA0/Tyi4OlTOtJt4f DERQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:to:subject:cc:user-agent:mime-version:date:message-id; bh=CuJ2Y0rOkHklLOcTOjEpGO4p3J0PDlS7E7Lavstr+CM=; b=r9EKxL9a9yF1j3GTZ6t5BPHmKcSvINn7lZEBRM9rFzHnCRWP9qXDZhL4R9AKSDdHTT B5i4xwaBmw7pqJEoFM/Dhuda8TkfdDiQ1X3lwqx0fJp1wBO8mlzOzvKMDSNPFfeBGXH/ QtxAScMBeQo7JwaxnASgqWwZAFTUUmTCEMfhqtWdudUubnmHCZLACVzbZINytiTMYxfh OMqZjdfHh6T6kDPJO0AOPtEDML5l3N2yPUGp+6336ZAnPugZ/bsHhl0835x8Lqlho0ee tL4c5mHnbzyYDnIFJMi5E07bKuaXt1e0T6OSiP4++BjH/56EkRsPBVEZKC2dKWjNFJ6k Cp7A== ARC-Authentication-Results: i=1; mx.google.com; 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 g16si4950834pfi.92.2021.05.06.19.14.14; Thu, 06 May 2021 19:14:28 -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; 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 S233663AbhEGBpc (ORCPT + 99 others); Thu, 6 May 2021 21:45:32 -0400 Received: from regular1.263xmail.com ([211.150.70.203]:52618 "EHLO regular1.263xmail.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229801AbhEGBpc (ORCPT ); Thu, 6 May 2021 21:45:32 -0400 Received: from localhost (unknown [192.168.167.16]) by regular1.263xmail.com (Postfix) with ESMTP id 90558776; Fri, 7 May 2021 09:44:31 +0800 (CST) X-MAIL-GRAY: 0 X-MAIL-DELIVERY: 1 X-ADDR-CHECKED4: 1 X-ANTISPAM-LEVEL: 2 X-SKE-CHECKED: 1 X-ABS-CHECKED: 1 Received: from [172.16.12.64] (unknown [58.22.7.114]) by smtp.263.net (postfix) whith ESMTP id P31917T139684137133824S1620351870407100_; Fri, 07 May 2021 09:44:31 +0800 (CST) X-IP-DOMAINF: 1 X-UNIQUE-TAG: <418bceb8c99b1cc94bbf797774860f9e> X-RL-SENDER: shawn.lin@rock-chips.com X-SENDER: lintao@rock-chips.com X-LOGIN-NAME: shawn.lin@rock-chips.com X-FST-TO: linux-kernel@vger.kernel.org X-RCPT-COUNT: 10 X-SENDER-IP: 58.22.7.114 X-ATTACHMENT-NUM: 0 X-System-Flag: 0 Message-ID: <6d528e02-dd27-65d3-0cd3-e764cc780a81@rock-chips.com> Date: Fri, 7 May 2021 09:44:30 +0800 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:87.0) Gecko/20100101 Thunderbird/87.0 Cc: shawn.lin@rock-chips.com, Linus Walleij , Wolfram Sang , Avri Altman , Masami Hiramatsu , linux-block@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH 02/11] mmc: core: Take into account MMC_CAP_NEED_RSP_BUSY for eMMC HPI commands To: Ulf Hansson , linux-mmc@vger.kernel.org, Adrian Hunter References: <20210504161222.101536-1-ulf.hansson@linaro.org> <20210504161222.101536-3-ulf.hansson@linaro.org> From: Shawn Lin In-Reply-To: <20210504161222.101536-3-ulf.hansson@linaro.org> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2021/5/5 0:12, Ulf Hansson wrote: > In mmc_send_hpi_cmd() the host->max_busy_timeout is being validated towards > the timeout for the eMMC HPI command, as to decide whether an R1 or R1B > response should be used. > > Although, it has turned out the some host can't cope with that conversion, > but needs R1B, which means MMC_CAP_NEED_RSP_BUSY is set for them. Let's > take this into account, via using the common mmc_prepare_busy_cmd() when > doing the validation, which also avoids some open coding. Reviewed-by: Shawn Lin > > Signed-off-by: Ulf Hansson > --- > drivers/mmc/core/mmc_ops.c | 21 +++++---------------- > 1 file changed, 5 insertions(+), 16 deletions(-) > > diff --git a/drivers/mmc/core/mmc_ops.c b/drivers/mmc/core/mmc_ops.c > index 025a4134d5c7..66ae699a410f 100644 > --- a/drivers/mmc/core/mmc_ops.c > +++ b/drivers/mmc/core/mmc_ops.c > @@ -817,28 +817,17 @@ static int mmc_send_hpi_cmd(struct mmc_card *card) > { > unsigned int busy_timeout_ms = card->ext_csd.out_of_int_time; > struct mmc_host *host = card->host; > - bool use_r1b_resp = true; > + bool use_r1b_resp = false; > struct mmc_command cmd = {}; > int err; > > cmd.opcode = card->ext_csd.hpi_cmd; > cmd.arg = card->rca << 16 | 1; > + cmd.flags = MMC_RSP_R1 | MMC_CMD_AC; > > - /* > - * Make sure the host's max_busy_timeout fit the needed timeout for HPI. > - * In case it doesn't, let's instruct the host to avoid HW busy > - * detection, by using a R1 response instead of R1B. > - */ > - if (host->max_busy_timeout && busy_timeout_ms > host->max_busy_timeout) > - use_r1b_resp = false; > - > - if (cmd.opcode == MMC_STOP_TRANSMISSION && use_r1b_resp) { > - cmd.flags = MMC_RSP_R1B | MMC_CMD_AC; > - cmd.busy_timeout = busy_timeout_ms; > - } else { > - cmd.flags = MMC_RSP_R1 | MMC_CMD_AC; > - use_r1b_resp = false; > - } > + if (cmd.opcode == MMC_STOP_TRANSMISSION) > + use_r1b_resp = mmc_prepare_busy_cmd(host, &cmd, > + busy_timeout_ms); > > err = mmc_wait_for_cmd(host, &cmd, 0); > if (err) { >