Merge branch 'sched-urgent-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip
* 'sched-urgent-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip: sched/events: Revert trace_sched_stat_sleeptime()
This commit is contained in:
@@ -370,56 +370,6 @@ TRACE_EVENT(sched_stat_runtime,
|
|||||||
(unsigned long long)__entry->vruntime)
|
(unsigned long long)__entry->vruntime)
|
||||||
);
|
);
|
||||||
|
|
||||||
#ifdef CREATE_TRACE_POINTS
|
|
||||||
static inline u64 trace_get_sleeptime(struct task_struct *tsk)
|
|
||||||
{
|
|
||||||
#ifdef CONFIG_SCHEDSTATS
|
|
||||||
u64 block, sleep;
|
|
||||||
|
|
||||||
block = tsk->se.statistics.block_start;
|
|
||||||
sleep = tsk->se.statistics.sleep_start;
|
|
||||||
tsk->se.statistics.block_start = 0;
|
|
||||||
tsk->se.statistics.sleep_start = 0;
|
|
||||||
|
|
||||||
return block ? block : sleep ? sleep : 0;
|
|
||||||
#else
|
|
||||||
return 0;
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Tracepoint for accounting sleeptime (time the task is sleeping
|
|
||||||
* or waiting for I/O).
|
|
||||||
*/
|
|
||||||
TRACE_EVENT(sched_stat_sleeptime,
|
|
||||||
|
|
||||||
TP_PROTO(struct task_struct *tsk, u64 now),
|
|
||||||
|
|
||||||
TP_ARGS(tsk, now),
|
|
||||||
|
|
||||||
TP_STRUCT__entry(
|
|
||||||
__array( char, comm, TASK_COMM_LEN )
|
|
||||||
__field( pid_t, pid )
|
|
||||||
__field( u64, sleeptime )
|
|
||||||
),
|
|
||||||
|
|
||||||
TP_fast_assign(
|
|
||||||
memcpy(__entry->comm, tsk->comm, TASK_COMM_LEN);
|
|
||||||
__entry->pid = tsk->pid;
|
|
||||||
__entry->sleeptime = trace_get_sleeptime(tsk);
|
|
||||||
__entry->sleeptime = __entry->sleeptime ?
|
|
||||||
now - __entry->sleeptime : 0;
|
|
||||||
)
|
|
||||||
TP_perf_assign(
|
|
||||||
__perf_count(__entry->sleeptime);
|
|
||||||
),
|
|
||||||
|
|
||||||
TP_printk("comm=%s pid=%d sleeptime=%Lu [ns]",
|
|
||||||
__entry->comm, __entry->pid,
|
|
||||||
(unsigned long long)__entry->sleeptime)
|
|
||||||
);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Tracepoint for showing priority inheritance modifying a tasks
|
* Tracepoint for showing priority inheritance modifying a tasks
|
||||||
* priority.
|
* priority.
|
||||||
|
@@ -1932,7 +1932,6 @@ static void finish_task_switch(struct rq *rq, struct task_struct *prev)
|
|||||||
local_irq_enable();
|
local_irq_enable();
|
||||||
#endif /* __ARCH_WANT_INTERRUPTS_ON_CTXSW */
|
#endif /* __ARCH_WANT_INTERRUPTS_ON_CTXSW */
|
||||||
finish_lock_switch(rq, prev);
|
finish_lock_switch(rq, prev);
|
||||||
trace_sched_stat_sleeptime(current, rq->clock);
|
|
||||||
|
|
||||||
fire_sched_in_preempt_notifiers(current);
|
fire_sched_in_preempt_notifiers(current);
|
||||||
if (mm)
|
if (mm)
|
||||||
|
@@ -1003,6 +1003,7 @@ static void enqueue_sleeper(struct cfs_rq *cfs_rq, struct sched_entity *se)
|
|||||||
if (unlikely(delta > se->statistics.sleep_max))
|
if (unlikely(delta > se->statistics.sleep_max))
|
||||||
se->statistics.sleep_max = delta;
|
se->statistics.sleep_max = delta;
|
||||||
|
|
||||||
|
se->statistics.sleep_start = 0;
|
||||||
se->statistics.sum_sleep_runtime += delta;
|
se->statistics.sum_sleep_runtime += delta;
|
||||||
|
|
||||||
if (tsk) {
|
if (tsk) {
|
||||||
@@ -1019,6 +1020,7 @@ static void enqueue_sleeper(struct cfs_rq *cfs_rq, struct sched_entity *se)
|
|||||||
if (unlikely(delta > se->statistics.block_max))
|
if (unlikely(delta > se->statistics.block_max))
|
||||||
se->statistics.block_max = delta;
|
se->statistics.block_max = delta;
|
||||||
|
|
||||||
|
se->statistics.block_start = 0;
|
||||||
se->statistics.sum_sleep_runtime += delta;
|
se->statistics.sum_sleep_runtime += delta;
|
||||||
|
|
||||||
if (tsk) {
|
if (tsk) {
|
||||||
|
Reference in New Issue
Block a user