[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