Re: [PATCH] rcu/tree: Improve comments in rcu_report_qs_rdp()
From: Joel Fernandes
Date: Fri Feb 10 2023 - 19:32:32 EST
On Fri, Feb 3, 2023 at 9:21 PM Joel Fernandes (Google)
<joel@xxxxxxxxxxxxxxxxx> wrote:
>
> Recent discussion triggered due to a patch linked below, from Qiang,
> shed light on the need to accelerate from QS reporting paths.
>
> Update the comments to capture this piece of knowledge.
>
> Link: https://lore.kernel.org/all/20230118073014.2020743-1-qiang1.zhang@xxxxxxxxx/
> Cc: Qiang Zhang <Qiang1.zhang@xxxxxxxxx>
> Cc: Frederic Weisbecker <frederic@xxxxxxxxxx>
> Signed-off-by: Joel Fernandes (Google) <joel@xxxxxxxxxxxxxxxxx>
>
> ---
> kernel/rcu/tree.c | 13 ++++++++++++-
> 1 file changed, 12 insertions(+), 1 deletion(-)
>
> diff --git a/kernel/rcu/tree.c b/kernel/rcu/tree.c
> index 93eb03f8ed99..713eb6ca6902 100644
> --- a/kernel/rcu/tree.c
> +++ b/kernel/rcu/tree.c
> @@ -1983,7 +1983,12 @@ rcu_report_qs_rdp(struct rcu_data *rdp)
> } else {
> /*
> * This GP can't end until cpu checks in, so all of our
> - * callbacks can be processed during the next GP.
> + * callbacks can be processed during the next GP. Do
> + * the acceleration from here otherwise there may be extra
> + * grace period delays, as any accelerations from rcu_core()
> + * or note_gp_changes() may happen only after the GP after the
> + * current one has already started. Further, rcu_core()
> + * only accelerates if RCU is idle (no GP in progress).
> *
And I couldn't help but pass this through ChatGPT:
Before:
This GP can't end until cpu checks in, so all of our callbacks can be
processed during the next GP. Do the acceleration from here otherwise
there may be extra grace period delays, as any accelerations from
rcu_core() or note_gp_changes() may happen only after the GP after the
current one has already started. Further, rcu_core() only accelerates
if RCU is idle (no GP in progress). NOCB kthreads have their own way
to deal with that...
After:
In order to ensure all callbacks are processed efficiently, this grace
period (GP) must not end until the CPU checks in. To avoid unnecessary
grace period delays, it is important to initiate acceleration from the
current location. Any acceleration from the functions "rcu_core()" or
"note_gp_changes()" may only occur after the next GP has already
started. It is important to note that "rcu_core()" will only initiate
acceleration if the RCU system is idle (no GP in progress). NOCB
kthreads, on the other hand, have their own unique method for handling
this situation.
It sounds well written, but maybe a bit factually incorrect.. trying again:
To ensure all callbacks are processed in the next grace period, this
GP must not end until the CPU has checked in. To avoid any additional
grace period delays, it's important to perform the acceleration from
here. If acceleration is performed from rcu_core() or
note_gp_changes(), it may only occur after the next GP has already
started. Additionally, it's important to note that rcu_core() will
only accelerate if RCU is idle and no GP is in progress. The NOCB
kthreads have a separate mechanism for dealing with this issue.
Not bad, but the first sentence is still factually incorrect. Yes, I'm
bored..why do you ask? ;-)
I think except for the first sentence though, it made for a nice
grammatical re-write (give or take Frederic and Qiang's comments ;-)).
- Joel
> * NOCB kthreads have their own way to deal with that...
> */
> @@ -1993,6 +1998,12 @@ rcu_report_qs_rdp(struct rcu_data *rdp)
> /*
> * ...but NOCB kthreads may miss or delay callbacks acceleration
> * if in the middle of a (de-)offloading process.
> + *
> + * Such missed acceleration may cause the callbacks to
> + * be stranded until RCU is fully de-offloaded, as
> + * acceleration from rcu_core() and note_gp_changes()
> + * cannot happen for fully/partially offloaded mode due
> + * to ordering dependency between rnp lock and nocb_lock.
> */
> needacc = true;
> }
> --
> 2.39.1.519.gcb327c4b5f-goog
>