Received: by 2002:ac0:946b:0:0:0:0:0 with SMTP id j40csp1701068imj; Thu, 14 Feb 2019 10:32:29 -0800 (PST) X-Google-Smtp-Source: AHgI3IY6DbLSUCTgl/5hUYbS3wDXcvLii6la6pJRSkTit89KovqoYbsSxvFd/ce5eBTbhwsMmFgB X-Received: by 2002:a63:9c1a:: with SMTP id f26mr1223388pge.381.1550169149757; Thu, 14 Feb 2019 10:32:29 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1550169149; cv=none; d=google.com; s=arc-20160816; b=DK+Amgp1VzV+buriOtTycEmyIQst8gH2fwLNmFGo0IwQpzZe74/qOVfaYnNwepFKlv wCamTahsB7ESKaqwnu+nki9hROcQFXVm2A/k2Mc9tryVv41pi5bZ7lW8QzJcMpTqBWYs SoX6GshyOdK4D/AGkcoEK+ekoVwqQ6csh15ny9by0ZjiLDQT4S6rSsZgZOuWFlYCtPJP E1NUEtqtH+1BCmSX8O1bupP0mFVykXqFTeJB4AhbsuwAUVkXTeHyv6cscoejMpgaHdLp AbtI5g64tpR8UKI6ni3YawbSY1zAzNLyupBxLOUqJtRTEmIAKOyxZ92rTVZDuTbr/v+H 2KsQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from; bh=pednms5nNzAygvq/6SHuGdkBAejWWgGAV7kLxC3yWic=; b=0D7zKtWecVkh5CDMgNREz9w2DGQCplUNgQQ7TpSosft9E34t/4Mpr9GbBW0saDceGs X+p4UAcETVC8ha4Uc5eHfv/GDjnW2uJEvDyvoktXhQHT7yr9R8QSAIEfIUlEU09NBOxh pp5sjvkAxwZ7fyHueypOiaquM83r1Lpzlp2lsbLNkfFH+1gSJNO7YMlQbOdoC0IAr5xv QYFUzYCCq9whxiIoGMol/nyzG/PlFJ6kUqq04wAKT48SyJzEuU2rEvwx4tsA1gY6PsYR Kik2v7KM95effPtrB6tqCF1kOiljxDy/ITm+U4kgGns+ENOIkoAk6TKo5soLH4ZE9f23 rulw== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id i186si3263044pfb.108.2019.02.14.10.32.13; Thu, 14 Feb 2019 10:32:29 -0800 (PST) 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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2395368AbfBNLPq (ORCPT + 99 others); Thu, 14 Feb 2019 06:15:46 -0500 Received: from 61-228-47-100.dynamic-ip.hinet.net ([61.228.47.100]:48278 "EHLO E6440.gar.corp.intel.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1731242AbfBNLPq (ORCPT ); Thu, 14 Feb 2019 06:15:46 -0500 X-Greylist: delayed 1109 seconds by postgrey-1.27 at vger.kernel.org; Thu, 14 Feb 2019 06:15:46 EST Received: from E6440.gar.corp.intel.com (localhost [127.0.0.1]) by E6440.gar.corp.intel.com (Postfix) with ESMTP id 16FBAC05C4; Thu, 14 Feb 2019 19:15:45 +0800 (CST) From: Harry Pan To: LKML Cc: gs0622@gmail.com, Harry Pan , rjw@rjwysocki.net, pavel@ucw.cz, len.brown@intel.com, linux-pm@vger.kernel.org Subject: [PATCH v3] PM / suspend: measure the time of filesystem syncing Date: Thu, 14 Feb 2019 19:15:43 +0800 Message-Id: <20190214111543.22137-1-harry.pan@intel.com> X-Mailer: git-send-email 2.18.1 In-Reply-To: <20190206154214.576-1-harry.pan@intel.com> References: <20190206154214.576-1-harry.pan@intel.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This patch gives the reader an intuitive metric of the time cost by the kernel issuing a filesystem sync during suspend; although developer can guess by the timestamp of next log or enable the ftrace power event for manual calculation, this manner is easier to read and benefits the automatic script. v2: simplify the variables, apply the simplest form of ktime API. v3: reduce conditional compilation, rectify profiling in better syntax Signed-off-by: Harry Pan --- kernel/power/suspend.c | 21 ++++++++++++++------- 1 file changed, 14 insertions(+), 7 deletions(-) diff --git a/kernel/power/suspend.c b/kernel/power/suspend.c index 0bd595a0b610..4844fc6a796d 100644 --- a/kernel/power/suspend.c +++ b/kernel/power/suspend.c @@ -568,13 +568,20 @@ static int enter_state(suspend_state_t state) if (state == PM_SUSPEND_TO_IDLE) s2idle_begin(); -#ifndef CONFIG_SUSPEND_SKIP_SYNC - trace_suspend_resume(TPS("sync_filesystems"), 0, true); - pr_info("Syncing filesystems ... "); - ksys_sync(); - pr_cont("done.\n"); - trace_suspend_resume(TPS("sync_filesystems"), 0, false); -#endif + if (!IS_ENABLED(CONFIG_SUSPEND_SKIP_SYNC)) { + ktime_t start; + unsigned int elapsed_msecs; + + trace_suspend_resume(TPS("sync_filesystems"), 0, true); + pr_info("Syncing filesystems ... "); + start = ktime_get(); + ksys_sync(); + elapsed_msecs = ktime_to_ms(ktime_sub(ktime_get(), start)); + pr_cont("(elapsed %d.%03d seconds) done.\n", + elapsed_msecs / MSEC_PER_SEC, + elapsed_msecs % MSEC_PER_SEC); + trace_suspend_resume(TPS("sync_filesystems"), 0, false); + } pm_pr_dbg("Preparing system for sleep (%s)\n", mem_sleep_labels[state]); pm_suspend_clear_flags(); -- 2.18.1