Man Page collector.1




NAME

     collector - subcommands of dbx  used  for  performance  data
     collection


SYNOPSIS

     dbx


DESCRIPTION

     The term collector is used to describe the  data  collection
     features  in  dbx and the runtime support for those features
     in libcollector.so.

     The  dbx collector does not work for applications written in
     the  Java(TM) programming language;  it can collect data for
     the Java virtual machine, but the Java-specific  functional-
     ity  does  not  work  from  dbx.  (The  terms  "Java virtual
     machine" and "JVM" mean a virtual machine for  the  Java(TM)
     platform.)

     The data collected is described in the collect(1) man  page.
     The collect command can collect data without using dbx.


DBX COMMANDS

     The commands accepted by dbx  to  support  performance  data
     collection are as follows.

     collector { enable | disable }
          Enable or disable data collection.

          If no process is active,  control  whether  or  not  an
          experiment  is collected when a process starts.  If the
          mode is disable, do not collect performance  data.   If
          the  mode  is  enable,  collect data for all subsequent
          runs.

          If a process is running, but  no  experiment  is  being
          collected,  and an enable command is received, start an
          experiment.  If disable is given,  ignore  the  command
          with a warning.

          If a process is running, an experiment  is  being  col-
          lected,  and  a  disable command is received, terminate
          the experiment.  If enable is given, ingore the command
          with a warning.

          If an experiment is terminated, but the process is left
          running  and an enable command is received, start a new
          experiment.

     collector pause
          Temporarily stop recording data during  an  experiment.
          Ignore the command with no warning if recording of data
          is already paused.  Ignore the command with  a  warning
          if no experiment is running.

     collector resume
          Resume recording data during an experiment.  Ignore the
          command  with  no  warning  if recording of data is not
          paused.  Ignore the command with a warning if no exper-
          iment is running.

     collector profile { on | off }
          Enable or disable collection of  clock-based  profiling
          data.  If  an  experiment is active, ignore the command
          with a warning.  Default is enabled.

     collector profile timer value
          Set the profiling timer interval to value.   The  value
          can  be  an  integer or a floating-point number, with a
          suffix of u for values in microseconds, or m for values
          in  milliseconds.   If  no  suffix  is used, assume the
          value to be in milliseconds.  Set the default  interval
          to 10 milliseconds.

          The interval value can also be  given  as  one  of  the
          strings "hi" or "high" for profiling at a 1 millisecond
          interval, "lo", "low"  for  profiling  at  a  100  mil-
          lisecond  interval,  or "on" for profiling at a 10 mil-
          lisecond interval.  These interval values are  approxi-
          mate.

          If the value is smaller than the system clock profiling
          minimum  set it to the minimum; if it is not a multiple
          of the clock profiling resolution  round  down  to  the
          nearest  multiple  of  the  clock  resolution.   If  it
          exceeds the clock profiling maximum, report  an  error.
          If it is negative or zero, report an error.

          If an experiment is active, ignore the command  with  a
          warning.

     collector hwprofile { on | off }
          Enable or disable hardware-counter overflow  profiling.
          On  systems whose hardware or operating system does not
          support hardware-counter overflow profiling, return  an
          error  on  detecting  an  attempt  to enable it.  If an
          experiment is active, ignore the command with  a  warn-
          ing.

     collector hwprofile list
          Print a usage summary, including the default configura-
          tion  of  the  experiment.  If  the  processor supports
          hardware counter profiling, print two lists  containing
          information  about  hardware  counters.  The first list
          will contain "well known" hardware counters; the second
          list will contain raw hardware counters.

          For example, the  collector  hwprofile  list    command
          invoked on a Sun OS SPARC-based system would produce an
          output similar to the following:

            Well known HW counters available for profiling:
                cycles[/{0|1}],9999991 (`CPU Cycles', alias for Cycle_cnt; CPU-cycles)
                insts[/{0|1}],9999991 (`Instructions Executed', alias for Instr_cnt; events)
                icm[/1],100003 (`I$ Misses', alias for IC_miss; events)
                ...
            Raw HW counters available for profiling:
                Cycle_cnt[/{0|1}],1000003 (CPU-cycles)
                Instr_cnt[/{0|1}],1000003 (events)
                Dispatch0_IC_miss[/0],1000003 (CPU-cycles)
                ...

     collector hwprofile counter ctr_def...[,ctr_n_def]
          Collect hardware counter overflow profiles. The  number
          of  counter definitions, (ctr_def through ctr_n_def) is
          processor-dependent. For example, on an UltraSPARC  III
          system,  up  to  two  counters may be programmed; on an
          Intel Pentium 4 with Hyperthreading, up to 18  counters
          are  available.  The  user  can  ascertain  the maximum
          number of hardware counters definitions  for  profiling
          on  a  target  system,  and  the full list of available
          hardware  counters,  by  running  the  collect  command
          without any arguments.  This option is not available on
          Linux systems.

          Each counter definition  takes  one  of  the  following
          forms,  depending  on  whether  attributes for hardware
          counters are supported on the processor:

          1. [+]ctr[/reg#],interval

             [+]ctr[/reg#] interval

             Examples:
                  collector hwprofile counter cycles,on,insts
                  collector hwprofile counter cycles on insts

             Note: For historical reasons, a space can  still  be
             used as the delimiter between hardware counters.

          2. [+]ctr[~attr=val]...[~attrN=valN][/reg#],interval



             Example:

               collector hwprofile counter FP_dispatched_fpu_ops~umask=0x3/2,10007

          enables the Floating Point Add and Multiply  operations
          to  be  tracked.  (For  more details on valid attribute
          values, refer to  the  processor  documentation).   The
          "/2"  value specifies instructions to be executed using
          the second register of the hardware. The CPU cycle pro-
          filing is done at an interval rate of 10007 events.

          The meanings of the counter definition options  are  as
          follows:

          Value     Meaning

          +         Optional parameter that  can  be  applied  to
                    memory-related  counters.  Causes  collect to
                    backtrack in an attempt to find the  instruc-
                    tion that triggered the overflow, and to find
                    the virtual and  physical  addresses  of  the
                    memory reference. Backtracking will only work
                    with counters of type load, store,  or  load-
                    store,  as  displayed  in  the  counter  list
                    obtained  by  running  the  collect   command
                    without any command-line arguments.

          ctr       Processor-specific counter name. The user can
                    ascertain  the  list of counter names by run-
                    ning  the  collect   command    without   any
                    command-line arguments.

          attr=val  On some processors, attribute options can  be
                    associated  with  a  hardware counter. If the
                    processor supports  attribute  options,  then
                    running   collect  without  any  command-line
                    arguments will specify  the  counter  defini-
                    tion,  ctr_def,  in  the  second  form listed
                    above, and provide a list of attribute  names
                    to use for attr.  Value val can be in decimal
                    or  hexadecimal  format.  Hexadecimal  format
                    numbers  are  in  C  program format where the
                    number is prepended by a zero and  lower-case
                    x (0x hex_number).

          reg#      Hardware register to use for the counter.  If
                    not  specified, collect will attempt to place
                    the counter into the first available register
                    and  as a result, may be unable to place sub-
                    sequent counters due to  register  conflicts.
                    If  the user specifies more than one counter,
                    the counters must  use  different  registers.
                    The list of allowable register numbers can be
                    ascertained by running  the  collect  command
                    without any command-line arguments.

          interval
                    Sampling  frequency,  set  by  defining   the
                    counter  overflow value.  Valid values are as
                    follows:

                    Value     Meaning

                    on        Select the default rate, which  can
                              be  determined  by running the col-
                              lect command without  any  command-
                              line   arguments.   Note  that  the
                              default value for all raw  counters
                              is  the  same,  and  may not be the
                              most suitable value for a  specific
                              counter.

                    hi        Set interval  to  approximately  10
                              times shorter than on.

                    lo        Set interval  to  approximately  10
                              times longer than on.

                    value     Set interval to a  specific  value,
                              specified in decimal or hexadecimal
                              format.

          An experiment can specify both hardware counter profil-
          ing  and  clock-based  profiling.   If hardware counter
          profiling is specified, but  clock-based  profiling  is
          not  explicitly specified, turn off clock-based profil-
          ing.


     collector synctrace { on | off }
               Enable or disable  collecting  of  synchronization
               tracing  data.   Default is off.  If an experiment
               is active, ignore the command with a warning.

     collector synctrace threshold value
               Set the threshold for synchronization delay  trac-
               ing according to the given value, which can be one
               of the following:

               Value     Meaning

               calibrate or on
                         Use a calibrated  threshold,  determined
                         at runtime.

               off       Turn off synchronization delay tracing.
               n         Use   an   threshold    value    of    n
                         microseconds. A zero value enables trac-
                         ing of all events.

               The default setting is calibrate.  If  an  experi-
               ment is active, ignore the command with a warning.

     collector mpitrace { on | off }
               Enable or disable collecting of MPI tracing  data.
               Default  is  off.   If  an  experiment  is active,
               ignore the command with a warning.

     collector heaptrace { on | off }
               Enable or disable collecting of heap tracing data.
               Default  is  off.   If  an  experiment  is active,
               ignore the command with a warning.

     collector archive { on | off | copy }
               Set the mode for archiving  the  experiment.   The
               default  is on, corresponding to normal archiving.
               If the mode is set to off, do no archiving. If the
               mode  is  set  to copy, copy all load objects used
               into the experiment.  A user that moves the exper-
               iment  to  a  different  machine, or reads it from
               another machine, should enable the copying of  all
               load  objects.  If an experiment is active, ignore
               the command with a warning.

     collector limit value
               Limit the amount of  profiling  data  recorded  to
               value  megabytes.  The limit applies to the sum of
               all profiling data and tracing data,  but  not  to
               sample  points. The limit is only approximate, and
               can be  exceeded.   When  the  limit  is  reached,
               record no more profiling or tracing data, but keep
               the experiment open and record samples  until  the
               target  process  terminates.   If an experiment is
               active, ignore the command with a warning.

               The default limit on the amount of  data  recorded
               is  2000  Mbytes.   To  remove the limit, the user
               sets value to "none" or "unlimited".

     collector status
               Report on the status of any open experiment.

     collector show
               Show the current settings of all collector control
               variables.

     collector sample { periodic | manual }
               Set  the  sampling  mode  to  either  periodic  or
               manual.  If  periodic is specified, record samples
               at the current sampling frequency.  If  manual  is
               specified,  record  periodic samples.  Samples can
               be recorded manually using collector sample record
               regardless  of  which  mode  is  specified.  If an
               experiment is active, ignore the  command  with  a
               warning.

     collector sample record [name]
               Record a sample, with the optional label name.  If
               an  experiment  is  not active, ingore the command
               with a warning.

     collector sample period value
               Set the sampling  frequency  to  value,  given  in
               seconds.   If  an experiment is active, ignore the
               command with a warning.

     collector dbxsample { on | off }
               Control the collection of samples when  dbx  stops
               the  target process.  For the on option, collect a
               sample ieach time dbx stops the target process; if
               off , collect no samples.  Default is on.

     collector store directory name
               Set the collector directory to name.  If an exper-
               iment  is  active, ignore the command with a warn-
               ing.

     collector store experiment name
               Set the output experiment name  to  name.   If  an
               experiment  is  active,  ignore the command with a
               warning.  If a name  is  not  specified,  use  the
               default name. The default name is described in the
               collect(1) man page.

     collector store group name
               Set the experiment group  name  to  name.   If  an
               experiment  is  active,  ignore the command with a
               warning.

     collector version
               Report the version of libcollector.so  that  would
               be used to collect data.

     help collector
               Prompt the user about the various  collector  com-
               mands available.


OBSOLETE DBX COMMANDS

     A few commands previously accepted by dbx are now  obsolete;
     they are:
     collector enable_once
          Ignored with a warning.  The command used to allow ena-
          bling data collection for just one run.

     collector close
          Treated as collector disable if an experiment  is  run-
          ning.   Ignored with a warning if no experiment is run-
          ning.

     collector quit
          Treated as collector disable if an experiment  is  run-
          ning.   Ignored with a warning if no experiment is run-
          ning.

     collector address_space { on | off }
          Address space data is no longer supported.  The command
          is ignored with a warning.

     collector store filename name
          Accepted as collector store experiment, for compatibil-
          ity.  Sets the output experiment name to name.


FOLLOWING DESCENDANT PROCESSES

     When a process that is collecting performance data creates a
     descendant  process, the collector continues to collect data
     on the parent process, with the following  exception:  If  a
     process calls any variant of exec, the experiment terminates
     abnormally if the exec succeeds, and continues if  the  exec
     fails.   In  either  case, the experiment can be read by the
     performance analysis tools.

     If you want to record data for  a  descendant  process,  you
     should  attach  dbx  to  the  newly created process and then
     start an experiment on the descendant process using  collec-
     tor  enable.   If  you want to automatically collect data on
     all descendant processes, use the collect(1) command.


ATTACHING TO A PROCESS

     You can attach dbx to a process, and use the collector  com-
     mands to collect performance data from it.

     To  collect  data  for  applications  that  install   signal
     handlers    or    use   libcpc.so,   preload   the   library
     libcollector.so before starting the executable. This ensures
     that  the  collector's  wrapper  around the real routines is
     referenced, rather than the routines themselves. To  preload
     the  library,  set  the  value  of  the environment variable
     LD_PRELOAD to libcollector.so  and  set  the  value  of  the
     environment  variable  LD_LIBRARY_PATH to /opt/SUNWspro/lib.
     If using SPARC[tm] V9 64-bit architecture, then also set the
     environment       variable       LD_LIBRARY_PATH_64       to
     /opt/SUNWspro/lib/v9.  If  the  performance  tools  are  not
     installed  in /opt/SUNWspro/lib, ask your system administra-
     tor for the  correct  path.   If  you  are  only  collecting
     clock-based  data or hardware-counter overflow data, you may
     not need to preload the collector  library,  but  preloading
     the  collector  library  ensures that the data collection is
     protected from various problems.

     To avoid having the LD_PRELOAD setting  in  effect  for  all
     other  programs  started  from  the  same  shell, remove the
     LD_PRELOAD setting after the data-collection run.

     After the executable has been started,  determine  its  PID,
     and  attach  dbx  to  it. At that point, you can enable data
     collection.

     If you started the executable from dbx without enabling data
     collection,  you can pause it from dbx at any time, and then
     enable data collection.


SEE ALSO

     analyzer(1), collect(1),  dbx(1),  er_archive(1),  er_cp(1),
     er_export(1),  er_mv(1),  er_print(1),  er_rm(1), libcollec-
     tor(3), and the Performance Analyzer manual.