From: John Ogness <john.ogness@linutronix.de>
To: Nam Cao <namcao@linutronix.de>, Gabriele Monaco <gmonaco@redhat.com>
Cc: Steven Rostedt <rostedt@goodmis.org>,
linux-trace-kernel@vger.kernel.org, linux-kernel@vger.kernel.org
Subject: Re: [PATCH v4 20/22] rv: Add rtapp_sleep monitor
Date: Fri, 25 Apr 2025 09:54:27 +0206 [thread overview]
Message-ID: <84a584isvo.fsf@jogness.linutronix.de> (raw)
In-Reply-To: <84ecxgit04.fsf@jogness.linutronix.de>
On 2025-04-25, John Ogness <john.ogness@linutronix.de> wrote:
>>> perf stat -e rv:error_sleep stress-ng --cpu-sched 1 -t 10s
>>> -- shows several errors --
>>
>> This one is a monitor's bug.
>>
>> The monitor mistakenly sees the task getting woken up, *then* sees it going
>> to sleep.
>>
>> This is due to trace_sched_switch() being called with a stale 'prev_state'.
>> 'prev_state' is read at the beginning of __schedule(), but
>> trace_sched_switch() is invoked a bit later. Therefore if task->__state is
>> changed inbetween, 'prev_state' is not the value of task->__state.
>>
>> The monitor checks (prev_state & TASK_INTERRUPTIBLE) to determine if the
>> task is going to sleep. This can be incorrect due to the race above. The
>> monitor sees the task going to sleep, but actually it is just preempted.
>
> If I understand this correctly, trace_sched_switch() is reporting
> accurate state transition information, but by the time it is reported
> that state may have already changed (in which case another
> trace_sched_switch() occurs later).
>
> So in this example, the task did go to sleep. Why do you think it was
> preempted instead?
On 2025-04-25, Gabriele Monaco <gmonaco@redhat.com> wrote:
> Peter's fix [1] landed on next recently, I guess in a couple of days
> you'll get it on the upstream tree and you may not see the problem.
Ah, thanks for pointing that out!
> [1] - https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git/commit/?id=8feb053d53194382fcfb68231296fdc220497ea6
next prev parent reply other threads:[~2025-04-25 7:48 UTC|newest]
Thread overview: 33+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-04-23 6:49 [PATCH v4 00/22] RV: Linear temporal logic monitors for RT application Nam Cao
2025-04-23 6:49 ` [PATCH v4 01/22] rv: Add #undef TRACE_INCLUDE_FILE Nam Cao
2025-04-23 6:49 ` [PATCH v4 02/22] printk: Make vprintk_deferred() public Nam Cao
2025-04-23 6:49 ` [PATCH v4 03/22] panic: Add vpanic() Nam Cao
2025-04-23 6:49 ` [PATCH v4 04/22] rv: Let the reactors take care of buffers Nam Cao
2025-04-23 6:50 ` [PATCH v4 05/22] verification/dot2k: Make a separate dot2k_templates/Kconfig_container Nam Cao
2025-04-23 6:50 ` [PATCH v4 06/22] verification/dot2k: Remove __buff_to_string() Nam Cao
2025-04-23 6:50 ` [PATCH v4 07/22] verification/dot2k: Replace is_container() hack with subparsers Nam Cao
2025-04-23 6:50 ` [PATCH v4 08/22] rv: rename CONFIG_DA_MON_EVENTS to CONFIG_RV_MON_EVENTS Nam Cao
2025-04-23 6:50 ` [PATCH v4 09/22] verification/dot2k: Prepare the frontend for LTL inclusion Nam Cao
2025-04-23 6:50 ` [PATCH v4 10/22] Documentation/rv: Prepare monitor synthesis document " Nam Cao
2025-04-23 6:50 ` [PATCH v4 11/22] verification/rvgen: Restructure the templates files Nam Cao
2025-04-23 6:50 ` [PATCH v4 12/22] verification/rvgen: Restructure the classes to prepare for LTL inclusion Nam Cao
2025-04-23 6:50 ` [PATCH v4 13/22] rv: Add support for LTL monitors Nam Cao
2025-04-23 6:50 ` [PATCH v4 14/22] rv: Add rtapp container monitor Nam Cao
2025-04-23 6:50 ` [PATCH v4 15/22] x86/tracing: Remove redundant trace_pagefault_key Nam Cao
2025-04-23 6:50 ` [PATCH v4 16/22] x86/tracing: Move page fault trace points to generic Nam Cao
2025-04-23 6:50 ` [PATCH v4 17/22] arm64: mm: Add page fault trace points Nam Cao
2025-04-23 6:50 ` [PATCH v4 18/22] riscv: " Nam Cao
2025-04-23 6:50 ` [PATCH v4 19/22] rv: Add rtapp_pagefault monitor Nam Cao
2025-04-23 10:37 ` Gabriele Monaco
2025-04-24 3:40 ` Nam Cao
2025-04-23 6:50 ` [PATCH v4 20/22] rv: Add rtapp_sleep monitor Nam Cao
2025-04-24 13:55 ` Gabriele Monaco
2025-04-25 6:34 ` Nam Cao
2025-04-25 7:35 ` Gabriele Monaco
2025-04-25 9:33 ` Nam Cao
2025-04-25 7:45 ` John Ogness
2025-04-25 7:48 ` John Ogness [this message]
2025-04-25 9:23 ` Nam Cao
2025-04-23 6:50 ` [PATCH v4 21/22] rv: Add documentation for rtapp monitor Nam Cao
2025-04-23 6:50 ` [PATCH v4 22/22] rv: Allow to configure the number of per-task monitor Nam Cao
2025-08-10 21:12 ` [PATCH v4 00/22] RV: Linear temporal logic monitors for RT application patchwork-bot+linux-riscv
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=84a584isvo.fsf@jogness.linutronix.de \
--to=john.ogness@linutronix.de \
--cc=gmonaco@redhat.com \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-trace-kernel@vger.kernel.org \
--cc=namcao@linutronix.de \
--cc=rostedt@goodmis.org \
/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