All of lore.kernel.org
 help / color / mirror / Atom feed
From: Andreas Hindborg <a.hindborg@kernel.org>
To: "Lyude Paul" <lyude@redhat.com>
Cc: rust-for-linux@vger.kernel.org, linux-kernel@vger.kernel.org,
	"Boqun Feng" <boqun.feng@gmail.com>,
	"FUJITA Tomonori" <fujita.tomonori@gmail.com>,
	"Frederic Weisbecker" <frederic@kernel.org>,
	"Thomas Gleixner" <tglx@linutronix.de>,
	"Anna-Maria Behnsen" <anna-maria@linutronix.de>,
	"John Stultz" <jstultz@google.com>,
	"Stephen Boyd" <sboyd@kernel.org>,
	"Miguel Ojeda" <ojeda@kernel.org>,
	"Alex Gaynor" <alex.gaynor@gmail.com>,
	"Gary Guo" <gary@garyguo.net>,
	"Björn Roy Baron" <bjorn3_gh@protonmail.com>,
	"Benno Lossin" <benno.lossin@proton.me>,
	"Alice Ryhl" <aliceryhl@google.com>,
	"Trevor Gross" <tmgross@umich.edu>,
	"Danilo Krummrich" <dakr@kernel.org>
Subject: Re: [PATCH v2 2/8] rust: hrtimer: Add HrTimer::raw_forward() and forward()
Date: Tue, 29 Apr 2025 12:10:23 +0200	[thread overview]
Message-ID: <87plgv2s8g.fsf@kernel.org> (raw)
In-Reply-To: <cdf47123d4115b0aca452dc6f6da8029cc77d292.camel@redhat.com> (Lyude Paul's message of "Fri, 25 Apr 2025 17:29:17 -0400")

"Lyude Paul" <lyude@redhat.com> writes:

> oh - nevermind I get it but I think you made a mistake andreas, comment below
>
> On Fri, 2025-04-25 at 17:06 -0400, Lyude Paul wrote:
>>
>>
>> Perhaps I will understand this at some point after sending this email, but as
>> I'm writing this I have to admit I'm very confused. This is the first time
>> I've actually looked directly at the hrtimer_forward() source and I have to
>> say this is 100% not what I expected the term "overrun" to mean. Honestly,
>> enough so I'm kind of wondering if overrun is even the right word for the C
>> documentation to be using here.
>>
>> To make sure I'm understanding this right, an overrun is not "how many times
>> we would have executed the timer between now and the new execution time" (e.g.
>> "how many times did our new expiration value overrun the previous expiry
>> interval"). Instead it's actually "if the timer's next execution time is
>> greater than the previous expiry time then the timer will be forwarded by
>> `interval`, but if the timer's execution time is shorter than the previous
>> expiry time then the new execution time will be determined by figuring out if
>> the timer were to execute at `interval` what the closest expiry time at that
>> interval to the previous expiry time would be". Which, I'm afraid to admit
>> doesn't actually make any sense to me and makes me feel like "overrun" is
>> entirely the wrong word to be used here.
>>
>> I'm having a little trouble understanding how I'd really describe this in the
>> documentation because I'm also having a lot of trouble understanding why this
>> behavior is the way it is and why someone would want it to work like this.
>> Should this be something like "Forward the timer to the closest expiry time to
>> the current expiry time that can be reached if the timer were to execute at
>> the given interval"?. Or should I maybe just copy the C documentation as close
>> as possible and just leave this strange behavior as an exercise for the
>> reader?
>
> Yeah I think you misunderstood how the code works. Going to show how the code
> would run through using the last example you gave of:
>
>>   If the timer expires 5s after `now` and `interval` is 2s, then the
>>   expiry time is moved 4s forward and the return value is 2.
>
> The timer value wouldn't actually be moved forward here and the return value
> would be 0:
>
> u64 hrtimer_forward(struct hrtimer *timer, ktime_t now, ktime_t interval)
> //                                 ^ now+5         ^ 5          ^ 2
> //                                 = 10
> {
> 	u64 orun = 1;
> 	ktime_t delta;
>
> 	//                5  - 10 = -5
> 	delta = ktime_sub(now, hrtimer_get_expires(timer));
>
> 	// -5 < 0 = true
> 	if (delta < 0)
> 		return 0; // 0 overruns, timer executes at the same interval
>
> 	// (we don't execute the rest, so I've ommitted it)
> 	// ...
> }
> EXPORT_SYMBOL_GPL(hrtimer_forward);

Thanks for explaining, that makes a lot more sense 😅 I think I flipped the sign
of `delta`.

However, I still think the documentation is not correct. How is this instead:

  Conditionally forward the timer.

  If the timer expires after `now`, this function does
  nothing and returns 0.

  If the timer expired at or before `now`, this function forwards the timer by `interval`
  until the timer expires after `now` and then returns the number of times
  the timer was forwarded by `interval`.

  This is mainly useful for timer types etc etc ...

Best regards,
Andreas Hindborg



  reply	other threads:[~2025-04-29 10:10 UTC|newest]

Thread overview: 31+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2025-04-15 19:48 [PATCH v2 0/8] rust/hrtimer: Various hrtimer + time additions Lyude Paul
2025-04-15 19:48 ` [PATCH v2 1/8] rust: hrtimer: Document the return value for HrTimerHandle::cancel() Lyude Paul
2025-04-23  8:36   ` Andreas Hindborg
2025-04-15 19:48 ` [PATCH v2 2/8] rust: hrtimer: Add HrTimer::raw_forward() and forward() Lyude Paul
2025-04-23 12:13   ` Andreas Hindborg
2025-04-25 20:15     ` Lyude Paul
2025-04-29  9:43       ` Andreas Hindborg
2025-04-29 21:04         ` Lyude Paul
2025-04-23 12:18   ` Andreas Hindborg
2025-04-23 12:57   ` Andreas Hindborg
2025-04-25 21:06     ` Lyude Paul
2025-04-25 21:29       ` Lyude Paul
2025-04-29 10:10         ` Andreas Hindborg [this message]
2025-04-15 19:48 ` [PATCH v2 3/8] rust: hrtimer: Add HrTimerCallbackContext and ::forward() Lyude Paul
2025-04-23 12:24   ` Andreas Hindborg
2025-04-15 19:48 ` [PATCH v2 4/8] rust: hrtimer: Add HrTimerClockBase Lyude Paul
2025-04-23 12:27   ` Andreas Hindborg
2025-04-28 18:22     ` Lyude Paul
2025-04-15 19:48 ` [PATCH v2 5/8] rust: time: Add Instant::from_nanos() Lyude Paul
2025-04-16  9:10   ` FUJITA Tomonori
2025-04-16 18:41     ` Lyude Paul
2025-04-23 12:29   ` Andreas Hindborg
2025-04-29 16:01     ` Lyude Paul
2025-04-29 19:53       ` Miguel Ojeda
2025-04-15 19:48 ` [PATCH v2 6/8] rust: hrtimer: Add HrTimerClockBase::time() Lyude Paul
2025-04-15 19:48 ` [PATCH v2 7/8] rust: hrtimer: Add forward_now() to HrTimer and HrTimerCallbackContext Lyude Paul
2025-04-15 20:17   ` [PATCH v3] " Lyude Paul
2025-04-22 12:18     ` Andreas Hindborg
2025-04-22 19:21       ` Lyude Paul
2025-04-15 19:48 ` [PATCH v2 8/8] rust: hrtimer: Add HrTimer::expires() Lyude Paul
2025-04-23 13:01   ` Andreas Hindborg

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=87plgv2s8g.fsf@kernel.org \
    --to=a.hindborg@kernel.org \
    --cc=alex.gaynor@gmail.com \
    --cc=aliceryhl@google.com \
    --cc=anna-maria@linutronix.de \
    --cc=benno.lossin@proton.me \
    --cc=bjorn3_gh@protonmail.com \
    --cc=boqun.feng@gmail.com \
    --cc=dakr@kernel.org \
    --cc=frederic@kernel.org \
    --cc=fujita.tomonori@gmail.com \
    --cc=gary@garyguo.net \
    --cc=jstultz@google.com \
    --cc=linux-kernel@vger.kernel.org \
    --cc=lyude@redhat.com \
    --cc=ojeda@kernel.org \
    --cc=rust-for-linux@vger.kernel.org \
    --cc=sboyd@kernel.org \
    --cc=tglx@linutronix.de \
    --cc=tmgross@umich.edu \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.