Clone this repo:
  1. bcb3607 i#2006: fixes drltrace test failures on Android (#2008) by Maksim Shudrak · 3 weeks ago master
  2. 942effc i#1948 drltrace libcall args printing: change comment character for config (#2007) by Maksim Shudrak · 3 weeks ago
  3. 39ac4be i#1948 drltrace libcall args printing: config file init (#2001) by Maksim Shudrak · 4 weeks ago
  4. 202ce25 Umbra docs: Adds note to umbra_insert_app_to_shadow (#1999) by Toshi Piazza · 8 weeks ago
  5. a72dff4 DRi#2453: add XP support for VS2013 builds (#1998) by Derek Bruening · 8 weeks ago

Dr. Memory: the memory debugger

About Dr. Memory

Dr. Memory is a memory monitoring tool capable of identifying memory-related programming errors such as accesses of uninitialized memory, accesses to unaddressable memory (including outside of allocated heap units and heap underflow and overflow), accesses to freed memory, double frees, memory leaks, and (on Windows) handle leaks, GDI API usage errors, and accesses to un-reserved thread local storage slots.

Dr. Memory operates on unmodified application binaries running on Windows, Linux, Mac, or Android on commodity IA-32, AMD64, and ARM hardware.

Dr. Memory is released under an LGPL license and binary packages are available for download.

Dr. Memory is built on the DynamoRIO dynamic instrumentation tool plaform.

DynamoRIO logo

Dr. Memory Performance

Dr. Memory is faster than comparable tools, including Valgrind, as shown in our CGO 2011 paper Practical Memory Checking with Dr. Memory, where we compare the two tools on Linux on the SPECCPU 2006 benchmark suite:

Performance chart

(Valgrind is unable to run 434.zeusmp and 447.dealII).


Documentation is included in the release package. We also maintain a copy for online browsing.

System call tracer for Windows

The Dr. Memory package includes an “strace for Windows” tool called drstrace.

Obtaining help

Dr. Memory has its own discussion list.

To report a bug, use the issue tracker.

See also the Dr. Memory home page: