Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 20a4a25f authored by Pavankumar Kondeti's avatar Pavankumar Kondeti
Browse files

sched, trace: Fix prev_state output in sched_switch tracepoint



commit 3f5fe9fef5b2 ("sched/debug: Fix task state recording/printout")
tried to fix the problem introduced by a previous commit efb40f58
("sched/tracing: Fix trace_sched_switch task-state printing"). However
the prev_state output in sched_switch is still broken.

__get_task_state() uses fls() which considers the LSB as 1. Left
shifting 1 by this value gives an incorrect mapping to the task state.
Fix this by decrementing the value returned by __get_task_state()
before shifting.

Change-Id: I0291652b4d50079d04b23327b5370f07a7e15be7
Signed-off-by: default avatarPavankumar Kondeti <pkondeti@codeaurora.org>
parent 4bd759b6
Loading
Loading
Loading
Loading
+11 −1
Original line number Diff line number Diff line
@@ -155,6 +155,8 @@ DEFINE_EVENT(sched_wakeup_template, sched_wakeup_new,
#ifdef CREATE_TRACE_POINTS
static inline long __trace_sched_switch_state(bool preempt, struct task_struct *p)
{
	unsigned int state;

#ifdef CONFIG_SCHED_DEBUG
	BUG_ON(p != current);
#endif /* CONFIG_SCHED_DEBUG */
@@ -166,7 +168,15 @@ static inline long __trace_sched_switch_state(bool preempt, struct task_struct *
	if (preempt)
		return TASK_REPORT_MAX;

	return 1 << __get_task_state(p);
	/*
	 * __get_task_state() uses fls(), which considers LSB as 0. So
	 * Decrement it by 1 (except TASK_RUNNING state i.e 0) before using
	 * it for left shift operation to get the correct task->state
	 * mapping.
	 */
	state = __get_task_state(p);

	return state ? (1 << (state - 1)) : state;
}
#endif /* CREATE_TRACE_POINTS */