Dr. Memory
|
First we give cross-plaform guidelines for how to build your application, before giving specific compiler parameters for each platform.
For All Platforms
These cross-platform steps apply to Linux, Mac, and Windows.
Debug Information
In order to obtain line number information, compile your target application with debugging information enabled. On Linux, Dr. Memory supports ELF files with DWARF line information. On Mac, Dr. Memory supports Mach-O files with DWARF line information. On Windows, Dr. Memory supports PDB debug information (produced by Visual Studio) as well as PECOFF files with DWARF line information (produced by MinGW gcc).
Callstack Quality
You'll get better callstacks in error reports if you disable inlining. Dr. Memory should be able to determine callstacks in the presence of frame pointer optimizations (FPO) in most cases, but if you see strange callstacks in an optimized application consider disabling FPO.
If your application links with a static library that was built with frame pointer optimizations and you observe missing frames on your callstacks, try running with the Dr. Memory runtime options -no_callstack_use_top_fp
, -no_callstack_use_fp
, and -callstack_conservative
. These will add some additional overhead on malloc-intensive applications, but should eliminate skipped frames.
Linux
Here is a sample command line for compiling your application that combines all of the above recommendations:
g++ -g -fno-inline -fno-omit-frame-pointer myfile1.cpp myfile2.cpp -o myapp
Mac
Ensure your compiler is able to build 32-bit applications.
Dr. Memory currently only supports DWARF2 through DWARF4 line information on Mac, not stabs nor DWARF5. DWARF4 can be requested from the compiler with the -gdwarf-4
flag.
Here is a sample command line for compiling your application that combines all of the above recommendations:
c++ -m32 -g -gdwarf-4 -fno-inline -fno-omit-frame-pointer myfile1.cpp myfile2.cpp -o myapp
Windows Visual Studio
To include debug information, use the /Zi
flag to the Visual Studio compiler. From the IDE, Press Alt-F7 to bring up the configuration properties of your build target. Under "Configuration Properties | C/C++ |
General", the "Debug Information Format" entry should either say "Program
Database (/Zi)" or "Program Database for Edit and Continue (/ZI)". Additionally, under "Configuration Properties | Linker | Debugging", the "Generate Debug Info" entry should say "Yes (/DEBUG)". For Visual Studio 2015, under "Configuration Properties | Linker | Debugging", the "Generate Debug Info" entry should say "Optimize for debugging (/DEBUG)" – it should not say "Optimize for faster linking (/DEBUG:FASTLINK)". For Visual Studio 2017 it should say "Generate Debug Information
optimized for sharing and publishing (/DEBUG:FULL)" – it should not say "Generate Debug Information (/DEBUG)" nor "Generate
Debug Information optimized for faster links (/DEBUG:FASTLINK)".
To disable inlining as recommended above, use the /Ob0
parameter. In the Visual Studio IDE, press Alt-F7 and then under "Configuration
Properties | C/C++ | Optimization" ensure "Inline Function Expansion" says "Disabled (/Ob0)".
To disable frame pointer optimization as recommended above, use the Oy-
parameter. In the Visual Studio IDE, press Alt-F7 and then under "Configuration Properties | C/C++ | Optimization" ensure "Omit Frame
Pointers" says "No (/Oy-)".
C Library Interactions
All combinations of the debug or release C library, linked statically or dynamically, are supported. When using static versions of msvcrt (the /MTd
or /MT
flags), if your application does not have symbols then Dr. Memory will not be able to identify memory allocation calls, which may lead to false positives and/or false negatives. Be sure to build with debugging information included using the instructions above.
The debug C library (specified with the /MDd
or /MTd
flags) contains its own redzone and heap error checks. Dr. Memory completely replaces these checks with its own, more complete checks.
Disable Runtime Checks
The Visual Studio compiler's /RTC1
flag can prevent Dr. Memory from reporting uninitialized reads of local variables, and the /RTC1
checks for uninitialized reads themselves may not catch everything that Dr. Memory finds. However, /RTC1
does perform additional stack checks that Dr. Memory does not, so for best results, your application should be run under Dr. Memory without /RTC1
, and run natively with /RTC1
.
In the Visual Studio IDE, press Alt-F7 and then under "Configuration Properties | C/C++ | Code Generation" ensure "Basic Runtime Checks" says "Default".
Parameter Summary
Here is a sample command line for Visual Studio:
cl /Zi /MT /EHsc /Oy- /Ob0 /Femyapp.exe *.cpp
Windows MinGW
Dr. Memory supports applications compiled with the MinGW gcc or g++ compilers, but will only provide line number information if DWARF debugging information is present. The default for MinGW gcc prior to version 4.3 is to use the stabs format, which is not supported by Dr. Memory. Pass the -ggdb
option to gcc to generate DWARF format instead.
You install the MinGW compiler in a Cygwin installation by running the Cygwin installer (setup.exe
), searching for "mingw", opening Devel, and installing mingw-gcc-g++
. Alternatively, MinGW can be installed on its own.
For MinGW C++ applications, we recommending building with static libstdc++ libraries. Pass -static-libgcc -static-libstdc++
to g++ to request this. These static libraries contain frame pointer optimizations but Dr. Memory automatically enables the -no_callstack_use_top_fp
runtime option for MinGW applications.
Here is a sample command line for MinGW, using the "mingw64-i686-gcc-g++: GCC for Win32 (i686-w64-mingw32) toolchain (C++)" Cygwin package (this is a 32-bit compiler available for both 32-bit and 64-bit Cygwin):
i686-w64-mingw32-g++.exe -static-libgcc -static-libstdc++ -ggdb -o myapp.exe myfile1.cpp myfile2.cpp
Windows Cygwin: Not Supported
Currently there is no support for applications built with Cygwin gcc or g++.
The regular Dr. Memory build can be executed just fine from a Cygwin shell when targeting non-Cygwin applications.
Android
Build your application using the Android NDK and copy it over to your device. Be sure to compile with debugging information included and to disable FPO, as described in For All Platforms.
While Java applications are not yet officially supported, we welcome contributions to help work toward full Android Java support. To launch an Android Java application under Dr. Memory, use a wrapper script and point at the script via the logwrapper
property set on your application's name prefixed by
. For example, if your application's name is wrap
.com.myco.appname
, set the property for wrap.com.myco.appname
, truncating to 31 characters:
The wrapper shell script should contain the command line prefix you wish to use to launch your application under Dr. Memory. It should also set TMPDIR
to point to the directory for your application, which is a location where SElinux allows writing:
See also the information on SElinux and writable directories under Installing on Android. Be sure to place the Dr. Memory binaries and the wrapper script in an executable location, such as /system/xbin
. Alternatively, disable SELinux via setenforce 0
.