d35ea2
/*
d35ea2
   This probe will fire when the perl script enters a subroutine.
d35ea2
 */
d35ea2
d35ea2
probe perl.sub.call = process("LIBRARY_PATH").mark("sub__entry")
d35ea2
{
d35ea2
d35ea2
  sub = user_string($arg1)
d35ea2
  filename = user_string($arg2)
d35ea2
  lineno = $arg3
d35ea2
  package = user_string($arg4)
d35ea2
d35ea2
}
d35ea2
d35ea2
/*
d35ea2
   This probe will fire when the return from a subroutine has been
d35ea2
   hit.
d35ea2
 */
d35ea2
d35ea2
probe perl.sub.return = process("LIBRARY_PATH").mark("sub__return")
d35ea2
{
d35ea2
d35ea2
  sub = user_string($arg1)
d35ea2
  filename = user_string($arg2)
d35ea2
  lineno = $arg3
d35ea2
  package = user_string($arg4)
d35ea2
d35ea2
}
d35ea2
d35ea2
/*
d35ea2
   This probe will fire when the Perl interperter changes state.
d35ea2
 */
d35ea2
d35ea2
probe perl.phase.change = process("LIBRARY_PATH").mark("phase__change")
d35ea2
{
d35ea2
  newphase = user_string($arg1)
d35ea2
  oldphase = user_string($arg2)
d35ea2
d35ea2
}
d35ea2
d35ea2
d35ea2
/*
d35ea2
   Fires when Perl has successfully loaded an individual file.
d35ea2
 */
d35ea2
d35ea2
probe perl.loaded.file = process("LIBRARY_PATH").mark("loaded__file")
d35ea2
{
d35ea2
  filename = user_string($arg1)
d35ea2
d35ea2
}
d35ea2
d35ea2
d35ea2
/*
d35ea2
   Fires when Perl is about to load an individual file.
d35ea2
 */
d35ea2
d35ea2
probe perl.loading.file = process("LIBRARY_PATH").mark("loading__file")
d35ea2
{
d35ea2
  filename = user_string($arg1)
d35ea2
d35ea2
}
d35ea2
d35ea2
d35ea2
/*
d35ea2
   Traces the execution of each opcode in the Perl runloop.
d35ea2
 */
d35ea2
d35ea2
probe perl.op.entry = process("LIBRARY_PATH").mark("op__entry")
d35ea2
{
d35ea2
  opname = user_string($arg1)
d35ea2
}