Release 4.10 kernel/trace/trace_sched_switch.c
/*
* trace context switch
*
* Copyright (C) 2007 Steven Rostedt <srostedt@redhat.com>
*
*/
#include <linux/module.h>
#include <linux/kallsyms.h>
#include <linux/uaccess.h>
#include <linux/ftrace.h>
#include <trace/events/sched.h>
#include "trace.h"
static int sched_ref;
static DEFINE_MUTEX(sched_register_mutex);
static void
probe_sched_switch(void *ignore, bool preempt,
struct task_struct *prev, struct task_struct *next)
{
if (unlikely(!sched_ref))
return;
tracing_record_cmdline(prev);
tracing_record_cmdline(next);
}
Contributors
| Person | Tokens | Prop | Commits | CommitProp |
steven rostedt | steven rostedt | 28 | 66.67% | 3 | 50.00% |
mathieu desnoyers | mathieu desnoyers | 8 | 19.05% | 1 | 16.67% |
peter zijlstra | peter zijlstra | 3 | 7.14% | 1 | 16.67% |
zhao lei | zhao lei | 3 | 7.14% | 1 | 16.67% |
| Total | 42 | 100.00% | 6 | 100.00% |
static void
probe_sched_wakeup(void *ignore, struct task_struct *wakee)
{
if (unlikely(!sched_ref))
return;
tracing_record_cmdline(current);
}
Contributors
| Person | Tokens | Prop | Commits | CommitProp |
ingo molnar | ingo molnar | 15 | 51.72% | 2 | 33.33% |
mathieu desnoyers | mathieu desnoyers | 7 | 24.14% | 2 | 33.33% |
steven rostedt | steven rostedt | 4 | 13.79% | 1 | 16.67% |
zhao lei | zhao lei | 3 | 10.34% | 1 | 16.67% |
| Total | 29 | 100.00% | 6 | 100.00% |
static int tracing_sched_register(void)
{
int ret;
ret = register_trace_sched_wakeup(probe_sched_wakeup, NULL);
if (ret) {
pr_info("wakeup trace: Couldn't activate tracepoint"
" probe to kernel_sched_wakeup\n");
return ret;
}
ret = register_trace_sched_wakeup_new(probe_sched_wakeup, NULL);
if (ret) {
pr_info("wakeup trace: Couldn't activate tracepoint"
" probe to kernel_sched_wakeup_new\n");
goto fail_deprobe;
}
ret = register_trace_sched_switch(probe_sched_switch, NULL);
if (ret) {
pr_info("sched trace: Couldn't activate tracepoint"
" probe to kernel_sched_switch\n");
goto fail_deprobe_wake_new;
}
return ret;
fail_deprobe_wake_new:
unregister_trace_sched_wakeup_new(probe_sched_wakeup, NULL);
fail_deprobe:
unregister_trace_sched_wakeup(probe_sched_wakeup, NULL);
return ret;
}
Contributors
| Person | Tokens | Prop | Commits | CommitProp |
mathieu desnoyers | mathieu desnoyers | 96 | 89.72% | 2 | 50.00% |
steven rostedt | steven rostedt | 10 | 9.35% | 1 | 25.00% |
wenji huang | wenji huang | 1 | 0.93% | 1 | 25.00% |
| Total | 107 | 100.00% | 4 | 100.00% |
static void tracing_sched_unregister(void)
{
unregister_trace_sched_switch(probe_sched_switch, NULL);
unregister_trace_sched_wakeup_new(probe_sched_wakeup, NULL);
unregister_trace_sched_wakeup(probe_sched_wakeup, NULL);
}
Contributors
| Person | Tokens | Prop | Commits | CommitProp |
mathieu desnoyers | mathieu desnoyers | 23 | 79.31% | 2 | 66.67% |
steven rostedt | steven rostedt | 6 | 20.69% | 1 | 33.33% |
| Total | 29 | 100.00% | 3 | 100.00% |
static void tracing_start_sched_switch(void)
{
mutex_lock(&sched_register_mutex);
if (!(sched_ref++))
tracing_sched_register();
mutex_unlock(&sched_register_mutex);
}
Contributors
| Person | Tokens | Prop | Commits | CommitProp |
frederic weisbecker | frederic weisbecker | 20 | 64.52% | 2 | 50.00% |
mathieu desnoyers | mathieu desnoyers | 10 | 32.26% | 1 | 25.00% |
ingo molnar | ingo molnar | 1 | 3.23% | 1 | 25.00% |
| Total | 31 | 100.00% | 4 | 100.00% |
static void tracing_stop_sched_switch(void)
{
mutex_lock(&sched_register_mutex);
if (!(--sched_ref))
tracing_sched_unregister();
mutex_unlock(&sched_register_mutex);
}
Contributors
| Person | Tokens | Prop | Commits | CommitProp |
frederic weisbecker | frederic weisbecker | 15 | 48.39% | 2 | 50.00% |
mathieu desnoyers | mathieu desnoyers | 15 | 48.39% | 1 | 25.00% |
ingo molnar | ingo molnar | 1 | 3.23% | 1 | 25.00% |
| Total | 31 | 100.00% | 4 | 100.00% |
void tracing_start_cmdline_record(void)
{
tracing_start_sched_switch();
}
Contributors
| Person | Tokens | Prop | Commits | CommitProp |
steven rostedt | steven rostedt | 10 | 100.00% | 1 | 100.00% |
| Total | 10 | 100.00% | 1 | 100.00% |
void tracing_stop_cmdline_record(void)
{
tracing_stop_sched_switch();
}
Contributors
| Person | Tokens | Prop | Commits | CommitProp |
steven rostedt | steven rostedt | 10 | 100.00% | 1 | 100.00% |
| Total | 10 | 100.00% | 1 | 100.00% |
Overall Contributors
| Person | Tokens | Prop | Commits | CommitProp |
mathieu desnoyers | mathieu desnoyers | 163 | 51.26% | 2 | 14.29% |
steven rostedt | steven rostedt | 86 | 27.04% | 4 | 28.57% |
frederic weisbecker | frederic weisbecker | 42 | 13.21% | 2 | 14.29% |
ingo molnar | ingo molnar | 17 | 5.35% | 3 | 21.43% |
zhao lei | zhao lei | 6 | 1.89% | 1 | 7.14% |
peter zijlstra | peter zijlstra | 3 | 0.94% | 1 | 7.14% |
wenji huang | wenji huang | 1 | 0.31% | 1 | 7.14% |
| Total | 318 | 100.00% | 14 | 100.00% |
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.