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 >