From: K Prateek Nayak <kprateek.nayak@amd.com>
To: Qing Wang <wangqing7171@gmail.com>,
Ingo Molnar <mingo@redhat.com>,
"Peter Zijlstra" <peterz@infradead.org>,
Juri Lelli <juri.lelli@redhat.com>,
"Vincent Guittot" <vincent.guittot@linaro.org>,
Dietmar Eggemann <dietmar.eggemann@arm.com>,
Steven Rostedt <rostedt@goodmis.org>,
Ben Segall <bsegall@google.com>, Mel Gorman <mgorman@suse.de>,
Valentin Schneider <vschneid@redhat.com>,
Li Chen <chenl311@chinatelecom.cn>,
<linux-kernel@vger.kernel.org>
Subject: Re: [PATCH] sched/fair: Replace random newidle_balance with Bresenham accumulator
Date: Wed, 13 May 2026 10:59:39 +0530 [thread overview]
Message-ID: <da1896b3-6bec-4b56-bf6d-9ce775b00b8d@amd.com> (raw)
In-Reply-To: <20260506024455.2799069-1-wangqing7171@gmail.com>
Hello Qing,
On 5/6/2026 8:14 AM, Qing Wang wrote:
> The current NI_RANDOM implementation uses a random dice roll to allow
> newidle_balance attempts according to the success rate. There is a better
> way to implememte it.
>
> Replace the random dice with a Bresenham accumulator that distributes the
> allowed attempts with uniformly spaced evenly across a 1024-step window:
>
> Each step do those:
> - Accumulate (1 + newidle_ratio) into newidle_window_pos.
> - If the accumulator reaches 1024, allow the balance attempt and
> subtract 1024.
>
> This guarantees exactly (1 + newidle_ratio) newidle_balance per 1024 steps
> and per newidle_balance with uniformly spaced for any ratio in [0, 1023].
I took the most sensitive workload I have for newidle balance (tbench)
and took it for a spin with these changes. Following are the results:
Clients: tip bresenham_accm
1 321.65 (0.00 pct) 313.97 (-2.38 pct)
2 641.92 (0.00 pct) 638.74 (-0.49 pct)
4 1245.65 (0.00 pct) 1237.26 (-0.67 pct)
8 2435.80 (0.00 pct) 2442.23 ( 0.26 pct)
16 4717.66 (0.00 pct) 4688.19 (-0.62 pct)
32 9303.53 (0.00 pct) 9390.71 ( 0.93 pct)
64 18002.57 (0.00 pct) 17911.56 (-0.50 pct)
128 27729.26 (0.00 pct) 27621.95 (-0.38 pct)
256 47134.77 (0.00 pct) 46137.36 (-2.11 pct)
512 43179.41 (0.00 pct) 43277.53 ( 0.22 pct)
1024 40339.30 (0.00 pct) 40176.49 (-0.40 pct)
The %diff is in noise range which is a good indication that there
shouldn't be any surprises. I'll queue a run overnight to see if
there are other benchmarks that like / dislike these changes.
I'll let Peter comment on the change itself since he knows these
bits best ;-)
--
Thanks and Regards,
Prateek
next prev parent reply other threads:[~2026-05-13 5:29 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
[not found] <20260429085147.1029505-1-wangqing7171@gmail.com>
2026-05-06 2:44 ` [PATCH] sched/fair: Replace random newidle_balance with Bresenham accumulator Qing Wang
2026-05-13 2:21 ` Qing Wang
2026-05-13 5:29 ` K Prateek Nayak [this message]
2026-05-14 2:22 ` Qing Wang
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=da1896b3-6bec-4b56-bf6d-9ce775b00b8d@amd.com \
--to=kprateek.nayak@amd.com \
--cc=bsegall@google.com \
--cc=chenl311@chinatelecom.cn \
--cc=dietmar.eggemann@arm.com \
--cc=juri.lelli@redhat.com \
--cc=linux-kernel@vger.kernel.org \
--cc=mgorman@suse.de \
--cc=mingo@redhat.com \
--cc=peterz@infradead.org \
--cc=rostedt@goodmis.org \
--cc=vincent.guittot@linaro.org \
--cc=vschneid@redhat.com \
--cc=wangqing7171@gmail.com \
/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