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 7<chapter id="manual-core" xreflabel="Valgrind's core"> 8<title>Using and understanding the Valgrind core</title> 9 10<para>This chapter describes the Valgrind core services, command-line 11options and behaviours. That means it is relevant regardless of what 12particular tool you are using. The information should be sufficient for you 13to make effective day-to-day use of Valgrind. Advanced topics related to 14the Valgrind core are described in <xref linkend="manual-core-adv"/>. 15</para> 16 17<para> 18A point of terminology: most references to "Valgrind" in this chapter 19refer to the Valgrind core services. </para> 20 21 22 23<sect1 id="manual-core.whatdoes" 24 xreflabel="What Valgrind does with your program"> 25<title>What Valgrind does with your program</title> 26 27<para>Valgrind is designed to be as non-intrusive as possible. It works 28directly with existing executables. You don't need to recompile, relink, 29or otherwise modify the program to be checked.</para> 30 31<para>You invoke Valgrind like this:</para> 32<programlisting><![CDATA[ 33valgrind [valgrind-options] your-prog [your-prog-options]]]></programlisting> 34 35<para>The most important option is <option>--tool</option> which dictates 36which Valgrind tool to run. For example, if want to run the command 37<computeroutput>ls -l</computeroutput> using the memory-checking tool 38Memcheck, issue this command:</para> 39 40<programlisting><![CDATA[ 41valgrind --tool=memcheck ls -l]]></programlisting> 42 43<para>However, Memcheck is the default, so if you want to use it you can 44omit the <option>--tool</option> option.</para> 45 46<para>Regardless of which tool is in use, Valgrind takes control of your 47program before it starts. Debugging information is read from the 48executable and associated libraries, so that error messages and other 49outputs can be phrased in terms of source code locations, when 50appropriate.</para> 51 52<para>Your program is then run on a synthetic CPU provided by the 53Valgrind core. As new code is executed for the first time, the core 54hands the code to the selected tool. The tool adds its own 55instrumentation code to this and hands the result back to the core, 56which coordinates the continued execution of this instrumented 57code.</para> 58 59<para>The amount of instrumentation code added varies widely between 60tools. At one end of the scale, Memcheck adds code to check every 61memory access and every value computed, 62making it run 10-50 times slower than natively. 63At the other end of the spectrum, the minimal tool, called Nulgrind, 64adds no instrumentation at all and causes in total "only" about a 4 times 65slowdown.</para> 66 67<para>Valgrind simulates every single instruction your program executes. 68Because of this, the active tool checks, or profiles, not only the code 69in your application but also in all supporting dynamically-linked libraries, 70including the C library, graphical libraries, and so on.</para> 71 72<para>If you're using an error-detection tool, Valgrind may 73detect errors in system libraries, for example the GNU C or X11 74libraries, which you have to use. You might not be interested in these 75errors, since you probably have no control over that code. Therefore, 76Valgrind allows you to selectively suppress errors, by recording them in 77a suppressions file which is read when Valgrind starts up. The build 78mechanism selects default suppressions which give reasonable 79behaviour for the OS and libraries detected on your machine. 80To make it easier to write suppressions, you can use the 81<option>--gen-suppressions=yes</option> option. This tells Valgrind to 82print out a suppression for each reported error, which you can then 83copy into a suppressions file.</para> 84 85<para>Different error-checking tools report different kinds of errors. 86The suppression mechanism therefore allows you to say which tool or 87tool(s) each suppression applies to.</para> 88 89</sect1> 90 91 92<sect1 id="manual-core.started" xreflabel="Getting started"> 93<title>Getting started</title> 94 95<para>First off, consider whether it might be beneficial to recompile 96your application and supporting libraries with debugging info enabled 97(the <option>-g</option> option). Without debugging info, the best 98Valgrind tools will be able to do is guess which function a particular 99piece of code belongs to, which makes both error messages and profiling 100output nearly useless. With <option>-g</option>, you'll get 101messages which point directly to the relevant source code lines.</para> 102 103<para>Another option you might like to consider, if you are working with 104C++, is <option>-fno-inline</option>. That makes it easier to see the 105function-call chain, which can help reduce confusion when navigating 106around large C++ apps. For example, debugging 107OpenOffice.org with Memcheck is a bit easier when using this option. You 108don't have to do this, but doing so helps Valgrind produce more accurate 109and less confusing error reports. Chances are you're set up like this 110already, if you intended to debug your program with GNU GDB, or some 111other debugger. Alternatively, the Valgrind option 112<option>--read-inline-info=yes</option> instructs Valgrind to read 113the debug information describing inlining information. With this, 114function call chain will be properly shown, even when your application 115is compiled with inlining. </para> 116 117<para>If you are planning to use Memcheck: On rare 118occasions, compiler optimisations (at <option>-O2</option> 119and above, and sometimes <option>-O1</option>) have been 120observed to generate code which fools Memcheck into wrongly reporting 121uninitialised value errors, or missing uninitialised value errors. We have 122looked in detail into fixing this, and unfortunately the result is that 123doing so would give a further significant slowdown in what is already a slow 124tool. So the best solution is to turn off optimisation altogether. Since 125this often makes things unmanageably slow, a reasonable compromise is to use 126<option>-O</option>. This gets you the majority of the 127benefits of higher optimisation levels whilst keeping relatively small the 128chances of false positives or false negatives from Memcheck. Also, you 129should compile your code with <option>-Wall</option> because 130it can identify some or all of the problems that Valgrind can miss at the 131higher optimisation levels. (Using <option>-Wall</option> 132is also a good idea in general.) All other tools (as far as we know) are 133unaffected by optimisation level, and for profiling tools like Cachegrind it 134is better to compile your program at its normal optimisation level.</para> 135 136<para>Valgrind understands the DWARF2/3/4 formats used by GCC 3.1 and 137later. The reader for "stabs" debugging format (used by GCC versions 138prior to 3.1) has been disabled in Valgrind 3.9.0.</para> 139 140<para>When you're ready to roll, run Valgrind as described above. 141Note that you should run the real 142(machine-code) executable here. If your application is started by, for 143example, a shell or Perl script, you'll need to modify it to invoke 144Valgrind on the real executables. Running such scripts directly under 145Valgrind will result in you getting error reports pertaining to 146<filename>/bin/sh</filename>, 147<filename>/usr/bin/perl</filename>, or whatever interpreter 148you're using. This may not be what you want and can be confusing. You 149can force the issue by giving the option 150<option>--trace-children=yes</option>, but confusion is still 151likely.</para> 152 153</sect1> 154 155 156<!-- Referenced from both the manual and manpage --> 157<sect1 id="&vg-comment-id;" xreflabel="&vg-comment-label;"> 158<title>The Commentary</title> 159 160<para>Valgrind tools write a commentary, a stream of text, detailing 161error reports and other significant events. All lines in the commentary 162have following form: 163 164<programlisting><![CDATA[ 165==12345== some-message-from-Valgrind]]></programlisting> 166</para> 167 168<para>The <computeroutput>12345</computeroutput> is the process ID. 169This scheme makes it easy to distinguish program output from Valgrind 170commentary, and also easy to differentiate commentaries from different 171processes which have become merged together, for whatever reason.</para> 172 173<para>By default, Valgrind tools write only essential messages to the 174commentary, so as to avoid flooding you with information of secondary 175importance. If you want more information about what is happening, 176re-run, passing the <option>-v</option> option to Valgrind. A second 177<option>-v</option> gives yet more detail. 178</para> 179 180<para>You can direct the commentary to three different places:</para> 181 182<orderedlist> 183 184 <listitem id="manual-core.out2fd" xreflabel="Directing output to fd"> 185 <para>The default: send it to a file descriptor, which is by default 186 2 (stderr). So, if you give the core no options, it will write 187 commentary to the standard error stream. If you want to send it to 188 some other file descriptor, for example number 9, you can specify 189 <option>--log-fd=9</option>.</para> 190 191 <para>This is the simplest and most common arrangement, but can 192 cause problems when Valgrinding entire trees of processes which 193 expect specific file descriptors, particularly stdin/stdout/stderr, 194 to be available for their own use.</para> 195 </listitem> 196 197 <listitem id="manual-core.out2file" 198 xreflabel="Directing output to file"> <para>A less intrusive 199 option is to write the commentary to a file, which you specify by 200 <option>--log-file=filename</option>. There are special format 201 specifiers that can be used to use a process ID or an environment 202 variable name in the log file name. These are useful/necessary if your 203 program invokes multiple processes (especially for MPI programs). 204 See the <link linkend="manual-core.basicopts">basic options section</link> 205 for more details.</para> 206 </listitem> 207 208 <listitem id="manual-core.out2socket" 209 xreflabel="Directing output to network socket"> <para>The 210 least intrusive option is to send the commentary to a network 211 socket. The socket is specified as an IP address and port number 212 pair, like this: <option>--log-socket=192.168.0.1:12345</option> if 213 you want to send the output to host IP 192.168.0.1 port 12345 214 (note: we 215 have no idea if 12345 is a port of pre-existing significance). You 216 can also omit the port number: 217 <option>--log-socket=192.168.0.1</option>, in which case a default 218 port of 1500 is used. This default is defined by the constant 219 <computeroutput>VG_CLO_DEFAULT_LOGPORT</computeroutput> in the 220 sources.</para> 221 222 <para>Note, unfortunately, that you have to use an IP address here, 223 rather than a hostname.</para> 224 225 <para>Writing to a network socket is pointless if you don't 226 have something listening at the other end. We provide a simple 227 listener program, 228 <computeroutput>valgrind-listener</computeroutput>, which accepts 229 connections on the specified port and copies whatever it is sent to 230 stdout. Probably someone will tell us this is a horrible security 231 risk. It seems likely that people will write more sophisticated 232 listeners in the fullness of time.</para> 233 234 <para><computeroutput>valgrind-listener</computeroutput> can accept 235 simultaneous connections from up to 50 Valgrinded processes. In front 236 of each line of output it prints the current number of active 237 connections in round brackets.</para> 238 239 <para><computeroutput>valgrind-listener</computeroutput> accepts three 240 command-line options:</para> 241 <!-- start of xi:include in the manpage --> 242 <variablelist id="listener.opts.list"> 243 <varlistentry> 244 <term><option>-e --exit-at-zero</option></term> 245 <listitem> 246 <para>When the number of connected processes falls back to zero, 247 exit. Without this, it will run forever, that is, until you 248 send it Control-C.</para> 249 </listitem> 250 </varlistentry> 251 <varlistentry> 252 <term><option>--max-connect=INTEGER</option></term> 253 <listitem> 254 <para>By default, the listener can connect to up to 50 processes. 255 Occasionally, that number is too small. Use this option to 256 provide a different limit. E.g. 257 <computeroutput>--max-connect=100</computeroutput>. 258 </para> 259 </listitem> 260 </varlistentry> 261 <varlistentry> 262 <term><option>portnumber</option></term> 263 <listitem> 264 <para>Changes the port it listens on from the default (1500). 265 The specified port must be in the range 1024 to 65535. 266 The same restriction applies to port numbers specified by a 267 <option>--log-socket</option> to Valgrind itself.</para> 268 </listitem> 269 </varlistentry> 270 </variablelist> 271 <!-- end of xi:include in the manpage --> 272 273 <para>If a Valgrinded process fails to connect to a listener, for 274 whatever reason (the listener isn't running, invalid or unreachable 275 host or port, etc), Valgrind switches back to writing the commentary 276 to stderr. The same goes for any process which loses an established 277 connection to a listener. In other words, killing the listener 278 doesn't kill the processes sending data to it.</para> 279 </listitem> 280 281</orderedlist> 282 283<para>Here is an important point about the relationship between the 284commentary and profiling output from tools. The commentary contains a 285mix of messages from the Valgrind core and the selected tool. If the 286tool reports errors, it will report them to the commentary. However, if 287the tool does profiling, the profile data will be written to a file of 288some kind, depending on the tool, and independent of what 289<option>--log-*</option> options are in force. The commentary is 290intended to be a low-bandwidth, human-readable channel. Profiling data, 291on the other hand, is usually voluminous and not meaningful without 292further processing, which is why we have chosen this arrangement.</para> 293 294</sect1> 295 296 297<sect1 id="manual-core.report" xreflabel="Reporting of errors"> 298<title>Reporting of errors</title> 299 300<para>When an error-checking tool 301detects something bad happening in the program, an error 302message is written to the commentary. Here's an example from Memcheck:</para> 303 304<programlisting><![CDATA[ 305==25832== Invalid read of size 4 306==25832== at 0x8048724: BandMatrix::ReSize(int, int, int) (bogon.cpp:45) 307==25832== by 0x80487AF: main (bogon.cpp:66) 308==25832== Address 0xBFFFF74C is not stack'd, malloc'd or free'd]]></programlisting> 309 310<para>This message says that the program did an illegal 4-byte read of 311address 0xBFFFF74C, which, as far as Memcheck can tell, is not a valid 312stack address, nor corresponds to any current heap blocks or recently freed 313heap blocks. The read is happening at line 45 of 314<filename>bogon.cpp</filename>, called from line 66 of the same file, 315etc. For errors associated with an identified (current or freed) heap block, 316for example reading freed memory, Valgrind reports not only the 317location where the error happened, but also where the associated heap block 318was allocated/freed.</para> 319 320<para>Valgrind remembers all error reports. When an error is detected, 321it is compared against old reports, to see if it is a duplicate. If so, 322the error is noted, but no further commentary is emitted. This avoids 323you being swamped with bazillions of duplicate error reports.</para> 324 325<para>If you want to know how many times each error occurred, run with 326the <option>-v</option> option. When execution finishes, all the 327reports are printed out, along with, and sorted by, their occurrence 328counts. This makes it easy to see which errors have occurred most 329frequently.</para> 330 331<para>Errors are reported before the associated operation actually 332happens. For example, if you're using Memcheck and your program attempts to 333read from address zero, Memcheck will emit a message to this effect, and 334your program will then likely die with a segmentation fault.</para> 335 336<para>In general, you should try and fix errors in the order that they 337are reported. Not doing so can be confusing. For example, a program 338which copies uninitialised values to several memory locations, and later 339uses them, will generate several error messages, when run on Memcheck. 340The first such error message may well give the most direct clue to the 341root cause of the problem.</para> 342 343<para>The process of detecting duplicate errors is quite an 344expensive one and can become a significant performance overhead 345if your program generates huge quantities of errors. To avoid 346serious problems, Valgrind will simply stop collecting 347errors after 1,000 different errors have been seen, or 10,000,000 errors 348in total have been seen. In this situation you might as well 349stop your program and fix it, because Valgrind won't tell you 350anything else useful after this. Note that the 1,000/10,000,000 limits 351apply after suppressed errors are removed. These limits are 352defined in <filename>m_errormgr.c</filename> and can be increased 353if necessary.</para> 354 355<para>To avoid this cutoff you can use the 356<option>--error-limit=no</option> option. Then Valgrind will always show 357errors, regardless of how many there are. Use this option carefully, 358since it may have a bad effect on performance.</para> 359 360</sect1> 361 362 363<sect1 id="manual-core.suppress" xreflabel="Suppressing errors"> 364<title>Suppressing errors</title> 365 366<para>The error-checking tools detect numerous problems in the system 367libraries, such as the C library, 368which come pre-installed with your OS. You can't easily fix 369these, but you don't want to see these errors (and yes, there are many!) 370So Valgrind reads a list of errors to suppress at startup. A default 371suppression file is created by the 372<computeroutput>./configure</computeroutput> script when the system is 373built.</para> 374 375<para>You can modify and add to the suppressions file at your leisure, 376or, better, write your own. Multiple suppression files are allowed. 377This is useful if part of your project contains errors you can't or 378don't want to fix, yet you don't want to continuously be reminded of 379them.</para> 380 381<formalpara><title>Note:</title> <para>By far the easiest way to add 382suppressions is to use the <option>--gen-suppressions=yes</option> option 383described in <xref linkend="manual-core.options"/>. This generates 384suppressions automatically. For best results, 385though, you may want to edit the output 386 of <option>--gen-suppressions=yes</option> by hand, in which 387case it would be advisable to read through this section. 388</para> 389</formalpara> 390 391<para>Each error to be suppressed is described very specifically, to 392minimise the possibility that a suppression-directive inadvertently 393suppresses a bunch of similar errors which you did want to see. The 394suppression mechanism is designed to allow precise yet flexible 395specification of errors to suppress.</para> 396 397<para>If you use the <option>-v</option> option, at the end of execution, 398Valgrind prints out one line for each used suppression, giving the number of times 399it got used, its name and the filename and line number where the suppression is 400defined. Depending on the suppression kind, the filename and line number are optionally 401followed by additional information (such as the number of blocks and bytes suppressed 402by a memcheck leak suppression). Here's the suppressions used by a 403run of <computeroutput>valgrind -v --tool=memcheck ls -l</computeroutput>:</para> 404 405<programlisting><![CDATA[ 406--1610-- used_suppression: 2 dl-hack3-cond-1 /usr/lib/valgrind/default.supp:1234 407--1610-- used_suppression: 2 glibc-2.5.x-on-SUSE-10.2-(PPC)-2a /usr/lib/valgrind/default.supp:1234 408]]></programlisting> 409 410<para>Multiple suppressions files are allowed. Valgrind loads suppression 411patterns from <filename>$PREFIX/lib/valgrind/default.supp</filename> unless 412<option>--default-suppressions=no</option> has been specified. You can 413ask to add suppressions from additional files by specifying 414<option>--suppressions=/path/to/file.supp</option> one or more times. 415</para> 416 417<para>If you want to understand more about suppressions, look at an 418existing suppressions file whilst reading the following documentation. 419The file <filename>glibc-2.3.supp</filename>, in the source 420distribution, provides some good examples.</para> 421 422<para>Each suppression has the following components:</para> 423 424<itemizedlist> 425 426 <listitem> 427 <para>First line: its name. This merely gives a handy name to the 428 suppression, by which it is referred to in the summary of used 429 suppressions printed out when a program finishes. It's not 430 important what the name is; any identifying string will do.</para> 431 </listitem> 432 433 <listitem> 434 <para>Second line: name of the tool(s) that the suppression is for 435 (if more than one, comma-separated), and the name of the suppression 436 itself, separated by a colon (n.b.: no spaces are allowed), eg:</para> 437<programlisting><![CDATA[ 438tool_name1,tool_name2:suppression_name]]></programlisting> 439 440 <para>Recall that Valgrind is a modular system, in which 441 different instrumentation tools can observe your program whilst it 442 is running. Since different tools detect different kinds of errors, 443 it is necessary to say which tool(s) the suppression is meaningful 444 to.</para> 445 446 <para>Tools will complain, at startup, if a tool does not understand 447 any suppression directed to it. Tools ignore suppressions which are 448 not directed to them. As a result, it is quite practical to put 449 suppressions for all tools into the same suppression file.</para> 450 </listitem> 451 452 <listitem> 453 <para>Next line: a small number of suppression types have extra 454 information after the second line (eg. the <varname>Param</varname> 455 suppression for Memcheck)</para> 456 </listitem> 457 458 <listitem> 459 <para>Remaining lines: This is the calling context for the error -- 460 the chain of function calls that led to it. There can be up to 24 461 of these lines.</para> 462 463 <para>Locations may be names of either shared objects or 464 functions. They begin 465 <computeroutput>obj:</computeroutput> and 466 <computeroutput>fun:</computeroutput> respectively. Function and 467 object names to match against may use the wildcard characters 468 <computeroutput>*</computeroutput> and 469 <computeroutput>?</computeroutput>.</para> 470 471 <para><command>Important note: </command> C++ function names must be 472 <command>mangled</command>. If you are writing suppressions by 473 hand, use the <option>--demangle=no</option> option to get the 474 mangled names in your error messages. An example of a mangled 475 C++ name is <computeroutput>_ZN9QListView4showEv</computeroutput>. 476 This is the form that the GNU C++ compiler uses internally, and 477 the form that must be used in suppression files. The equivalent 478 demangled name, <computeroutput>QListView::show()</computeroutput>, 479 is what you see at the C++ source code level. 480 </para> 481 482 <para>A location line may also be 483 simply "<computeroutput>...</computeroutput>" (three dots). This is 484 a frame-level wildcard, which matches zero or more frames. Frame 485 level wildcards are useful because they make it easy to ignore 486 varying numbers of uninteresting frames in between frames of 487 interest. That is often important when writing suppressions which 488 are intended to be robust against variations in the amount of 489 function inlining done by compilers.</para> 490 </listitem> 491 492 <listitem> 493 <para>Finally, the entire suppression must be between curly 494 braces. Each brace must be the first character on its own 495 line.</para> 496 </listitem> 497 498 </itemizedlist> 499 500<para>A suppression only suppresses an error when the error matches all 501the details in the suppression. Here's an example:</para> 502 503<programlisting><![CDATA[ 504{ 505 __gconv_transform_ascii_internal/__mbrtowc/mbtowc 506 Memcheck:Value4 507 fun:__gconv_transform_ascii_internal 508 fun:__mbr*toc 509 fun:mbtowc 510}]]></programlisting> 511 512 513<para>What it means is: for Memcheck only, suppress a 514use-of-uninitialised-value error, when the data size is 4, when it 515occurs in the function 516<computeroutput>__gconv_transform_ascii_internal</computeroutput>, when 517that is called from any function of name matching 518<computeroutput>__mbr*toc</computeroutput>, when that is called from 519<computeroutput>mbtowc</computeroutput>. It doesn't apply under any 520other circumstances. The string by which this suppression is identified 521to the user is 522<computeroutput>__gconv_transform_ascii_internal/__mbrtowc/mbtowc</computeroutput>.</para> 523 524<para>(See <xref linkend="mc-manual.suppfiles"/> for more details 525on the specifics of Memcheck's suppression kinds.)</para> 526 527<para>Another example, again for the Memcheck tool:</para> 528 529<programlisting><![CDATA[ 530{ 531 libX11.so.6.2/libX11.so.6.2/libXaw.so.7.0 532 Memcheck:Value4 533 obj:/usr/X11R6/lib/libX11.so.6.2 534 obj:/usr/X11R6/lib/libX11.so.6.2 535 obj:/usr/X11R6/lib/libXaw.so.7.0 536}]]></programlisting> 537 538<para>This suppresses any size 4 uninitialised-value error which occurs 539anywhere in <filename>libX11.so.6.2</filename>, when called from 540anywhere in the same library, when called from anywhere in 541<filename>libXaw.so.7.0</filename>. The inexact specification of 542locations is regrettable, but is about all you can hope for, given that 543the X11 libraries shipped on the Linux distro on which this example 544was made have had their symbol tables removed.</para> 545 546<para>Although the above two examples do not make this clear, you can 547freely mix <computeroutput>obj:</computeroutput> and 548<computeroutput>fun:</computeroutput> lines in a suppression.</para> 549 550<para>Finally, here's an example using three frame-level wildcards:</para> 551 552<programlisting><![CDATA[ 553{ 554 a-contrived-example 555 Memcheck:Leak 556 fun:malloc 557 ... 558 fun:ddd 559 ... 560 fun:ccc 561 ... 562 fun:main 563} 564]]></programlisting> 565This suppresses Memcheck memory-leak errors, in the case where 566the allocation was done by <computeroutput>main</computeroutput> 567calling (though any number of intermediaries, including zero) 568<computeroutput>ccc</computeroutput>, 569calling onwards via 570<computeroutput>ddd</computeroutput> and eventually 571to <computeroutput>malloc.</computeroutput>. 572</sect1> 573 574 575<sect1 id="manual-core.options" 576 xreflabel="Core Command-line Options"> 577<title>Core Command-line Options</title> 578 579<para>As mentioned above, Valgrind's core accepts a common set of options. 580The tools also accept tool-specific options, which are documented 581separately for each tool.</para> 582 583<para>Valgrind's default settings succeed in giving reasonable behaviour 584in most cases. We group the available options by rough categories.</para> 585 586<sect2 id="manual-core.toolopts" xreflabel="Tool-selection Option"> 587<title>Tool-selection Option</title> 588 589<para id="tool.opts.para">The single most important option.</para> 590 591<variablelist id="tool.opts.list"> 592 593 <varlistentry id="tool_name" xreflabel="--tool"> 594 <term> 595 <option><![CDATA[--tool=<toolname> [default: memcheck] ]]></option> 596 </term> 597 <listitem> 598 <para>Run the Valgrind tool called <varname>toolname</varname>, 599 e.g. memcheck, cachegrind, callgrind, helgrind, drd, massif, 600 lackey, none, exp-sgcheck, exp-bbv, exp-dhat, etc.</para> 601 </listitem> 602 </varlistentry> 603 604</variablelist> 605 606</sect2> 607 608 609 610<sect2 id="manual-core.basicopts" xreflabel="Basic Options"> 611<title>Basic Options</title> 612 613<!-- start of xi:include in the manpage --> 614<para id="basic.opts.para">These options work with all tools.</para> 615 616<variablelist id="basic.opts.list"> 617 618 <varlistentry id="opt.help" xreflabel="--help"> 619 <term><option>-h --help</option></term> 620 <listitem> 621 <para>Show help for all options, both for the core and for the 622 selected tool. If the option is repeated it is equivalent to giving 623 <option>--help-debug</option>.</para> 624 </listitem> 625 </varlistentry> 626 627 <varlistentry id="opt.help-debug" xreflabel="--help-debug"> 628 <term><option>--help-debug</option></term> 629 <listitem> 630 <para>Same as <option>--help</option>, but also lists debugging 631 options which usually are only of use to Valgrind's 632 developers.</para> 633 </listitem> 634 </varlistentry> 635 636 <varlistentry id="opt.version" xreflabel="--version"> 637 <term><option>--version</option></term> 638 <listitem> 639 <para>Show the version number of the Valgrind core. Tools can have 640 their own version numbers. There is a scheme in place to ensure 641 that tools only execute when the core version is one they are 642 known to work with. This was done to minimise the chances of 643 strange problems arising from tool-vs-core version 644 incompatibilities.</para> 645 </listitem> 646 </varlistentry> 647 648 <varlistentry id="opt.quiet" xreflabel="--quiet"> 649 <term><option>-q</option>, <option>--quiet</option></term> 650 <listitem> 651 <para>Run silently, and only print error messages. Useful if you 652 are running regression tests or have some other automated test 653 machinery.</para> 654 </listitem> 655 </varlistentry> 656 657 <varlistentry id="opt.verbose" xreflabel="--verbose"> 658 <term><option>-v</option>, <option>--verbose</option></term> 659 <listitem> 660 <para>Be more verbose. Gives extra information on various aspects 661 of your program, such as: the shared objects loaded, the 662 suppressions used, the progress of the instrumentation and 663 execution engines, and warnings about unusual behaviour. Repeating 664 the option increases the verbosity level.</para> 665 </listitem> 666 </varlistentry> 667 668 <varlistentry id="opt.trace-children" xreflabel="--trace-children"> 669 <term> 670 <option><![CDATA[--trace-children=<yes|no> [default: no] ]]></option> 671 </term> 672 <listitem> 673 <para>When enabled, Valgrind will trace into sub-processes 674 initiated via the <varname>exec</varname> system call. This is 675 necessary for multi-process programs. 676 </para> 677 <para>Note that Valgrind does trace into the child of a 678 <varname>fork</varname> (it would be difficult not to, since 679 <varname>fork</varname> makes an identical copy of a process), so this 680 option is arguably badly named. However, most children of 681 <varname>fork</varname> calls immediately call <varname>exec</varname> 682 anyway. 683 </para> 684 </listitem> 685 </varlistentry> 686 687 <varlistentry id="opt.trace-children-skip" xreflabel="--trace-children-skip"> 688 <term> 689 <option><![CDATA[--trace-children-skip=patt1,patt2,... ]]></option> 690 </term> 691 <listitem> 692 <para>This option only has an effect when 693 <option>--trace-children=yes</option> is specified. It allows 694 for some children to be skipped. The option takes a comma 695 separated list of patterns for the names of child executables 696 that Valgrind should not trace into. Patterns may include the 697 metacharacters <computeroutput>?</computeroutput> 698 and <computeroutput>*</computeroutput>, which have the usual 699 meaning.</para> 700 <para> 701 This can be useful for pruning uninteresting branches from a 702 tree of processes being run on Valgrind. But you should be 703 careful when using it. When Valgrind skips tracing into an 704 executable, it doesn't just skip tracing that executable, it 705 also skips tracing any of that executable's child processes. 706 In other words, the flag doesn't merely cause tracing to stop 707 at the specified executables -- it skips tracing of entire 708 process subtrees rooted at any of the specified 709 executables.</para> 710 </listitem> 711 </varlistentry> 712 713 <varlistentry id="opt.trace-children-skip-by-arg" 714 xreflabel="--trace-children-skip-by-arg"> 715 <term> 716 <option><![CDATA[--trace-children-skip-by-arg=patt1,patt2,... ]]></option> 717 </term> 718 <listitem> 719 <para>This is the same as 720 <option>--trace-children-skip</option>, with one difference: 721 the decision as to whether to trace into a child process is 722 made by examining the arguments to the child process, rather 723 than the name of its executable.</para> 724 </listitem> 725 </varlistentry> 726 727 <varlistentry id="opt.child-silent-after-fork" 728 xreflabel="--child-silent-after-fork"> 729 <term> 730 <option><![CDATA[--child-silent-after-fork=<yes|no> [default: no] ]]></option> 731 </term> 732 <listitem> 733 <para>When enabled, Valgrind will not show any debugging or 734 logging output for the child process resulting from 735 a <varname>fork</varname> call. This can make the output less 736 confusing (although more misleading) when dealing with processes 737 that create children. It is particularly useful in conjunction 738 with <varname>--trace-children=</varname>. Use of this option is also 739 strongly recommended if you are requesting XML output 740 (<varname>--xml=yes</varname>), since otherwise the XML from child and 741 parent may become mixed up, which usually makes it useless. 742 </para> 743 </listitem> 744 </varlistentry> 745 746 <varlistentry id="opt.vgdb" xreflabel="--vgdb"> 747 <term> 748 <option><![CDATA[--vgdb=<no|yes|full> [default: yes] ]]></option> 749 </term> 750 <listitem> 751 752 <para>Valgrind will provide "gdbserver" functionality when 753 <option>--vgdb=yes</option> or <option>--vgdb=full</option> is 754 specified. This allows an external GNU GDB debugger to control 755 and debug your program when it runs on Valgrind. 756 <option>--vgdb=full</option> incurs significant performance 757 overheads, but provides more precise breakpoints and 758 watchpoints. See <xref linkend="manual-core-adv.gdbserver"/> for 759 a detailed description. 760 </para> 761 762 <para> If the embedded gdbserver is enabled but no gdb is 763 currently being used, the <xref linkend="manual-core-adv.vgdb"/> 764 command line utility can send "monitor commands" to Valgrind 765 from a shell. The Valgrind core provides a set of 766 <xref linkend="manual-core-adv.valgrind-monitor-commands"/>. A tool 767 can optionally provide tool specific monitor commands, which are 768 documented in the tool specific chapter. 769 </para> 770 771 </listitem> 772 </varlistentry> 773 774 <varlistentry id="opt.vgdb-error" xreflabel="--vgdb-error"> 775 <term> 776 <option><![CDATA[--vgdb-error=<number> [default: 999999999] ]]></option> 777 </term> 778 <listitem> 779 <para> Use this option when the Valgrind gdbserver is enabled with 780 <option>--vgdb=yes</option> or <option>--vgdb=full</option>. 781 Tools that report errors will wait 782 for "<computeroutput>number</computeroutput>" errors to be 783 reported before freezing the program and waiting for you to 784 connect with GDB. It follows that a value of zero will cause 785 the gdbserver to be started before your program is executed. 786 This is typically used to insert GDB breakpoints before 787 execution, and also works with tools that do not report 788 errors, such as Massif. 789 </para> 790 </listitem> 791 </varlistentry> 792 793 <varlistentry id="opt.vgdb-stop-at" xreflabel="--vgdb-stop-at"> 794 <term> 795 <option><![CDATA[--vgdb-stop-at=<set> [default: none] ]]></option> 796 </term> 797 <listitem> 798 <para> Use this option when the Valgrind gdbserver is enabled with 799 <option>--vgdb=yes</option> or <option>--vgdb=full</option>. 800 The Valgrind gdbserver will be invoked for each error after 801 <option>--vgdb-error</option> have been reported. 802 You can additionally ask the Valgrind gdbserver to be invoked 803 for other events, specified in one of the following ways: </para> 804 <itemizedlist> 805 <listitem><para>a comma separated list of one or more of 806 <option>startup exit valgrindabexit</option>.</para> 807 808 <para>The values <option>startup</option> <option>exit</option> 809 <option>valgrindabexit</option> respectively indicate to 810 invoke gdbserver before your program is executed, after the 811 last instruction of your program, on Valgrind abnormal exit 812 (e.g. internal error, out of memory, ...).</para> 813 814 <para>Note: <option>startup</option> and 815 <option>--vgdb-error=0</option> will both cause Valgrind 816 gdbserver to be invoked before your program is executed. The 817 <option>--vgdb-error=0</option> will in addition cause your 818 program to stop on all subsequent errors.</para> 819 820 </listitem> 821 822 <listitem><para><option>all</option> to specify the complete set. 823 It is equivalent to 824 <option>--vgdb-stop-at=startup,exit,valgrindabexit</option>.</para> 825 </listitem> 826 827 <listitem><para><option>none</option> for the empty set.</para> 828 </listitem> 829 </itemizedlist> 830 </listitem> 831 </varlistentry> 832 833 <varlistentry id="opt.track-fds" xreflabel="--track-fds"> 834 <term> 835 <option><![CDATA[--track-fds=<yes|no> [default: no] ]]></option> 836 </term> 837 <listitem> 838 <para>When enabled, Valgrind will print out a list of open file 839 descriptors on exit or on request, via the gdbserver monitor 840 command <varname>v.info open_fds</varname>. Along with each 841 file descriptor is printed a stack backtrace of where the file 842 was opened and any details relating to the file descriptor such 843 as the file name or socket details.</para> 844 </listitem> 845 </varlistentry> 846 847 <varlistentry id="opt.time-stamp" xreflabel="--time-stamp"> 848 <term> 849 <option><![CDATA[--time-stamp=<yes|no> [default: no] ]]></option> 850 </term> 851 <listitem> 852 <para>When enabled, each message is preceded with an indication of 853 the elapsed wallclock time since startup, expressed as days, 854 hours, minutes, seconds and milliseconds.</para> 855 </listitem> 856 </varlistentry> 857 858 <varlistentry id="opt.log-fd" xreflabel="--log-fd"> 859 <term> 860 <option><![CDATA[--log-fd=<number> [default: 2, stderr] ]]></option> 861 </term> 862 <listitem> 863 <para>Specifies that Valgrind should send all of its messages to 864 the specified file descriptor. The default, 2, is the standard 865 error channel (stderr). Note that this may interfere with the 866 client's own use of stderr, as Valgrind's output will be 867 interleaved with any output that the client sends to 868 stderr.</para> 869 </listitem> 870 </varlistentry> 871 872 <varlistentry id="opt.log-file" xreflabel="--log-file"> 873 <term> 874 <option><![CDATA[--log-file=<filename> ]]></option> 875 </term> 876 <listitem> 877 <para>Specifies that Valgrind should send all of its messages to 878 the specified file. If the file name is empty, it causes an abort. 879 There are three special format specifiers that can be used in the file 880 name.</para> 881 882 <para><option>%p</option> is replaced with the current process ID. 883 This is very useful for program that invoke multiple processes. 884 WARNING: If you use <option>--trace-children=yes</option> and your 885 program invokes multiple processes OR your program forks without 886 calling exec afterwards, and you don't use this specifier 887 (or the <option>%q</option> specifier below), the Valgrind output from 888 all those processes will go into one file, possibly jumbled up, and 889 possibly incomplete.</para> 890 891 <para><option>%q{FOO}</option> is replaced with the contents of the 892 environment variable <varname>FOO</varname>. If the 893 <option>{FOO}</option> part is malformed, it causes an abort. This 894 specifier is rarely needed, but very useful in certain circumstances 895 (eg. when running MPI programs). The idea is that you specify a 896 variable which will be set differently for each process in the job, 897 for example <computeroutput>BPROC_RANK</computeroutput> or whatever is 898 applicable in your MPI setup. If the named environment variable is not 899 set, it causes an abort. Note that in some shells, the 900 <option>{</option> and <option>}</option> characters may need to be 901 escaped with a backslash.</para> 902 903 <para><option>%%</option> is replaced with <option>%</option>.</para> 904 905 <para>If an <option>%</option> is followed by any other character, it 906 causes an abort.</para> 907 908 <para>If the file name specifies a relative file name, it is put 909 in the program's initial working directory : this is the current 910 directory when the program started its execution after the fork 911 or after the exec. If it specifies an absolute file name (ie. 912 starts with '/') then it is put there. 913 </para> 914 </listitem> 915 </varlistentry> 916 917 <varlistentry id="opt.log-socket" xreflabel="--log-socket"> 918 <term> 919 <option><![CDATA[--log-socket=<ip-address:port-number> ]]></option> 920 </term> 921 <listitem> 922 <para>Specifies that Valgrind should send all of its messages to 923 the specified port at the specified IP address. The port may be 924 omitted, in which case port 1500 is used. If a connection cannot 925 be made to the specified socket, Valgrind falls back to writing 926 output to the standard error (stderr). This option is intended to 927 be used in conjunction with the 928 <computeroutput>valgrind-listener</computeroutput> program. For 929 further details, see 930 <link linkend="&vg-comment-id;">the commentary</link> 931 in the manual.</para> 932 </listitem> 933 </varlistentry> 934 935</variablelist> 936<!-- end of xi:include in the manpage --> 937 938</sect2> 939 940 941<sect2 id="manual-core.erropts" xreflabel="Error-related Options"> 942<title>Error-related Options</title> 943 944<!-- start of xi:include in the manpage --> 945<para id="error-related.opts.para">These options are used by all tools 946that can report errors, e.g. Memcheck, but not Cachegrind.</para> 947 948<variablelist id="error-related.opts.list"> 949 950 <varlistentry id="opt.xml" xreflabel="--xml"> 951 <term> 952 <option><![CDATA[--xml=<yes|no> [default: no] ]]></option> 953 </term> 954 <listitem> 955 <para>When enabled, the important parts of the output (e.g. tool error 956 messages) will be in XML format rather than plain text. Furthermore, 957 the XML output will be sent to a different output channel than the 958 plain text output. Therefore, you also must use one of 959 <option>--xml-fd</option>, <option>--xml-file</option> or 960 <option>--xml-socket</option> to specify where the XML is to be sent. 961 </para> 962 963 <para>Less important messages will still be printed in plain text, but 964 because the XML output and plain text output are sent to different 965 output channels (the destination of the plain text output is still 966 controlled by <option>--log-fd</option>, <option>--log-file</option> 967 and <option>--log-socket</option>) this should not cause problems. 968 </para> 969 970 <para>This option is aimed at making life easier for tools that consume 971 Valgrind's output as input, such as GUI front ends. Currently this 972 option works with Memcheck, Helgrind, DRD and SGcheck. The output 973 format is specified in the file 974 <computeroutput>docs/internals/xml-output-protocol4.txt</computeroutput> 975 in the source tree for Valgrind 3.5.0 or later.</para> 976 977 <para>The recommended options for a GUI to pass, when requesting 978 XML output, are: <option>--xml=yes</option> to enable XML output, 979 <option>--xml-file</option> to send the XML output to a (presumably 980 GUI-selected) file, <option>--log-file</option> to send the plain 981 text output to a second GUI-selected file, 982 <option>--child-silent-after-fork=yes</option>, and 983 <option>-q</option> to restrict the plain text output to critical 984 error messages created by Valgrind itself. For example, failure to 985 read a specified suppressions file counts as a critical error message. 986 In this way, for a successful run the text output file will be empty. 987 But if it isn't empty, then it will contain important information 988 which the GUI user should be made aware 989 of.</para> 990 </listitem> 991 </varlistentry> 992 993 <varlistentry id="opt.xml-fd" xreflabel="--xml-fd"> 994 <term> 995 <option><![CDATA[--xml-fd=<number> [default: -1, disabled] ]]></option> 996 </term> 997 <listitem> 998 <para>Specifies that Valgrind should send its XML output to the 999 specified file descriptor. It must be used in conjunction with 1000 <option>--xml=yes</option>.</para> 1001 </listitem> 1002 </varlistentry> 1003 1004 <varlistentry id="opt.xml-file" xreflabel="--xml-file"> 1005 <term> 1006 <option><![CDATA[--xml-file=<filename> ]]></option> 1007 </term> 1008 <listitem> 1009 <para>Specifies that Valgrind should send its XML output 1010 to the specified file. It must be used in conjunction with 1011 <option>--xml=yes</option>. Any <option>%p</option> or 1012 <option>%q</option> sequences appearing in the filename are expanded 1013 in exactly the same way as they are for <option>--log-file</option>. 1014 See the description of <option>--log-file</option> for details. 1015 </para> 1016 </listitem> 1017 </varlistentry> 1018 1019 <varlistentry id="opt.xml-socket" xreflabel="--xml-socket"> 1020 <term> 1021 <option><![CDATA[--xml-socket=<ip-address:port-number> ]]></option> 1022 </term> 1023 <listitem> 1024 <para>Specifies that Valgrind should send its XML output the 1025 specified port at the specified IP address. It must be used in 1026 conjunction with <option>--xml=yes</option>. The form of the argument 1027 is the same as that used by <option>--log-socket</option>. 1028 See the description of <option>--log-socket</option> 1029 for further details.</para> 1030 </listitem> 1031 </varlistentry> 1032 1033 <varlistentry id="opt.xml-user-comment" xreflabel="--xml-user-comment"> 1034 <term> 1035 <option><![CDATA[--xml-user-comment=<string> ]]></option> 1036 </term> 1037 <listitem> 1038 <para>Embeds an extra user comment string at the start of the XML 1039 output. Only works when <option>--xml=yes</option> is specified; 1040 ignored otherwise.</para> 1041 </listitem> 1042 </varlistentry> 1043 1044 <varlistentry id="opt.demangle" xreflabel="--demangle"> 1045 <term> 1046 <option><![CDATA[--demangle=<yes|no> [default: yes] ]]></option> 1047 </term> 1048 <listitem> 1049 <para>Enable/disable automatic demangling (decoding) of C++ names. 1050 Enabled by default. When enabled, Valgrind will attempt to 1051 translate encoded C++ names back to something approaching the 1052 original. The demangler handles symbols mangled by g++ versions 1053 2.X, 3.X and 4.X.</para> 1054 1055 <para>An important fact about demangling is that function names 1056 mentioned in suppressions files should be in their mangled form. 1057 Valgrind does not demangle function names when searching for 1058 applicable suppressions, because to do otherwise would make 1059 suppression file contents dependent on the state of Valgrind's 1060 demangling machinery, and also slow down suppression matching.</para> 1061 </listitem> 1062 </varlistentry> 1063 1064 <varlistentry id="opt.num-callers" xreflabel="--num-callers"> 1065 <term> 1066 <option><![CDATA[--num-callers=<number> [default: 12] ]]></option> 1067 </term> 1068 <listitem> 1069 <para>Specifies the maximum number of entries shown in stack traces 1070 that identify program locations. Note that errors are commoned up 1071 using only the top four function locations (the place in the current 1072 function, and that of its three immediate callers). So this doesn't 1073 affect the total number of errors reported.</para> 1074 1075 <para>The maximum value for this is 500. Note that higher settings 1076 will make Valgrind run a bit more slowly and take a bit more 1077 memory, but can be useful when working with programs with 1078 deeply-nested call chains.</para> 1079 </listitem> 1080 </varlistentry> 1081 1082 <varlistentry id="opt.unw-stack-scan-thresh" 1083 xreflabel="--unw-stack-scan-thresh"> 1084 <term> 1085 <option><![CDATA[--unw-stack-scan-thresh=<number> [default: 0] ]]></option> 1086 </term> 1087 <term> 1088 <option><![CDATA[--unw-stack-scan-frames=<number> [default: 5] ]]></option> 1089 </term> 1090 <listitem> 1091 <para>Stack-scanning support is available only on ARM 1092 targets.</para> 1093 1094 <para>These flags enable and control stack unwinding by stack 1095 scanning. When the normal stack unwinding mechanisms -- usage 1096 of Dwarf CFI records, and frame-pointer following -- fail, stack 1097 scanning may be able to recover a stack trace.</para> 1098 1099 <para>Note that stack scanning is an imprecise, heuristic 1100 mechanism that may give very misleading results, or none at all. 1101 It should be used only in emergencies, when normal unwinding 1102 fails, and it is important to nevertheless have stack 1103 traces.</para> 1104 1105 <para>Stack scanning is a simple technique: the unwinder reads 1106 words from the stack, and tries to guess which of them might be 1107 return addresses, by checking to see if they point just after 1108 ARM or Thumb call instructions. If so, the word is added to the 1109 backtrace.</para> 1110 1111 <para>The main danger occurs when a function call returns, 1112 leaving its return address exposed, and a new function is 1113 called, but the new function does not overwrite the old address. 1114 The result of this is that the backtrace may contain entries for 1115 functions which have already returned, and so be very 1116 confusing.</para> 1117 1118 <para>A second limitation of this implementation is that it will 1119 scan only the page (4KB, normally) containing the starting stack 1120 pointer. If the stack frames are large, this may result in only 1121 a few (or not even any) being present in the trace. Also, if 1122 you are unlucky and have an initial stack pointer near the end 1123 of its containing page, the scan may miss all interesting 1124 frames.</para> 1125 1126 <para>By default stack scanning is disabled. The normal use 1127 case is to ask for it when a stack trace would otherwise be very 1128 short. So, to enable it, 1129 use <computeroutput>--unw-stack-scan-thresh=number</computeroutput>. 1130 This requests Valgrind to try using stack scanning to "extend" 1131 stack traces which contain fewer 1132 than <computeroutput>number</computeroutput> frames.</para> 1133 1134 <para>If stack scanning does take place, it will only generate 1135 at most the number of frames specified 1136 by <computeroutput>--unw-stack-scan-frames</computeroutput>. 1137 Typically, stack scanning generates so many garbage entries that 1138 this value is set to a low value (5) by default. In no case 1139 will a stack trace larger than the value specified 1140 by <computeroutput>--num-callers</computeroutput> be 1141 created.</para> 1142 </listitem> 1143 </varlistentry> 1144 1145 <varlistentry id="opt.error-limit" xreflabel="--error-limit"> 1146 <term> 1147 <option><![CDATA[--error-limit=<yes|no> [default: yes] ]]></option> 1148 </term> 1149 <listitem> 1150 <para>When enabled, Valgrind stops reporting errors after 10,000,000 1151 in total, or 1,000 different ones, have been seen. This is to 1152 stop the error tracking machinery from becoming a huge performance 1153 overhead in programs with many errors.</para> 1154 </listitem> 1155 </varlistentry> 1156 1157 <varlistentry id="opt.error-exitcode" xreflabel="--error-exitcode"> 1158 <term> 1159 <option><![CDATA[--error-exitcode=<number> [default: 0] ]]></option> 1160 </term> 1161 <listitem> 1162 <para>Specifies an alternative exit code to return if Valgrind 1163 reported any errors in the run. When set to the default value 1164 (zero), the return value from Valgrind will always be the return 1165 value of the process being simulated. When set to a nonzero value, 1166 that value is returned instead, if Valgrind detects any errors. 1167 This is useful for using Valgrind as part of an automated test 1168 suite, since it makes it easy to detect test cases for which 1169 Valgrind has reported errors, just by inspecting return codes.</para> 1170 </listitem> 1171 </varlistentry> 1172 1173 <varlistentry id="opt.error-markers" xreflabel="--error-markers"> 1174 <term> 1175 <option><![CDATA[--error-markers=<begin>,<end> [default: none]]]></option> 1176 </term> 1177 <listitem> 1178 <para>When errors are output as plain text (i.e. XML not used), 1179 <option>--error-markers</option> instructs to output a line 1180 containing the <option>begin</option> (<option>end</option>) 1181 string before (after) each error. </para> 1182 <para> Such marker lines facilitate searching for errors and/or 1183 extracting errors in an output file that contain valgrind errors mixed 1184 with the program output. </para> 1185 <para> Note that empty markers are accepted. So, only using a begin 1186 (or an end) marker is possible.</para> 1187 </listitem> 1188 </varlistentry> 1189 1190 <varlistentry id="opt.sigill-diagnostics" xreflabel="--sigill-diagnostics"> 1191 <term> 1192 <option><![CDATA[--sigill-diagnostics=<yes|no> [default: yes] ]]></option> 1193 </term> 1194 <listitem> 1195 <para>Enable/disable printing of illegal instruction diagnostics. 1196 Enabled by default, but defaults to disabled when 1197 <option>--quiet</option> is given. The default can always be explicitly 1198 overridden by giving this option.</para> 1199 1200 <para>When enabled, a warning message will be printed, along with some 1201 diagnostics, whenever an instruction is encountered that Valgrind 1202 cannot decode or translate, before the program is given a SIGILL signal. 1203 Often an illegal instruction indicates a bug in the program or missing 1204 support for the particular instruction in Valgrind. But some programs 1205 do deliberately try to execute an instruction that might be missing 1206 and trap the SIGILL signal to detect processor features. Using 1207 this flag makes it possible to avoid the diagnostic output 1208 that you would otherwise get in such cases.</para> 1209 </listitem> 1210 </varlistentry> 1211 1212 <varlistentry id="opt.show-below-main" xreflabel="--show-below-main"> 1213 <term> 1214 <option><![CDATA[--show-below-main=<yes|no> [default: no] ]]></option> 1215 </term> 1216 <listitem> 1217 <para>By default, stack traces for errors do not show any 1218 functions that appear beneath <function>main</function> because 1219 most of the time it's uninteresting C library stuff and/or 1220 gobbledygook. Alternatively, if <function>main</function> is not 1221 present in the stack trace, stack traces will not show any functions 1222 below <function>main</function>-like functions such as glibc's 1223 <function>__libc_start_main</function>. Furthermore, if 1224 <function>main</function>-like functions are present in the trace, 1225 they are normalised as <function>(below main)</function>, in order to 1226 make the output more deterministic.</para> 1227 1228 <para>If this option is enabled, all stack trace entries will be 1229 shown and <function>main</function>-like functions will not be 1230 normalised.</para> 1231 </listitem> 1232 </varlistentry> 1233 1234 <varlistentry id="opt.fullpath-after" xreflabel="--fullpath-after"> 1235 <term> 1236 <option><![CDATA[--fullpath-after=<string> 1237 [default: don't show source paths] ]]></option> 1238 </term> 1239 <listitem> 1240 <para>By default Valgrind only shows the filenames in stack 1241 traces, but not full paths to source files. When using Valgrind 1242 in large projects where the sources reside in multiple different 1243 directories, this can be inconvenient. 1244 <option>--fullpath-after</option> provides a flexible solution 1245 to this problem. When this option is present, the path to each 1246 source file is shown, with the following all-important caveat: 1247 if <option>string</option> is found in the path, then the path 1248 up to and including <option>string</option> is omitted, else the 1249 path is shown unmodified. Note that <option>string</option> is 1250 not required to be a prefix of the path.</para> 1251 1252 <para>For example, consider a file named 1253 <computeroutput>/home/janedoe/blah/src/foo/bar/xyzzy.c</computeroutput>. 1254 Specifying <option>--fullpath-after=/home/janedoe/blah/src/</option> 1255 will cause Valgrind to show the name 1256 as <computeroutput>foo/bar/xyzzy.c</computeroutput>.</para> 1257 1258 <para>Because the string is not required to be a prefix, 1259 <option>--fullpath-after=src/</option> will produce the same 1260 output. This is useful when the path contains arbitrary 1261 machine-generated characters. For example, the 1262 path 1263 <computeroutput>/my/build/dir/C32A1B47/blah/src/foo/xyzzy</computeroutput> 1264 can be pruned to <computeroutput>foo/xyzzy</computeroutput> 1265 using 1266 <option>--fullpath-after=/blah/src/</option>.</para> 1267 1268 <para>If you simply want to see the full path, just specify an 1269 empty string: <option>--fullpath-after=</option>. This isn't a 1270 special case, merely a logical consequence of the above rules.</para> 1271 1272 <para>Finally, you can use <option>--fullpath-after</option> 1273 multiple times. Any appearance of it causes Valgrind to switch 1274 to producing full paths and applying the above filtering rule. 1275 Each produced path is compared against all 1276 the <option>--fullpath-after</option>-specified strings, in the 1277 order specified. The first string to match causes the path to 1278 be truncated as described above. If none match, the full path 1279 is shown. This facilitates chopping off prefixes when the 1280 sources are drawn from a number of unrelated directories. 1281 </para> 1282 </listitem> 1283 </varlistentry> 1284 1285 <varlistentry id="opt.extra-debuginfo-path" xreflabel="--extra-debuginfo-path"> 1286 <term> 1287 <option><![CDATA[--extra-debuginfo-path=<path> [default: undefined and unused] ]]></option> 1288 </term> 1289 <listitem> 1290 <para>By default Valgrind searches in several well-known paths 1291 for debug objects, such 1292 as <computeroutput>/usr/lib/debug/</computeroutput>.</para> 1293 1294 <para>However, there may be scenarios where you may wish to put 1295 debug objects at an arbitrary location, such as external storage 1296 when running Valgrind on a mobile device with limited local 1297 storage. Another example might be a situation where you do not 1298 have permission to install debug object packages on the system 1299 where you are running Valgrind.</para> 1300 1301 <para>In these scenarios, you may provide an absolute path as an extra, 1302 final place for Valgrind to search for debug objects by specifying 1303 <option>--extra-debuginfo-path=/path/to/debug/objects</option>. 1304 The given path will be prepended to the absolute path name of 1305 the searched-for object. For example, if Valgrind is looking 1306 for the debuginfo 1307 for <computeroutput>/w/x/y/zz.so</computeroutput> 1308 and <option>--extra-debuginfo-path=/a/b/c</option> is specified, 1309 it will look for a debug object at 1310 <computeroutput>/a/b/c/w/x/y/zz.so</computeroutput>.</para> 1311 1312 <para>This flag should only be specified once. If it is 1313 specified multiple times, only the last instance is 1314 honoured.</para> 1315 </listitem> 1316 </varlistentry> 1317 1318 <varlistentry id="opt.debuginfo-server" xreflabel="--debuginfo-server"> 1319 <term> 1320 <option><![CDATA[--debuginfo-server=ipaddr:port [default: undefined and unused]]]></option> 1321 </term> 1322 <listitem> 1323 <para>This is a new, experimental, feature introduced in version 1324 3.9.0.</para> 1325 1326 <para>In some scenarios it may be convenient to read debuginfo 1327 from objects stored on a different machine. With this flag, 1328 Valgrind will query a debuginfo server running 1329 on <computeroutput>ipaddr</computeroutput> and listening on 1330 port <computeroutput>port</computeroutput>, if it cannot find 1331 the debuginfo object in the local filesystem.</para> 1332 1333 <para>The debuginfo server must accept TCP connections on 1334 port <computeroutput>port</computeroutput>. The debuginfo 1335 server is contained in the source 1336 file <computeroutput>auxprogs/valgrind-di-server.c</computeroutput>. 1337 It will only serve from the directory it is started 1338 in. <computeroutput>port</computeroutput> defaults to 1500 in 1339 both client and server if not specified.</para> 1340 1341 <para>If Valgrind looks for the debuginfo for 1342 <computeroutput>/w/x/y/zz.so</computeroutput> by using the 1343 debuginfo server, it will strip the pathname components and 1344 merely request <computeroutput>zz.so</computeroutput> on the 1345 server. That in turn will look only in its current working 1346 directory for a matching debuginfo object.</para> 1347 1348 <para>The debuginfo data is transmitted in small fragments (8 1349 KB) as requested by Valgrind. Each block is compressed using 1350 LZO to reduce transmission time. The implementation has been 1351 tuned for best performance over a single-stage 802.11g (WiFi) 1352 network link.</para> 1353 1354 <para>Note that checks for matching primary vs debug objects, 1355 using GNU debuglink CRC scheme, are performed even when using 1356 the debuginfo server. To disable such checking, you need to 1357 also specify 1358 <computeroutput>--allow-mismatched-debuginfo=yes</computeroutput>. 1359 </para> 1360 1361 <para>By default the Valgrind build system will 1362 build <computeroutput>valgrind-di-server</computeroutput> for 1363 the target platform, which is almost certainly not what you 1364 want. So far we have been unable to find out how to get 1365 automake/autoconf to build it for the build platform. If 1366 you want to use it, you will have to recompile it by hand using 1367 the command shown at the top 1368 of <computeroutput>auxprogs/valgrind-di-server.c</computeroutput>.</para> 1369 </listitem> 1370 </varlistentry> 1371 1372 <varlistentry id="opt.allow-mismatched-debuginfo" 1373 xreflabel="--allow-mismatched-debuginfo"> 1374 <term> 1375 <option><![CDATA[--allow-mismatched-debuginfo=no|yes [no] ]]></option> 1376 </term> 1377 <listitem> 1378 <para>When reading debuginfo from separate debuginfo objects, 1379 Valgrind will by default check that the main and debuginfo 1380 objects match, using the GNU debuglink mechanism. This 1381 guarantees that it does not read debuginfo from out of date 1382 debuginfo objects, and also ensures that Valgrind can't crash as 1383 a result of mismatches.</para> 1384 1385 <para>This check can be overridden using 1386 <computeroutput>--allow-mismatched-debuginfo=yes</computeroutput>. 1387 This may be useful when the debuginfo and main objects have not 1388 been split in the proper way. Be careful when using this, 1389 though: it disables all consistency checking, and Valgrind has 1390 been observed to crash when the main and debuginfo objects don't 1391 match.</para> 1392 </listitem> 1393 </varlistentry> 1394 1395 <varlistentry id="opt.suppressions" xreflabel="--suppressions"> 1396 <term> 1397 <option><![CDATA[--suppressions=<filename> [default: $PREFIX/lib/valgrind/default.supp] ]]></option> 1398 </term> 1399 <listitem> 1400 <para>Specifies an extra file from which to read descriptions of 1401 errors to suppress. You may use up to 100 extra suppression 1402 files.</para> 1403 </listitem> 1404 </varlistentry> 1405 1406 <varlistentry id="opt.gen-suppressions" xreflabel="--gen-suppressions"> 1407 <term> 1408 <option><![CDATA[--gen-suppressions=<yes|no|all> [default: no] ]]></option> 1409 </term> 1410 <listitem> 1411 <para>When set to <varname>yes</varname>, Valgrind will pause 1412 after every error shown and print the line: 1413 <literallayout><computeroutput> ---- Print suppression ? --- [Return/N/n/Y/y/C/c] ----</computeroutput></literallayout> 1414 1415 The prompt's behaviour is the same as for the 1416 <option>--db-attach</option> option (see below).</para> 1417 1418 <para>If you choose to, Valgrind will print out a suppression for 1419 this error. You can then cut and paste it into a suppression file 1420 if you don't want to hear about the error in the future.</para> 1421 1422 <para>When set to <varname>all</varname>, Valgrind will print a 1423 suppression for every reported error, without querying the 1424 user.</para> 1425 1426 <para>This option is particularly useful with C++ programs, as it 1427 prints out the suppressions with mangled names, as 1428 required.</para> 1429 1430 <para>Note that the suppressions printed are as specific as 1431 possible. You may want to common up similar ones, by adding 1432 wildcards to function names, and by using frame-level wildcards. 1433 The wildcarding facilities are powerful yet flexible, and with a 1434 bit of careful editing, you may be able to suppress a whole 1435 family of related errors with only a few suppressions. 1436 <!-- commented out because it causes broken links in the man page 1437 For details on how to do this, see 1438 <xref linkend="manual-core.suppress"/>. 1439 --> 1440 </para> 1441 1442 <para>Sometimes two different errors 1443 are suppressed by the same suppression, in which case Valgrind 1444 will output the suppression more than once, but you only need to 1445 have one copy in your suppression file (but having more than one 1446 won't cause problems). Also, the suppression name is given as 1447 <computeroutput><insert a suppression name 1448 here></computeroutput>; the name doesn't really matter, it's 1449 only used with the <option>-v</option> option which prints out all 1450 used suppression records.</para> 1451 </listitem> 1452 </varlistentry> 1453 1454 <varlistentry id="opt.db-attach" xreflabel="--db-attach"> 1455 <term> 1456 <option><![CDATA[--db-attach=<yes|no> [default: no] ]]></option> 1457 </term> 1458 <listitem> 1459 <para>When enabled, Valgrind will pause after every error shown 1460 and print the line: 1461 <literallayout><computeroutput> ---- Attach to debugger ? --- [Return/N/n/Y/y/C/c] ----</computeroutput></literallayout> 1462 1463 Pressing <varname>Ret</varname>, or <varname>N Ret</varname> or 1464 <varname>n Ret</varname>, causes Valgrind not to start a debugger 1465 for this error.</para> 1466 1467 <para>Pressing <varname>Y Ret</varname> or 1468 <varname>y Ret</varname> causes Valgrind to start a debugger for 1469 the program at this point. When you have finished with the 1470 debugger, quit from it, and the program will continue. Trying to 1471 continue from inside the debugger doesn't work.</para> 1472 1473 <para> 1474 Note: if you use GDB, more powerful debugging support is 1475 provided by the <option>--vgdb=</option> <varname>yes</varname> 1476 or <varname>full</varname> value. This activates Valgrind's 1477 internal gdbserver, which provides more-or-less full GDB-style 1478 control of the application: insertion of breakpoints, continuing 1479 from inside GDB, inferior function calls, and much more. 1480 </para> 1481 1482 <para><varname>C Ret</varname> or <varname>c Ret</varname> causes 1483 Valgrind not to start a debugger, and not to ask again.</para> 1484 </listitem> 1485 </varlistentry> 1486 1487 <varlistentry id="opt.db-command" xreflabel="--db-command"> 1488 <term> 1489 <option><![CDATA[--db-command=<command> [default: gdb -nw %f %p] ]]></option> 1490 </term> 1491 <listitem> 1492 <para>Specify the debugger to use with the 1493 <option>--db-attach</option> command. The default debugger is 1494 GDB. This option is a template that is expanded by Valgrind at 1495 runtime. <literal>%f</literal> is replaced with the executable's 1496 file name and <literal>%p</literal> is replaced by the process ID 1497 of the executable.</para> 1498 1499 <para>This specifies how Valgrind will invoke the debugger. By 1500 default it will use whatever GDB is detected at build time, which 1501 is usually <computeroutput>/usr/bin/gdb</computeroutput>. Using 1502 this command, you can specify some alternative command to invoke 1503 the debugger you want to use.</para> 1504 1505 <para>The command string given can include one or instances of the 1506 <literal>%p</literal> and <literal>%f</literal> expansions. Each 1507 instance of <literal>%p</literal> expands to the PID of the 1508 process to be debugged and each instance of <literal>%f</literal> 1509 expands to the path to the executable for the process to be 1510 debugged.</para> 1511 1512 <para>Since <computeroutput><command></computeroutput> is likely 1513 to contain spaces, you will need to put this entire option in 1514 quotes to ensure it is correctly handled by the shell.</para> 1515 </listitem> 1516 </varlistentry> 1517 1518 <varlistentry id="opt.input-fd" xreflabel="--input-fd"> 1519 <term> 1520 <option><![CDATA[--input-fd=<number> [default: 0, stdin] ]]></option> 1521 </term> 1522 <listitem> 1523 <para>When using <option>--db-attach=yes</option> or 1524 <option>--gen-suppressions=yes</option>, Valgrind will stop so as 1525 to read keyboard input from you when each error occurs. By 1526 default it reads from the standard input (stdin), which is 1527 problematic for programs which close stdin. This option allows 1528 you to specify an alternative file descriptor from which to read 1529 input.</para> 1530 </listitem> 1531 </varlistentry> 1532 1533 <varlistentry id="opt.dsymutil" xreflabel="--dsymutil"> 1534 <term> 1535 <option><![CDATA[--dsymutil=no|yes [no] ]]></option> 1536 </term> 1537 <listitem> 1538 <para>This option is only relevant when running Valgrind on 1539 Mac OS X.</para> 1540 1541 <para>Mac OS X uses a deferred debug information (debuginfo) 1542 linking scheme. When object files containing debuginfo are 1543 linked into a <computeroutput>.dylib</computeroutput> or an 1544 executable, the debuginfo is not copied into the final file. 1545 Instead, the debuginfo must be linked manually by 1546 running <computeroutput>dsymutil</computeroutput>, a 1547 system-provided utility, on the executable 1548 or <computeroutput>.dylib</computeroutput>. The resulting 1549 combined debuginfo is placed in a directory alongside the 1550 executable or <computeroutput>.dylib</computeroutput>, but with 1551 the extension <computeroutput>.dSYM</computeroutput>.</para> 1552 1553 <para>With <option>--dsymutil=no</option>, Valgrind 1554 will detect cases where the 1555 <computeroutput>.dSYM</computeroutput> directory is either 1556 missing, or is present but does not appear to match the 1557 associated executable or <computeroutput>.dylib</computeroutput>, 1558 most likely because it is out of date. In these cases, Valgrind 1559 will print a warning message but take no further action.</para> 1560 1561 <para>With <option>--dsymutil=yes</option>, Valgrind 1562 will, in such cases, automatically 1563 run <computeroutput>dsymutil</computeroutput> as necessary to 1564 bring the debuginfo up to date. For all practical purposes, if 1565 you always use <option>--dsymutil=yes</option>, then 1566 there is never any need to 1567 run <computeroutput>dsymutil</computeroutput> manually or as part 1568 of your applications's build system, since Valgrind will run it 1569 as necessary.</para> 1570 1571 <para>Valgrind will not attempt to 1572 run <computeroutput>dsymutil</computeroutput> on any 1573 executable or library in 1574 <computeroutput>/usr/</computeroutput>, 1575 <computeroutput>/bin/</computeroutput>, 1576 <computeroutput>/sbin/</computeroutput>, 1577 <computeroutput>/opt/</computeroutput>, 1578 <computeroutput>/sw/</computeroutput>, 1579 <computeroutput>/System/</computeroutput>, 1580 <computeroutput>/Library/</computeroutput> or 1581 <computeroutput>/Applications/</computeroutput> 1582 since <computeroutput>dsymutil</computeroutput> will always fail 1583 in such situations. It fails both because the debuginfo for 1584 such pre-installed system components is not available anywhere, 1585 and also because it would require write privileges in those 1586 directories.</para> 1587 1588 <para>Be careful when 1589 using <option>--dsymutil=yes</option>, since it will 1590 cause pre-existing <computeroutput>.dSYM</computeroutput> 1591 directories to be silently deleted and re-created. Also note that 1592 <computeroutput>dsymutil</computeroutput> is quite slow, sometimes 1593 excessively so.</para> 1594 </listitem> 1595 </varlistentry> 1596 1597 <varlistentry id="opt.max-stackframe" xreflabel="--max-stackframe"> 1598 <term> 1599 <option><![CDATA[--max-stackframe=<number> [default: 2000000] ]]></option> 1600 </term> 1601 <listitem> 1602 <para>The maximum size of a stack frame. If the stack pointer moves by 1603 more than this amount then Valgrind will assume that 1604 the program is switching to a different stack.</para> 1605 1606 <para>You may need to use this option if your program has large 1607 stack-allocated arrays. Valgrind keeps track of your program's 1608 stack pointer. If it changes by more than the threshold amount, 1609 Valgrind assumes your program is switching to a different stack, 1610 and Memcheck behaves differently than it would for a stack pointer 1611 change smaller than the threshold. Usually this heuristic works 1612 well. However, if your program allocates large structures on the 1613 stack, this heuristic will be fooled, and Memcheck will 1614 subsequently report large numbers of invalid stack accesses. This 1615 option allows you to change the threshold to a different 1616 value.</para> 1617 1618 <para>You should only consider use of this option if Valgrind's 1619 debug output directs you to do so. In that case it will tell you 1620 the new threshold you should specify.</para> 1621 1622 <para>In general, allocating large structures on the stack is a 1623 bad idea, because you can easily run out of stack space, 1624 especially on systems with limited memory or which expect to 1625 support large numbers of threads each with a small stack, and also 1626 because the error checking performed by Memcheck is more effective 1627 for heap-allocated data than for stack-allocated data. If you 1628 have to use this option, you may wish to consider rewriting your 1629 code to allocate on the heap rather than on the stack.</para> 1630 </listitem> 1631 </varlistentry> 1632 1633 <varlistentry id="opt.main-stacksize" xreflabel="--main-stacksize"> 1634 <term> 1635 <option><![CDATA[--main-stacksize=<number> 1636 [default: use current 'ulimit' value] ]]></option> 1637 </term> 1638 <listitem> 1639 <para>Specifies the size of the main thread's stack.</para> 1640 1641 <para>To simplify its memory management, Valgrind reserves all 1642 required space for the main thread's stack at startup. That 1643 means it needs to know the required stack size at 1644 startup.</para> 1645 1646 <para>By default, Valgrind uses the current "ulimit" value for 1647 the stack size, or 16 MB, whichever is lower. In many cases 1648 this gives a stack size in the range 8 to 16 MB, which almost 1649 never overflows for most applications.</para> 1650 1651 <para>If you need a larger total stack size, 1652 use <option>--main-stacksize</option> to specify it. Only set 1653 it as high as you need, since reserving far more space than you 1654 need (that is, hundreds of megabytes more than you need) 1655 constrains Valgrind's memory allocators and may reduce the total 1656 amount of memory that Valgrind can use. This is only really of 1657 significance on 32-bit machines.</para> 1658 1659 <para>On Linux, you may request a stack of size up to 2GB. 1660 Valgrind will stop with a diagnostic message if the stack cannot 1661 be allocated.</para> 1662 1663 <para><option>--main-stacksize</option> only affects the stack 1664 size for the program's initial thread. It has no bearing on the 1665 size of thread stacks, as Valgrind does not allocate 1666 those.</para> 1667 1668 <para>You may need to use both <option>--main-stacksize</option> 1669 and <option>--max-stackframe</option> together. It is important 1670 to understand that <option>--main-stacksize</option> sets the 1671 maximum total stack size, 1672 whilst <option>--max-stackframe</option> specifies the largest 1673 size of any one stack frame. You will have to work out 1674 the <option>--main-stacksize</option> value for yourself 1675 (usually, if your applications segfaults). But Valgrind will 1676 tell you the needed <option>--max-stackframe</option> size, if 1677 necessary.</para> 1678 1679 <para>As discussed further in the description 1680 of <option>--max-stackframe</option>, a requirement for a large 1681 stack is a sign of potential portability problems. You are best 1682 advised to place all large data in heap-allocated memory.</para> 1683 </listitem> 1684 </varlistentry> 1685 1686 <varlistentry id="opt.max-threads" xreflabel="--max-threads"> 1687 <term> 1688 <option><![CDATA[--max-threads=<number> [default: 500] ]]></option> 1689 </term> 1690 <listitem> 1691 <para>By default, Valgrind can handle to up to 500 threads. 1692 Occasionally, that number is too small. Use this option to 1693 provide a different limit. E.g. 1694 <computeroutput>--max-threads=3000</computeroutput>. 1695 </para> 1696 </listitem> 1697 </varlistentry> 1698 1699</variablelist> 1700<!-- end of xi:include in the manpage --> 1701 1702</sect2> 1703 1704 1705<sect2 id="manual-core.mallocopts" xreflabel="malloc-related Options"> 1706<title>malloc-related Options</title> 1707 1708<!-- start of xi:include in the manpage --> 1709<para id="malloc-related.opts.para">For tools that use their own version of 1710<computeroutput>malloc</computeroutput> (e.g. Memcheck, 1711Massif, Helgrind, DRD), the following options apply.</para> 1712 1713<variablelist id="malloc-related.opts.list"> 1714 1715 <varlistentry id="opt.alignment" xreflabel="--alignment"> 1716 <term> 1717 <option><![CDATA[--alignment=<number> [default: 8 or 16, depending on the platform] ]]></option> 1718 </term> 1719 <listitem> 1720 <para>By default Valgrind's <function>malloc</function>, 1721 <function>realloc</function>, etc, return a block whose starting 1722 address is 8-byte aligned or 16-byte aligned (the value depends on the 1723 platform and matches the platform default). This option allows you to 1724 specify a different alignment. The supplied value must be greater 1725 than or equal to the default, less than or equal to 4096, and must be 1726 a power of two.</para> 1727 </listitem> 1728 </varlistentry> 1729 1730 <varlistentry id="opt.redzone-size" xreflabel="--redzone-size"> 1731 <term> 1732 <option><![CDATA[--redzone-size=<number> [default: depends on the tool] ]]></option> 1733 </term> 1734 <listitem> 1735 <para> Valgrind's <function>malloc, realloc,</function> etc, add 1736 padding blocks before and after each heap block allocated by the 1737 program being run. Such padding blocks are called redzones. The 1738 default value for the redzone size depends on the tool. For 1739 example, Memcheck adds and protects a minimum of 16 bytes before 1740 and after each block allocated by the client. This allows it to 1741 detect block underruns or overruns of up to 16 bytes. 1742 </para> 1743 <para>Increasing the redzone size makes it possible to detect 1744 overruns of larger distances, but increases the amount of memory 1745 used by Valgrind. Decreasing the redzone size will reduce the 1746 memory needed by Valgrind but also reduces the chances of 1747 detecting over/underruns, so is not recommended.</para> 1748 </listitem> 1749 </varlistentry> 1750 1751</variablelist> 1752<!-- end of xi:include in the manpage --> 1753 1754</sect2> 1755 1756 1757<sect2 id="manual-core.rareopts" xreflabel="Uncommon Options"> 1758<title>Uncommon Options</title> 1759 1760<!-- start of xi:include in the manpage --> 1761<para id="uncommon.opts.para">These options apply to all tools, as they 1762affect certain obscure workings of the Valgrind core. Most people won't 1763need to use them.</para> 1764 1765<variablelist id="uncommon.opts.list"> 1766 1767 <varlistentry id="opt.smc-check" xreflabel="--smc-check"> 1768 <term> 1769 <option><![CDATA[--smc-check=<none|stack|all|all-non-file> [default: stack] ]]></option> 1770 </term> 1771 <listitem> 1772 <para>This option controls Valgrind's detection of self-modifying 1773 code. If no checking is done, if a program executes some code, then 1774 overwrites it with new code, and executes the new code, Valgrind will 1775 continue to execute the translations it made for the old code. This 1776 will likely lead to incorrect behaviour and/or crashes.</para> 1777 1778 <para>Valgrind has four levels of self-modifying code detection: 1779 no detection, detect self-modifying code on the stack (which is used by 1780 GCC to implement nested functions), detect self-modifying code 1781 everywhere, and detect self-modifying code everywhere except in 1782 file-backed mappings. 1783 1784 Note that the default option will catch the vast majority 1785 of cases. The main case it will not catch is programs such as JIT 1786 compilers that dynamically generate code <emphasis>and</emphasis> 1787 subsequently overwrite part or all of it. Running with 1788 <varname>all</varname> will slow Valgrind down noticeably. 1789 Running with 1790 <varname>none</varname> will rarely speed things up, since very little 1791 code gets put on the stack for most programs. The 1792 <function>VALGRIND_DISCARD_TRANSLATIONS</function> client 1793 request is an alternative to <option>--smc-check=all</option> 1794 that requires more programmer effort but allows Valgrind to run 1795 your program faster, by telling it precisely when translations 1796 need to be re-made. 1797 <!-- commented out because it causes broken links in the man page 1798 ; see <xref 1799 linkend="manual-core-adv.clientreq"/> for more details. 1800 --> 1801 </para> 1802 1803 <para><option>--smc-check=all-non-file</option> provides a 1804 cheaper but more limited version 1805 of <option>--smc-check=all</option>. It adds checks to any 1806 translations that do not originate from file-backed memory 1807 mappings. Typical applications that generate code, for example 1808 JITs in web browsers, generate code into anonymous mmaped areas, 1809 whereas the "fixed" code of the browser always lives in 1810 file-backed mappings. <option>--smc-check=all-non-file</option> 1811 takes advantage of this observation, limiting the overhead of 1812 checking to code which is likely to be JIT generated.</para> 1813 1814 <para>Some architectures (including ppc32, ppc64, ARM and MIPS) 1815 require programs which create code at runtime to flush the 1816 instruction cache in between code generation and first use. 1817 Valgrind observes and honours such instructions. Hence, on 1818 ppc32/Linux, ppc64/Linux and ARM/Linux, Valgrind always provides 1819 complete, transparent support for self-modifying code. It is 1820 only on platforms such as x86/Linux, AMD64/Linux, x86/Darwin and 1821 AMD64/Darwin that you need to use this option.</para> 1822 </listitem> 1823 </varlistentry> 1824 1825 <varlistentry id="opt.read-inline-info" xreflabel="--read-inline-info"> 1826 <term> 1827 <option><![CDATA[--read-inline-info=<yes|no> [default: see below] ]]></option> 1828 </term> 1829 <listitem> 1830 <para>When enabled, Valgrind will read information about inlined 1831 function calls from DWARF3 debug info. This slows Valgrind 1832 startup and makes it use more memory (typically for each inlined 1833 piece of code, 6 words and space for the function name), but it 1834 results in more descriptive stacktraces. For the 3.10.0 1835 release, this functionality is enabled by default only for Linux 1836 and Android targets and only for the tools Memcheck, Helgrind 1837 and DRD. Here is an example of some stacktraces with 1838 <option>--read-inline-info=no</option>: 1839</para> 1840<programlisting><![CDATA[ 1841==15380== Conditional jump or move depends on uninitialised value(s) 1842==15380== at 0x80484EA: main (inlinfo.c:6) 1843==15380== 1844==15380== Conditional jump or move depends on uninitialised value(s) 1845==15380== at 0x8048550: fun_noninline (inlinfo.c:6) 1846==15380== by 0x804850E: main (inlinfo.c:34) 1847==15380== 1848==15380== Conditional jump or move depends on uninitialised value(s) 1849==15380== at 0x8048520: main (inlinfo.c:6) 1850]]></programlisting> 1851 <para>And here are the same errors with 1852 <option>--read-inline-info=yes</option>:</para> 1853<programlisting><![CDATA[ 1854==15377== Conditional jump or move depends on uninitialised value(s) 1855==15377== at 0x80484EA: fun_d (inlinfo.c:6) 1856==15377== by 0x80484EA: fun_c (inlinfo.c:14) 1857==15377== by 0x80484EA: fun_b (inlinfo.c:20) 1858==15377== by 0x80484EA: fun_a (inlinfo.c:26) 1859==15377== by 0x80484EA: main (inlinfo.c:33) 1860==15377== 1861==15377== Conditional jump or move depends on uninitialised value(s) 1862==15377== at 0x8048550: fun_d (inlinfo.c:6) 1863==15377== by 0x8048550: fun_noninline (inlinfo.c:41) 1864==15377== by 0x804850E: main (inlinfo.c:34) 1865==15377== 1866==15377== Conditional jump or move depends on uninitialised value(s) 1867==15377== at 0x8048520: fun_d (inlinfo.c:6) 1868==15377== by 0x8048520: main (inlinfo.c:35) 1869]]></programlisting> 1870 </listitem> 1871 </varlistentry> 1872 1873 <varlistentry id="opt.read-var-info" xreflabel="--read-var-info"> 1874 <term> 1875 <option><![CDATA[--read-var-info=<yes|no> [default: no] ]]></option> 1876 </term> 1877 <listitem> 1878 <para>When enabled, Valgrind will read information about 1879 variable types and locations from DWARF3 debug info. 1880 This slows Valgrind startup significantly and makes it use significantly 1881 more memory, but for the tools that can take advantage of it (Memcheck, 1882 Helgrind, DRD) it can result in more precise error messages. For example, 1883 here are some standard errors issued by Memcheck:</para> 1884<programlisting><![CDATA[ 1885==15363== Uninitialised byte(s) found during client check request 1886==15363== at 0x80484A9: croak (varinfo1.c:28) 1887==15363== by 0x8048544: main (varinfo1.c:55) 1888==15363== Address 0x80497f7 is 7 bytes inside data symbol "global_i2" 1889==15363== 1890==15363== Uninitialised byte(s) found during client check request 1891==15363== at 0x80484A9: croak (varinfo1.c:28) 1892==15363== by 0x8048550: main (varinfo1.c:56) 1893==15363== Address 0xbea0d0cc is on thread 1's stack 1894==15363== in frame #1, created by main (varinfo1.c:45) 1895]]></programlisting> 1896 1897 <para>And here are the same errors with 1898 <option>--read-var-info=yes</option>:</para> 1899 1900<programlisting><![CDATA[ 1901==15370== Uninitialised byte(s) found during client check request 1902==15370== at 0x80484A9: croak (varinfo1.c:28) 1903==15370== by 0x8048544: main (varinfo1.c:55) 1904==15370== Location 0x80497f7 is 0 bytes inside global_i2[7], 1905==15370== a global variable declared at varinfo1.c:41 1906==15370== 1907==15370== Uninitialised byte(s) found during client check request 1908==15370== at 0x80484A9: croak (varinfo1.c:28) 1909==15370== by 0x8048550: main (varinfo1.c:56) 1910==15370== Location 0xbeb4a0cc is 0 bytes inside local var "local" 1911==15370== declared at varinfo1.c:46, in frame #1 of thread 1 1912]]></programlisting> 1913 </listitem> 1914 </varlistentry> 1915 1916 <varlistentry id="opt.vgdb-poll" xreflabel="--vgdb-poll"> 1917 <term> 1918 <option><![CDATA[--vgdb-poll=<number> [default: 5000] ]]></option> 1919 </term> 1920 <listitem> 1921 <para> As part of its main loop, the Valgrind scheduler will 1922 poll to check if some activity (such as an external command or 1923 some input from a gdb) has to be handled by gdbserver. This 1924 activity poll will be done after having run the given number of 1925 basic blocks (or slightly more than the given number of basic 1926 blocks). This poll is quite cheap so the default value is set 1927 relatively low. You might further decrease this value if vgdb 1928 cannot use ptrace system call to interrupt Valgrind if all 1929 threads are (most of the time) blocked in a system call. 1930 </para> 1931 </listitem> 1932 </varlistentry> 1933 1934 <varlistentry id="opt.vgdb-shadow-registers" xreflabel="--vgdb-shadow-registers"> 1935 <term> 1936 <option><![CDATA[--vgdb-shadow-registers=no|yes [default: no] ]]></option> 1937 </term> 1938 <listitem> 1939 <para> When activated, gdbserver will expose the Valgrind shadow registers 1940 to GDB. With this, the value of the Valgrind shadow registers can be examined 1941 or changed using GDB. Exposing shadow registers only works with GDB version 1942 7.1 or later. 1943 </para> 1944 </listitem> 1945 </varlistentry> 1946 1947 <varlistentry id="opt.vgdb-prefix" xreflabel="--vgdb-prefix"> 1948 <term> 1949 <option><![CDATA[--vgdb-prefix=<prefix> [default: /tmp/vgdb-pipe] ]]></option> 1950 </term> 1951 <listitem> 1952 <para> To communicate with gdb/vgdb, the Valgrind gdbserver 1953 creates 3 files (2 named FIFOs and a mmap shared memory 1954 file). The prefix option controls the directory and prefix for 1955 the creation of these files. 1956 </para> 1957 </listitem> 1958 </varlistentry> 1959 1960 <varlistentry id="opt.run-libc-freeres" xreflabel="--run-libc-freeres"> 1961 <term> 1962 <option><![CDATA[--run-libc-freeres=<yes|no> [default: yes] ]]></option> 1963 </term> 1964 <listitem> 1965 <para>This option is only relevant when running Valgrind on Linux.</para> 1966 1967 <para>The GNU C library (<function>libc.so</function>), which is 1968 used by all programs, may allocate memory for its own uses. 1969 Usually it doesn't bother to free that memory when the program 1970 ends—there would be no point, since the Linux kernel reclaims 1971 all process resources when a process exits anyway, so it would 1972 just slow things down.</para> 1973 1974 <para>The glibc authors realised that this behaviour causes leak 1975 checkers, such as Valgrind, to falsely report leaks in glibc, when 1976 a leak check is done at exit. In order to avoid this, they 1977 provided a routine called <function>__libc_freeres</function> 1978 specifically to make glibc release all memory it has allocated. 1979 Memcheck therefore tries to run 1980 <function>__libc_freeres</function> at exit.</para> 1981 1982 <para>Unfortunately, in some very old versions of glibc, 1983 <function>__libc_freeres</function> is sufficiently buggy to cause 1984 segmentation faults. This was particularly noticeable on Red Hat 1985 7.1. So this option is provided in order to inhibit the run of 1986 <function>__libc_freeres</function>. If your program seems to run 1987 fine on Valgrind, but segfaults at exit, you may find that 1988 <option>--run-libc-freeres=no</option> fixes that, although at the 1989 cost of possibly falsely reporting space leaks in 1990 <filename>libc.so</filename>.</para> 1991 </listitem> 1992 </varlistentry> 1993 1994 <varlistentry id="opt.sim-hints" xreflabel="--sim-hints"> 1995 <term> 1996 <option><![CDATA[--sim-hints=hint1,hint2,... ]]></option> 1997 </term> 1998 <listitem> 1999 <para>Pass miscellaneous hints to Valgrind which slightly modify 2000 the simulated behaviour in nonstandard or dangerous ways, possibly 2001 to help the simulation of strange features. By default no hints 2002 are enabled. Use with caution! Currently known hints are:</para> 2003 2004 <itemizedlist> 2005 <listitem> 2006 <para><option>lax-ioctls: </option> Be very lax about ioctl 2007 handling; the only assumption is that the size is 2008 correct. Doesn't require the full buffer to be initialized 2009 when writing. Without this, using some device drivers with a 2010 large number of strange ioctl commands becomes very 2011 tiresome.</para> 2012 </listitem> 2013 2014 <listitem> 2015 <para><option>fuse-compatible: </option> Enable special 2016 handling for certain system calls that may block in a FUSE 2017 file-system. This may be necessary when running Valgrind 2018 on a multi-threaded program that uses one thread to manage 2019 a FUSE file-system and another thread to access that 2020 file-system. 2021 </para> 2022 </listitem> 2023 2024 <listitem> 2025 <para><option>enable-outer: </option> Enable some special 2026 magic needed when the program being run is itself 2027 Valgrind.</para> 2028 </listitem> 2029 2030 <listitem> 2031 <para><option>no-inner-prefix: </option> Disable printing 2032 a prefix <option>></option> in front of each stdout or 2033 stderr output line in an inner Valgrind being run by an 2034 outer Valgrind. This is useful when running Valgrind 2035 regression tests in an outer/inner setup. Note that the 2036 prefix <option>></option> will always be printed in 2037 front of the inner debug logging lines.</para> 2038 </listitem> 2039 <listitem> 2040 <para><option>no-nptl-pthread-stackcache: </option> 2041 This hint is only relevant when running Valgrind on Linux.</para> 2042 2043 <para>The GNU glibc pthread library 2044 (<function>libpthread.so</function>), which is used by 2045 pthread programs, maintains a cache of pthread stacks. 2046 When a pthread terminates, the memory used for the pthread 2047 stack and some thread local storage related data structure 2048 are not always directly released. This memory is kept in 2049 a cache (up to a certain size), and is re-used if a new 2050 thread is started.</para> 2051 2052 <para>This cache causes the helgrind tool to report some 2053 false positive race condition errors on this cached 2054 memory, as helgrind does not understand the internal glibc 2055 cache synchronisation primitives. So, when using helgrind, 2056 disabling the cache helps to avoid false positive race 2057 conditions, in particular when using thread local storage 2058 variables (e.g. variables using the 2059 <function>__thread</function> qualifier).</para> 2060 2061 <para>When using the memcheck tool, disabling the cache 2062 ensures the memory used by glibc to handle __thread 2063 variables is directly released when a thread 2064 terminates.</para> 2065 2066 <para>Note: Valgrind disables the cache using some internal 2067 knowledge of the glibc stack cache implementation and by 2068 examining the debug information of the pthread 2069 library. This technique is thus somewhat fragile and might 2070 not work for all glibc versions. This has been succesfully 2071 tested with various glibc versions (e.g. 2.11, 2.16, 2.18) 2072 on various platforms.</para> 2073 </listitem> 2074 </itemizedlist> 2075 </listitem> 2076 </varlistentry> 2077 2078 <varlistentry id="opt.fair-sched" xreflabel="--fair-sched"> 2079 <term> 2080 <option><![CDATA[--fair-sched=<no|yes|try> [default: no] ]]></option> 2081 </term> 2082 2083 <listitem> <para>The <option>--fair-sched</option> option controls 2084 the locking mechanism used by Valgrind to serialise thread 2085 execution. The locking mechanism controls the way the threads 2086 are scheduled, and different settings give different trade-offs 2087 between fairness and performance. For more details about the 2088 Valgrind thread serialisation scheme and its impact on 2089 performance and thread scheduling, see 2090 <xref linkend="&vg-pthreads-perf-sched-id;"/>.</para> 2091 2092 <itemizedlist> 2093 <listitem> <para>The value <option>--fair-sched=yes</option> 2094 activates a fair scheduler. In short, if multiple threads are 2095 ready to run, the threads will be scheduled in a round robin 2096 fashion. This mechanism is not available on all platforms or 2097 Linux versions. If not available, 2098 using <option>--fair-sched=yes</option> will cause Valgrind to 2099 terminate with an error.</para> 2100 <para>You may find this setting improves overall 2101 responsiveness if you are running an interactive 2102 multithreaded program, for example a web browser, on 2103 Valgrind.</para> 2104 </listitem> 2105 2106 <listitem> <para>The value <option>--fair-sched=try</option> 2107 activates fair scheduling if available on the 2108 platform. Otherwise, it will automatically fall back 2109 to <option>--fair-sched=no</option>.</para> 2110 </listitem> 2111 2112 <listitem> <para>The value <option>--fair-sched=no</option> activates 2113 a scheduler which does not guarantee fairness 2114 between threads ready to run, but which in general gives the 2115 highest performance.</para> 2116 </listitem> 2117 </itemizedlist> 2118 </listitem> 2119 2120 </varlistentry> 2121 2122 <varlistentry id="opt.kernel-variant" xreflabel="--kernel-variant"> 2123 <term> 2124 <option>--kernel-variant=variant1,variant2,...</option> 2125 </term> 2126 <listitem> 2127 <para>Handle system calls and ioctls arising from minor variants 2128 of the default kernel for this platform. This is useful for 2129 running on hacked kernels or with kernel modules which support 2130 nonstandard ioctls, for example. Use with caution. If you don't 2131 understand what this option does then you almost certainly don't 2132 need it. Currently known variants are:</para> 2133 <itemizedlist> 2134 <listitem> 2135 <para><option>bproc</option>: support the 2136 <function>sys_broc</function> system call on x86. This is for 2137 running on BProc, which is a minor variant of standard Linux which 2138 is sometimes used for building clusters. 2139 </para> 2140 </listitem> 2141 <listitem> 2142 <para><option>android-no-hw-tls</option>: some 2143 versions of the Android emulator for ARM do not provide a 2144 hardware TLS (thread-local state) register, and Valgrind 2145 crashes at startup. Use this variant to select software 2146 support for TLS. 2147 </para> 2148 </listitem> 2149 <listitem> 2150 <para><option>android-gpu-sgx5xx</option>: use this to 2151 support handling of proprietary ioctls for the PowerVR SGX 2152 5XX series of GPUs on Android devices. Failure to select 2153 this does not cause stability problems, but may cause 2154 Memcheck to report false errors after the program performs 2155 GPU-specific ioctls. 2156 </para> 2157 </listitem> 2158 <listitem> 2159 <para><option>android-gpu-adreno3xx</option>: similarly, use 2160 this to support handling of proprietary ioctls for the 2161 Qualcomm Adreno 3XX series of GPUs on Android devices. 2162 </para> 2163 </listitem> 2164 </itemizedlist> 2165 </listitem> 2166 </varlistentry> 2167 2168 <varlistentry id="opt.merge-recursive-frames" xreflabel="--merge-recursive-frames"> 2169 <term> 2170 <option><![CDATA[--merge-recursive-frames=<number> [default: 0] ]]></option> 2171 </term> 2172 <listitem> 2173 <para>Some recursive algorithms, for example balanced binary 2174 tree implementations, create many different stack traces, each 2175 containing cycles of calls. A cycle is defined as two identical 2176 program counter values separated by zero or more other program 2177 counter values. Valgrind may then use a lot of memory to store 2178 all these stack traces. This is a poor use of memory 2179 considering that such stack traces contain repeated 2180 uninteresting recursive calls instead of more interesting 2181 information such as the function that has initiated the 2182 recursive call. 2183 </para> 2184 <para>The option <option>--merge-recursive-frames=<number></option> 2185 instructs Valgrind to detect and merge recursive call cycles 2186 having a size of up to <option><number></option> 2187 frames. When such a cycle is detected, Valgrind records the 2188 cycle in the stack trace as a unique program counter. 2189 </para> 2190 <para> 2191 The value 0 (the default) causes no recursive call merging. 2192 A value of 1 will cause stack traces of simple recursive algorithms 2193 (for example, a factorial implementation) to be collapsed. 2194 A value of 2 will usually be needed to collapse stack traces produced 2195 by recursive algorithms such as binary trees, quick sort, etc. 2196 Higher values might be needed for more complex recursive algorithms. 2197 </para> 2198 <para>Note: recursive calls are detected by analysis of program 2199 counter values. They are not detected by looking at function 2200 names.</para> 2201 </listitem> 2202 </varlistentry> 2203 2204 <varlistentry id="opt.num-transtab-sectors" xreflabel="--num-transtab-sectors"> 2205 <term> 2206 <option><![CDATA[--num-transtab-sectors=<number> [default: 6 2207 for Android platforms, 16 for all others] ]]></option> 2208 </term> 2209 <listitem> 2210 <para>Valgrind translates and instruments your program's machine 2211 code in small fragments (basic blocks). The translations are stored in a 2212 translation cache that is divided into a number of sections 2213 (sectors). If the cache is full, the sector containing the 2214 oldest translations is emptied and reused. If these old 2215 translations are needed again, Valgrind must re-translate and 2216 re-instrument the corresponding machine code, which is 2217 expensive. If the "executed instructions" working set of a 2218 program is big, increasing the number of sectors may improve 2219 performance by reducing the number of re-translations needed. 2220 Sectors are allocated on demand. Once allocated, a sector can 2221 never be freed, and occupies considerable space, depending on the tool 2222 and the value of <option>--avg-transtab-entry-size</option> 2223 (about 40 MB per sector for Memcheck). Use the 2224 option <option>--stats=yes</option> to obtain precise 2225 information about the memory used by a sector and the allocation 2226 and recycling of sectors.</para> 2227 </listitem> 2228 </varlistentry> 2229 2230 <varlistentry id="opt.avg-transtab-entry-size" xreflabel="--avg-transtab-entry-size"> 2231 <term> 2232 <option><![CDATA[--avg-transtab-entry-size=<number> [default: 0, 2233 meaning use tool provided default] ]]></option> 2234 </term> 2235 <listitem> 2236 <para>Average size of translated basic block. This average size 2237 is used to dimension the size of a sector. 2238 Each tool provides a default value to be used. 2239 If this default value is too small, the translation sectors 2240 will become full too quickly. If this default value is too big, 2241 a significant part of the translation sector memory will be unused. 2242 Note that the average size of a basic block translation depends 2243 on the tool, and might depend on tool options. For example, 2244 the memcheck option <option>--track-origins=yes</option> 2245 increases the size of the basic block translations. 2246 Use <option>--avg-transtab-entry-size</option> to tune the size of the 2247 sectors, either to gain memory or to avoid too many retranslations. 2248 </para> 2249 </listitem> 2250 </varlistentry> 2251 2252 <varlistentry id="opt.aspace-minaddr" xreflabel="----aspace-minaddr"> 2253 <term> 2254 <option><![CDATA[--aspace-minaddr=<address> [default: depends 2255 on the platform] ]]></option> 2256 </term> 2257 <listitem> 2258 <para>To avoid potential conflicts with some system libraries, 2259 Valgrind does not use the address space 2260 below <option>--aspace-minaddr</option> value, keeping it 2261 reserved in case a library specifically requests memory in this 2262 region. So, some "pessimistic" value is guessed by Valgrind 2263 depending on the platform. On linux, by default, Valgrind avoids 2264 using the first 64MB even if typically there is no conflict in 2265 this complete zone. You can use the 2266 option <option>--aspace-minaddr</option> to have your memory 2267 hungry application benefitting from more of this lower memory. 2268 On the other hand, if you encounter a conflict, increasing 2269 aspace-minaddr value might solve it. Conflicts will typically 2270 manifest themselves with mmap failures in the low range of the 2271 address space. The 2272 provided <computeroutput>address</computeroutput> must be page 2273 aligned and must be equal or bigger to 0x1000 (4KB). To find the 2274 default value on your platform, do something such as 2275 <computeroutput>valgrind -d -d date 2>&1 | grep -i minaddr</computeroutput>. 2276 Values lower than 0x10000 (64KB) are known to create problems 2277 on some distributions. 2278 </para> 2279 </listitem> 2280 </varlistentry> 2281 2282 <varlistentry id="opt.valgrind-stacksize" xreflabel="----valgrind-stacksize"> 2283 <term> 2284 <option><![CDATA[--valgrind-stacksize=<number> [default: 1MB] ]]></option> 2285 </term> 2286 <listitem> 2287 <para>For each thread, Valgrind needs its own 'private' stack. 2288 The default size for these stacks is largely dimensioned, and so 2289 should be sufficient in most cases. In case the size is too small, 2290 Valgrind will segfault. Before segfaulting, a warning might be produced 2291 by Valgrind when approaching the limit. 2292 </para> 2293 <para> 2294 Use the option <option>--valgrind-stacksize</option> if such an (unlikely) 2295 warning is produced, or Valgrind dies due to a segmentation violation. 2296 Such segmentation violations have been seen when demangling huge C++ 2297 symbols. 2298 </para> 2299 <para>If your application uses many threads and needs a lot of memory, you can 2300 gain some memory by reducing the size of these Valgrind stacks using 2301 the option <option>--valgrind-stacksize</option>. 2302 </para> 2303 </listitem> 2304 </varlistentry> 2305 2306 <varlistentry id="opt.show-emwarns" xreflabel="--show-emwarns"> 2307 <term> 2308 <option><![CDATA[--show-emwarns=<yes|no> [default: no] ]]></option> 2309 </term> 2310 <listitem> 2311 <para>When enabled, Valgrind will emit warnings about its CPU 2312 emulation in certain cases. These are usually not 2313 interesting.</para> 2314 </listitem> 2315 </varlistentry> 2316 2317 <varlistentry id="opt.require-text-symbol" 2318 xreflabel="--require-text-symbol"> 2319 <term> 2320 <option><![CDATA[--require-text-symbol=:sonamepatt:fnnamepatt]]></option> 2321 </term> 2322 <listitem> 2323 <para>When a shared object whose soname 2324 matches <varname>sonamepatt</varname> is loaded into the 2325 process, examine all the text symbols it exports. If none of 2326 those match <varname>fnnamepatt</varname>, print an error 2327 message and abandon the run. This makes it possible to ensure 2328 that the run does not continue unless a given shared object 2329 contains a particular function name. 2330 </para> 2331 <para> 2332 Both <varname>sonamepatt</varname> and 2333 <varname>fnnamepatt</varname> can be written using the usual 2334 <varname>?</varname> and <varname>*</varname> wildcards. For 2335 example: <varname>":*libc.so*:foo?bar"</varname>. You may use 2336 characters other than a colon to separate the two patterns. It 2337 is only important that the first character and the separator 2338 character are the same. For example, the above example could 2339 also be written <varname>"Q*libc.so*Qfoo?bar"</varname>. 2340 Multiple <varname> --require-text-symbol</varname> flags are 2341 allowed, in which case shared objects that are loaded into 2342 the process will be checked against all of them. 2343 </para> 2344 <para> 2345 The purpose of this is to support reliable usage of marked-up 2346 libraries. For example, suppose we have a version of GCC's 2347 <varname>libgomp.so</varname> which has been marked up with 2348 annotations to support Helgrind. It is only too easy and 2349 confusing to load the wrong, un-annotated 2350 <varname>libgomp.so</varname> into the application. So the idea 2351 is: add a text symbol in the marked-up library, for 2352 example <varname>annotated_for_helgrind_3_6</varname>, and then 2353 give the flag 2354 <varname>--require-text-symbol=:*libgomp*so*:annotated_for_helgrind_3_6</varname> 2355 so that when <varname>libgomp.so</varname> is loaded, Valgrind 2356 scans its symbol table, and if the symbol isn't present the run 2357 is aborted, rather than continuing silently with the 2358 un-marked-up library. Note that you should put the entire flag 2359 in quotes to stop shells expanding up the <varname>*</varname> 2360 and <varname>?</varname> wildcards. 2361 </para> 2362 </listitem> 2363 </varlistentry> 2364 2365 <varlistentry id="opt.soname-synonyms" 2366 xreflabel="--soname-synonyms"> 2367 <term> 2368 <option><![CDATA[--soname-synonyms=syn1=pattern1,syn2=pattern2,...]]></option> 2369 </term> 2370 <listitem> 2371 <para>When a shared library is loaded, Valgrind checks for 2372 functions in the library that must be replaced or wrapped. 2373 For example, Memcheck replaces all malloc related 2374 functions (malloc, free, calloc, ...) with its own versions. 2375 Such replacements are done by default only in shared libraries whose 2376 soname matches a predefined soname pattern (e.g. 2377 <varname>libc.so*</varname> on linux). 2378 By default, no replacement is done for a statically linked 2379 library or for alternative libraries such as tcmalloc. 2380 In some cases, the replacements allow 2381 <option>--soname-synonyms</option> to specify one additional 2382 synonym pattern, giving flexibility in the replacement. </para> 2383 2384 <para>Currently, this flexibility is only allowed for the 2385 malloc related functions, using the 2386 synonym <varname>somalloc</varname>. This synonym is usable for 2387 all tools doing standard replacement of malloc related functions 2388 (e.g. memcheck, massif, drd, helgrind, exp-dhat, exp-sgcheck). 2389 </para> 2390 2391 <itemizedlist> 2392 <listitem> 2393 2394 <para>Alternate malloc library: to replace the malloc 2395 related functions in an alternate library with 2396 soname <varname>mymalloclib.so</varname>, give the 2397 option <option>--soname-synonyms=somalloc=mymalloclib.so</option>. 2398 A pattern can be used to match multiple libraries sonames. 2399 For 2400 example, <option>--soname-synonyms=somalloc=*tcmalloc*</option> 2401 will match the soname of all variants of the tcmalloc library 2402 (native, debug, profiled, ... tcmalloc variants). </para> 2403 <para>Note: the soname of a elf shared library can be 2404 retrieved using the readelf utility. </para> 2405 2406 </listitem> 2407 2408 <listitem> 2409 <para>Replacements in a statically linked library are done by 2410 using the <varname>NONE</varname> pattern. For example, if 2411 you link with <varname>libtcmalloc.a</varname>, memcheck 2412 will properly work when you give the 2413 option <option>--soname-synonyms=somalloc=NONE</option>. Note 2414 that a NONE pattern will match the main executable and any 2415 shared library having no soname. </para> 2416 </listitem> 2417 2418 <listitem> 2419 <para>To run a "default" Firefox build for Linux, in which 2420 JEMalloc is linked in to the main executable, 2421 use <option>--soname-synonyms=somalloc=NONE</option>. 2422 </para> 2423 </listitem> 2424 2425 </itemizedlist> 2426 </listitem> 2427 </varlistentry> 2428 2429 2430</variablelist> 2431<!-- end of xi:include in the manpage --> 2432 2433</sect2> 2434 2435 2436<sect2 id="manual-core.debugopts" xreflabel="Debugging Options"> 2437<title>Debugging Options</title> 2438 2439<!-- start of xi:include in the manpage --> 2440<para id="debug.opts.para">There are also some options for debugging 2441Valgrind itself. You shouldn't need to use them in the normal run of 2442things. If you wish to see the list, use the 2443<option>--help-debug</option> option.</para> 2444 2445<para>If you wish to debug your program rather than debugging 2446Valgrind itself, then you should use the options 2447<option>--vgdb=yes</option> or <option>--vgdb=full</option> 2448or <option>--db-attach=yes</option>. 2449</para> 2450 2451<!-- end of xi:include in the manpage --> 2452 2453</sect2> 2454 2455 2456<sect2 id="manual-core.defopts" xreflabel="Setting Default Options"> 2457<title>Setting Default Options</title> 2458 2459<para>Note that Valgrind also reads options from three places:</para> 2460 2461 <orderedlist> 2462 <listitem> 2463 <para>The file <computeroutput>~/.valgrindrc</computeroutput></para> 2464 </listitem> 2465 2466 <listitem> 2467 <para>The environment variable 2468 <computeroutput>$VALGRIND_OPTS</computeroutput></para> 2469 </listitem> 2470 2471 <listitem> 2472 <para>The file <computeroutput>./.valgrindrc</computeroutput></para> 2473 </listitem> 2474 </orderedlist> 2475 2476<para>These are processed in the given order, before the 2477command-line options. Options processed later override those 2478processed earlier; for example, options in 2479<computeroutput>./.valgrindrc</computeroutput> will take 2480precedence over those in 2481<computeroutput>~/.valgrindrc</computeroutput>. 2482</para> 2483 2484<para>Please note that the <computeroutput>./.valgrindrc</computeroutput> 2485file is ignored if it is marked as world writeable or not owned 2486by the current user. This is because the 2487<computeroutput>./.valgrindrc</computeroutput> can contain options that are 2488potentially harmful or can be used by a local attacker to execute code under 2489your user account. 2490</para> 2491 2492<para>Any tool-specific options put in 2493<computeroutput>$VALGRIND_OPTS</computeroutput> or the 2494<computeroutput>.valgrindrc</computeroutput> files should be 2495prefixed with the tool name and a colon. For example, if you 2496want Memcheck to always do leak checking, you can put the 2497following entry in <literal>~/.valgrindrc</literal>:</para> 2498 2499<programlisting><![CDATA[ 2500--memcheck:leak-check=yes]]></programlisting> 2501 2502<para>This will be ignored if any tool other than Memcheck is 2503run. Without the <computeroutput>memcheck:</computeroutput> 2504part, this will cause problems if you select other tools that 2505don't understand 2506<option>--leak-check=yes</option>.</para> 2507 2508</sect2> 2509 2510</sect1> 2511 2512 2513 2514<sect1 id="manual-core.pthreads" xreflabel="Support for Threads"> 2515<title>Support for Threads</title> 2516 2517<para>Threaded programs are fully supported.</para> 2518 2519<para>The main thing to point out with respect to threaded programs is 2520that your program will use the native threading library, but Valgrind 2521serialises execution so that only one (kernel) thread is running at a 2522time. This approach avoids the horrible implementation problems of 2523implementing a truly multithreaded version of Valgrind, but it does 2524mean that threaded apps never use more than one CPU simultaneously, 2525even if you have a multiprocessor or multicore machine.</para> 2526 2527<para>Valgrind doesn't schedule the threads itself. It merely ensures 2528that only one thread runs at once, using a simple locking scheme. The 2529actual thread scheduling remains under control of the OS kernel. What 2530this does mean, though, is that your program will see very different 2531scheduling when run on Valgrind than it does when running normally. 2532This is both because Valgrind is serialising the threads, and because 2533the code runs so much slower than normal.</para> 2534 2535<para>This difference in scheduling may cause your program to behave 2536differently, if you have some kind of concurrency, critical race, 2537locking, or similar, bugs. In that case you might consider using the 2538tools Helgrind and/or DRD to track them down.</para> 2539 2540<para>On Linux, Valgrind also supports direct use of the 2541<computeroutput>clone</computeroutput> system call, 2542<computeroutput>futex</computeroutput> and so on. 2543<computeroutput>clone</computeroutput> is supported where either 2544everything is shared (a thread) or nothing is shared (fork-like); partial 2545sharing will fail. 2546</para> 2547 2548<!-- Referenced from both the manual and manpage --> 2549<sect2 id="&vg-pthreads-perf-sched-id;" xreflabel="&vg-pthreads-perf-sched-label;"> 2550<title>Scheduling and Multi-Thread Performance</title> 2551 2552<para>A thread executes code only when it holds the abovementioned 2553lock. After executing some number of instructions, the running thread 2554will release the lock. All threads ready to run will then compete to 2555acquire the lock.</para> 2556 2557<para>The <option>--fair-sched</option> option controls the locking mechanism 2558used to serialise thread execution.</para> 2559 2560<para>The default pipe based locking mechanism 2561(<option>--fair-sched=no</option>) is available on all 2562platforms. Pipe based locking does not guarantee fairness between 2563threads: it is quite likely that a thread that has just released the 2564lock reacquires it immediately, even though other threads are ready to 2565run. When using pipe based locking, different runs of the same 2566multithreaded application might give very different thread 2567scheduling.</para> 2568 2569<para>An alternative locking mechanism, based on futexes, is available 2570on some platforms. If available, it is activated 2571by <option>--fair-sched=yes</option> or 2572<option>--fair-sched=try</option>. Futex based locking ensures 2573fairness (round-robin scheduling) between threads: if multiple threads 2574are ready to run, the lock will be given to the thread which first 2575requested the lock. Note that a thread which is blocked in a system 2576call (e.g. in a blocking read system call) has not (yet) requested the 2577lock: such a thread requests the lock only after the system call is 2578finished.</para> 2579 2580<para> The fairness of the futex based locking produces better 2581reproducibility of thread scheduling for different executions of a 2582multithreaded application. This better reproducibility is particularly 2583helpful when using Helgrind or DRD.</para> 2584 2585<para>Valgrind's use of thread serialisation implies that only one 2586thread at a time may run. On a multiprocessor/multicore system, the 2587running thread is assigned to one of the CPUs by the OS kernel 2588scheduler. When a thread acquires the lock, sometimes the thread will 2589be assigned to the same CPU as the thread that just released the 2590lock. Sometimes, the thread will be assigned to another CPU. When 2591using pipe based locking, the thread that just acquired the lock 2592will usually be scheduled on the same CPU as the thread that just 2593released the lock. With the futex based mechanism, the thread that 2594just acquired the lock will more often be scheduled on another 2595CPU.</para> 2596 2597<para>Valgrind's thread serialisation and CPU assignment by the OS 2598kernel scheduler can interact badly with the CPU frequency scaling 2599available on many modern CPUs. To decrease power consumption, the 2600frequency of a CPU or core is automatically decreased if the CPU/core 2601has not been used recently. If the OS kernel often assigns the thread 2602which just acquired the lock to another CPU/core, it is quite likely 2603that this CPU/core is currently at a low frequency. The frequency of 2604this CPU will be increased after some time. However, during this 2605time, the (only) running thread will have run at the low frequency. 2606Once this thread has run for some time, it will release the lock. 2607Another thread will acquire this lock, and might be scheduled again on 2608another CPU whose clock frequency was decreased in the 2609meantime.</para> 2610 2611<para>The futex based locking causes threads to change CPUs/cores more 2612often. So, if CPU frequency scaling is activated, the futex based 2613locking might decrease significantly the performance of a 2614multithreaded app running under Valgrind. Performance losses of up to 261550% degradation have been observed, as compared to running on a 2616machine for which CPU frequency scaling has been disabled. The pipe 2617based locking locking scheme also interacts badly with CPU frequency 2618scaling, with performance losses in the range 10..20% having been 2619observed.</para> 2620 2621<para>To avoid such performance degradation, you should indicate to 2622the kernel that all CPUs/cores should always run at maximum clock 2623speed. Depending on your Linux distribution, CPU frequency scaling 2624may be controlled using a graphical interface or using command line 2625such as 2626<computeroutput>cpufreq-selector</computeroutput> or 2627<computeroutput>cpufreq-set</computeroutput>. 2628</para> 2629 2630<para>An alternative way to avoid these problems is to tell the 2631OS scheduler to tie a Valgrind process to a specific (fixed) CPU using the 2632<computeroutput>taskset</computeroutput> command. This should ensure 2633that the selected CPU does not fall below its maximum frequency 2634setting so long as any thread of the program has work to do. 2635</para> 2636 2637</sect2> 2638 2639 2640</sect1> 2641 2642<sect1 id="manual-core.signals" xreflabel="Handling of Signals"> 2643<title>Handling of Signals</title> 2644 2645<para>Valgrind has a fairly complete signal implementation. It should be 2646able to cope with any POSIX-compliant use of signals.</para> 2647 2648<para>If you're using signals in clever ways (for example, catching 2649SIGSEGV, modifying page state and restarting the instruction), you're 2650probably relying on precise exceptions. In this case, you will need 2651to use <option>--vex-iropt-register-updates=allregs-at-mem-access</option> 2652or <option>--vex-iropt-register-updates=allregs-at-each-insn</option>. 2653</para> 2654 2655<para>If your program dies as a result of a fatal core-dumping signal, 2656Valgrind will generate its own core file 2657(<computeroutput>vgcore.NNNNN</computeroutput>) containing your program's 2658state. You may use this core file for post-mortem debugging with GDB or 2659similar. (Note: it will not generate a core if your core dump size limit is 26600.) At the time of writing the core dumps do not include all the floating 2661point register information.</para> 2662 2663<para>In the unlikely event that Valgrind itself crashes, the operating system 2664will create a core dump in the usual way.</para> 2665 2666</sect1> 2667 2668 2669 2670 2671 2672 2673 2674 2675<sect1 id="manual-core.install" xreflabel="Building and Installing"> 2676<title>Building and Installing Valgrind</title> 2677 2678<para>We use the standard Unix 2679<computeroutput>./configure</computeroutput>, 2680<computeroutput>make</computeroutput>, <computeroutput>make 2681install</computeroutput> mechanism. Once you have completed 2682<computeroutput>make install</computeroutput> you may then want 2683to run the regression tests 2684with <computeroutput>make regtest</computeroutput>. 2685</para> 2686 2687<para>In addition to the usual 2688<option>--prefix=/path/to/install/tree</option>, there are three 2689 options which affect how Valgrind is built: 2690<itemizedlist> 2691 2692 <listitem> 2693 <para><option>--enable-inner</option></para> 2694 <para>This builds Valgrind with some special magic hacks which make 2695 it possible to run it on a standard build of Valgrind (what the 2696 developers call "self-hosting"). Ordinarily you should not use 2697 this option as various kinds of safety checks are disabled. 2698 </para> 2699 </listitem> 2700 2701 <listitem> 2702 <para><option>--enable-only64bit</option></para> 2703 <para><option>--enable-only32bit</option></para> 2704 <para>On 64-bit platforms (amd64-linux, ppc64-linux, 2705 amd64-darwin), Valgrind is by default built in such a way that 2706 both 32-bit and 64-bit executables can be run. Sometimes this 2707 cleverness is a problem for a variety of reasons. These two 2708 options allow for single-target builds in this situation. If you 2709 issue both, the configure script will complain. Note they are 2710 ignored on 32-bit-only platforms (x86-linux, ppc32-linux, 2711 arm-linux, x86-darwin). 2712 </para> 2713 </listitem> 2714 2715</itemizedlist> 2716</para> 2717 2718<para>The <computeroutput>configure</computeroutput> script tests 2719the version of the X server currently indicated by the current 2720<computeroutput>$DISPLAY</computeroutput>. This is a known bug. 2721The intention was to detect the version of the current X 2722client libraries, so that correct suppressions could be selected 2723for them, but instead the test checks the server version. This 2724is just plain wrong.</para> 2725 2726<para>If you are building a binary package of Valgrind for 2727distribution, please read <literal>README_PACKAGERS</literal> 2728<xref linkend="dist.readme-packagers"/>. It contains some 2729important information.</para> 2730 2731<para>Apart from that, there's not much excitement here. Let us 2732know if you have build problems.</para> 2733 2734</sect1> 2735 2736 2737 2738<sect1 id="manual-core.problems" xreflabel="If You Have Problems"> 2739<title>If You Have Problems</title> 2740 2741<para>Contact us at <ulink url="&vg-url;">&vg-url;</ulink>.</para> 2742 2743<para>See <xref linkend="manual-core.limits"/> for the known 2744limitations of Valgrind, and for a list of programs which are 2745known not to work on it.</para> 2746 2747<para>All parts of the system make heavy use of assertions and 2748internal self-checks. They are permanently enabled, and we have no 2749plans to disable them. If one of them breaks, please mail us!</para> 2750 2751<para>If you get an assertion failure 2752in <filename>m_mallocfree.c</filename>, this may have happened because 2753your program wrote off the end of a heap block, or before its 2754beginning, thus corrupting heap metadata. Valgrind hopefully will have 2755emitted a message to that effect before dying in this way.</para> 2756 2757<para>Read the <xref linkend="FAQ"/> for more advice about common problems, 2758crashes, etc.</para> 2759 2760</sect1> 2761 2762 2763 2764<sect1 id="manual-core.limits" xreflabel="Limitations"> 2765<title>Limitations</title> 2766 2767<para>The following list of limitations seems long. However, most 2768programs actually work fine.</para> 2769 2770<para>Valgrind will run programs on the supported platforms 2771subject to the following constraints:</para> 2772 2773 <itemizedlist> 2774 <listitem> 2775 <para>On x86 and amd64, there is no support for 3DNow! 2776 instructions. If the translator encounters these, Valgrind will 2777 generate a SIGILL when the instruction is executed. Apart from 2778 that, on x86 and amd64, essentially all instructions are supported, 2779 up to and including AVX and AES in 64-bit mode and SSSE3 in 32-bit 2780 mode. 32-bit mode does in fact support the bare minimum SSE4 2781 instructions needed to run programs on MacOSX 10.6 on 32-bit 2782 targets. 2783 </para> 2784 </listitem> 2785 2786 <listitem> 2787 <para>On ppc32 and ppc64, almost all integer, floating point and 2788 Altivec instructions are supported. Specifically: integer and FP 2789 insns that are mandatory for PowerPC, the "General-purpose 2790 optional" group (fsqrt, fsqrts, stfiwx), the "Graphics optional" 2791 group (fre, fres, frsqrte, frsqrtes), and the Altivec (also known 2792 as VMX) SIMD instruction set, are supported. Also, instructions 2793 from the Power ISA 2.05 specification, as present in POWER6 CPUs, 2794 are supported.</para> 2795 </listitem> 2796 2797 <listitem> 2798 <para>On ARM, essentially the entire ARMv7-A instruction set 2799 is supported, in both ARM and Thumb mode. ThumbEE and Jazelle are 2800 not supported. NEON, VFPv3 and ARMv6 media support is fairly 2801 complete. 2802 </para> 2803 </listitem> 2804 2805 <listitem> 2806 <para>If your program does its own memory management, rather than 2807 using malloc/new/free/delete, it should still work, but Memcheck's 2808 error checking won't be so effective. If you describe your 2809 program's memory management scheme using "client requests" (see 2810 <xref linkend="manual-core-adv.clientreq"/>), Memcheck can do 2811 better. Nevertheless, using malloc/new and free/delete is still 2812 the best approach.</para> 2813 </listitem> 2814 2815 <listitem> 2816 <para>Valgrind's signal simulation is not as robust as it could be. 2817 Basic POSIX-compliant sigaction and sigprocmask functionality is 2818 supplied, but it's conceivable that things could go badly awry if you 2819 do weird things with signals. Workaround: don't. Programs that do 2820 non-POSIX signal tricks are in any case inherently unportable, so 2821 should be avoided if possible.</para> 2822 </listitem> 2823 2824 <listitem> 2825 <para>Machine instructions, and system calls, have been implemented 2826 on demand. So it's possible, although unlikely, that a program will 2827 fall over with a message to that effect. If this happens, please 2828 report all the details printed out, so we can try and implement the 2829 missing feature.</para> 2830 </listitem> 2831 2832 <listitem> 2833 <para>Memory consumption of your program is majorly increased 2834 whilst running under Valgrind's Memcheck tool. This is due to the 2835 large amount of administrative information maintained behind the 2836 scenes. Another cause is that Valgrind dynamically translates the 2837 original executable. Translated, instrumented code is 12-18 times 2838 larger than the original so you can easily end up with 150+ MB of 2839 translations when running (eg) a web browser.</para> 2840 </listitem> 2841 2842 <listitem> 2843 <para>Valgrind can handle dynamically-generated code just fine. If 2844 you regenerate code over the top of old code (ie. at the same 2845 memory addresses), if the code is on the stack Valgrind will 2846 realise the code has changed, and work correctly. This is 2847 necessary to handle the trampolines GCC uses to implemented nested 2848 functions. If you regenerate code somewhere other than the stack, 2849 and you are running on an 32- or 64-bit x86 CPU, you will need to 2850 use the <option>--smc-check=all</option> option, and Valgrind will 2851 run more slowly than normal. Or you can add client requests that 2852 tell Valgrind when your program has overwritten code. 2853 </para> 2854 <para> On other platforms (ARM, PowerPC) Valgrind observes and 2855 honours the cache invalidation hints that programs are obliged to 2856 emit to notify new code, and so self-modifying-code support should 2857 work automatically, without the need 2858 for <option>--smc-check=all</option>.</para> 2859 </listitem> 2860 2861 <listitem> 2862 <para>Valgrind has the following limitations 2863 in its implementation of x86/AMD64 floating point relative to 2864 IEEE754.</para> 2865 2866 <para>Precision: There is no support for 80 bit arithmetic. 2867 Internally, Valgrind represents all such "long double" numbers in 64 2868 bits, and so there may be some differences in results. Whether or 2869 not this is critical remains to be seen. Note, the x86/amd64 2870 fldt/fstpt instructions (read/write 80-bit numbers) are correctly 2871 simulated, using conversions to/from 64 bits, so that in-memory 2872 images of 80-bit numbers look correct if anyone wants to see.</para> 2873 2874 <para>The impression observed from many FP regression tests is that 2875 the accuracy differences aren't significant. Generally speaking, if 2876 a program relies on 80-bit precision, there may be difficulties 2877 porting it to non x86/amd64 platforms which only support 64-bit FP 2878 precision. Even on x86/amd64, the program may get different results 2879 depending on whether it is compiled to use SSE2 instructions (64-bits 2880 only), or x87 instructions (80-bit). The net effect is to make FP 2881 programs behave as if they had been run on a machine with 64-bit IEEE 2882 floats, for example PowerPC. On amd64 FP arithmetic is done by 2883 default on SSE2, so amd64 looks more like PowerPC than x86 from an FP 2884 perspective, and there are far fewer noticeable accuracy differences 2885 than with x86.</para> 2886 2887 <para>Rounding: Valgrind does observe the 4 IEEE-mandated rounding 2888 modes (to nearest, to +infinity, to -infinity, to zero) for the 2889 following conversions: float to integer, integer to float where 2890 there is a possibility of loss of precision, and float-to-float 2891 rounding. For all other FP operations, only the IEEE default mode 2892 (round to nearest) is supported.</para> 2893 2894 <para>Numeric exceptions in FP code: IEEE754 defines five types of 2895 numeric exception that can happen: invalid operation (sqrt of 2896 negative number, etc), division by zero, overflow, underflow, 2897 inexact (loss of precision).</para> 2898 2899 <para>For each exception, two courses of action are defined by IEEE754: 2900 either (1) a user-defined exception handler may be called, or (2) a 2901 default action is defined, which "fixes things up" and allows the 2902 computation to proceed without throwing an exception.</para> 2903 2904 <para>Currently Valgrind only supports the default fixup actions. 2905 Again, feedback on the importance of exception support would be 2906 appreciated.</para> 2907 2908 <para>When Valgrind detects that the program is trying to exceed any 2909 of these limitations (setting exception handlers, rounding mode, or 2910 precision control), it can print a message giving a traceback of 2911 where this has happened, and continue execution. This behaviour used 2912 to be the default, but the messages are annoying and so showing them 2913 is now disabled by default. Use <option>--show-emwarns=yes</option> to see 2914 them.</para> 2915 2916 <para>The above limitations define precisely the IEEE754 'default' 2917 behaviour: default fixup on all exceptions, round-to-nearest 2918 operations, and 64-bit precision.</para> 2919 </listitem> 2920 2921 <listitem> 2922 <para>Valgrind has the following limitations in 2923 its implementation of x86/AMD64 SSE2 FP arithmetic, relative to 2924 IEEE754.</para> 2925 2926 <para>Essentially the same: no exceptions, and limited observance of 2927 rounding mode. Also, SSE2 has control bits which make it treat 2928 denormalised numbers as zero (DAZ) and a related action, flush 2929 denormals to zero (FTZ). Both of these cause SSE2 arithmetic to be 2930 less accurate than IEEE requires. Valgrind detects, ignores, and can 2931 warn about, attempts to enable either mode.</para> 2932 </listitem> 2933 2934 <listitem> 2935 <para>Valgrind has the following limitations in 2936 its implementation of ARM VFPv3 arithmetic, relative to 2937 IEEE754.</para> 2938 2939 <para>Essentially the same: no exceptions, and limited observance 2940 of rounding mode. Also, switching the VFP unit into vector mode 2941 will cause Valgrind to abort the program -- it has no way to 2942 emulate vector uses of VFP at a reasonable performance level. This 2943 is no big deal given that non-scalar uses of VFP instructions are 2944 in any case deprecated.</para> 2945 </listitem> 2946 2947 <listitem> 2948 <para>Valgrind has the following limitations 2949 in its implementation of PPC32 and PPC64 floating point 2950 arithmetic, relative to IEEE754.</para> 2951 2952 <para>Scalar (non-Altivec): Valgrind provides a bit-exact emulation of 2953 all floating point instructions, except for "fre" and "fres", which are 2954 done more precisely than required by the PowerPC architecture specification. 2955 All floating point operations observe the current rounding mode. 2956 </para> 2957 2958 <para>However, fpscr[FPRF] is not set after each operation. That could 2959 be done but would give measurable performance overheads, and so far 2960 no need for it has been found.</para> 2961 2962 <para>As on x86/AMD64, IEEE754 exceptions are not supported: all floating 2963 point exceptions are handled using the default IEEE fixup actions. 2964 Valgrind detects, ignores, and can warn about, attempts to unmask 2965 the 5 IEEE FP exception kinds by writing to the floating-point status 2966 and control register (fpscr). 2967 </para> 2968 2969 <para>Vector (Altivec, VMX): essentially as with x86/AMD64 SSE/SSE2: 2970 no exceptions, and limited observance of rounding mode. 2971 For Altivec, FP arithmetic 2972 is done in IEEE/Java mode, which is more accurate than the Linux default 2973 setting. "More accurate" means that denormals are handled properly, 2974 rather than simply being flushed to zero.</para> 2975 </listitem> 2976 </itemizedlist> 2977 2978 <para>Programs which are known not to work are:</para> 2979 <itemizedlist> 2980 <listitem> 2981 <para>emacs starts up but immediately concludes it is out of 2982 memory and aborts. It may be that Memcheck does not provide 2983 a good enough emulation of the 2984 <computeroutput>mallinfo</computeroutput> function. 2985 Emacs works fine if you build it to use 2986 the standard malloc/free routines.</para> 2987 </listitem> 2988 </itemizedlist> 2989 2990</sect1> 2991 2992 2993<sect1 id="manual-core.example" xreflabel="An Example Run"> 2994<title>An Example Run</title> 2995 2996<para>This is the log for a run of a small program using Memcheck. 2997The program is in fact correct, and the reported error is as the 2998result of a potentially serious code generation bug in GNU g++ 2999(snapshot 20010527).</para> 3000 3001<programlisting><![CDATA[ 3002sewardj@phoenix:~/newmat10$ ~/Valgrind-6/valgrind -v ./bogon 3003==25832== Valgrind 0.10, a memory error detector for x86 RedHat 7.1. 3004==25832== Copyright (C) 2000-2001, and GNU GPL'd, by Julian Seward. 3005==25832== Startup, with flags: 3006==25832== --suppressions=/home/sewardj/Valgrind/redhat71.supp 3007==25832== reading syms from /lib/ld-linux.so.2 3008==25832== reading syms from /lib/libc.so.6 3009==25832== reading syms from /mnt/pima/jrs/Inst/lib/libgcc_s.so.0 3010==25832== reading syms from /lib/libm.so.6 3011==25832== reading syms from /mnt/pima/jrs/Inst/lib/libstdc++.so.3 3012==25832== reading syms from /home/sewardj/Valgrind/valgrind.so 3013==25832== reading syms from /proc/self/exe 3014==25832== 3015==25832== Invalid read of size 4 3016==25832== at 0x8048724: BandMatrix::ReSize(int,int,int) (bogon.cpp:45) 3017==25832== by 0x80487AF: main (bogon.cpp:66) 3018==25832== Address 0xBFFFF74C is not stack'd, malloc'd or free'd 3019==25832== 3020==25832== ERROR SUMMARY: 1 errors from 1 contexts (suppressed: 0 from 0) 3021==25832== malloc/free: in use at exit: 0 bytes in 0 blocks. 3022==25832== malloc/free: 0 allocs, 0 frees, 0 bytes allocated. 3023==25832== For a detailed leak analysis, rerun with: --leak-check=yes 3024]]></programlisting> 3025 3026<para>The GCC folks fixed this about a week before GCC 3.0 3027shipped.</para> 3028 3029</sect1> 3030 3031 3032<sect1 id="manual-core.warnings" xreflabel="Warning Messages"> 3033<title>Warning Messages You Might See</title> 3034 3035<para>Some of these only appear if you run in verbose mode 3036(enabled by <option>-v</option>):</para> 3037 3038 <itemizedlist> 3039 3040 <listitem> 3041 <para><computeroutput>More than 100 errors detected. Subsequent 3042 errors will still be recorded, but in less detail than 3043 before.</computeroutput></para> 3044 3045 <para>After 100 different errors have been shown, Valgrind becomes 3046 more conservative about collecting them. It then requires only the 3047 program counters in the top two stack frames to match when deciding 3048 whether or not two errors are really the same one. Prior to this 3049 point, the PCs in the top four frames are required to match. This 3050 hack has the effect of slowing down the appearance of new errors 3051 after the first 100. The 100 constant can be changed by recompiling 3052 Valgrind.</para> 3053 </listitem> 3054 3055 <listitem> 3056 <para><computeroutput>More than 1000 errors detected. I'm not 3057 reporting any more. Final error counts may be inaccurate. Go fix 3058 your program!</computeroutput></para> 3059 3060 <para>After 1000 different errors have been detected, Valgrind 3061 ignores any more. It seems unlikely that collecting even more 3062 different ones would be of practical help to anybody, and it avoids 3063 the danger that Valgrind spends more and more of its time comparing 3064 new errors against an ever-growing collection. As above, the 1000 3065 number is a compile-time constant.</para> 3066 </listitem> 3067 3068 <listitem> 3069 <para><computeroutput>Warning: client switching stacks?</computeroutput></para> 3070 3071 <para>Valgrind spotted such a large change in the stack pointer 3072 that it guesses the client is switching to a different stack. At 3073 this point it makes a kludgey guess where the base of the new 3074 stack is, and sets memory permissions accordingly. At the moment 3075 "large change" is defined as a change of more that 2000000 in the 3076 value of the stack pointer register. If Valgrind guesses wrong, 3077 you may get many bogus error messages following this and/or have 3078 crashes in the stack trace recording code. You might avoid these 3079 problems by informing Valgrind about the stack bounds using 3080 VALGRIND_STACK_REGISTER client request. </para> 3081 3082 </listitem> 3083 3084 <listitem> 3085 <para><computeroutput>Warning: client attempted to close Valgrind's 3086 logfile fd <number></computeroutput></para> 3087 3088 <para>Valgrind doesn't allow the client to close the logfile, 3089 because you'd never see any diagnostic information after that point. 3090 If you see this message, you may want to use the 3091 <option>--log-fd=<number></option> option to specify a 3092 different logfile file-descriptor number.</para> 3093 </listitem> 3094 3095 <listitem> 3096 <para><computeroutput>Warning: noted but unhandled ioctl 3097 <number></computeroutput></para> 3098 3099 <para>Valgrind observed a call to one of the vast family of 3100 <computeroutput>ioctl</computeroutput> system calls, but did not 3101 modify its memory status info (because nobody has yet written a 3102 suitable wrapper). The call will still have gone through, but you may get 3103 spurious errors after this as a result of the non-update of the 3104 memory info.</para> 3105 </listitem> 3106 3107 <listitem> 3108 <para><computeroutput>Warning: set address range perms: large range 3109 <number></computeroutput></para> 3110 3111 <para>Diagnostic message, mostly for benefit of the Valgrind 3112 developers, to do with memory permissions.</para> 3113 </listitem> 3114 3115 </itemizedlist> 3116 3117</sect1> 3118 3119 3120 3121 3122 3123 3124</chapter> 3125