Received: by 2002:a05:6602:18e:0:0:0:0 with SMTP id m14csp5730222ioo; Wed, 1 Jun 2022 11:17:26 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzY/npAHVT6RMB67gOIer6qsrBXp1ThVsryopqQyHoBpOmFWbTRzueBfZDmyGzpKWJs+te1 X-Received: by 2002:a17:907:868c:b0:6fe:fd7a:e0d7 with SMTP id qa12-20020a170907868c00b006fefd7ae0d7mr777083ejc.90.1654107446112; Wed, 01 Jun 2022 11:17:26 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1654107446; cv=none; d=google.com; s=arc-20160816; b=nyu6KHvCOp5lHq7HWlM00kCwyH8NQujHOhHWEk1ntOqfRXjz7ymeJ0KMCUgdVB2K8/ WA4TTQb1gp7OSsUbo+hpQg7nnfglpPpzBVXie8CywHH4FFCwKq2gTFuNghmLz9Uf3ZZJ 1TA1mvhfiS5XI99ass0OKDyB35U61lZSX8isHXJVVwbdzkCULFSBBTY2ALbez5ad4Nhl 3AYffM5MdB2+t98gWD6QCW+NsmUev8aVld52jF1mB8iCue6g8n5IzI9GjghAYxJuYKAd oP8OfFKs+g0cqZBWjF2tBqJkmSkcaS1YJSb4/sVRkb0Fy+sMUopsgwrpjHGEnfVWde91 pQLQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=ubHn1vvyy0LeW/urHZ3Pi1a4zlwad6P7YCJ0BsM+UD8=; b=VuSSh/+uRFKP5OH5LYkN61aEfnpuYkJbu2s9FJ8FlxKdAxotOUKn1aaF3Dbi3mXUaX XI8arLxcqq+1VC8DbH+0Jq2cO+Iw2LSNBFTpGHmhA0Uyn6k03YY8PfgmbpV1dW/y8Djy 9K4zMwEymE4g5l5hqCMaGD7FJwwuIvwwPQHYc+kKgMvNxu+0+3wK+2tz34qYkqdTQ0+c 0rsvF56oHhBeAhDO0neXC5HvuOWEqAuRrSvO2x1WaozC5ptvNWyVwCkRoOSUT8ZkQIQ/ GMbBUEGKTnuG6i+NEZsAVi+C80RK6QvuvdM3IICwxGqb6Q/f2Jtyls1Y7Ymor4ow7XI0 eTnw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b="pwp/6tjy"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id t2-20020a1709066bc200b006ff0fb360ffsi2361779ejs.10.2022.06.01.11.16.59; Wed, 01 Jun 2022 11:17:26 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b="pwp/6tjy"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1347758AbiEaUee (ORCPT + 99 others); Tue, 31 May 2022 16:34:34 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:47546 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1343972AbiEaUeb (ORCPT ); Tue, 31 May 2022 16:34:31 -0400 Received: from dfw.source.kernel.org (dfw.source.kernel.org [139.178.84.217]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id C31D5994F3; Tue, 31 May 2022 13:34:30 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id 648B9612DC; Tue, 31 May 2022 20:34:30 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 93414C385A9; Tue, 31 May 2022 20:34:29 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1654029269; bh=7k+SyZk2P/BnS4w86E2eL0uEWgnk76t6CF+HTgTg0AE=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=pwp/6tjyjxCp5GCv6vLMwD9am8lKRAiPUFdqbbNoKWaEUEuYbmSeWIt9TXFkloHm3 E2OMrcRtiyzUhr4/TJGq/90Ps7rSP4mC36Ly7tLyPC29q58uEnz2JG7avVkHwbJ91/ C6Rfz/PDrpHD5H0hcMSjiCsi7q7/bDqfvATGGgcRwJBIyDp9sOQWACQWBEDl3K07KV LDINTykeU0xu3c6hkgrIerHS1GjWqmgxrNiMfYfSdFJ6pCrSDBNHkCv4tfTLFQ9Re0 08BwvGyz/KPazINRI8XkYejSwicDmhqqzs60RkSNPTS+WG2eG9nuuxcg3YIpGj4gMQ lCPt6se3JHC6w== Date: Tue, 31 May 2022 20:34:28 +0000 From: Eric Biggers To: Jaegeuk Kim Cc: linux-kernel@vger.kernel.org, linux-scsi@vger.kernel.org, "Martin K . Petersen" , Bart Van Assche , Adrian Hunter , Asutosh Das , Avri Altman , Bean Huo , Stanley Chu , Can Guo Subject: Re: [PATCH] scsi: ufs: add a quirk to disable FUA support Message-ID: References: <20220531201053.3300018-1-jaegeuk@kernel.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20220531201053.3300018-1-jaegeuk@kernel.org> X-Spam-Status: No, score=-7.7 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_HI, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, May 31, 2022 at 01:10:53PM -0700, Jaegeuk Kim wrote: > UFS stack shows very low performance of FUA comparing to write and cache_flush. > Let's add a quirk to adjust it. > > E.g., average latency according to the chunk size of write > > Write(us/KB) 4 64 256 1024 2048 > FUA 873.792 754.604 995.624 1011.67 1067.99 > CACHE_FLUSH 824.703 712.98 800.307 1019.5 1037.37 > > Signed-off-by: Jaegeuk Kim > --- > drivers/scsi/ufs/ufshcd.c | 3 +++ > drivers/scsi/ufs/ufshcd.h | 5 +++++ > 2 files changed, 8 insertions(+) > > diff --git a/drivers/scsi/ufs/ufshcd.c b/drivers/scsi/ufs/ufshcd.c > index 3f9caafa91bf..811f3467879c 100644 > --- a/drivers/scsi/ufs/ufshcd.c > +++ b/drivers/scsi/ufs/ufshcd.c > @@ -5035,6 +5035,9 @@ static int ufshcd_slave_configure(struct scsi_device *sdev) > */ > sdev->silence_suspend = 1; > > + if (hba->quirks & UFSHCD_QUIRK_BROKEN_FUA) > + sdev->broken_fua = 1; > + > ufshcd_crypto_register(hba, q); > > return 0; > diff --git a/drivers/scsi/ufs/ufshcd.h b/drivers/scsi/ufs/ufshcd.h > index 94f545be183a..6c480c6741d6 100644 > --- a/drivers/scsi/ufs/ufshcd.h > +++ b/drivers/scsi/ufs/ufshcd.h > @@ -602,6 +602,11 @@ enum ufshcd_quirks { > * support physical host configuration. > */ > UFSHCD_QUIRK_SKIP_PH_CONFIGURATION = 1 << 16, > + > + /* > + * This quirk disables FUA support. > + */ > + UFSHCD_QUIRK_BROKEN_FUA = 1 << 17, > }; "Broken" is ambiguous. IIUC, the issue is that FUA performance is very bad, not that it doesn't work. Can you clarify the intent in the comment? Also, this patch does nothing by itself. Which UFS host driver(s) need this quirk bit? Can you update them to use it? Or do they all need this, in which case a quirk bit would be unnecessary? - Eric