Jump to content

OProfile: Difference between revisions

From Wikipedia, the free encyclopedia
Content deleted Content added
Medovina (talk | contribs)
m minor English fixes
No edit summary
Line 11: Line 11:
| released = 2001
| released = 2001
| discontinued =
| discontinued =
| latest release version = 0.9.8
| latest release version = 0.9.9
| latest release date = {{Start date and age|2012|8|27}}
| latest release date = {{Start date and age|2013|7|29}}
| latest preview version =
| latest preview version =
| latest preview date = <!-- {{Start date and age|YYYY|MM|DD|df=yes/no}} -->
| latest preview date = <!-- {{Start date and age|YYYY|MM|DD|df=yes/no}} -->

Revision as of 21:13, 6 November 2013

Original author(s)John Levon
Initial release2001
Stable release
0.9.9 / July 29, 2013; 11 years ago (2013-07-29)
Written inC
Operating systemLinux
Platformcross-platform
Typeprofiler
LicenseGPL
Websiteoprofile.sourceforge.net/news/

OProfile is a system-wide statistical profiling tool for Linux. It was written by John Levon in 2001 for Linux kernel version 2.4 after his M.Sc. project,[1] and consists of a kernel module, a user-space daemon and several user-space tools.

OProfile is capable of profiling an entire system or its parts, from interrupt routines or drivers, to user-space processes. It has low overhead.

The most portable mode of oprofile uses a system timer to generate sampling interrupts (events). A less portable mode allows hardware performance counters to be used for sampling events generationed on several processor architectures. In Linux 2.2/2.4 only 32-bit x86 and IA64 are supported; in Linux 2.6 there is wider support: x86 (32 and 64 bit), DEC Alpha, MIPS, ARM, sparc64, ppc64, AVR32.

Call graphs are supported only on x86 and ARM.

In 2012 it was recognized by IBM's engineers as one of two most commonly used performance counter monitor profiling tools on Linux; the other was perf tool.[2]

User-space tools

  • opcontrol is used to start and stop the daemon, which collects profiling data. This data is periodically saved to the /var/lib/oprofile/samples directory.
  • opreport shows basic profiling data. 'opannotate' can produce annotated sources or assembly.
  • opgprof converts from oprofile data into gprof-compatible format.[3]

Example:

 opcontrol ---start ( If there are any issues in starting like --vm-linux just follow the instructions)

 run <example>

 opcontrol --dump

 opreport -l <example> > <outputfile>

 opcontrol --stop (stops collecting the data)

 opcontrol --shutdown (Stops the demon)

 opcontrol --reset (clears the profile data which was stored in the sample file given)

See also

References

  1. ^ Interview: John Levon, 11 Nov 2001 // KernelTrap: "John Levon, the author of OProfile"
  2. ^ A. Zanella, R. Arnold. Evaluate performance for Linux on POWER. Analyze performance using Linux tools, 12 Jun 2012 // IBM DeveloperWorks Technical library
  3. ^ http://oprofile.sourceforge.net/doc/tools-overview.html