Home | History | Annotate | Download | only in xml
      1 <?xml version="1.0"?> <!-- -*- sgml -*- -->
      2 <!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.2//EN"
      3   "http://www.oasis-open.org/docbook/xml/4.2/docbookx.dtd"
      4 [ <!ENTITY % vg-entities SYSTEM "vg-entities.xml"> %vg-entities; ]>
      5 
      6 <chapter id="manual-intro" xreflabel="Introduction">
      7 <title>Introduction</title>
      8 
      9 <sect1 id="manual-intro.overview" xreflabel="An Overview of Valgrind">
     10 <title>An Overview of Valgrind</title>
     11 
     12 <para>Valgrind is an instrumentation framework for building dynamic analysis
     13 tools.  It comes with a set of tools each of which performs some kind of
     14 debugging, profiling, or similar task that helps you improve your programs.
     15 Valgrind's architecture is modular, so new tools can be created easily
     16 and without disturbing the existing structure.</para>
     17 
     18 <para>A number of useful tools are supplied as standard.</para>
     19 
     20 <orderedlist>
     21 
     22   <listitem>
     23     <para><command>Memcheck</command> is a memory error detector.  It helps
     24     you make your programs, particularly those written in C and C++, more
     25     correct.</para>
     26   </listitem>
     27  
     28   <listitem>
     29     <para><command>Cachegrind</command> is a cache and branch-prediction
     30     profiler.  It helps you make your programs run faster.</para>
     31   </listitem>
     32 
     33   <listitem>
     34     <para><command>Callgrind</command> is a call-graph generating cache
     35     profiler.  It has some overlap with Cachegrind, but also gathers some
     36     information that Cachegrind does not.</para>
     37   </listitem>
     38 
     39   <listitem>
     40     <para><command>Helgrind</command> is a thread error detector.
     41     It helps you make your multi-threaded programs more correct.
     42     </para>
     43   </listitem>
     44 
     45   <listitem>
     46     <para><command>DRD</command> is also a thread error detector.  It is
     47     similar to Helgrind but uses different analysis techniques and so may
     48     find different problems.</para>
     49   </listitem>
     50 
     51   <listitem>
     52     <para><command>Massif</command> is a heap profiler.  It helps you
     53     make your programs use less memory.</para>
     54   </listitem>
     55 
     56   <listitem>
     57     <para><command>DHAT</command> is a different kind of heap
     58     profiler.  It helps you understand issues of block lifetimes,
     59     block utilisation, and layout inefficiencies.</para>
     60   </listitem>
     61 
     62   <listitem>
     63     <para><command>SGcheck</command> is an experimental tool that can
     64     detect overruns of stack and global arrays.  Its functionality is
     65     complementary to that of Memcheck: SGcheck finds problems that
     66     Memcheck can't, and vice versa..</para>
     67   </listitem>
     68 
     69   <listitem>
     70     <para><command>BBV</command> is an experimental SimPoint basic block
     71     vector generator.  It is useful to people doing computer architecture
     72     research and development.</para>
     73   </listitem>
     74 
     75 </orderedlist>
     76   
     77 <para>There are also a couple of minor tools that aren't useful to
     78 most users:  <command>Lackey</command> is an example tool that illustrates
     79 some instrumentation basics; and <command>Nulgrind</command> is the minimal
     80 Valgrind tool that does no analysis or instrumentation, and is only useful
     81 for testing purposes.</para>
     82 
     83 <para>Valgrind is closely tied to details of the CPU and operating
     84 system, and to a lesser extent, the compiler and basic C libraries.
     85 Nonetheless, it supports a number of widely-used platforms, listed in full
     86 at <ulink url="&vg-url;">&vg-url;</ulink>.</para>
     87 
     88 <para>Valgrind is built via the standard Unix
     89 <computeroutput>./configure</computeroutput>,
     90 <computeroutput>make</computeroutput>, <computeroutput>make
     91 install</computeroutput> process;  full details are given in the
     92 README file in the distribution.</para>
     93 
     94 <para>Valgrind is licensed under the <xref linkend="license.gpl"/>,
     95 version 2.  The <computeroutput>valgrind/*.h</computeroutput> headers
     96 that you may wish to include in your code (eg.
     97 <filename>valgrind.h</filename>, <filename>memcheck.h</filename>,
     98 <filename>helgrind.h</filename>, etc.) are
     99 distributed under a BSD-style license, so you may include them in your
    100 code without worrying about license conflicts.  Some of the PThreads
    101 test cases, <filename>pth_*.c</filename>, are taken from "Pthreads
    102 Programming" by Bradford Nichols, Dick Buttlar &amp; Jacqueline Proulx
    103 Farrell, ISBN 1-56592-115-1, published by O'Reilly &amp; Associates,
    104 Inc.</para>
    105 
    106 <para>If you contribute code to Valgrind, please ensure your
    107 contributions are licensed as "GPLv2, or (at your option) any later
    108 version."  This is so as to allow the possibility of easily upgrading
    109 the license to GPLv3 in future.  If you want to modify code in the VEX
    110 subdirectory, please also see the file VEX/HACKING.README in the
    111 distribution.</para>
    112 
    113 
    114 </sect1>
    115 
    116 
    117 <sect1 id="manual-intro.navigation" xreflabel="How to navigate this manual">
    118 <title>How to navigate this manual</title>
    119 
    120 <para>This manual's structure reflects the structure of Valgrind itself.
    121 First, we describe the Valgrind core, how to use it, and the options
    122 it supports.  Then, each tool has its own chapter in this manual.  You
    123 only need to read the documentation for the core and for the tool(s) you
    124 actually use, although you may find it helpful to be at least a little
    125 bit familiar with what all tools do.  If you're new to all this, you probably
    126 want to run the Memcheck tool and you might find the <xref
    127 linkend="quick-start"/> useful.</para>
    128 
    129 <para>Be aware that the core understands some command line options, and
    130 the tools have their own options which they know about.  This means
    131 there is no central place describing all the options that are
    132 accepted -- you have to read the options documentation both for
    133 <xref linkend="manual-core"/> and for the tool you want to use.</para>
    134 
    135 
    136 </sect1>
    137 
    138 </chapter>
    139