sched, trace: Fix prev_state output in sched_switch tracepoint
commit 3054426dc68e5d63aa6a6e9b91ac4ec78e3f3805 upstream.
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.
task_state_index() 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.
Link: http://lkml.kernel.org/r/1540882473-1103-1-git-send-email-pkondeti@codeaurora.org
Cc: stable@vger.kernel.org
Fixes: 3f5fe9fef5b2 ("sched/debug: Fix task state recording/printout")
Signed-off-by:  Pavankumar Kondeti <pkondeti@codeaurora.org>
Signed-off-by:
Pavankumar Kondeti <pkondeti@codeaurora.org>
Signed-off-by:  Steven Rostedt (VMware) <rostedt@goodmis.org>
Signed-off-by:
Steven Rostedt (VMware) <rostedt@goodmis.org>
Signed-off-by:  Sudip Mukherjee <sudipm.mukherjee@gmail.com>
Signed-off-by:
Sudip Mukherjee <sudipm.mukherjee@gmail.com>
Signed-off-by:  Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Loading
Please register or sign in to comment
