From Fedora Project Wiki
 
(18 intermediate revisions by 2 users not shown)
Line 3: Line 3:
Installation of the Eclipse SystemTap plugin will be done through the yum repository. Users can simply type from command-line :  
Installation of the Eclipse SystemTap plugin will be done through the yum repository. Users can simply type from command-line :  


'yum install systemtap-eclipse'
'yum install eclipse-callgraph'
 


== General Usage ==
== General Usage ==
Line 10: Line 9:
All the SystemTap plugins are accessible from the C/C++ perspective, by right clicking on C/C++ source file in the editor view, or by right clicking on the corresponding binary in the package explorer view.
All the SystemTap plugins are accessible from the C/C++ perspective, by right clicking on C/C++ source file in the editor view, or by right clicking on the corresponding binary in the package explorer view.


 
<center>
[[File:Profile-screen.png]]
[[File:Profile-screen.png]]
 
</center>


== Features ==
== Features ==
Line 18: Line 17:
'''Call Graph'''
'''Call Graph'''


Clicking on the 'function callgraph' will render a visual representation of the functions that were called while running the executable.
Renders a visual function trace of the program, tracking selected or all functions.


[[File:Stapgraph_regular_view_scaled.png]]


This feature comes with a few different display options and various other information such as :
* function parent/children relationships
* number of times a function is called
* time spent in an instance of a function
* time spent in all instances of a function


This feature comes with a few different display options and various other information such as the percentage time spent in a function and the number of times a function is called. All of these settings can be changed and accessed through the SystemTap view menu.


<center>[[File:Stapgraph menu.png]]</center>
<center>[[File:Stapgraph menu.png]]</center>


Also, the following types of views are available to see the call hierarchy of the functions belonging to the executable.
The following types of views are available to see the call hierarchy of the functions belonging to the executable.
 
 
<center>
<table>
<tr>
<td>[[File:Radial_view.png]]</td>
<td>[[File:Tree_view.png]]</td>
</tr>
<tr>
<td>[[File:Box_view.png]]</td>
<td>[[File:Aggregate_view.png]]</td>
</tr>
</table>
</center>
 




[[File:Radial_view.png]]
[[File:Tree_view.png]]
[[File:Box_view.png]]
[[File:Aggregate_view.png]]


'''File IO Monitor'''


Clicking on 'File IO Monitor' will prompt the user to specify the location of a file. After this, any read/write calls to that file will be shown with the process that made the read/write call, and the time at which this happened.
'''Linkage To Source Code'''


Since this script can run for as long as is necessary, the user must manually stop the script by clicking on the 'kill script' button in the SystemTap view.
The graph views are linked to their source code -- hold CTRL and double-click any function in a non-aggregate view to be taken to where that function was called. Doing the same for an aggregate node will take you to where that function is defined.


[[File:Fileiomonitor scaled.png]]


''' Function Calls In Chronological Order'''


'''Function Trace'''
Using the "Go To" menu, one can step through functions in chronological order, using the Previous/Next options.


Clicking on 'Function Trace' will render a text-based representation of the series of function calls, and returns that were executed.
<center>[[FILE:Callgraph goto menu.png]]</center>


[[File:Callgraph_text_scaled.png‎]]


''' Open / Save Call Graphs '''


'''Script Launch Wizard'''
Certain large projects might take longer to render, and so users have the ability to save the data collected from having profiled their project. Loading the data file and attempting to render that will take a much shorter time than attempting to go through the full process of profiling a project.


Clicking on the 'Launch Wizard' will help the user in launching custom made SystemTap scripts on any chosen C/C++ executable.
<center>[[FILE:Callgraph_file_menu.png]]</center>

Latest revision as of 23:59, 1 October 2009

Installation

Installation of the Eclipse SystemTap plugin will be done through the yum repository. Users can simply type from command-line :

'yum install eclipse-callgraph'

General Usage

All the SystemTap plugins are accessible from the C/C++ perspective, by right clicking on C/C++ source file in the editor view, or by right clicking on the corresponding binary in the package explorer view.

Features

Call Graph

Renders a visual function trace of the program, tracking selected or all functions.


This feature comes with a few different display options and various other information such as :

  • function parent/children relationships
  • number of times a function is called
  • time spent in an instance of a function
  • time spent in all instances of a function


The following types of views are available to see the call hierarchy of the functions belonging to the executable.



Linkage To Source Code

The graph views are linked to their source code -- hold CTRL and double-click any function in a non-aggregate view to be taken to where that function was called. Doing the same for an aggregate node will take you to where that function is defined.


Function Calls In Chronological Order

Using the "Go To" menu, one can step through functions in chronological order, using the Previous/Next options.


Open / Save Call Graphs

Certain large projects might take longer to render, and so users have the ability to save the data collected from having profiled their project. Loading the data file and attempting to render that will take a much shorter time than attempting to go through the full process of profiling a project.