[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <65795E11DBF1E645A09CEC7EAEE94B9CB574E70F@USINDEVS02.corp.hds.com>
Date: Mon, 28 Nov 2011 17:44:56 -0500
From: Satoru Moriya <satoru.moriya@....com>
To: "linux-kernel@...r.kernel.org" <linux-kernel@...r.kernel.org>
CC: "bsingharora@...il.com" <bsingharora@...il.com>,
"mingo@...e.hu" <mingo@...e.hu>,
"peterz@...radead.org" <peterz@...radead.org>,
"nagar@...son.ibm.com" <nagar@...son.ibm.com>,
"kobayashi.kk@...s.nec.co.jp" <kobayashi.kk@...s.nec.co.jp>,
Randy Dunlap <rdunlap@...otime.net>,
"linux-doc@...r.kernel.org" <linux-doc@...r.kernel.org>,
"dle-develop@...ts.sourceforge.net"
<dle-develop@...ts.sourceforge.net>,
Seiji Aguchi <seiji.aguchi@....com>
Subject: [PATCH 1/4] sched: add members to struct sched_info to save maximum
This patch adds members to struct sched_info and save max delays
into it.
Signed-off-by: Satoru Moriya <satoru.moriya@....com>
---
include/linux/sched.h | 2 ++
kernel/sched_stats.h | 5 +++++
2 files changed, 7 insertions(+), 0 deletions(-)
diff --git a/include/linux/sched.h b/include/linux/sched.h
index 1c4f3e9..1665e2c 100644
--- a/include/linux/sched.h
+++ b/include/linux/sched.h
@@ -736,6 +736,8 @@ struct sched_info {
/* cumulative counters */
unsigned long pcount; /* # of times run on this cpu */
unsigned long long run_delay; /* time spent waiting on a runqueue */
+ unsigned long long max_delay; /* max run_delay */
+ unsigned long long prev_cpu_delay; /* time spent waiting on prev cpus' runqueue */
/* timestamps */
unsigned long long last_arrival,/* when we last ran on a cpu */
diff --git a/kernel/sched_stats.h b/kernel/sched_stats.h
index 87f9e36..48e9db9 100644
--- a/kernel/sched_stats.h
+++ b/kernel/sched_stats.h
@@ -171,6 +171,7 @@ static inline void sched_info_dequeued(struct task_struct *t)
delta = now - t->sched_info.last_queued;
sched_info_reset_dequeued(t);
t->sched_info.run_delay += delta;
+ t->sched_info.prev_cpu_delay += delta;
rq_sched_info_dequeued(task_rq(t), delta);
}
@@ -190,6 +191,10 @@ static void sched_info_arrive(struct task_struct *t)
t->sched_info.run_delay += delta;
t->sched_info.last_arrival = now;
t->sched_info.pcount++;
+ t->sched_info.prev_cpu_delay += delta;
+ if (t->sched_info.max_delay < t->sched_info.prev_cpu_delay)
+ t->sched_info.max_delay = t->sched_info.prev_cpu_delay;
+ t->sched_info.prev_cpu_delay = 0;
rq_sched_info_arrive(task_rq(t), delta);
}
--
1.7.6.4
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists