diff options
| author | Arun Bharadwaj <abharadw@codeaurora.org> | 2013-06-19 16:55:29 -0700 |
|---|---|---|
| committer | David Keitel <dkeitel@codeaurora.org> | 2016-03-23 19:58:34 -0700 |
| commit | 9f6eb26ae8f49eba60d5aaf10affdc28fd42608c (patch) | |
| tree | bb83d53a3750a9ee50b940410e7f26d85604194b /kernel | |
| parent | 0ec4cf2484ad5860d84dda1aef44dc35e7c2a81d (diff) | |
tracing/sched: Track per-cpu rt and non-rt cpu_load.
Add a new tracepoint trace_sched_enq_deq_task to track
per-cpu rt and non-rt cpu_load during task enqueue
and dequeue.
This is useful to visualize and compare the load on
different cpus and also to understand how balanced
the load is at any point of time.
Note: We only print cpu_load[0] because we only care about
the most recent load history for tracking load balancer
effectiveness.
Change-Id: I46f0bb84e81652099ed5edf8c2686c70c8b8330c
Signed-off-by: Arun Bharadwaj <abharadw@codeaurora.org>
Diffstat (limited to 'kernel')
| -rw-r--r-- | kernel/sched/core.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/kernel/sched/core.c b/kernel/sched/core.c index daababd6b211..3d06045706c6 100644 --- a/kernel/sched/core.c +++ b/kernel/sched/core.c @@ -852,6 +852,7 @@ static inline void enqueue_task(struct rq *rq, struct task_struct *p, int flags) if (!(flags & ENQUEUE_RESTORE)) sched_info_queued(rq, p); p->sched_class->enqueue_task(rq, p, flags); + trace_sched_enq_deq_task(p, 1); } static inline void dequeue_task(struct rq *rq, struct task_struct *p, int flags) @@ -860,6 +861,7 @@ static inline void dequeue_task(struct rq *rq, struct task_struct *p, int flags) if (!(flags & DEQUEUE_SAVE)) sched_info_dequeued(rq, p); p->sched_class->dequeue_task(rq, p, flags); + trace_sched_enq_deq_task(p, 0); } void activate_task(struct rq *rq, struct task_struct *p, int flags) |
