Training courses

Kernel and Embedded Linux

Bootlin training courses

Embedded Linux, kernel,
Yocto Project, Buildroot, real-time,
graphics, boot time, debugging...

Bootlin logo

Elixir Cross Referencer

The following are examples of rb_flow.d.

This is a simple script to trace the flow of Ruby functions.
Here it traces the example program, Code/Ruby/func_abc.rb
 
# rb_flow.d
  C TIME(us)         FILE                   -- CLASS::METHOD
  0 3066417516583    func_abc.rb            -> Module::method_added
  0 3066417516640    func_abc.rb            <- Module::method_added
  0 3066417516658    func_abc.rb            -> Module::method_added
  0 3066417516668    func_abc.rb            <- Module::method_added
  0 3066417516680    func_abc.rb            -> Module::method_added
  0 3066417516689    func_abc.rb            <- Module::method_added
  0 3066417516701    func_abc.rb            -> Object::func_a
  0 3066417516711    func_abc.rb              -> Object::print
  0 3066417516730    func_abc.rb                -> IO::write
  0 3066417516832    func_abc.rb                <- IO::write
  0 3066417516841    func_abc.rb              <- Object::print
  0 3066417516849    func_abc.rb              -> Object::sleep
  0 3066418520705    func_abc.rb              <- Object::sleep
  0 3066418520727    func_abc.rb              -> Object::func_b
  0 3066418520744    func_abc.rb                -> Object::print
  0 3066418520753    func_abc.rb                  -> IO::write
  0 3066418520796    func_abc.rb                  <- IO::write
  0 3066418520805    func_abc.rb                <- Object::print
  0 3066418520813    func_abc.rb                -> Object::sleep
  0 3066419530803    func_abc.rb                <- Object::sleep
  0 3066419530825    func_abc.rb                -> Object::func_c
  0 3066419530842    func_abc.rb                  -> Object::print
  0 3066419530852    func_abc.rb                    -> IO::write
  0 3066419530893    func_abc.rb                    <- IO::write
  0 3066419530902    func_abc.rb                  <- Object::print
  0 3066419530910    func_abc.rb                  -> Object::sleep
  0 3066420540804    func_abc.rb                  <- Object::sleep
  0 3066420540822    func_abc.rb                <- Object::func_c
  0 3066420540831    func_abc.rb              <- Object::func_b
  0 3066420540840    func_abc.rb            <- Object::func_a
^C

The fourth column is indented by 2 spaces to show when a new function begins.
This shows which function is calling which - the output above begins by adding
new methods, then showing that func_a began; did some print IO; slept, and 
returned from sleep; and then called func_b.

The TIME(us) column shows time from boot in microseconds.

The FILE column shows the file that was being executed. 

If the output looks illogical, check the CPU "C" column - if it changes,
then the output is probably shuffled. See Notes/ALLsnoop_notes.txt for
details and suggested workarounds.

See Notes/ALLflow_notes.txt for important notes about reading flow outputs.