From: Aaron Tomlin <atomlin@atomlin.com>
To: akpm@linux-foundation.org, lance.yang@linux.dev,
mhiramat@kernel.org, gregkh@linuxfoundation.org,
pmladek@suse.com, joel.granados@kernel.org
Cc: neelx@suse.com, sean@ashe.io, mproche@gmail.com,
chjohnst@gmail.com, nick.lange@gmail.com,
linux-kernel@vger.kernel.org
Subject: [v2 PATCH 0/1] hung_task: Explicitly report I/O wait state in log output
Date: Wed, 28 Jan 2026 15:45:15 -0500 [thread overview]
Message-ID: <20260128204516.3473709-1-atomlin@atomlin.com> (raw)
Hi Lance, Masami, Petr, Andrew,
Currently, the hung task reporting mechanism indiscriminately labels all
TASK_UNINTERRUPTIBLE (D) tasks as "blocked", irrespective of whether they
are awaiting I/O completion or kernel locking primitives. This ambiguity
compels system administrators to manually inspect stack traces to discern
whether the delay stems from an I/O wait (typically indicative of
hardware or filesystem anomalies) or software contention. Such detailed
analysis is not always immediately accessible to system administrators
or support engineers.
To address this, this patch utilises the existing in_iowait field within
struct task_struct to augment the failure report. If the task is blocked
due to I/O (e.g., via io_schedule_prepare()), the log message is updated
to explicitly state "blocked in I/O wait".
Examples:
- Standard Block: "INFO: task bash:123 blocked for more than 120
seconds".
- I/O Block: "INFO: task dd:456 blocked in I/O wait for more than
120 seconds".
Accessing in_iowait is safe in this context. The detector holds
rcu_read_lock() within check_hung_uninterruptible_tasks(), ensuring the
task structure remains valid in memory. Furthermore, as the task is
confirmed to be in a persistent TASK_UNINTERRUPTIBLE state, it cannot
modify its own in_iowait flag, rendering the read operation stable and
free from data races.
Please let me know your thoughts.
Changes since v1 [1]:
- Updated patch subject to reflect the new output format (was: "hung_task:
Differentiate between I/O and Lock/Resource waits")
- Changed log output from "D (Disk I/O)" to "blocked in I/O wait"
(Masami Hiramatsu)
[1]: https://lore.kernel.org/lkml/20260125203905.3393869-1-atomlin@atomlin.com/
Aaron Tomlin (1):
hung_task: Explicitly report I/O wait state in log output
kernel/hung_task.c | 5 +++--
1 file changed, 3 insertions(+), 2 deletions(-)
--
2.51.0
next reply other threads:[~2026-01-28 20:45 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-01-28 20:45 Aaron Tomlin [this message]
2026-01-28 20:45 ` [v2 PATCH 1/1] hung_task: Explicitly report I/O wait state in log output Aaron Tomlin
2026-01-28 23:16 ` Masami Hiramatsu
2026-02-03 1:32 ` Aaron Tomlin
2026-02-02 15:14 ` Petr Mladek
2026-02-02 15:28 ` Lance Yang
2026-02-03 1:24 ` Aaron Tomlin
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=20260128204516.3473709-1-atomlin@atomlin.com \
--to=atomlin@atomlin.com \
--cc=akpm@linux-foundation.org \
--cc=chjohnst@gmail.com \
--cc=gregkh@linuxfoundation.org \
--cc=joel.granados@kernel.org \
--cc=lance.yang@linux.dev \
--cc=linux-kernel@vger.kernel.org \
--cc=mhiramat@kernel.org \
--cc=mproche@gmail.com \
--cc=neelx@suse.com \
--cc=nick.lange@gmail.com \
--cc=pmladek@suse.com \
--cc=sean@ashe.io \
/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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox