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

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [rtos/] [ecos-2.0/] [packages/] [kernel/] [v2_0/] [host/] [instr/] [readme.txt] - Rev 174

Compare with Previous | Blame | View Log


README for User Friendly Instrumentation Messages
=================================================

The CDL option CYGDBG_KERNEL_INSTRUMENT_MSGS controls whether the
system is capable of displaying user friendly instrumentation
messages.  To do this it needs to know what event numbers mean
what events - as a text string to print for you.

It gets the information from a table created by the header file
instrument_desc.h in the kernel.  If the instrumentation numbers
change, you must rebuild that header to match.

A further CDL option is provided to help you with that.  The
procedure is as follows:

1) Remove kernel/VERSION/include/instrument_desc.h from your
   repository.  Is is probably a good idea to move it away rather
   than deleting it in case the next stages fail.

2) Make a build configuration, enabling options
   CYGDBG_KERNEL_INSTRUMENT, CYGDBG_KERNEL_INSTRUMENT_MSGS and
   CYGDBG_KERNEL_INSTRUMENT_MSGS_BUILD_HEADERFILE in the kernel.
   Viewed in the GUI configtool, "Kernel instrumentation", "Print
   user friendly instrument messages" and "Rebuild the header
   file" respectively.

3) Make eCos within this build configuration.  It should create
   install/include/cyg/kernel/instrument_desc.h

4) Copy that new file back to your repository, to
   kernel/VERSION/include/instrument_desc.h replacing the file
   you moved aside in step 1.

5) Commit the new file to your version control system or whatever
   you use.

If you wish to rebuild the file "by hand" the command to use, in
a suitable shell, is this:

   $ECOS_REPOSITORY/kernel/$ECOS_VERSION/host/instr/instrument.sh 
        $ECOS_REPOSITORY/kernel/$ECOS_VERSION/include/instrmnt.h
        > $ECOS_BUILD_PREFIX/include/cyg/kernel/instrument_desc.h

(all on one line of course) or to rebuild it directly into the
kernel source repository:

   $ECOS_REPOSITORY/kernel/$ECOS_VERSION/host/instr/instrument.sh 
        $ECOS_REPOSITORY/kernel/$ECOS_VERSION/include/instrmnt.h
        > $ECOS_REPOSITORY/kernel/$ECOS_VERSION/include/instrument_desc.h

It's up to you to sort out file permissions for this to work, and
to set environment variables as required or edit these lines as
you type them.


There is also a host-based program which can print a buffer
nicely for you - if you can get the data into your host.
Enabling CDL option CYGDBG_KERNEL_INSTRUMENT_BUILD_HOST_DUMP or
"Build the host tool to print out a dump" will build it for you
in install/bin.  To build it instead "by hand", use

    mkdir -p tempinc
    cp -r $(ECOS_BUILD_PREFIX)/include/cyg tempinc
    cp -r $(ECOS_BUILD_PREFIX)/include/pkgconf tempinc
    cc -I./tempinc
    $(ECOS_REPOSITORY)/kernel/${ECOS_VERSION}/host/instr/dump_instr.c
    -o $(PREFIX)/bin/dump_instr

again with environment variables as required, or type in whatever
is appropriate.  You still have to somehow get the
instrumentation buffer into a file on the host. 'Exercise for the
reader' as university lecturers tend to say.

One possibility is to set up a tftp *server* in the target which
will serve the instrumentation buffer.  This hint is as far as
support for this goes.



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.