Geeks With Blogs
Rupreet's Weblog Looking deep inside under the hood

If anyone of you has debugged managed crash dumps, I am sure you must have come across a situation when debugger keeps telling you it’s not able to load mscordacwks.dll.

It usually happens when the dump was taken from a machine that had a specific version on .NET framework with patches installed and the machine where the crash dump is being analyzed has different .NET framework version number. When I talk about different version no, I mean the minor version. E.g. Crash dump was taken from machine v2.0.50727.5448 but the debugger is running on machine v2.0.50727.4016, the debugger would complain as version doesn’t match. Something like this –

windbg

OR

Failed to load data access DLL, 0x80004005
Verify that 1) you have a recent build of the debugger (6.2.14 or newer)
            2) the file mscordacwks.dll that matches your version of mscorwks.dll is
                in the version directory
            3) or, if you are debugging a dump file, verify that the file
                mscordacwks_<arch>_<arch>_<version>.dll is on your symbol path.
            4) you are debugging on the same architecture as the dump file.
                For example, an IA64 dump file must be debugged on an IA64
                machine.

Resolution

To solve this, we need this specific version of the assembly to continue debugging. The minor version of the framework changes whenever Microsoft releases some patches, hot fixes or service packs. Depending on what patch or hot fix is applied on that machine, the version of the assembly will differ.

One of the easy ways to resolve is to copy the mscordacwks.dll from the machine the dump was taken and copy in the “discoverable” folder (path which is part of .sympath).

But there are times when that machine is not available or don’t have access to it or simply you are not able to get your hands on the specific assembly.

This site(http://www.mskbfiles.com/mscorwks.dll.php) details out each and every hotfix/patch with specific framework version number associated to it so that when we need a specific version, we can download the patch and extract the required assemblies.

Once the update/hotfix is downloaded, we extract the required assemblies using the below commands –

c:\ >expand.exe -f:* C:\Windows6.0-KB983589-x64.msu C:\temp

c:\ >expand.exe -f:* C:\temp\Windows6.0-KB983589-x64.cab C:\temp\cab

In the cab folder, the required assembly would be present.

The other way to extract the files is to use Winzip or some compression tool which lets you extract files from *.cab.

Just rename the assembly in mscordacwks_<arch>_<arch>_<version>.dll format and place it in the discoverable path of the debugger (path which is part of .sympath).

Posted on Monday, March 12, 2012 3:58 PM Debugging , .NET Framework | Back to top


Comments on this post: WinDBG: How to load specific version of mscordacwks.dll for debugging crash dumps

# re: WinDBG: How to load specific version of mscordacwks.dll for debugging crash dumps
Requesting Gravatar...
Actually I tried a lot to load the specific version of mscordacwks.dll. At that time it shows some errors. I couldn’t fix those errors. manufactured homes for sale in arizona But after reading this post I just tried to fix it and it completed successfully. Keep sharing such useful information!
Left by Sam on Nov 16, 2015 9:43 AM

# re: WinDBG: How to load specific version of mscordacwks.dll for debugging crash dumps
Requesting Gravatar...
Glad it helped! I am coming up with new website where you can debug all the crashes automatically instead of manually debugging the crash dumps.

Stay tuned, it should be live within this month - www.debuggable.io
Left by Rupreet on Nov 16, 2015 4:08 PM

# gamesdro.com
Requesting Gravatar...
Amazing post thanks for adding me, there are many different types of online games are available in the gamesdro.com play the many fantastic free game without download & registration required on your pc tablet & mobile.
Left by Vivek on Oct 12, 2017 5:42 PM

Your comment:
 (will show your gravatar)


Copyright © Rupreet Singh Gujral | Powered by: GeeksWithBlogs.net