Analyzing Parallel Programs with Pin

  • Authors:
  • Moshe (Maury) Bach;Mark Charney;Robert Cohn;Elena Demikhovsky;Tevi Devor;Kim Hazelwood;Aamer Jaleel;Chi-Keung Luk;Gail Lyons;Harish Patil;Ady Tal

  • Affiliations:
  • Intel;Intel;Intel;Intel;Intel;Intel;Intel;Intel;Intel;Intel;Intel

  • Venue:
  • Computer
  • Year:
  • 2010

Quantified Score

Hi-index 4.10

Visualization

Abstract

Software instrumentation provides the means to collect information on and efficiently analyze parallel programs. Using Pin, developers can build tools to detect and examine dynamic behavior including data races, memory system behavior, and parallelizable loops. Pin is a software system that performs runtime binary instrumentation of Linux and Microsoft Windows applications. Pin's aim is to provide an instrumentation platform for building a wide variety of program analysis tools, called pintools. By performing the instrumentation on the binary at runtime, Pin eliminates the need to modify or recompile the application's source and supports the instrumentation of programs that dynamically generate code.