Merge branch 'docs-next' of git://git.lwn.net/linux-2.6
[linux-2.6/next.git] / include / trace / events / workqueue.h
blobe4612dbd7ba6070d3d2a28e8a7f4359524cbe77c
1 #undef TRACE_SYSTEM
2 #define TRACE_SYSTEM workqueue
4 #if !defined(_TRACE_WORKQUEUE_H) || defined(TRACE_HEADER_MULTI_READ)
5 #define _TRACE_WORKQUEUE_H
7 #include <linux/workqueue.h>
8 #include <linux/sched.h>
9 #include <linux/tracepoint.h>
11 TRACE_EVENT(workqueue_insertion,
13 TP_PROTO(struct task_struct *wq_thread, struct work_struct *work),
15 TP_ARGS(wq_thread, work),
17 TP_STRUCT__entry(
18 __array(char, thread_comm, TASK_COMM_LEN)
19 __field(pid_t, thread_pid)
20 __field(work_func_t, func)
23 TP_fast_assign(
24 memcpy(__entry->thread_comm, wq_thread->comm, TASK_COMM_LEN);
25 __entry->thread_pid = wq_thread->pid;
26 __entry->func = work->func;
29 TP_printk("thread=%s:%d func=%pf", __entry->thread_comm,
30 __entry->thread_pid, __entry->func)
33 TRACE_EVENT(workqueue_execution,
35 TP_PROTO(struct task_struct *wq_thread, struct work_struct *work),
37 TP_ARGS(wq_thread, work),
39 TP_STRUCT__entry(
40 __array(char, thread_comm, TASK_COMM_LEN)
41 __field(pid_t, thread_pid)
42 __field(work_func_t, func)
45 TP_fast_assign(
46 memcpy(__entry->thread_comm, wq_thread->comm, TASK_COMM_LEN);
47 __entry->thread_pid = wq_thread->pid;
48 __entry->func = work->func;
51 TP_printk("thread=%s:%d func=%pf", __entry->thread_comm,
52 __entry->thread_pid, __entry->func)
55 /* Trace the creation of one workqueue thread on a cpu */
56 TRACE_EVENT(workqueue_creation,
58 TP_PROTO(struct task_struct *wq_thread, int cpu),
60 TP_ARGS(wq_thread, cpu),
62 TP_STRUCT__entry(
63 __array(char, thread_comm, TASK_COMM_LEN)
64 __field(pid_t, thread_pid)
65 __field(int, cpu)
68 TP_fast_assign(
69 memcpy(__entry->thread_comm, wq_thread->comm, TASK_COMM_LEN);
70 __entry->thread_pid = wq_thread->pid;
71 __entry->cpu = cpu;
74 TP_printk("thread=%s:%d cpu=%d", __entry->thread_comm,
75 __entry->thread_pid, __entry->cpu)
78 TRACE_EVENT(workqueue_destruction,
80 TP_PROTO(struct task_struct *wq_thread),
82 TP_ARGS(wq_thread),
84 TP_STRUCT__entry(
85 __array(char, thread_comm, TASK_COMM_LEN)
86 __field(pid_t, thread_pid)
89 TP_fast_assign(
90 memcpy(__entry->thread_comm, wq_thread->comm, TASK_COMM_LEN);
91 __entry->thread_pid = wq_thread->pid;
94 TP_printk("thread=%s:%d", __entry->thread_comm, __entry->thread_pid)
97 #endif /* _TRACE_WORKQUEUE_H */
99 /* This part must be outside protection */
100 #include <trace/define_trace.h>