2 * Copyright 2009, Intel Corporation
3 * Copyright 2009, Sun Microsystems, Inc
5 * This file is part of PowerTOP
7 * This program file is free software; you can redistribute it and/or modify it
8 * under the terms of the GNU General Public License as published by the
9 * Free Software Foundation; version 2 of the License.
11 * This program is distributed in the hope that it will be useful, but WITHOUT
12 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
13 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
16 * You should have received a copy of the GNU General Public License
17 * along with this program in a file named COPYING; if not, write to the
18 * Free Software Foundation, Inc.,
19 * 51 Franklin Street, Fifth Floor,
20 * Boston, MA 02110-1301 USA
23 * Arjan van de Ven <arjan@linux.intel.com>
24 * Eric C Saxe <eric.saxe@sun.com>
25 * Aubrey Li <aubrey.li@intel.com>
31 * For the avoidance of doubt, except that if any license choice other
32 * than GPL or LGPL is available it will apply instead, Sun elects to
33 * use only the General Public License version 2 (GPLv2) at this time
34 * for any software where a choice of GPL license versions is made
35 * available with the language indicating that GPLv2 or any later
36 * version may be used, or where a choice of which version of the GPL
37 * is applied is otherwise unspecified.
41 * DTrace scripts for observing interrupts, callouts and cyclic events
42 * that cause CPU activity. Such activity prevents the processor from
43 * entering lower power states and reducing power consumption.
45 * g_dtp_events is the default script
47 const char *g_dtp_events
=
49 "/arg0 != NULL && arg3 !=0/"
51 " this->devi = (struct dev_info *)arg0;"
52 " @interrupts[stringof(`devnamesp[this->devi->devi_major].dn_name),"
53 " this->devi->devi_instance] = count();"
57 "/(caddr_t)((callout_t *)arg0)->c_func == (caddr_t)&`setrun/"
59 " this->thr = (kthread_t *)(((callout_t *)arg0)->c_arg);"
60 " @events_u[stringof(this->thr->t_procp->p_user.u_comm)] = count();"
64 "/(caddr_t)((callout_t *)arg0)->c_func != (caddr_t)&`setrun/"
66 " @events_k[(caddr_t)((callout_t *)arg0)->c_func] = count();"
70 "/(caddr_t)((cyclic_t *)arg0)->cy_handler == (caddr_t)&`clock/"
72 " @events_k[(caddr_t)((cyclic_t *)arg0)->cy_handler] = count();"
78 " self->xc_func = arg0;"
81 "fbt::xt_one_unchecked:entry,"
86 " self->xc_func = arg1;"
92 " @events_x[execname, self->xc_func] = sum(arg0);"
97 * g_dtp_events_v is enabled through the -v option, it includes cyclic events
98 * in the report, allowing a complete view of system activity
100 const char *g_dtp_events_v
=
102 "/arg0 != NULL && arg3 !=0/"
104 " this->devi = (struct dev_info *)arg0;"
105 " @interrupts[stringof(`devnamesp[this->devi->devi_major].dn_name),"
106 " this->devi->devi_instance] = count();"
109 "sdt:::callout-start"
110 "/(caddr_t)((callout_t *)arg0)->c_func == (caddr_t)&`setrun/"
112 " this->thr = (kthread_t *)(((callout_t *)arg0)->c_arg);"
113 " @events_u[stringof(this->thr->t_procp->p_user.u_comm)] = count();"
116 "sdt:::callout-start"
117 "/(caddr_t)((callout_t *)arg0)->c_func != (caddr_t)&`setrun/"
119 " @events_k[(caddr_t)((callout_t *)arg0)->c_func] = count();"
123 "/(caddr_t)((cyclic_t *)arg0)->cy_handler != (caddr_t)&`dtrace_state_deadman &&"
124 " (caddr_t)((cyclic_t *)arg0)->cy_handler != (caddr_t)&`dtrace_state_clean/"
126 " @events_k[(caddr_t)((cyclic_t *)arg0)->cy_handler] = count();"
132 " self->xc_func = arg0;"
135 "fbt::xt_one_unchecked:entry,"
136 "fbt::xt_some:entry,"
140 " self->xc_func = arg1;"
146 " @events_x[execname, self->xc_func] = sum(arg0);"
147 " self->xc_func = 0;"
151 * This script is selected through the -c option, it takes the CPU id as
152 * argument and observes activity generated by that CPU
154 const char *g_dtp_events_c
=
157 " arg0 != NULL && arg3 != 0/"
159 " this->devi = (struct dev_info *)arg0;"
160 " @interrupts[stringof(`devnamesp[this->devi->devi_major].dn_name),"
161 " this->devi->devi_instance] = count();"
164 "sdt:::callout-start"
166 " (caddr_t)((callout_t *)arg0)->c_func == (caddr_t)&`setrun/"
168 " this->thr = (kthread_t *)(((callout_t *)arg0)->c_arg);"
169 " @events_u[stringof(this->thr->t_procp->p_user.u_comm)] = count();"
172 "sdt:::callout-start"
174 " (caddr_t)((callout_t *)arg0)->c_func != (caddr_t)&`setrun/"
176 " @events_k[(caddr_t)((callout_t *)arg0)->c_func] = count();"
181 " (caddr_t)((cyclic_t *)arg0)->cy_handler == (caddr_t)&`clock/"
183 " @events_k[(caddr_t)((cyclic_t *)arg0)->cy_handler] = count();"
187 * xcalls to all CPUs. We're only interested in firings from other CPUs since
188 * the system doesn't xcall itself
195 " self->xc_func = arg0;"
196 " self->xc_cpu = cpu;"
197 " self->cpu_known = 1;"
201 * xcalls to a subset of CPUs. No way of knowing if the observed CPU is in
202 * it, so account it in the generic @events_x aggregation. Again, we don't
203 * xcall the current CPU.
205 "fbt::xt_some:entry,"
210 " self->xc_func = arg1;"
214 * xcalls to a specific CPU, with all the necessary information
216 "fbt::xt_one_unchecked:entry,"
220 " self->xc_func = arg1;"
221 " self->xc_cpu = arg0;"
222 " self->cpu_known = 1;"
230 " @events_x[execname, self->xc_func] = sum(arg0);"
231 " self->xc_func = 0;"
239 " @events_xc[execname, self->xc_func, self->xc_cpu] = sum(arg0);"
240 " self->xc_func = 0;"
242 " self->cpu_known = 0;"
246 * sparcv9 platform specific display messages
248 const char *g_msg_idle_state
= "Idle Power States";
249 const char *g_msg_freq_state
= "Frequency Levels";
250 const char *g_msg_freq_enable
= "P - Enable CPU PM";