diff options
Diffstat (limited to 'cpukit/libmisc/monitor/mon-extension.c')
-rw-r--r-- | cpukit/libmisc/monitor/mon-extension.c | 102 |
1 files changed, 102 insertions, 0 deletions
diff --git a/cpukit/libmisc/monitor/mon-extension.c b/cpukit/libmisc/monitor/mon-extension.c new file mode 100644 index 0000000000..c6a9f72040 --- /dev/null +++ b/cpukit/libmisc/monitor/mon-extension.c @@ -0,0 +1,102 @@ +/* + * RTEMS Monitor extension support + * + * $Id$ + */ + +#ifdef HAVE_CONFIG_H +#include "config.h" +#endif + +#include <rtems.h> +#include <rtems/monitor.h> + +#include <stdio.h> + +void +rtems_monitor_extension_canonical( + rtems_monitor_extension_t *canonical_extension, + void *extension_void +) +{ + Extension_Control *rtems_extension = (Extension_Control *) extension_void; + rtems_extensions_table *e = &rtems_extension->Extension.Callouts; + + rtems_monitor_symbol_canonical_by_value(&canonical_extension->e_create, + (void *) e->thread_create); + + rtems_monitor_symbol_canonical_by_value(&canonical_extension->e_start, + (void *) e->thread_start); + rtems_monitor_symbol_canonical_by_value(&canonical_extension->e_restart, + (void *) e->thread_restart); + rtems_monitor_symbol_canonical_by_value(&canonical_extension->e_delete, + (void *) e->thread_delete); + rtems_monitor_symbol_canonical_by_value(&canonical_extension->e_tswitch, + (void *) e->thread_switch); + rtems_monitor_symbol_canonical_by_value(&canonical_extension->e_begin, + (void *) e->thread_begin); + rtems_monitor_symbol_canonical_by_value(&canonical_extension->e_exitted, + (void *) e->thread_exitted); + rtems_monitor_symbol_canonical_by_value(&canonical_extension->e_fatal, + (void *) e->fatal); +} + +void +rtems_monitor_extension_dump_header( + bool verbose __attribute__((unused)) +) +{ + fprintf(stdout,"\ + ID NAME\n"); +/*23456789 123456789 123456789 123456789 123456789 123456789 123456789 123456789 +0 1 2 3 4 5 6 7 */ + + rtems_monitor_separator(); +} + + +/* + * Dump out the canonical form + */ + +void +rtems_monitor_extension_dump( + rtems_monitor_extension_t *monitor_extension, + bool verbose +) +{ + uint32_t length = 0; + + length += rtems_monitor_dump_id(monitor_extension->id); + length += rtems_monitor_pad(11, length); + length += rtems_monitor_dump_name(monitor_extension->id); + + length += rtems_monitor_pad(18, length); + length += fprintf(stdout,"create: "); + length += rtems_monitor_symbol_dump(&monitor_extension->e_create, verbose); + length += fprintf(stdout,"; start: "); + length += rtems_monitor_symbol_dump(&monitor_extension->e_start, verbose); + length += fprintf(stdout,"; restart: "); + length += rtems_monitor_symbol_dump(&monitor_extension->e_restart, verbose); + length += fprintf(stdout,"\n"); + length = 0; + + length += rtems_monitor_pad(18, length); + length += fprintf(stdout,"delete: "); + length += rtems_monitor_symbol_dump(&monitor_extension->e_delete, verbose); + length += fprintf(stdout,"; switch: "); + length += rtems_monitor_symbol_dump(&monitor_extension->e_tswitch, verbose); + length += fprintf(stdout,"; begin: "); + length += rtems_monitor_symbol_dump(&monitor_extension->e_begin, verbose); + length += fprintf(stdout,"\n"); + length = 0; + + length += rtems_monitor_pad(18, length); + length += fprintf(stdout,"exitted: "); + length += rtems_monitor_symbol_dump(&monitor_extension->e_exitted, verbose); + length += fprintf(stdout,"; fatal: "); + length += rtems_monitor_symbol_dump(&monitor_extension->e_fatal, verbose); + length += fprintf(stdout,"\n"); + length = 0; + fprintf(stdout,"\n"); +} |