From: wu860403-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org
To: tj-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org,
cgroups-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
398776277-9uewiaClKEY@public.gmane.org
Cc: Liming Wu <wu860403-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
Subject: [PATCH] tg: add cpu's wait_count of a task group
Date: Fri, 15 Jan 2021 22:30:05 +0800 [thread overview]
Message-ID: <20210115143005.7071-1-wu860403@gmail.com> (raw)
From: Liming Wu <wu860403-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
Now we can rely on PSI to reflect whether there is contention in
the task group, but it cannot reflect the details of the contention.
Through this metric, we can get details of task group contention
from the dimension of scheduling.
delta(wait_sum)/delta(wait_count)
Also unified the cpu.stat output of cgroup v1 and v2
Signed-off-by Liming Wu <19092205-t/fWbKJQg0/QT0dZR+AlfA@public.gmane.org>
---
kernel/sched/core.c | 33 ++++++++++++++++++++++++++++-----
1 file changed, 28 insertions(+), 5 deletions(-)
diff --git a/kernel/sched/core.c b/kernel/sched/core.c
index e7e453492..e7ff47436 100644
--- a/kernel/sched/core.c
+++ b/kernel/sched/core.c
@@ -8139,19 +8139,29 @@ static int cpu_cfs_stat_show(struct seq_file *sf, void *v)
{
struct task_group *tg = css_tg(seq_css(sf));
struct cfs_bandwidth *cfs_b = &tg->cfs_bandwidth;
+ u64 throttled_usec;
- seq_printf(sf, "nr_periods %d\n", cfs_b->nr_periods);
- seq_printf(sf, "nr_throttled %d\n", cfs_b->nr_throttled);
- seq_printf(sf, "throttled_time %llu\n", cfs_b->throttled_time);
+ throttled_usec = cfs_b->throttled_time;
+ do_div(throttled_usec, NSEC_PER_USEC);
+
+ seq_printf(sf, "nr_periods %d\n"
+ "nr_throttled %d\n"
+ "throttled_usec %llu\n",
+ cfs_b->nr_periods, cfs_b->nr_throttled,
+ throttled_usec);
if (schedstat_enabled() && tg != &root_task_group) {
u64 ws = 0;
+ u64 wc = 0;
int i;
- for_each_possible_cpu(i)
+ for_each_possible_cpu(i) {
ws += schedstat_val(tg->se[i]->statistics.wait_sum);
+ wc += schedstat_val(tg->se[i]->statistics.wait_count);
+ }
- seq_printf(sf, "wait_sum %llu\n", ws);
+ seq_printf(sf, "wait_sum %llu\n"
+ "wait_count %llu\n", ws, wc);
}
return 0;
@@ -8255,6 +8265,19 @@ static int cpu_extra_stat_show(struct seq_file *sf,
"throttled_usec %llu\n",
cfs_b->nr_periods, cfs_b->nr_throttled,
throttled_usec);
+ if (schedstat_enabled() && tg != &root_task_group) {
+ u64 ws = 0;
+ u64 wc = 0;
+ int i;
+
+ for_each_possible_cpu(i) {
+ ws += schedstat_val(tg->se[i]->statistics.wait_sum);
+ wc += schedstat_val(tg->se[i]->statistics.wait_count);
+ }
+
+ seq_printf(sf, "wait_sum %llu\n"
+ "wait_count %llu\n", ws, wc);
+ }
}
#endif
return 0;
--
2.20.1
next reply other threads:[~2021-01-15 14:30 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-01-15 14:30 wu860403-Re5JQEeQqe8AvxtiuMwx3w [this message]
[not found] ` <20210115143005.7071-1-wu860403-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
2021-01-15 20:19 ` [PATCH] tg: add cpu's wait_count of a task group Tejun Heo
[not found] ` <YAH4w5T3/oCTGJny-qYNAdHglDFBN0TnZuCh8vA@public.gmane.org>
2021-01-18 3:07 ` liming wu
[not found] ` <CAPnMXWWmfzWh9J_G4OPT=eCFySaD2NAFE0_OiWFQKL-1R0uOkA-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2021-01-19 15:32 ` Tejun Heo
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=20210115143005.7071-1-wu860403@gmail.com \
--to=wu860403-re5jqeeqqe8avxtiumwx3w@public.gmane.org \
--cc=398776277-9uewiaClKEY@public.gmane.org \
--cc=cgroups-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
--cc=tj-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.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