Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752627AbcKUINH (ORCPT ); Mon, 21 Nov 2016 03:13:07 -0500 Received: from mail-wj0-f193.google.com ([209.85.210.193]:34124 "EHLO mail-wj0-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750944AbcKUING (ORCPT ); Mon, 21 Nov 2016 03:13:06 -0500 Date: Mon, 21 Nov 2016 09:13:01 +0100 From: Ingo Molnar To: John Stultz Cc: lkml , Baolin Wang , Thomas Gleixner , Richard Cochran , Steven Rostedt Subject: Re: [PATCH 1/4] time: alarmtimer: Add the trcepoints for alarmtimer Message-ID: <20161121081301.GA14231@gmail.com> References: <1479531014-25264-1-git-send-email-john.stultz@linaro.org> <1479531014-25264-2-git-send-email-john.stultz@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1479531014-25264-2-git-send-email-john.stultz@linaro.org> User-Agent: Mutt/1.5.24 (2015-08-30) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1361 Lines: 48 * John Stultz wrote: > @@ -222,7 +226,7 @@ static int alarmtimer_suspend(struct device *dev) > ktime_t min, now; > unsigned long flags; > struct rtc_device *rtc; > - int i; > + int i, type = 0; > int ret; > > spin_lock_irqsave(&freezer_delta_lock, flags); > @@ -247,8 +251,10 @@ static int alarmtimer_suspend(struct device *dev) > if (!next) > continue; > delta = ktime_sub(next->expires, base->gettime()); > - if (!min.tv64 || (delta.tv64 < min.tv64)) > + if (!min.tv64 || (delta.tv64 < min.tv64)) { > min = delta; > + type = i; > + } > } > if (min.tv64 == 0) > return 0; > @@ -264,6 +270,8 @@ static int alarmtimer_suspend(struct device *dev) > now = rtc_tm_to_ktime(tm); > now = ktime_add(now, min); > > + trace_alarmtimer_suspend(now, type); > + > /* Set alarm, if in the past reject suspend briefly to handle */ > ret = rtc_timer_start(rtc, &rtctimer, now, ktime_set(0, 0)); > if (ret < 0) Hm, there's a weirdness here: if freezer_delta != 0 when alarmtimer_suspend() is called then type might be '0', although it's not alarm_bases[0] this value is picked up from. Wouldn't it be better to initialize 'type' to -1 instead? (And rename it to min_type or so.) That would disambiguate the freezer_delta special case in the trace. (Unless I missed something.) Thanks, Ingo