SOS: Commands not working on a mini-dump

Problem

So occasionally I run into people trying to analyze a managed mini-dump and they have problems.  They run a command like !dumpobj and it fails.

Cause

The reason that these commands fail is that the CLR stores all it’s data in virtual memory.  That memory is not written when creating a mini-dump.

Solution

In order to run SOS commands, many CLR data structures need to be traversed. When creating a mini-dump without full memory, special functions are called at dump creation time to bring those structures into the mini-dump, and allow a minimum set of SOS debugging commands to work. At this time, those commands that can provide full or partial output are:

 CLRStack
Threads
Help
PrintException
EEVersion

For a mini-dump created with this minimal set of functionality in mind, you will get an error message when running any other commands. A full memory dump (obtained with ".dump /ma <filename>" in the Windows Debugger) is the best way to debug a managed program at this level.

Comments

  • Anonymous
    July 27, 2008
    PingBack from http://blog.a-foton.ru/2008/07/sos-commands-not-working-on-a-mini-dump/

  • Anonymous
    July 29, 2008
    Hello! How can PrintException work when no Managed Heap is available in the Minidump? Since the Exception instance is located on the managed Heap too?

  • Anonymous
    July 29, 2008
    GProssliner, There was extra data that gets written out that allow these commands to give you some data.  It isn't as full as you would normally see because you are right, the instace is located in the managed heap.