From a7817010c505b4cf51196695e979647d7bae6517 Mon Sep 17 00:00:00 2001 From: Jennifer Averett Date: Mon, 29 Sep 2014 10:21:00 -0500 Subject: libmisc: Add top to shell. --- cpukit/libmisc/Makefile.am | 2 +- cpukit/libmisc/shell/main_top.c | 60 ++++++++++++++++++++++++++++++++++++++ cpukit/libmisc/shell/shellconfig.h | 6 ++++ 3 files changed, 67 insertions(+), 1 deletion(-) create mode 100644 cpukit/libmisc/shell/main_top.c (limited to 'cpukit') diff --git a/cpukit/libmisc/Makefile.am b/cpukit/libmisc/Makefile.am index d26c4844b2..021a25112e 100644 --- a/cpukit/libmisc/Makefile.am +++ b/cpukit/libmisc/Makefile.am @@ -88,7 +88,7 @@ libshell_a_SOURCES = shell/cat_file.c shell/cmds.c shell/internal.h \ shell/main_mallocinfo.c shell/main_md5.c shell/main_mdump.c \ shell/main_medit.c shell/main_mfill.c shell/main_mkdir.c \ shell/main_mount.c shell/main_mmove.c shell/main_msdosfmt.c \ - shell/main_mv.c shell/main_perioduse.c \ + shell/main_mv.c shell/main_perioduse.c shell/main_top.c \ shell/main_pwd.c shell/main_rm.c shell/main_rmdir.c shell/main_sleep.c \ shell/main_stackuse.c shell/main_tty.c shell/main_umask.c \ shell/main_unmount.c shell/main_blksync.c shell/main_whoami.c \ diff --git a/cpukit/libmisc/shell/main_top.c b/cpukit/libmisc/shell/main_top.c new file mode 100644 index 0000000000..ad6223a560 --- /dev/null +++ b/cpukit/libmisc/shell/main_top.c @@ -0,0 +1,60 @@ +/* + * TOP Command Implementation + * + * COPYRIGHT (c) 2014. + * On-Line Applications Research Corporation (OAR). + * + * The license and distribution terms for this file may be + * found in the file LICENSE in this distribution or at + * http://www.rtems.org/license/LICENSE. + */ + +#ifdef HAVE_CONFIG_H +#include "config.h" +#endif + +#include +#include + +#include +#include +#include +#include "internal.h" + +static int rtems_shell_main_top( + int argc, + char *argv[] +) +{ + /* + * When invoked with no arguments, print the report. + */ + if ( argc == 1 ) { + rtems_cpu_usage_top_with_plugin(stdout, (rtems_printk_plugin_t)fprintf); + return 0; + } + + /* + * When invoked with the single argument -r, reset the statistics. + */ + if ( argc == 2 && !strcmp( argv[1], "-r" ) ) { + printf( "Resetting CPU Usage information\n" ); + rtems_cpu_usage_reset(); + return 0; + } + + /* + * OK. The user did something wrong. + */ + fprintf( stderr, "%s: [-r]\n", argv[0] ); + return -1; +} + +rtems_shell_cmd_t rtems_shell_TOP_Command = { + "top", /* name */ + "[-r] print or reset per thread cpu usage", /* usage */ + "rtems", /* topic */ + rtems_shell_main_top, /* command */ + NULL, /* alias */ + NULL /* next */ +}; diff --git a/cpukit/libmisc/shell/shellconfig.h b/cpukit/libmisc/shell/shellconfig.h index 377695287c..e58916e214 100644 --- a/cpukit/libmisc/shell/shellconfig.h +++ b/cpukit/libmisc/shell/shellconfig.h @@ -78,6 +78,7 @@ extern rtems_shell_cmd_t rtems_shell_RTC_Command; extern rtems_shell_cmd_t rtems_shell_HALT_Command; extern rtems_shell_cmd_t rtems_shell_CPUUSE_Command; +extern rtems_shell_cmd_t rtems_shell_TOP_Command; extern rtems_shell_cmd_t rtems_shell_STACKUSE_Command; extern rtems_shell_cmd_t rtems_shell_PERIODUSE_Command; extern rtems_shell_cmd_t rtems_shell_WKSPACE_INFO_Command; @@ -409,6 +410,11 @@ extern rtems_shell_alias_t *rtems_shell_Initial_aliases[]; &rtems_shell_CPUUSE_Command, #endif #if (defined(CONFIGURE_SHELL_COMMANDS_ALL) && \ + !defined(CONFIGURE_SHELL_NO_COMMAND_TOP)) || \ + defined(CONFIGURE_SHELL_COMMAND_TOP) + &rtems_shell_TOP_Command, + #endif + #if (defined(CONFIGURE_SHELL_COMMANDS_ALL) && \ !defined(CONFIGURE_SHELL_NO_COMMAND_STACKUSE)) || \ defined(CONFIGURE_SHELL_COMMAND_STACKUSE) &rtems_shell_STACKUSE_Command, -- cgit v1.2.3