1b47b5b34SRafael Vanoni /* 2b47b5b34SRafael Vanoni * Copyright 2009, Intel Corporation 3b47b5b34SRafael Vanoni * Copyright 2009, Sun Microsystems, Inc 4b47b5b34SRafael Vanoni * 5b47b5b34SRafael Vanoni * This file is part of PowerTOP 6b47b5b34SRafael Vanoni * 7b47b5b34SRafael Vanoni * This program file is free software; you can redistribute it and/or modify it 8b47b5b34SRafael Vanoni * under the terms of the GNU General Public License as published by the 9b47b5b34SRafael Vanoni * Free Software Foundation; version 2 of the License. 10b47b5b34SRafael Vanoni * 11b47b5b34SRafael Vanoni * This program is distributed in the hope that it will be useful, but WITHOUT 12b47b5b34SRafael Vanoni * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 13b47b5b34SRafael Vanoni * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License 14b47b5b34SRafael Vanoni * for more details. 15b47b5b34SRafael Vanoni * 16b47b5b34SRafael Vanoni * You should have received a copy of the GNU General Public License 17b47b5b34SRafael Vanoni * along with this program in a file named COPYING; if not, write to the 18b47b5b34SRafael Vanoni * Free Software Foundation, Inc., 19b47b5b34SRafael Vanoni * 51 Franklin Street, Fifth Floor, 20b47b5b34SRafael Vanoni * Boston, MA 02110-1301 USA 21b47b5b34SRafael Vanoni * 22b47b5b34SRafael Vanoni * Authors: 23b47b5b34SRafael Vanoni * Arjan van de Ven <arjan@linux.intel.com> 24b47b5b34SRafael Vanoni * Eric C Saxe <eric.saxe@sun.com> 25b47b5b34SRafael Vanoni * Aubrey Li <aubrey.li@intel.com> 26b47b5b34SRafael Vanoni */ 27b47b5b34SRafael Vanoni 28b47b5b34SRafael Vanoni /* 29b47b5b34SRafael Vanoni * GPL Disclaimer 30b47b5b34SRafael Vanoni * 31b47b5b34SRafael Vanoni * For the avoidance of doubt, except that if any license choice other 32b47b5b34SRafael Vanoni * than GPL or LGPL is available it will apply instead, Sun elects to 33b47b5b34SRafael Vanoni * use only the General Public License version 2 (GPLv2) at this time 34b47b5b34SRafael Vanoni * for any software where a choice of GPL license versions is made 35b47b5b34SRafael Vanoni * available with the language indicating that GPLv2 or any later 36b47b5b34SRafael Vanoni * version may be used, or where a choice of which version of the GPL 37b47b5b34SRafael Vanoni * is applied is otherwise unspecified. 38b47b5b34SRafael Vanoni */ 39b47b5b34SRafael Vanoni 40b47b5b34SRafael Vanoni #include <getopt.h> 41b47b5b34SRafael Vanoni #include <unistd.h> 42b47b5b34SRafael Vanoni #include <stdio.h> 43b47b5b34SRafael Vanoni #include <stdlib.h> 44*9bbf5ba1SRafael Vanoni #include <signal.h> 45b47b5b34SRafael Vanoni #include <string.h> 46b47b5b34SRafael Vanoni #include <ctype.h> 47b47b5b34SRafael Vanoni #include <locale.h> 48b47b5b34SRafael Vanoni #include "powertop.h" 49b47b5b34SRafael Vanoni 50b47b5b34SRafael Vanoni /* 51b47b5b34SRafael Vanoni * Global variables, see powertop.h for comments and extern declarations. 52b47b5b34SRafael Vanoni * These are ordered by type, grouped by usage. 53b47b5b34SRafael Vanoni */ 54b47b5b34SRafael Vanoni double g_ticktime, g_ticktime_usr; 55b47b5b34SRafael Vanoni double g_interval; 56b47b5b34SRafael Vanoni 57b47b5b34SRafael Vanoni int g_bit_depth; 58636423dbSRafael Vanoni int g_total_events, g_top_events; 59b47b5b34SRafael Vanoni int g_npstates, g_max_cstate, g_longest_cstate; 60*9bbf5ba1SRafael Vanoni uint_t g_features; 61b47b5b34SRafael Vanoni uint_t g_ncpus; 62b47b5b34SRafael Vanoni uint_t g_ncpus_observed; 63b47b5b34SRafael Vanoni 64b47b5b34SRafael Vanoni processorid_t *g_cpu_table; 65b47b5b34SRafael Vanoni 66b47b5b34SRafael Vanoni hrtime_t g_total_c_time; 67b47b5b34SRafael Vanoni 68b47b5b34SRafael Vanoni uchar_t g_op_mode; 69b47b5b34SRafael Vanoni boolean_t g_gui; 70b47b5b34SRafael Vanoni uint_t g_observed_cpu; 71b47b5b34SRafael Vanoni 72b47b5b34SRafael Vanoni event_info_t g_event_info[EVENT_NUM_MAX]; 73b47b5b34SRafael Vanoni state_info_t g_cstate_info[NSTATES]; 74b47b5b34SRafael Vanoni freq_state_info_t g_pstate_info[NSTATES]; 75b47b5b34SRafael Vanoni cpu_power_info_t *g_cpu_power_states; 76b47b5b34SRafael Vanoni 77b47b5b34SRafael Vanoni boolean_t g_turbo_supported; 78b47b5b34SRafael Vanoni 79b47b5b34SRafael Vanoni uint_t g_argc; 80b47b5b34SRafael Vanoni char **g_argv; 81b47b5b34SRafael Vanoni 82b47b5b34SRafael Vanoni char *optarg; 83b47b5b34SRafael Vanoni 84b47b5b34SRafael Vanoni static const int true = 1; 85b47b5b34SRafael Vanoni 86b47b5b34SRafael Vanoni int 87b47b5b34SRafael Vanoni main(int argc, char **argv) 88b47b5b34SRafael Vanoni { 89b47b5b34SRafael Vanoni hrtime_t last, now; 90*9bbf5ba1SRafael Vanoni uint_t user_interval = 0; 91*9bbf5ba1SRafael Vanoni int index2 = 0, c, ret, dump_count = 0; 92b47b5b34SRafael Vanoni double last_time; 93b47b5b34SRafael Vanoni char *endptr; 94*9bbf5ba1SRafael Vanoni boolean_t root_user = B_FALSE; 95b47b5b34SRafael Vanoni 96b47b5b34SRafael Vanoni static struct option opts[] = { 97b47b5b34SRafael Vanoni { "dump", 1, NULL, 'd' }, 98b47b5b34SRafael Vanoni { "time", 1, NULL, 't' }, 99b47b5b34SRafael Vanoni { "help", 0, NULL, 'h' }, 100b47b5b34SRafael Vanoni { "cpu", 1, NULL, 'c' }, 101b47b5b34SRafael Vanoni { "verbose", 0, NULL, 'v' }, 102b47b5b34SRafael Vanoni { 0, 0, NULL, 0 } 103b47b5b34SRafael Vanoni }; 104b47b5b34SRafael Vanoni 105b47b5b34SRafael Vanoni (void) setlocale(LC_ALL, ""); 106b47b5b34SRafael Vanoni (void) bindtextdomain("powertop", "/usr/share/locale"); 107b47b5b34SRafael Vanoni (void) textdomain("powertop"); 108b47b5b34SRafael Vanoni 109b47b5b34SRafael Vanoni pt_set_progname(argv[0]); 110b47b5b34SRafael Vanoni 111b47b5b34SRafael Vanoni /* 112*9bbf5ba1SRafael Vanoni * Enumerate the system's CPUs, populate cpu_table, g_ncpus 113b47b5b34SRafael Vanoni */ 114b47b5b34SRafael Vanoni if ((g_ncpus = g_ncpus_observed = enumerate_cpus()) == 0) 115b47b5b34SRafael Vanoni exit(EXIT_FAILURE); 116b47b5b34SRafael Vanoni 117b47b5b34SRafael Vanoni if ((g_bit_depth = get_bit_depth()) < 0) 118b47b5b34SRafael Vanoni exit(EXIT_FAILURE); 119b47b5b34SRafael Vanoni 120*9bbf5ba1SRafael Vanoni g_features = 0; 121b47b5b34SRafael Vanoni g_ticktime = g_ticktime_usr = INTERVAL_DEFAULT; 122636423dbSRafael Vanoni g_op_mode = PT_MODE_DEFAULT; 123b47b5b34SRafael Vanoni g_gui = B_FALSE; 124b47b5b34SRafael Vanoni g_max_cstate = 0; 125b47b5b34SRafael Vanoni g_argv = NULL; 126b47b5b34SRafael Vanoni g_argc = 0; 127b47b5b34SRafael Vanoni g_observed_cpu = 0; 128b47b5b34SRafael Vanoni g_turbo_supported = B_FALSE; 129*9bbf5ba1SRafael Vanoni g_curr_sugg = NULL; 130b47b5b34SRafael Vanoni 131b47b5b34SRafael Vanoni while ((c = getopt_long(argc, argv, "d:t:h:vc:", opts, &index2)) 132b47b5b34SRafael Vanoni != EOF) { 133b47b5b34SRafael Vanoni if (c == -1) 134b47b5b34SRafael Vanoni break; 135b47b5b34SRafael Vanoni 136b47b5b34SRafael Vanoni switch (c) { 137b47b5b34SRafael Vanoni case 'd': 138636423dbSRafael Vanoni if (PT_ON_DUMP) 139b47b5b34SRafael Vanoni usage(); 140b47b5b34SRafael Vanoni 141636423dbSRafael Vanoni g_op_mode |= PT_MODE_DUMP; 142b47b5b34SRafael Vanoni dump_count = (int)strtod(optarg, &endptr); 143b47b5b34SRafael Vanoni 144b47b5b34SRafael Vanoni if (dump_count <= 0 || *endptr != NULL) 145b47b5b34SRafael Vanoni usage(); 146b47b5b34SRafael Vanoni break; 147b47b5b34SRafael Vanoni case 't': 148b47b5b34SRafael Vanoni if (user_interval) 149b47b5b34SRafael Vanoni usage(); 150b47b5b34SRafael Vanoni 151b47b5b34SRafael Vanoni user_interval = 1; 152b47b5b34SRafael Vanoni g_ticktime = g_ticktime_usr = (double)strtod(optarg, 153b47b5b34SRafael Vanoni &endptr); 154b47b5b34SRafael Vanoni 155b47b5b34SRafael Vanoni if (*endptr != NULL || g_ticktime < 1 || 156b47b5b34SRafael Vanoni g_ticktime > INTERVAL_MAX) 157b47b5b34SRafael Vanoni usage(); 158b47b5b34SRafael Vanoni break; 159b47b5b34SRafael Vanoni case 'v': 160636423dbSRafael Vanoni if (PT_ON_CPU || PT_ON_VERBOSE) 161b47b5b34SRafael Vanoni usage(); 162b47b5b34SRafael Vanoni 163636423dbSRafael Vanoni g_op_mode |= PT_MODE_VERBOSE; 164b47b5b34SRafael Vanoni break; 165b47b5b34SRafael Vanoni case 'c': 166636423dbSRafael Vanoni if (PT_ON_CPU || PT_ON_VERBOSE) 167b47b5b34SRafael Vanoni usage(); 168b47b5b34SRafael Vanoni 169636423dbSRafael Vanoni g_op_mode |= PT_MODE_CPU; 170b47b5b34SRafael Vanoni g_observed_cpu = (uint_t)strtod(optarg, &endptr); 171b47b5b34SRafael Vanoni 172b47b5b34SRafael Vanoni if (g_observed_cpu >= g_ncpus) 173b47b5b34SRafael Vanoni usage(); 174b47b5b34SRafael Vanoni 175b47b5b34SRafael Vanoni g_argc = 1; 176b47b5b34SRafael Vanoni g_ncpus_observed = 1; 177b47b5b34SRafael Vanoni 178b47b5b34SRafael Vanoni if ((g_argv = malloc(sizeof (char *))) == NULL) 179b47b5b34SRafael Vanoni return (EXIT_FAILURE); 180b47b5b34SRafael Vanoni 181b47b5b34SRafael Vanoni if ((*g_argv = malloc(sizeof (char) * 5)) == NULL) 182b47b5b34SRafael Vanoni return (EXIT_FAILURE); 183b47b5b34SRafael Vanoni 184b47b5b34SRafael Vanoni (void) snprintf(*g_argv, 5, "%d\0", g_observed_cpu); 185b47b5b34SRafael Vanoni break; 186b47b5b34SRafael Vanoni case 'h': 187b47b5b34SRafael Vanoni default: 188b47b5b34SRafael Vanoni usage(); 189b47b5b34SRafael Vanoni return (EXIT_USAGE); 190b47b5b34SRafael Vanoni } 191b47b5b34SRafael Vanoni } 192b47b5b34SRafael Vanoni 193*9bbf5ba1SRafael Vanoni if (optind < argc) 194b47b5b34SRafael Vanoni usage(); 195b47b5b34SRafael Vanoni 196b47b5b34SRafael Vanoni (void) printf("%s %s\n\n", TITLE, COPYRIGHT_INTEL); 197b47b5b34SRafael Vanoni 198*9bbf5ba1SRafael Vanoni (void) printf(_("Collecting data for %.2f second(s) \n"), 199*9bbf5ba1SRafael Vanoni (float)g_ticktime); 200*9bbf5ba1SRafael Vanoni 201*9bbf5ba1SRafael Vanoni /* Prepare P-state statistics */ 202*9bbf5ba1SRafael Vanoni if (pt_cpufreq_stat_prepare() == 0) 203*9bbf5ba1SRafael Vanoni g_features |= FEATURE_PSTATE; 204b47b5b34SRafael Vanoni 205b47b5b34SRafael Vanoni /* Prepare C-state statistics */ 206b47b5b34SRafael Vanoni ret = pt_cpuidle_stat_prepare(); 207b47b5b34SRafael Vanoni if (ret == 0) 208*9bbf5ba1SRafael Vanoni g_features |= FEATURE_CSTATE; 209b47b5b34SRafael Vanoni else 210b47b5b34SRafael Vanoni /* 211b47b5b34SRafael Vanoni * PowerTop was unable to run a DTrace program, 212b47b5b34SRafael Vanoni * most likely for lack of permissions. 213b47b5b34SRafael Vanoni */ 214b47b5b34SRafael Vanoni exit(EXIT_FAILURE); 215b47b5b34SRafael Vanoni 216*9bbf5ba1SRafael Vanoni /* 217*9bbf5ba1SRafael Vanoni * We need to initiate the display to make sure there's enough space 218*9bbf5ba1SRafael Vanoni * in the terminal for all of PowerTOP's subwindows, but after 219*9bbf5ba1SRafael Vanoni * pt_cpufreq_stat_prepare() which finds out how many states the 220*9bbf5ba1SRafael Vanoni * system supports. 221*9bbf5ba1SRafael Vanoni */ 222*9bbf5ba1SRafael Vanoni if (!PT_ON_DUMP) { 223*9bbf5ba1SRafael Vanoni pt_display_init_curses(); 224*9bbf5ba1SRafael Vanoni pt_display_setup(B_FALSE); 225*9bbf5ba1SRafael Vanoni g_gui = B_TRUE; 226*9bbf5ba1SRafael Vanoni pt_display_title_bar(); 227*9bbf5ba1SRafael Vanoni pt_display_status_bar(); 228*9bbf5ba1SRafael Vanoni } 229b47b5b34SRafael Vanoni 230b47b5b34SRafael Vanoni /* Prepare event statistics */ 231b47b5b34SRafael Vanoni if (pt_events_stat_prepare() != -1) 232*9bbf5ba1SRafael Vanoni g_features |= FEATURE_EVENTS; 233*9bbf5ba1SRafael Vanoni 234*9bbf5ba1SRafael Vanoni /* 235*9bbf5ba1SRafael Vanoni * If the system is running on battery, find out what's 236*9bbf5ba1SRafael Vanoni * the kstat module for it 237*9bbf5ba1SRafael Vanoni */ 238*9bbf5ba1SRafael Vanoni battery_mod_lookup(); 239b47b5b34SRafael Vanoni 240b47b5b34SRafael Vanoni /* Prepare turbo statistics */ 241*9bbf5ba1SRafael Vanoni if (pt_turbo_stat_prepare() == 0) 242*9bbf5ba1SRafael Vanoni g_features |= FEATURE_TURBO; 243*9bbf5ba1SRafael Vanoni 244*9bbf5ba1SRafael Vanoni /* 245*9bbf5ba1SRafael Vanoni * Installs the initial suggestions, running as root and turning CPU 246*9bbf5ba1SRafael Vanoni * power management ON. 247*9bbf5ba1SRafael Vanoni */ 248*9bbf5ba1SRafael Vanoni if (geteuid() != 0) 249*9bbf5ba1SRafael Vanoni pt_sugg_as_root(); 250*9bbf5ba1SRafael Vanoni else { 251*9bbf5ba1SRafael Vanoni root_user = B_TRUE; 252*9bbf5ba1SRafael Vanoni pt_cpufreq_suggest(); 253b47b5b34SRafael Vanoni } 254b47b5b34SRafael Vanoni 255b47b5b34SRafael Vanoni last = gethrtime(); 256b47b5b34SRafael Vanoni 257b47b5b34SRafael Vanoni while (true) { 258b47b5b34SRafael Vanoni fd_set rfds; 259b47b5b34SRafael Vanoni struct timeval tv; 260*9bbf5ba1SRafael Vanoni int key; 261b47b5b34SRafael Vanoni char keychar; 262b47b5b34SRafael Vanoni 263b47b5b34SRafael Vanoni /* 264b47b5b34SRafael Vanoni * Sleep for a while waiting either for input (if we're not 265b47b5b34SRafael Vanoni * in dump mode) or for the timeout to elapse 266b47b5b34SRafael Vanoni */ 267b47b5b34SRafael Vanoni FD_ZERO(&rfds); 268b47b5b34SRafael Vanoni FD_SET(0, &rfds); 269b47b5b34SRafael Vanoni 270b47b5b34SRafael Vanoni tv.tv_sec = (long)g_ticktime; 271636423dbSRafael Vanoni tv.tv_usec = (long)((g_ticktime - tv.tv_sec) * MICROSEC); 272b47b5b34SRafael Vanoni 273*9bbf5ba1SRafael Vanoni if (!PT_ON_DUMP) { 274b47b5b34SRafael Vanoni key = select(1, &rfds, NULL, NULL, &tv); 275*9bbf5ba1SRafael Vanoni } else 276b47b5b34SRafael Vanoni key = select(1, NULL, NULL, NULL, &tv); 277b47b5b34SRafael Vanoni 278b47b5b34SRafael Vanoni now = gethrtime(); 279b47b5b34SRafael Vanoni 280b47b5b34SRafael Vanoni g_interval = (double)(now - last)/NANOSEC; 281b47b5b34SRafael Vanoni last = now; 282b47b5b34SRafael Vanoni 283636423dbSRafael Vanoni g_top_events = 0; 284b47b5b34SRafael Vanoni g_total_events = 0; 285b47b5b34SRafael Vanoni 2869b37b909SRafael Vanoni (void) memset(g_event_info, 0, 2879b37b909SRafael Vanoni EVENT_NUM_MAX * sizeof (event_info_t)); 28892ad8f28SRafael Vanoni (void) memset(g_cstate_info, 0, 28992ad8f28SRafael Vanoni NSTATES * sizeof (state_info_t)); 290b47b5b34SRafael Vanoni 291b47b5b34SRafael Vanoni /* Collect idle state transition stats */ 292*9bbf5ba1SRafael Vanoni if (g_features & FEATURE_CSTATE && 293b47b5b34SRafael Vanoni pt_cpuidle_stat_collect(g_interval) < 0) { 294b47b5b34SRafael Vanoni /* Reinitialize C-state statistics */ 295b47b5b34SRafael Vanoni if (pt_cpuidle_stat_prepare() != 0) 296b47b5b34SRafael Vanoni exit(EXIT_FAILURE); 297b47b5b34SRafael Vanoni 298*9bbf5ba1SRafael Vanoni continue; 299b47b5b34SRafael Vanoni } 300b47b5b34SRafael Vanoni 301b47b5b34SRafael Vanoni /* Collect frequency change stats */ 302*9bbf5ba1SRafael Vanoni if (g_features & FEATURE_PSTATE && 303b47b5b34SRafael Vanoni pt_cpufreq_stat_collect(g_interval) < 0) { 304b47b5b34SRafael Vanoni /* Reinitialize P-state statistics */ 305b47b5b34SRafael Vanoni if (pt_cpufreq_stat_prepare() != 0) 306b47b5b34SRafael Vanoni exit(EXIT_FAILURE); 307b47b5b34SRafael Vanoni 308*9bbf5ba1SRafael Vanoni continue; 309b47b5b34SRafael Vanoni } 310b47b5b34SRafael Vanoni 311b47b5b34SRafael Vanoni /* Collect event statistics */ 312*9bbf5ba1SRafael Vanoni if (g_features & FEATURE_EVENTS && 313b47b5b34SRafael Vanoni pt_events_stat_collect() < 0) { 314b47b5b34SRafael Vanoni /* Reinitialize event statistics */ 315b47b5b34SRafael Vanoni if (pt_events_stat_prepare() != 0) 316b47b5b34SRafael Vanoni exit(EXIT_FAILURE); 317b47b5b34SRafael Vanoni 318b47b5b34SRafael Vanoni continue; 319*9bbf5ba1SRafael Vanoni } 320b47b5b34SRafael Vanoni 321b47b5b34SRafael Vanoni /* Collect turbo statistics */ 322*9bbf5ba1SRafael Vanoni if (g_features & FEATURE_TURBO && 323*9bbf5ba1SRafael Vanoni pt_turbo_stat_collect() < 0) 324b47b5b34SRafael Vanoni exit(EXIT_FAILURE); 325b47b5b34SRafael Vanoni 326b47b5b34SRafael Vanoni /* Show CPU power states */ 327*9bbf5ba1SRafael Vanoni pt_display_states(); 328b47b5b34SRafael Vanoni 329b47b5b34SRafael Vanoni /* Show wakeups events affecting PM */ 330*9bbf5ba1SRafael Vanoni if (g_features & FEATURE_EVENTS) { 331*9bbf5ba1SRafael Vanoni pt_display_wakeups(g_interval); 332*9bbf5ba1SRafael Vanoni pt_display_events(g_interval); 333b47b5b34SRafael Vanoni } 334b47b5b34SRafael Vanoni 335*9bbf5ba1SRafael Vanoni pt_battery_print(); 336b47b5b34SRafael Vanoni 337636423dbSRafael Vanoni if (key && !PT_ON_DUMP) { 338b47b5b34SRafael Vanoni keychar = toupper(fgetc(stdin)); 339b47b5b34SRafael Vanoni 340b47b5b34SRafael Vanoni switch (keychar) { 341b47b5b34SRafael Vanoni case 'Q': 342b47b5b34SRafael Vanoni exit(EXIT_SUCCESS); 343b47b5b34SRafael Vanoni break; 344*9bbf5ba1SRafael Vanoni 345b47b5b34SRafael Vanoni case 'R': 346b47b5b34SRafael Vanoni g_ticktime = 3; 347b47b5b34SRafael Vanoni break; 348b47b5b34SRafael Vanoni } 349b47b5b34SRafael Vanoni 350*9bbf5ba1SRafael Vanoni /* 351*9bbf5ba1SRafael Vanoni * Check if the user has activated the current 352*9bbf5ba1SRafael Vanoni * suggestion. 353*9bbf5ba1SRafael Vanoni */ 354*9bbf5ba1SRafael Vanoni if (g_curr_sugg != NULL && 355*9bbf5ba1SRafael Vanoni keychar == g_curr_sugg->key && g_curr_sugg->func) 356*9bbf5ba1SRafael Vanoni g_curr_sugg->func(); 357b47b5b34SRafael Vanoni } 358b47b5b34SRafael Vanoni 359b47b5b34SRafael Vanoni if (dump_count) 360b47b5b34SRafael Vanoni dump_count--; 361b47b5b34SRafael Vanoni 362b47b5b34SRafael Vanoni /* Exits if user requested a dump */ 363*9bbf5ba1SRafael Vanoni if (PT_ON_DUMP && !dump_count) 364b47b5b34SRafael Vanoni exit(EXIT_SUCCESS); 365b47b5b34SRafael Vanoni 366b47b5b34SRafael Vanoni /* No key pressed, will suggest something */ 367b47b5b34SRafael Vanoni if (!key && !dump_count) 368*9bbf5ba1SRafael Vanoni pt_sugg_pick(); 369b47b5b34SRafael Vanoni 370b47b5b34SRafael Vanoni /* Refresh display */ 371*9bbf5ba1SRafael Vanoni if (!PT_ON_DUMP) 372*9bbf5ba1SRafael Vanoni pt_display_update(); 373*9bbf5ba1SRafael Vanoni 374*9bbf5ba1SRafael Vanoni if (root_user) 375*9bbf5ba1SRafael Vanoni pt_cpufreq_suggest(); 376b47b5b34SRafael Vanoni 377b47b5b34SRafael Vanoni /* 378b47b5b34SRafael Vanoni * Update the interval based on how long the CPU was in the 379b47b5b34SRafael Vanoni * longest c-state during the last snapshot. If the user 380b47b5b34SRafael Vanoni * specified an interval we skip this bit and keep it fixed. 381b47b5b34SRafael Vanoni */ 382*9bbf5ba1SRafael Vanoni if (g_features & FEATURE_CSTATE && !user_interval) { 383*9bbf5ba1SRafael Vanoni last_time = (((double) 384*9bbf5ba1SRafael Vanoni g_cstate_info[g_longest_cstate].total_time/MICROSEC 385*9bbf5ba1SRafael Vanoni /g_ncpus)/g_cstate_info[g_longest_cstate].events); 386b47b5b34SRafael Vanoni 387b47b5b34SRafael Vanoni if (last_time < INTERVAL_DEFAULT || 388b47b5b34SRafael Vanoni (g_total_events/g_ticktime) < 1) 389b47b5b34SRafael Vanoni g_ticktime = INTERVAL_DEFAULT; 390b47b5b34SRafael Vanoni else 391b47b5b34SRafael Vanoni g_ticktime = INTERVAL_UPDATE(last_time); 392*9bbf5ba1SRafael Vanoni } else { 393b47b5b34SRafael Vanoni /* 394*9bbf5ba1SRafael Vanoni * Restore interval after a refresh. 395b47b5b34SRafael Vanoni */ 396*9bbf5ba1SRafael Vanoni if (key) 397b47b5b34SRafael Vanoni g_ticktime = g_ticktime_usr; 398b47b5b34SRafael Vanoni } 399b47b5b34SRafael Vanoni } 400b47b5b34SRafael Vanoni 401*9bbf5ba1SRafael Vanoni return (EXIT_SUCCESS); 402b47b5b34SRafael Vanoni } 403