Received: by 2002:ac0:a5a6:0:0:0:0:0 with SMTP id m35-v6csp872925imm; Sun, 2 Sep 2018 01:55:35 -0700 (PDT) X-Google-Smtp-Source: ANB0VdaDdzpFJByZCIC8BIlsQFVD5S0zwg+9At/DfqwOLsoE9gUhEnLdQAbL6+K9VW8anZNoo+yK X-Received: by 2002:a65:5286:: with SMTP id y6-v6mr20982902pgp.65.1535878535726; Sun, 02 Sep 2018 01:55:35 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1535878535; cv=none; d=google.com; s=arc-20160816; b=ZHGT0lBCCWhXqCNvmSesnLHC+yYxzkgFbPXkvoM/4fxycKZFyB0wpS6rKHY2IMBToL NKT2NHWiLX6LndcT8Tq6Vin0yiy36Z6v7WjSDhFJs9NfjyyeqBECKepbg4J/PykGGRZi ZodspScZMABmhdcUQYFdEDMrd/YLdvsDp4IUb+9eQWPtgVQF2WgXbUCvKbfw9NAQITJm Dc46O+Ra3Kg+yiuPTWgKFX+Ch01g44+jYGZThf/SoIX6npnQP1RUjp2l+A3T774vQpdB uIDDcvt0qy9qzeCDCFSLgN+uMJLnalPl6NSU27+t46DWbOzGJF2x41jdQDnv4VOVVXxS SkVg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature :arc-authentication-results; bh=eIiO9EJCZgE9kFhLLb1SQDnT8xnEuHb2thnIwpZn/WI=; b=RQ9E7oupQBYtDEAUTkmBe2PUVOgm/f33UY5wy8+Dh20nIpZHGRyllCMnPIlCvwiBCE l1BI7E/5GesCssCXKdnrgauHwKN5TIuAGzBXGByGYipDxXjEQpW773St4KsfSr98Xf8a oR+9i9u3HkMNRJEJPc6L1kl9kW5F2HHG6lP44jidjfxB1LT94KR/nDM36jN+rE2wOLtH bHMi+eeL2gaDP7wdfzfe8TLKH61KxGxcV313V8/rVs6En9KxOiJnoyLS6uUvA6lv/OiZ ccwkX2C1gFWfS0i9yYEbjvzQx5m2tHVgFu0Lvqt/MXRwE7b2qEY8iTsHmNARfWNQlE8c o0og== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=hRI3abis; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 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 vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 9-v6si15073103plf.374.2018.09.02.01.54.53; Sun, 02 Sep 2018 01:55:35 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=hRI3abis; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 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 S1726909AbeIBNH7 (ORCPT + 99 others); Sun, 2 Sep 2018 09:07:59 -0400 Received: from mail.kernel.org ([198.145.29.99]:58258 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725834AbeIBNH7 (ORCPT ); Sun, 2 Sep 2018 09:07:59 -0400 Received: from [192.168.0.101] (unknown [49.77.178.191]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 831D92077C; Sun, 2 Sep 2018 08:52:57 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1535878378; bh=ORYRmp7XvZNceMFVVyDNeNUqZnpIo8F+RNdd/HHbGtg=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=hRI3abisOJuALg3Cr3eJNCMvX6GTr9IMk+vYGbuVQ3sStctjSmx/kn+KFtDzBeb1u r4XNaEmyPm6YfbFwBDvVAzb28lgJ2Ipkz6HiMi7KiX4ncg3kgx/Elg7dnN61Iak2wO mowf3K6v1k19rn6Ho2Ofz29rhqd/QbkTx0Xxy0qI= Subject: Re: [f2fs-dev] [PATCH] f2fs: fix unnecessary periodic wakeup of discard thread when dev is busy To: Sahitya Tummala , Jaegeuk Kim , Chao Yu , linux-f2fs-devel@lists.sourceforge.net Cc: linux-kernel@vger.kernel.org References: <1535708366-11318-1-git-send-email-stummala@codeaurora.org> From: Chao Yu Message-ID: Date: Sun, 2 Sep 2018 16:52:40 +0800 User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:52.0) Gecko/20100101 Thunderbird/52.9.1 MIME-Version: 1.0 In-Reply-To: <1535708366-11318-1-git-send-email-stummala@codeaurora.org> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2018/8/31 17:39, Sahitya Tummala wrote: > When dev is busy, discard thread wake up timeout can be aligned with the > exact time that it needs to wait for dev to come out of busy. This helps > to avoid unnecessary periodic wakeups and thus save some power. > > Signed-off-by: Sahitya Tummala > --- > fs/f2fs/segment.c | 8 +++++++- > 1 file changed, 7 insertions(+), 1 deletion(-) > > diff --git a/fs/f2fs/segment.c b/fs/f2fs/segment.c > index 8bcbb50..df14030 100644 > --- a/fs/f2fs/segment.c > +++ b/fs/f2fs/segment.c > @@ -1379,6 +1379,8 @@ static int issue_discard_thread(void *data) > struct discard_policy dpolicy; > unsigned int wait_ms = DEF_MIN_DISCARD_ISSUE_TIME; > int issued; > + unsigned long interval = sbi->interval_time[REQ_TIME] * HZ; > + long delta; > > set_freezable(); > > @@ -1410,7 +1412,11 @@ static int issue_discard_thread(void *data) > __wait_all_discard_cmd(sbi, &dpolicy); > wait_ms = dpolicy.min_interval; > } else if (issued == -1){ > - wait_ms = dpolicy.mid_interval; > + delta = (sbi->last_time[REQ_TIME] + interval) - jiffies; I agree that we need to consider power consumption. One more consideration is that discard thread may need different submission frequency comparing to garbage collection thread, maybe a little fast, would it be better to split sbi->interval_time[REQ_TIME] according to gc/discard type. How do you think? Thanks, > + if (delta > 0) > + wait_ms = jiffies_to_msecs(delta); > + else > + wait_ms = dpolicy.mid_interval; > } else { > wait_ms = dpolicy.max_interval; > } >