[PATCH v3 0/2] Add read_poll_timeout_atomic support

FUJITA Tomonori posted 2 patches 3 months, 2 weeks ago
There is a newer version of this series
rust/helpers/time.c       |  5 +++
rust/kernel/io/poll.rs    | 72 ++++++++++++++++++++++++++++++++++++++-
rust/kernel/time/delay.rs | 39 +++++++++++++++++++++
3 files changed, 115 insertions(+), 1 deletion(-)
[PATCH v3 0/2] Add read_poll_timeout_atomic support
Posted by FUJITA Tomonori 3 months, 2 weeks ago
Add read_poll_timeout_atomic function which polls periodically until a
condition is met, an error occurs, or the attempt limit is reached.

This helper is used to wait for a condition in atomic context,
mirroring the C's read_poll_timeout_atomic().

In atomic context, the timekeeping infrastructure is unavailable, so
reliable time-based timeouts cannot be implemented. So instead, the
helper accepts a maximum number of attempts and busy-waits (udelay +
cpu_relax) between tries.


v2: https://lore.kernel.org/lkml/20251021071146.2357069-1-fujita.tomonori@gmail.com/
- revert the function name
- simplify the example code
- add debug_assert to check the range for udelay
v1: https://lore.kernel.org/lkml/20250821035710.3692455-1-fujita.tomonori@gmail.com/
- use the attempt limit instead of timeout
- rename the function to read_poll_count_atomic
- add the comment about C's udelay behavior.


FUJITA Tomonori (2):
  rust: add udelay() function
  rust: Add read_poll_timeout_atomic function

 rust/helpers/time.c       |  5 +++
 rust/kernel/io/poll.rs    | 72 ++++++++++++++++++++++++++++++++++++++-
 rust/kernel/time/delay.rs | 39 +++++++++++++++++++++
 3 files changed, 115 insertions(+), 1 deletion(-)


base-commit: 26c1a20bf7ce76e9afe4030f25bec20e3c63dcf8
-- 
2.43.0