[PATCH 7/9] libmisc: Add top to shell.
Jennifer Averett
jennifer.averett at oarcorp.com
Tue Sep 30 14:13:26 UTC 2014
---
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
diff --git a/cpukit/libmisc/Makefile.am b/cpukit/libmisc/Makefile.am
index 6c13071..d0cd7e7 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 0000000..ad6223a
--- /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 <stdio.h>
+#include <string.h>
+
+#include <rtems.h>
+#include <rtems/cpuuse.h>
+#include <rtems/shell.h>
+#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 eacfac2..e00f6cd 100644
--- a/cpukit/libmisc/shell/shellconfig.h
+++ b/cpukit/libmisc/shell/shellconfig.h
@@ -77,6 +77,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;
@@ -403,6 +404,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,
--
1.8.1.4
More information about the devel
mailing list