mirror of
https://github.com/FEX-Emu/linux.git
synced 2025-01-11 20:07:00 +00:00
sched/tracing: Use common task-state helpers
Remove yet another task-state char instance. Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org> Cc: Linus Torvalds <torvalds@linux-foundation.org> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: linux-kernel@vger.kernel.org Signed-off-by: Ingo Molnar <mingo@kernel.org>
This commit is contained in:
parent
efb40f588b
commit
5f6ad26ea3
@ -83,8 +83,6 @@ struct task_group;
|
|||||||
#define TASK_NEW 0x0800
|
#define TASK_NEW 0x0800
|
||||||
#define TASK_STATE_MAX 0x1000
|
#define TASK_STATE_MAX 0x1000
|
||||||
|
|
||||||
#define TASK_STATE_TO_CHAR_STR "RSDTtXZxKWPNn"
|
|
||||||
|
|
||||||
/* Convenience macros for the sake of set_current_state: */
|
/* Convenience macros for the sake of set_current_state: */
|
||||||
#define TASK_KILLABLE (TASK_WAKEKILL | TASK_UNINTERRUPTIBLE)
|
#define TASK_KILLABLE (TASK_WAKEKILL | TASK_UNINTERRUPTIBLE)
|
||||||
#define TASK_STOPPED (TASK_WAKEKILL | __TASK_STOPPED)
|
#define TASK_STOPPED (TASK_WAKEKILL | __TASK_STOPPED)
|
||||||
|
@ -656,15 +656,6 @@ int trace_print_lat_context(struct trace_iterator *iter)
|
|||||||
return !trace_seq_has_overflowed(s);
|
return !trace_seq_has_overflowed(s);
|
||||||
}
|
}
|
||||||
|
|
||||||
static const char state_to_char[] = TASK_STATE_TO_CHAR_STR;
|
|
||||||
|
|
||||||
static int task_state_char(unsigned long state)
|
|
||||||
{
|
|
||||||
int bit = state ? __ffs(state) + 1 : 0;
|
|
||||||
|
|
||||||
return bit < sizeof(state_to_char) - 1 ? state_to_char[bit] : '?';
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* ftrace_find_event - find a registered event
|
* ftrace_find_event - find a registered event
|
||||||
* @type: the type of event to look for
|
* @type: the type of event to look for
|
||||||
@ -930,8 +921,8 @@ static enum print_line_t trace_ctxwake_print(struct trace_iterator *iter,
|
|||||||
|
|
||||||
trace_assign_type(field, iter->ent);
|
trace_assign_type(field, iter->ent);
|
||||||
|
|
||||||
T = task_state_char(field->next_state);
|
T = __task_state_to_char(field->next_state);
|
||||||
S = task_state_char(field->prev_state);
|
S = __task_state_to_char(field->prev_state);
|
||||||
trace_find_cmdline(field->next_pid, comm);
|
trace_find_cmdline(field->next_pid, comm);
|
||||||
trace_seq_printf(&iter->seq,
|
trace_seq_printf(&iter->seq,
|
||||||
" %5d:%3d:%c %s [%03d] %5d:%3d:%c %s\n",
|
" %5d:%3d:%c %s [%03d] %5d:%3d:%c %s\n",
|
||||||
@ -966,8 +957,8 @@ static int trace_ctxwake_raw(struct trace_iterator *iter, char S)
|
|||||||
trace_assign_type(field, iter->ent);
|
trace_assign_type(field, iter->ent);
|
||||||
|
|
||||||
if (!S)
|
if (!S)
|
||||||
S = task_state_char(field->prev_state);
|
S = __task_state_to_char(field->prev_state);
|
||||||
T = task_state_char(field->next_state);
|
T = __task_state_to_char(field->next_state);
|
||||||
trace_seq_printf(&iter->seq, "%d %d %c %d %d %d %c\n",
|
trace_seq_printf(&iter->seq, "%d %d %c %d %d %d %c\n",
|
||||||
field->prev_pid,
|
field->prev_pid,
|
||||||
field->prev_prio,
|
field->prev_prio,
|
||||||
@ -1002,8 +993,8 @@ static int trace_ctxwake_hex(struct trace_iterator *iter, char S)
|
|||||||
trace_assign_type(field, iter->ent);
|
trace_assign_type(field, iter->ent);
|
||||||
|
|
||||||
if (!S)
|
if (!S)
|
||||||
S = task_state_char(field->prev_state);
|
S = __task_state_to_char(field->prev_state);
|
||||||
T = task_state_char(field->next_state);
|
T = __task_state_to_char(field->next_state);
|
||||||
|
|
||||||
SEQ_PUT_HEX_FIELD(s, field->prev_pid);
|
SEQ_PUT_HEX_FIELD(s, field->prev_pid);
|
||||||
SEQ_PUT_HEX_FIELD(s, field->prev_prio);
|
SEQ_PUT_HEX_FIELD(s, field->prev_prio);
|
||||||
|
@ -397,10 +397,10 @@ tracing_sched_switch_trace(struct trace_array *tr,
|
|||||||
entry = ring_buffer_event_data(event);
|
entry = ring_buffer_event_data(event);
|
||||||
entry->prev_pid = prev->pid;
|
entry->prev_pid = prev->pid;
|
||||||
entry->prev_prio = prev->prio;
|
entry->prev_prio = prev->prio;
|
||||||
entry->prev_state = prev->state;
|
entry->prev_state = __get_task_state(prev);
|
||||||
entry->next_pid = next->pid;
|
entry->next_pid = next->pid;
|
||||||
entry->next_prio = next->prio;
|
entry->next_prio = next->prio;
|
||||||
entry->next_state = next->state;
|
entry->next_state = __get_task_state(next);
|
||||||
entry->next_cpu = task_cpu(next);
|
entry->next_cpu = task_cpu(next);
|
||||||
|
|
||||||
if (!call_filter_check_discard(call, entry, buffer, event))
|
if (!call_filter_check_discard(call, entry, buffer, event))
|
||||||
@ -425,10 +425,10 @@ tracing_sched_wakeup_trace(struct trace_array *tr,
|
|||||||
entry = ring_buffer_event_data(event);
|
entry = ring_buffer_event_data(event);
|
||||||
entry->prev_pid = curr->pid;
|
entry->prev_pid = curr->pid;
|
||||||
entry->prev_prio = curr->prio;
|
entry->prev_prio = curr->prio;
|
||||||
entry->prev_state = curr->state;
|
entry->prev_state = __get_task_state(curr);
|
||||||
entry->next_pid = wakee->pid;
|
entry->next_pid = wakee->pid;
|
||||||
entry->next_prio = wakee->prio;
|
entry->next_prio = wakee->prio;
|
||||||
entry->next_state = wakee->state;
|
entry->next_state = __get_task_state(wakee);
|
||||||
entry->next_cpu = task_cpu(wakee);
|
entry->next_cpu = task_cpu(wakee);
|
||||||
|
|
||||||
if (!call_filter_check_discard(call, entry, buffer, event))
|
if (!call_filter_check_discard(call, entry, buffer, event))
|
||||||
|
Loading…
x
Reference in New Issue
Block a user