Received: by 2002:a05:7412:d8a:b0:e2:908c:2ebd with SMTP id b10csp407282rdg; Tue, 10 Oct 2023 14:05:38 -0700 (PDT) X-Google-Smtp-Source: AGHT+IHQG7Ls7ZfBMvfOE3y4+bL+zt3h6ZEvBHU1yImba/lQUVbRQWVRhDq3WWky7dSnbq7kKl7a X-Received: by 2002:a17:903:120f:b0:1c0:c86a:5425 with SMTP id l15-20020a170903120f00b001c0c86a5425mr19403219plh.19.1696971938475; Tue, 10 Oct 2023 14:05:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1696971938; cv=none; d=google.com; s=arc-20160816; b=eoqgMrBk/j3/gSXwEKq4H9cPRRE76VVTkmaMFVy+Vz0X35t5FqM/AL2hu3FnUVN5/h Xx3IquN6ULf4SXNI1ap2tLaNwHpvh/8ycrtjU68jJBrOSjVXTWCBZz/al8A6E9DFTyub SFCBPIlU4MhhId9P3IEXJKPo4TlO8MnSotx7MRVd/OfJcJAZdPWLgDQg+XFIB4pzqK1p pKgG1NKALenWx/gKc5Q4MQrOoMQbjJkNn6giUFYb2QjecR+N5zDF1wlTNexQ2DcqLjNf p+OD7WVvG0689fCRwxjKhkk+baUEKbxtpev49Dc8iQbSpvhqrBp/p3BDTc1qZkMXCdrz tP1w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version:dkim-signature; bh=0JPdI81s1g1jD64Q6FcuAIQKwcDv5/ca0TQcTmOhurM=; fh=TRN1TXWiFd3OvAVWEiax81muEXdVxfteWX6ynVUChlI=; b=Ry2FQc8e8iYr1Wr7XWZjcXlBm3kt/tVrCLsIqzFprdIBJdBOnIaAAjGHgWwWWI7WV4 5cr6W6S5Pv82EMsqEOX4g5jFY/6WaCz6K0xXy3dhCF2huFDFwZWG/XllP9XG3pAwAqPB PlnLFetGJZNAHQW8AF0LyKMA8g6ecexDtTJ66qm+gtKcoQje4ORkNnFiYxrC3Pa9ipph HH5h6GqwlmBU58yTwpHBAUInMzjQbmQTKYz0iMjhZhHSeLpfkXyM0pmQzEehtNYetAmv qwJZ/YnmAtftMNJyN+zfVPuoPwmY60nlSu+t7OaWpKRzYS8WHxHQh8tKpt6qFvU4YvR2 zIrw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=Os+bFrzj; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.34 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from howler.vger.email (howler.vger.email. [23.128.96.34]) by mx.google.com with ESMTPS id kx3-20020a170902f94300b001bdf225d158si2002788plb.284.2023.10.10.14.05.38 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 10 Oct 2023 14:05:38 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.34 as permitted sender) client-ip=23.128.96.34; Authentication-Results: mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=Os+bFrzj; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.34 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by howler.vger.email (Postfix) with ESMTP id D6EE48083B66; Tue, 10 Oct 2023 14:05:29 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at howler.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231768AbjJJVE5 (ORCPT + 99 others); Tue, 10 Oct 2023 17:04:57 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:50940 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229749AbjJJVE4 (ORCPT ); Tue, 10 Oct 2023 17:04:56 -0400 Received: from mail-yb1-xb2a.google.com (mail-yb1-xb2a.google.com [IPv6:2607:f8b0:4864:20::b2a]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id AF8E091 for ; Tue, 10 Oct 2023 14:04:54 -0700 (PDT) Received: by mail-yb1-xb2a.google.com with SMTP id 3f1490d57ef6-d9a4c0d89f7so1699457276.1 for ; Tue, 10 Oct 2023 14:04:54 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; t=1696971894; x=1697576694; darn=vger.kernel.org; h=cc:to:subject:message-id:date:from:in-reply-to:references :mime-version:from:to:cc:subject:date:message-id:reply-to; bh=0JPdI81s1g1jD64Q6FcuAIQKwcDv5/ca0TQcTmOhurM=; b=Os+bFrzjhKtV+ps1T390Qm8hpHMVq3LwUOgCgOVfUlkN3Q8TL8cVK0ReTu0o6Sq4JB 2/wAEYVjoN2plvvMndkzomzIMsYozdssEUPQx5b5NS0wz5W3noHvSJMeB3mvmwW4oFnu FXMA4aVMjstZ4AvEWAcR736DnW62WaGhYP7aezjJK+/mPOITmfXCHoiGCLgiJlMl1pPv 4/VpSq3O+EYV7x7Hk2TI1Gcp0UGmYE/x2oMdl689WUHUHorp56k2jfmOnjliti+CfnJ1 Ck1dHaOiYmtG8dCclg7t2TwRqapvu4cr5BpQu4DHsSVTrUDDSJ6dPs0TqMpaY4VsTTmc Dm2w== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1696971894; x=1697576694; h=cc:to:subject:message-id:date:from:in-reply-to:references :mime-version:x-gm-message-state:from:to:cc:subject:date:message-id :reply-to; bh=0JPdI81s1g1jD64Q6FcuAIQKwcDv5/ca0TQcTmOhurM=; b=sQpfWpwGZ/ZTiV/ZVJ93ktH6o59CVTbVJ6do19nVU2wmo7E0p2hal03pjsuFo+5K1G SXm7JP94xv4suzx9YKiNdfCzJMlDOnanzcebjuWRSbp9jAkGu7dJnBNMQqoAoNs2qY63 fOXFUYkDQuPDUbFbgVnDRRDSD7QA081hq+Tg2d9uZf4C/7sdSd0YtFik4463jWYwVlxe dRvxPuR79FOEB6Nl4tQ5WmMEdCzW6xiLv/fQlXgwuKlHf9anFIYcWH1jp40Bh6mYIgVz wtxHy3frnZhMm4H4BeY4lr/b4JN5ldD5gjZf3u88tlw/GrL6m8+8WVxog51e3qrjcIWQ mi/w== X-Gm-Message-State: AOJu0Yx8xRDjI7gaEqNhdkaQLyXfvxBTG3QgPqLaDBljFoERrXI0uSTs 588FuYn88MHalrZ3RWHYoLQhLs0a40OpOT/pxp943vSxcMT0oETPcFw= X-Received: by 2002:a05:6902:707:b0:d84:afae:96a8 with SMTP id k7-20020a056902070700b00d84afae96a8mr23439973ybt.7.1696971893895; Tue, 10 Oct 2023 14:04:53 -0700 (PDT) MIME-Version: 1.0 References: <20231001194943.658299-1-beanhuo@iokpp.de> <254df9b8ca7475ad9dbd3a303c60e1f99eca9c56.camel@iokpp.de> In-Reply-To: <254df9b8ca7475ad9dbd3a303c60e1f99eca9c56.camel@iokpp.de> From: Ulf Hansson Date: Tue, 10 Oct 2023 23:04:16 +0200 Message-ID: Subject: Re: [PATCH v4] mmc: Add quirk MMC_QUIRK_BROKEN_CACHE_FLUSH for Micron eMMC Q2J54A To: Bean Huo Cc: adrian.hunter@intel.com, beanhuo@micron.com, jakub.kwapisz@toradex.com, rafael.beims@toradex.com, linux-mmc@vger.kernel.org, linux-kernel@vger.kernel.org, stable@vger.kernel.org Content-Type: text/plain; charset="UTF-8" X-Spam-Status: No, score=2.7 required=5.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI, RCVD_IN_SBL_CSS,SPF_HELO_NONE,SPF_PASS autolearn=no autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on howler.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (howler.vger.email [0.0.0.0]); Tue, 10 Oct 2023 14:05:30 -0700 (PDT) X-Spam-Level: ** On Tue, 10 Oct 2023 at 17:33, Bean Huo wrote: > > Hi Ulf, > > thanks for your comments, I didn't quite get your points: > > On Tue, 2023-10-10 at 16:20 +0200, Ulf Hansson wrote: > > > @@ -2381,8 +2381,11 @@ enum mmc_issued mmc_blk_mq_issue_rq(struct > > > mmc_queue *mq, struct request *req) > > > } > > > ret = mmc_blk_cqe_issue_flush(mq, req); > > > break; > > > - case REQ_OP_READ: > > > case REQ_OP_WRITE: > > > + if (mmc_card_broken_cache_flush(card) && > > > !card->written_flag) > > > > It looks superfluous to me to check mmc_card_broken_cache_flush() and > > !card->written_flag. Just set the card->written_flag unconditionally. > > what did you mean "Just set the card->written_flag unconditionally."? > This means I just need to check card->written_flag and set card- > >written_flag to true and false in the case > MMC_QUIRK_BROKEN_CACHE_FLUSH? or don't need to call > mmc_card_broken_cache_flush()? I mean skip the checks above and just do the assignment below. > > > > > > + card->written_flag = true; > > > + fallthrough; > > > + case REQ_OP_READ: > > > if (host->cqe_enabled) > > > ret = mmc_blk_cqe_issue_rw_rq(mq, > > > req); > > > else > > > diff --git a/drivers/mmc/core/card.h b/drivers/mmc/core/card.h > > > index 4edf9057fa79..b7754a1b8d97 100644 > > > --- a/drivers/mmc/core/card.h > > > +++ b/drivers/mmc/core/card.h > > > @@ -280,4 +280,8 @@ static inline int > > > mmc_card_broken_sd_cache(const struct mmc_card *c) > > > return c->quirks & MMC_QUIRK_BROKEN_SD_CACHE; > > > } > > > > > > +static inline int mmc_card_broken_cache_flush(const struct > > > mmc_card *c) > > > +{ > > > + return c->quirks & MMC_QUIRK_BROKEN_CACHE_FLUSH; > > > +} > > > #endif > > > diff --git a/drivers/mmc/core/mmc.c b/drivers/mmc/core/mmc.c > > > index 89cd48fcec79..47896c32086e 100644 > > > --- a/drivers/mmc/core/mmc.c > > > +++ b/drivers/mmc/core/mmc.c > > > @@ -1929,6 +1929,8 @@ static int mmc_init_card(struct mmc_host > > > *host, u32 ocr, > > > if (!oldcard) > > > host->card = card; > > > > > > + card->written_flag = false; > > > + > > > > How about doing this after a successful flush operation instead? In > > other words in _mmc_flush_cache(). > > Here initializes flag and the patch is intenting to eliminate the cache > flush command before writing. what do you mean adding in > mmc_flush_cache()? mmc_init_card() is called while initializing and re-initializing the card. So, it certainly works to reset the flag from here. However, _mmc_flush_cache() is called before powering off the card, which then would work similarly to the above, but also gets called for REQ_OP_FLUSH. Wouldn't that mean that we may be able to skip some unnecessary/troublesome cache flush requests if we would reset the flag from mmc_flush_cache(), rather than from mmc_init_card()? Kind regards Uffe