Perf (Linux) Explained

perf
Programming Language:C
Operating System:Linux kernel
Genre:Performance monitor and testing
License:GNU GPL
Repo:https://github.com/torvalds/linux/tree/master/tools/perf

perf (sometimes called perf_events[1] or perf tools, originally Performance Counters for Linux, PCL)[2] is a performance analyzing tool in Linux, available from Linux kernel version 2.6.31 in 2009.[3] Userspace controlling utility, named perf, is accessed from the command line and provides a number of subcommands; it is capable of statistical profiling of the entire system (both kernel and userland code).

It supports hardware performance counters, tracepoints, software performance counters (e.g. hrtimer), and dynamic probes (for example, kprobes or uprobes). In 2012, two IBM engineers recognized perf (along with OProfile) as one of the two most commonly used performance counter profiling tools on Linux.[4]

Implementation

The interface between the perf utility and the kernel consists of only one syscall and is done via a file descriptor and a mapped memory region.[5] Unlike LTTng or older versions of oprofile, no service daemons are needed, as most functionality is integrated into the kernel. The perf utility dumps raw data from the mapped buffer to disk when the buffer becomes filled up. According to R. Vitillo (LBNL), profiling performed by perf involves a very low overhead.

, architectures that provide support for hardware counters include x86, PowerPC64, UltraSPARC (III and IV), ARM (v5, v6, v7, Cortex-A8 and -A9), Alpha EV56 and SuperH.[6] Usage of Last Branch Records,[7] a branch tracing implementation available in Intel CPUs since Pentium 4, is available as a patch. Since version 3.14 of the Linux kernel mainline, released on March 31, 2014, perf also supports running average power limit (RAPL) for power consumption measurements, which is available as a feature of certain Intel CPUs.[8] [9] [10]

Perf is natively supported in many popular Linux distributions, including Red Hat Enterprise Linux (since its version 6 released in 2010)[11] and Debian in the linux-tools-common package (since Debian 6.0 (Squeeze) released in 2011).[12]

Subcommands

perf is used with several subcommands:

Criticism

The documentation of perf is not very detailed (as of 2014); for example, it does not document most events or explain their aliases (often external tools are used to get names and codes of events[15]). Perf tools also cannot profile based on true wall-clock time.[16]

Security

The perf subsystem of Linux kernels from 2.6.37 up to 3.8.8 and RHEL6 kernel 2.6.32 contained a security vulnerability, which was exploited to gain root privileges by a local user.[17] [18] The problem was due to an incorrect type being used (32-bit int instead of 64-bit) in the event_id verification code path.[19]

See also

External links

Notes and References

  1. Vince Weaver, The Unofficial Linux Perf Events Web-Page
  2. http://web.eece.maine.edu/~vweaver/projects/perf_events/overhead/fastpath2013_perfevent_slides.pdf Linux perf event Features and Overhead
  3. Jake Edge, Perfcounters added to the mainline, LWN July 1, 2009, "perfcounters being included into the mainline during the recently completed 2.6.31 merge window"
  4. A. Zanella, R. Arnold. Evaluate performance for Linux on POWER. Analyze performance using Linux tools, 12 Jun 2012 // IBM DeveloperWorks Technical library
  5. Roberto A. Vitillo (LBNL). PERFORMANCE TOOLS DEVELOPMENTS, 16 June 2011, presentation from "Future computing in particle physics" conference
  6. Arnaldo Carvalho de Melo, The New Linux ’perf’ tools, presentation from Linux Kongress, September, 2010
  7. Book: Intel® 64 and IA-32 Architectures Software Developer's Manual Volume 3B: System Programming Guide, Part 2. June 2009. Intel. 19-2 vol. 3.
  8. Web site: Lots of new perf features . 2014-04-09 . 2014-04-22 . Jake Edge . LWN.net.
  9. Web site: RAPL (Running Average Power Limit) driver . 2013-04-02 . 2014-04-22 . Jacob Pan . LWN.net.
  10. Web site: kernel/git/torvalds/linux.git - Linux kernel source tree . Git.kernel.org . 2014-01-20 . 2014-03-31.
  11. https://access.redhat.com/site/documentation/en-US/Red_Hat_Enterprise_Linux/6/html/Developer_Guide/perf.html 6.4. Performance Counters for Linux (PCL) Tools and perf
  12. Web site: Debian - Details of package linux-tools-2.6.32 in squeeze . Packages.debian.org . 2014-03-31.
  13. Urs Fässlerperf file format, CERN OpenLab, 2011
  14. [Ingo Molnar]
  15. http://www.bnikolic.co.uk/blog/hpc-prof-events.html How to monitor the full range of CPU performance events
  16. Robert Haas (PostgreSQL), perf: the good, the bad, the ugly // June 06, 2012
  17. Web site: New Linux Kernel Vulnerability Exploited. Phoronix. Michael Larabel . 2013-05-15.
  18. Web site: Local root vulnerability in the kernel. LWN. 2013-05-15. corbet.
  19. Web site: A closer look at a recent privilege escalation bug in Linux (CVE-2013-2094). 2013-05-20. Joe Damato.