1 /*******************************************************************************
2 * Copyright (c) 2015 Ericsson
4 * All rights reserved. This program and the accompanying materials are
5 * made available under the terms of the Eclipse Public License v1.0 which
6 * accompanies this distribution, and is available at
7 * http://www.eclipse.org/legal/epl-v10.html
10 * Alexandre Montplaisir - Initial API and implementation
11 ******************************************************************************/
13 package org
.eclipse
.tracecompass
.analysis
.os
.linux
.core
.trace
;
15 import static org
.eclipse
.tracecompass
.common
.core
.NonNullUtils
.checkNotNull
;
17 import java
.util
.Collection
;
19 import org
.eclipse
.jdt
.annotation
.NonNull
;
21 import com
.google
.common
.collect
.ImmutableList
;
24 * A kernel event layout to be used by default. This can be useful for
25 * data-driven traces for example, where they can provide whatever event names
28 * Due to historical reasons, the definitions are the same as LTTng event names.
30 * @author Alexandre Montplaisir
33 public class DefaultEventLayout
implements IKernelAnalysisEventLayout
{
36 private static final String IRQ_HANDLER_ENTRY
= "irq_handler_entry"; //$NON-NLS-1$
37 private static final String IRQ_HANDLER_EXIT
= "irq_handler_exit"; //$NON-NLS-1$
38 private static final String SOFTIRQ_ENTRY
= "softirq_entry"; //$NON-NLS-1$
39 private static final String SOFTIRQ_EXIT
= "softirq_exit"; //$NON-NLS-1$
40 private static final String SOFTIRQ_RAISE
= "softirq_raise"; //$NON-NLS-1$
41 private static final String HRTIMER_START
= "hrtimer_start"; //$NON-NLS-1$
42 private static final String HRTIMER_CANCEL
= "hrtimer_cancel"; //$NON-NLS-1$
43 private static final String HRTIMER_EXPIRE_ENTRY
= "hrtimer_expire_entry"; //$NON-NLS-1$
44 private static final String HRTIMER_EXPIRE_EXIT
= "hrtimer_expire_exit"; //$NON-NLS-1$
45 private static final String SCHED_SWITCH
= "sched_switch"; //$NON-NLS-1$
46 private static final String SCHED_PI_SETPRIO
= "sched_pi_setprio"; //$NON-NLS-1$
48 private static final String SCHED_TTWU
= "sched_ttwu"; //$NON-NLS-1$
49 private static final String SCHED_WAKEUP
= "sched_wakeup"; //$NON-NLS-1$
50 private static final String SCHED_WAKEUP_NEW
= "sched_wakeup_new"; //$NON-NLS-1$
51 private static final Collection
<String
> SCHED_WAKEUP_EVENTS
=
52 checkNotNull(ImmutableList
.of(SCHED_WAKEUP
, SCHED_WAKEUP_NEW
));
54 private static final String SCHED_PROCESS_FORK
= "sched_process_fork"; //$NON-NLS-1$
55 private static final String SCHED_PROCESS_EXIT
= "sched_process_exit"; //$NON-NLS-1$
56 private static final String SCHED_PROCESS_FREE
= "sched_process_free"; //$NON-NLS-1$
57 private static final String SCHED_PROCESS_EXEC
= "sched_process_exec"; //$NON-NLS-1$
58 private static final String STATEDUMP_PROCESS_STATE
= "lttng_statedump_process_state"; //$NON-NLS-1$
60 private static final String SYSCALL_ENTRY_PREFIX
= "sys_"; //$NON-NLS-1$
61 private static final String COMPAT_SYSCALL_ENTRY_PREFIX
= "compat_sys_"; //$NON-NLS-1$
62 private static final String SYSCALL_EXIT_PREFIX
= "exit_syscall"; //$NON-NLS-1$
65 private static final String IRQ
= "irq"; //$NON-NLS-1$
66 private static final String TID
= "tid"; //$NON-NLS-1$
67 private static final String VEC
= "vec"; //$NON-NLS-1$
68 private static final String PREV_TID
= "prev_tid"; //$NON-NLS-1$
69 private static final String PREV_STATE
= "prev_state"; //$NON-NLS-1$
70 private static final String NEXT_COMM
= "next_comm"; //$NON-NLS-1$
71 private static final String NEXT_TID
= "next_tid"; //$NON-NLS-1$
72 private static final String PARENT_TID
= "parent_tid"; //$NON-NLS-1$
73 private static final String CHILD_COMM
= "child_comm"; //$NON-NLS-1$
74 private static final String CHILD_TID
= "child_tid"; //$NON-NLS-1$
75 private static final String PRIO
= "prio"; //$NON-NLS-1$
76 private static final String NEW_PRIO
= "newprio"; //$NON-NLS-1$
77 private static final String NEXT_PRIO
= "next_prio"; //$NON-NLS-1$
78 private static final String COMM
= "comm"; //$NON-NLS-1$
79 private static final String NAME
= "name"; //$NON-NLS-1$
80 private static final String STATUS
= "status"; //$NON-NLS-1$
81 private static final String PREV_COMM
= "prev_comm"; //$NON-NLS-1$
82 private static final String FILENAME
= "filename"; //$NON-NLS-1$
83 private static final String HRTIMER
= "hrtimer"; //$NON-NLS-1$
84 private static final String FUNCTION
= "function"; //$NON-NLS-1$
85 private static final String EXPIRES
= "expires"; //$NON-NLS-1$
86 private static final String NOW
= "now"; //$NON-NLS-1$
87 private static final String SOFT_EXPIRES
= "softexpires"; //$NON-NLS-1$
89 /** All instances are the same. Only provide a static instance getter */
90 private DefaultEventLayout() {
94 * The instance of this event layout
96 * This object is completely immutable, so no need to create additional
97 * instances via the constructor.
99 static final IKernelAnalysisEventLayout INSTANCE
= new DefaultEventLayout();
101 // ------------------------------------------------------------------------
103 // ------------------------------------------------------------------------
106 public String
eventIrqHandlerEntry() {
107 return IRQ_HANDLER_ENTRY
;
111 public String
eventIrqHandlerExit() {
112 return IRQ_HANDLER_EXIT
;
116 public String
eventSoftIrqEntry() {
117 return SOFTIRQ_ENTRY
;
121 public String
eventSoftIrqExit() {
126 public String
eventSoftIrqRaise() {
127 return SOFTIRQ_RAISE
;
131 public String
eventSchedSwitch() {
139 public String
eventSchedPiSetprio() {
140 return SCHED_PI_SETPRIO
;
144 public Collection
<String
> eventsSchedWakeup() {
145 return SCHED_WAKEUP_EVENTS
;
149 public String
eventSchedProcessFork() {
150 return SCHED_PROCESS_FORK
;
154 public String
eventSchedProcessExit() {
155 return SCHED_PROCESS_EXIT
;
159 public String
eventSchedProcessFree() {
160 return SCHED_PROCESS_FREE
;
164 public @NonNull String
eventStatedumpProcessState() {
165 return STATEDUMP_PROCESS_STATE
;
169 public String
eventSyscallEntryPrefix() {
170 return SYSCALL_ENTRY_PREFIX
;
174 public String
eventCompatSyscallEntryPrefix() {
175 return COMPAT_SYSCALL_ENTRY_PREFIX
;
179 public String
eventSyscallExitPrefix() {
180 return SYSCALL_EXIT_PREFIX
;
183 // ------------------------------------------------------------------------
185 // ------------------------------------------------------------------------
188 public String
fieldIrq() {
193 public String
fieldVec() {
198 public String
fieldTid() {
203 public String
fieldPrevTid() {
208 public String
fieldPrevState() {
213 public String
fieldNextComm() {
218 public String
fieldNextTid() {
223 public String
fieldChildComm() {
228 public String
fieldParentTid() {
233 public String
fieldChildTid() {
239 public String
fieldPrio() {
245 public String
fieldNewPrio() {
251 public String
fieldNextPrio() {
257 public String
fieldComm() {
263 public String
fieldName() {
269 public String
fieldStatus() {
275 public String
fieldPrevComm() {
281 public String
fieldFilename() {
287 public String
eventSchedProcessExec() {
288 return SCHED_PROCESS_EXEC
;
293 public String
eventSchedProcessWakeup() {
299 public String
eventSchedProcessWakeupNew() {
300 return SCHED_WAKEUP_NEW
;
305 public String
eventHRTimerStart() {
306 return HRTIMER_START
;
311 public String
eventHRTimerCancel() {
312 return HRTIMER_CANCEL
;
317 public String
eventHRTimerExpireEntry() {
318 return HRTIMER_EXPIRE_ENTRY
;
323 public String
eventHRTimerExpireExit() {
324 return HRTIMER_EXPIRE_EXIT
;
328 * Event indicating the source of the wakeup signal.
330 * @return The name of the event
333 public String
eventSchedProcessTTWU() {
339 public String
fieldHRtimer() {
345 public String
fieldHRtimerFunction() {
351 public String
fieldHRtimerExpires() {
357 public String
fieldHRtimerSoftexpires() {
363 public String
fieldHRtimerNow() {