OpenCores
URL https://opencores.org/ocsvn/or1k/or1k/trunk

Subversion Repositories or1k

[/] [or1k/] [trunk/] [rtems-20020807/] [c/] [src/] [libmisc/] [monitor/] [mon-prmisc.c] - Rev 1780

Go to most recent revision | Compare with Previous | Blame | View Log

/*
 * Print misc stuff for the monitor dump routines
 * Each routine returns the number of characters it output.
 *
 * TODO:
 *
 *  mon-prmisc.c,v 1.10 2002/03/20 14:33:00 joel Exp
 */
 
#include <rtems.h>
#include <rtems/monitor.h>
 
#include <rtems/assoc.h>
 
#include <stdio.h>
#include <ctype.h>
 
void
rtems_monitor_separator(void)
{
    printf("------------------------------------------------------------------------------\n");
}
 
unsigned32
rtems_monitor_pad(
    unsigned32  destination_column,
    unsigned32  current_column
)
{
    int pad_length;
 
    if (destination_column <= current_column)
        pad_length = 1;
    else
        pad_length = destination_column - current_column;
 
    return printf("%*s", pad_length, "");
}
 
unsigned32
rtems_monitor_dump_char(rtems_unsigned8 ch)
{
    if (isprint(ch))
        return printf("%c", ch);
    else
        return printf("%02x", ch);
}
 
unsigned32
rtems_monitor_dump_decimal(unsigned32 num)
{
    return printf("%4d", num);
}
 
unsigned32
rtems_monitor_dump_hex(unsigned32 num)
{
    return printf("0x%x", num);
}
 
unsigned32
rtems_monitor_dump_assoc_bitfield(
    rtems_assoc_t *ap,
    char          *separator,
    unsigned32     value
  )
{  
    unsigned32 b;
    unsigned32 length = 0;
    const char *name;
 
    for (b = 1; b; b <<= 1)
        if (b & value)
        {
            if (length)
                length += printf("%s", separator);
 
            name = rtems_assoc_name_by_local(ap, b);
 
            if (name)
                length += printf("%s", name);
            else
                length += printf("0x%x", b);
        }
 
    return length;
}
 
unsigned32
rtems_monitor_dump_id(rtems_id id)
{
    return printf("%08x", id);
}
 
unsigned32
rtems_monitor_dump_name(rtems_name name)
{
    unsigned32 i;
    unsigned32 length = 0;
    union {
        unsigned32 ui;
        char       c[4];
    } u;
 
    u.ui = (rtems_unsigned32) name;
 
#if (CPU_BIG_ENDIAN == TRUE)
    for (i=0; i<sizeof(u.c); i++)
        length += rtems_monitor_dump_char(u.c[i]);
#else
    for (i=0; i<sizeof(u.c); i++)
        length += rtems_monitor_dump_char(u.c[sizeof(u.c)-1-i]);
#endif
    return length;
}
 
unsigned32
rtems_monitor_dump_priority(rtems_task_priority priority)
{
    return printf("%3d", priority);
}
 
 
rtems_assoc_t rtems_monitor_state_assoc[] = {
    { "DORM",   STATES_DORMANT },
    { "SUSP",   STATES_SUSPENDED },
    { "TRANS",  STATES_TRANSIENT },
    { "DELAY",  STATES_DELAYING },
    { "Wbuf",   STATES_WAITING_FOR_BUFFER },
    { "Wseg",   STATES_WAITING_FOR_SEGMENT },
    { "Wmsg" ,  STATES_WAITING_FOR_MESSAGE },
    { "Wevnt",  STATES_WAITING_FOR_EVENT },
    { "Wsem",   STATES_WAITING_FOR_SEMAPHORE },
    { "Wtime",  STATES_WAITING_FOR_TIME },
    { "Wrpc",   STATES_WAITING_FOR_RPC_REPLY },
    { "Wmutex", STATES_WAITING_FOR_MUTEX },
    { "Wcvar",  STATES_WAITING_FOR_CONDITION_VARIABLE },
    { "Wjatx",  STATES_WAITING_FOR_JOIN_AT_EXIT },
    { "Wsig",   STATES_WAITING_FOR_SIGNAL },
    { "WRATE",  STATES_WAITING_FOR_PERIOD },
    { "Wisig",  STATES_INTERRUPTIBLE_BY_SIGNAL },
    { 0, 0, 0 },
};
 
unsigned32
rtems_monitor_dump_state(States_Control state)
{
    unsigned32 length = 0;
 
    if (state == STATES_READY)  /* assoc doesn't deal with this as it is 0 */
        length += printf("READY");
 
    length += rtems_monitor_dump_assoc_bitfield(rtems_monitor_state_assoc,
                                                ":",
                                                state);
    return length;
}
 
rtems_assoc_t rtems_monitor_attribute_assoc[] = {
    { "FL",  RTEMS_FLOATING_POINT },
    { "GL",  RTEMS_GLOBAL },
    { "PR",  RTEMS_PRIORITY },
    { "BI",  RTEMS_BINARY_SEMAPHORE },
    { "IN",  RTEMS_INHERIT_PRIORITY },
    { 0, 0, 0 },
};
 
unsigned32
rtems_monitor_dump_attributes(rtems_attribute attributes)
{
    unsigned32 length = 0;
 
    if (attributes == RTEMS_DEFAULT_ATTRIBUTES)  /* value is 0 */
        length += printf("DEFAULT");
 
    length += rtems_monitor_dump_assoc_bitfield(rtems_monitor_attribute_assoc,
                                                ":",
                                                attributes);
    return length;
}
 
rtems_assoc_t rtems_monitor_modes_assoc[] = {
    { "nP",     RTEMS_NO_PREEMPT },
    { "T",      RTEMS_TIMESLICE },
    { "nA",     RTEMS_NO_ASR },
    { 0, 0, 0 },
};
 
unsigned32
rtems_monitor_dump_modes(rtems_mode modes)
{
    unsigned32 length = 0;
 
    if (modes == RTEMS_DEFAULT_MODES)  /* value is 0 */
        length += printf("P:T:nA");
 
    length += rtems_monitor_dump_assoc_bitfield(rtems_monitor_modes_assoc,
                                                ":",
                                                modes);
    return length;
}
 
rtems_assoc_t rtems_monitor_events_assoc[] = {
    { "0",   RTEMS_EVENT_0 },
    { "1",   RTEMS_EVENT_1 },
    { "2",   RTEMS_EVENT_2 },
    { "3",   RTEMS_EVENT_3 },
    { "4",   RTEMS_EVENT_4 },
    { "5",   RTEMS_EVENT_5 },
    { "6",   RTEMS_EVENT_6 },
    { "7",   RTEMS_EVENT_7 },
    { "8",   RTEMS_EVENT_8 },
    { "9",   RTEMS_EVENT_9 },
    { "10",  RTEMS_EVENT_10 },
    { "11",  RTEMS_EVENT_11 },
    { "12",  RTEMS_EVENT_12 },
    { "13",  RTEMS_EVENT_13 },
    { "14",  RTEMS_EVENT_14 },
    { "15",  RTEMS_EVENT_15 },
    { "16",  RTEMS_EVENT_16 },
    { "17",  RTEMS_EVENT_17 },
    { "18",  RTEMS_EVENT_18 },
    { "19",  RTEMS_EVENT_19 },
    { "20",  RTEMS_EVENT_20 },
    { "21",  RTEMS_EVENT_21 },
    { "22",  RTEMS_EVENT_22 },
    { "23",  RTEMS_EVENT_23 },
    { "24",  RTEMS_EVENT_24 },
    { "25",  RTEMS_EVENT_25 },
    { "26",  RTEMS_EVENT_26 },
    { "27",  RTEMS_EVENT_27 },
    { "28",  RTEMS_EVENT_28 },
    { "29",  RTEMS_EVENT_29 },
    { "30",  RTEMS_EVENT_30 },
    { "31",  RTEMS_EVENT_31 },
    { 0, 0, 0 },
};
 
unsigned32
rtems_monitor_dump_events(rtems_event_set events)
{
    unsigned32 length = 0;
 
    if (events == EVENT_SETS_NONE_PENDING)  /* value is 0 */
        length += printf("NONE");
 
    length += rtems_monitor_dump_assoc_bitfield(rtems_monitor_events_assoc,
                                                ":",
                                                events);
    return length;
}
 
unsigned32
rtems_monitor_dump_notepad(unsigned32 *notepad)
{
    unsigned32 length = 0;
    int i;
 
    for (i=0; i < RTEMS_NUMBER_NOTEPADS; i++)
        if (notepad[i])
            length += printf("%d: 0x%x ", i, notepad[i]);
 
    return length;
}
 

Go to most recent revision | Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.