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 j_calltime.d.

This script traces the elapsed time of Java methods and prints a report of the
top ten in each category.   This number is configurable with simple edit of
the DTrace script

Here it traces the example program, Code/Java/Func_abc

# j_calltime.d
Tracing... Hit Ctrl-C to end.
^C

Top 10 counts,
      PID TYPE       NAME                                                COUNT
   311358 method     java/lang/String.equals                               202
   311358 method     java/lang/Math.min                                    208
   311358 method     java/lang/String.hashCode                             213
   311358 method     java/lang/String.indexOf                              302
   311358 method     java/lang/System.arraycopy                            360
   311358 method     java/lang/StringBuilder.append                        533
   311358 method     java/lang/AbstractStringBuilder.append                549
   311358 method     java/lang/Object.<init>                               823
   311358 method     java/lang/String.charAt                              1960
        0 total      -                                                   12020

Top 10 elapsed times (us),
      PID TYPE       NAME                                                TOTAL

Top 10 exclusive method elapsed times (us),
      PID TYPE       NAME                                                TOTAL
   311358 method     java/nio/ByteBuffer.<init>                           5430
   311358 method     java/lang/String.charAt                              6079
   311358 method     java/lang/String.<init>                              7306
   311358 method     java/lang/StringBuilder.append                      10240
   311358 method     java/util/StringTokenizer.scanToken                 11075
   311358 method     java/net/URL.<clinit>                               12519
   311358 method     java/io/UnixFileSystem.normalize                    13218
   311358 method     sun/net/www/ParseUtil.decode                        14208
   311358 method     java/lang/Thread.sleep                            3016374
        0 total      -                                                 3344993

Top 10 inclusive method elapsed times (us),
      PID TYPE       NAME                                                TOTAL
   311358 method     sun/misc/Launcher.<clinit>                         129120
   311358 method     java/lang/ClassLoader.initSystemClassLoader        129851
   311358 method     java/lang/ClassLoader.getSystemClassLoader         129897
   311358 method     java/lang/ClassLoader.loadClass                    267404
   311358 method     java/security/AccessController.doPrivileged        278364
   311358 method     Func_abc.func_c                                   1009971
   311358 method     Func_abc.func_b                                   2019995
   311358 method     java/lang/Thread.sleep                            3016374
   311358 method     Func_abc.func_a                                   3027043
   311358 method     Func_abc.main                                     3027068

Counts shows us how many times each different method was called, and how
many methods were called in total.

The exclusive method elapsed times show the time that each method spent
processing code - while not in other method.

The inclusive method elapsed times show the time that each method spent
processing code, including the time spent in other calls.

These elapsed times are the absolute time from when the method began to
when it completed - which includes off-CPU time due to other system events
such as I/O, scheduling, interrupts, etc.