![]() |
![]() | ![]() | ![]() | ![]() | ![]() | ![]() | ![]() |
| Welcome to Windows Vista Forums. Our forum is dedicated to helping you find solutions with any problems, errors or issues you are experiencing with Windows Vista. The Vista forum also covers news and updates and has an extensive Windows Vista tutorial section that covers a wide range of tips and tricks. |
| |||||||
![]() |
| |
| | #1 (permalink) |
| DNPNWO | Reading BSOD crash files This Microsoft software will allow the reading of crash Dumps. Simplifying the issues with Blue-Screen driver/hardware exceptions, and providing the data necessary for resolution for the problem(s). To use it Run the executable as "Admin", Click "file" and "open Crash Dump" navigate to the Windows\Minidump file (or other location) Vista x64 systems: http://www.microsoft.com/whdc/devtoo...tall64bit.mspx Vista x86/XP: Install Debugging Tools for Windows 32-bit Version note- for futher info on overriding the default Install location and setting dump files for default handling by the debugger (advanced Users) see:Crash Dumps - Analyse Bugcheck and Process Any questions/advanced dump file analysis/troubleshooting/Install/default handling Issues should be directed to the Tutorial for proper resolution. -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- Step 1 Download the debugging tool for your system Step 2 Override installation/or Install to default Location Step 3 Create symbol cache folder Step 4 Set the debuggging tool path for for the symbol cache --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- Download the debugger package that matches YOUR machine's architecture In other words, if you're running 32-bit Vista, install the 32-bit version of the "Debugging Tools for Windows", irrespective of whether you intend to debug 32-bit or 64-bit code. Vice versa for x64 - download and install the x64 package, and you'll still be able to debug 32-bit dumps. I suspect that few people would be running Itaniums around here, so don't grab the IA-64 build. "IA-64" (Itanium) is a vastly different architecture to "x64" (AMD64, a.k.a. EM64T when sold by Intel). Override the default install path and install to 'c:\debuggers' instead Or Install into default Programs location This is entirely optional but you'll be happier, especially if you intend to do a fair amount of dump gazing. Choose the "custom" install option and use c:\debuggers (or d:\debuggers or whatever drive) as the install path. It makes it easier to work with the tools and removes that pesky "Program Files" space from the path name. The debugger package is a lot more command-line oriented than many apps nowadays. Set your symbol path (critical- and not optional) - Start WinDBG - WITHOUT opening any dump files, click File, "Symbol File Path..." - Set the path to be the following: SRV*C:\SymCache*http://msdl.microsoft.com/download/symbols note-this works if you set "c:\SymCache" as you local file path (creating the file), If for example, you use "c:\windows\symbols" the path would be: SRV*c:\windows\symbols*http://msdl.microsoft.com/download/symbols It can be any valid local path, c:\Symbols or e:\MySymbols or whatever, but the SRV and http bits must be exactly as above. Don't move the local path around too much though because the idea is to build up a local cache of symbols that minimises your waiting time while symbols are being downloaded from MS. That local cache can grow quite large over time, if you do a lot of this. - Exit WinDBG. It should ask you whether you wish to save workspace settings. "Yes" is the answer. - Check that from now onwards the symbol file path is always set that way whenever you start WinDBG. Opening and analysing dumps Once you've done the preparatory steps above, "File | Open Crash Dump..." in WinDBG to get it to open up and analyse a minidump or any other memory dump, including crashes from user-mode processes. If you want to re-invoke its automated analysis engine, use the !ANALYZE -V command. The "v" switch stands for "verbose" - it spews out a bit more detail. Your done!! [Thanks to H2S04 for the Walkthrough.] Last edited by rive0108; 06-02-2009 at 01:04 PM.. |
My System Specs![]() |
| | #2 (permalink) |
| A bit of a numpty | Re: Reading BSOD crash files You need to set the symbol path before the debugger can provide useful feedback on what it finds in the dump. Vast Amount of Blue Screens The same procedure also works on user-mode crash dumps. It's not limited to BSoDs. |
My System Specs![]() |
| | #3 (permalink) |
| Member | Re: Reading BSOD crash files Yes and probably best to put in link to path instead of downloading - they say many things on that MS page about symbols http://support.microsoft.com/kb/311503 - Code: SRV*c:\symbols*http://msdl.microsoft.com/download/symbols |
My System Specs![]() |
| | #4 (permalink) |
| A bit of a numpty | Re: Reading BSOD crash files What dk70 said. If the symbol path is configured that way, whenever the debugger encounters a new binary for which it must find symbols, it will: 1) Check first in C:\symbols. If a matching symbol is not found... 2) Check whether the symbol is available from the MS symbol server. If it is, copy it down to C:\symbols so it can be cached. In practice, the MS symbol server will contain symbols for MS binaries (exe, dll, sys), but not for 3rd-party modules, obviously. To have WinDBG attempt analysis of a crash dump, either a BSoD or a usermode process dump, simply open the dump via File | Open, or pass it as a command-line arg. The debugger will attempt to find the relevant symbols and it will then produce a diagnosis, to the best of its automated abilities. Look for a line like this in the output: Probably caused by : win32k.sys ( win32k!FindTimer+57 )If that references a non-default driver, the first thing to do is to update the driver. If that doesn't help and subsequent dumps all point at the same driver again, try removing it as a test. In the example above, it's win32k.sys and that's a rather important system driver. When the "probably caused by" verdict points at an OS binary, the situation is far more complex and minidump analysis cannot always pinpoint the true cause. |
My System Specs![]() |
| | #5 (permalink) |
| A bit of a numpty | More Debugger Trickery For The Interested A minidump contains 3 main items of information: 1) The stack of the thread which directly caused the crash. This can be viewed with the various 'k' (stack unwind) commands: 1: kd> kL Child-SP RetAddr Call Site fffffa60`09cd0528 fffff800`01cb60ee nt!KeBugCheckEx fffffa60`09cd0530 fffff800`01cb5abc nt!KiBugCheckDispatch+0x6e fffffa60`09cd0670 fffff800`01cc96bd nt!KiSystemServiceHandler+0x7c fffffa60`09cd06b0 fffff800`01cd0cff nt!RtlpExecuteHandlerForException+0xd fffffa60`09cd06e0 fffff800`01c8dd83 nt!RtlDispatchException+0x22f fffffa60`09cd0dd0 fffff800`01cb61a9 nt!KiDispatchException+0xc3 fffffa60`09cd13d0 fffff800`01cb4d8d nt!KiExceptionDispatch+0xa9 fffffa60`09cd15b0 fffff960`0011c947 nt!KiGeneralProtectionFault+0xcd fffffa60`09cd1740 fffff960`00121e2d win32k!FindTimer+0x57 fffffa60`09cd1790 fffff800`01cb5df3 win32k!NtUserKillTimer+0x5d fffffa60`09cd17d0 00000000`7790c24a nt!KiSystemServiceCopyEnd+0x13 2) The processor register context of that thread: 1: kd> r rax=fffffa6009cd0630 rbx=fffffa6009cd17d0 rcx=000000000000003b rdx=00000000c0000005 rsi=fffff80001cb5df3 rdi=fffff80001e64df4 rip=fffff80001cb6350 rsp=fffffa6009cd0528 rbp=fffffa6009cd1508 r8=fffff9600011c947 r9=fffffa6009cd0ee0 r10=0000000000000000 r11=0000000000000001 r12=fffffa6009cc4000 r13=fffffa6009cd4000 r14=fffff80001c61000 r15=fffff80001daf4ec iopl=0 nv up ei ng nz na po nc cs=0010 ss=0018 ds=002b es=002b fs=0053 gs=002b efl=00000286 nt!KeBugCheckEx: fffff800`01cb6350 48894c2408 mov qword ptr [rsp+8],rcx ss:0018:fffffa60`09cd0530=000000000000003b In this case, the 64-bit instruction pointer (RIP) was in nt!KeBugCheckEx at the time of the crash, which is not surprising given that's the "bluescreen" function. 3) A list of loaded modules at the time of the crash. The 'lm' (list modules) command can show these: 1: kd> lm start end module name fffff800`01c1b000 fffff800`01c61000 hal (deferred) fffff800`01c61000 fffff800`02179000 nt (pdb symbols) c:\symcache\ntkrnlmp.pdb\149C563625CA49CEA2881CEDF5D55CCF2\ntkrnlmp.pdb fffff960`00050000 fffff960`00301000 win32k (pdb symbols) c:\symcache\win32k.pdb\97A727330C184A9B9E1BDA0C3293AA142\win32k.pdb fffff960`00410000 fffff960`0041a000 TSDDD (deferred) fffff960`00620000 fffff960`00631000 cdd (deferred) ... In the example above, the debugger has only encountered "nt" (NTOSKRNL itself) and win32k.sys code in the stack, which is why it has downloaded symbols (they have a PDB extension) from the MS symbol server for those two binaries, but not for hal.dll, TSDDD.dll, and cdd.dll. Their symbol status is listed as "deferred". Even More Debugger Trickery For The Really Interested Minidumps can also easily reveal basic information about the Windows version, service pack level, time of the crash, and system uptime: 1: kd> vertarget Windows Server 2008/Windows Vista Kernel Version 6001 (Service Pack 1) MP (4 procs) Free x64 Product: WinNt, suite: TerminalServer SingleUserTS Built by: 6001.18145.amd64fre.vistasp1_gdr.080917-1612 Machine Name: Kernel base = 0xfffff800`01c61000 PsLoadedModuleList = 0xfffff800`01e26db0 Debug session time: Thu Apr 2 07:07:55.076 2009 (GMT+11) System Uptime: 0 days 0:02:00.122 Say you've identified a driver that you believe to be responsible, and now you want to see more particulars about that binary. Use 'lmvm' with the module name: 1: kd> lmvm tdrpm147 start end module name fffffa60`0140c000 fffffa60`01590000 tdrpm147 (deferred) Image path: \SystemRoot\system32\DRIVERS\tdrpm147.sys Image name: tdrpm147.sys Timestamp: Mon Oct 13 21:14:16 2008 (48F31F78) CheckSum: 0018472C ImageSize: 00184000 Translations: 0000.04b0 0000.04e4 0409.04b0 0409.04e4 To get more info on the processor(s): 1: kd> !cpuinfo CP F/M/S Manufacturer MHz PRCB Signature MSR 8B Signature Features 1 6,15,11 GenuineIntel 2405 000000b600000000 20193ffe Cached Update Signature 000000b600000000 Initial Update Signature 000000b600000000 To see the writeup for a given bugcheck code: 1: kd> !analyze -show D1 DRIVER_IRQL_NOT_LESS_OR_EQUAL (d1) An attempt was made to access a pageable (or completely invalid) address at an interrupt request level (IRQL) that is too high. This is usually caused by drivers using improper addresses. If kernel debugger is available get stack backtrace. Arguments: Arg1: 0000000000000000, memory referenced Arg2: 0000000000000000, IRQL Arg3: 0000000000000000, value 0 = read operation, 1 = write operation Arg4: 0000000000000000, address which referenced memory And the most useful command of all (try it): windbg> .hh ============================================= Full dumps allow for much more meaningful analysis but they're hundreds of MB or even several GB in size, depending on the dump type, and for a 2-minute look at someone's BSoD problem a minidump is perfectly sufficient. If their system is going up and down like a yo-yo and the dumps all point at the same 3rd-party driver - bingo. Otherwise, if virtually every dump points at a different culprit and they mostly look odd, chances are it's a hardware issue. Last edited by Brink; 04-14-2009 at 12:04 PM.. |
My System Specs![]() |
| | #6 (permalink) |
| DNPNWO | Re: Reading BSOD crash files H2SO4- How about providing the entire "Admin:Command Prompt" Run Command for registering the dump files at the installed location? |
My System Specs![]() |
| | #7 (permalink) |
| Member | Re: Reading BSOD crash files How about making this thread sticky? |
My System Specs![]() |
| | #8 (permalink) |
| A bit of a numpty | Re: Reading BSOD crash files Sorry Rive0108, I forgot about that before. OK, rewinding a bit to the beginning... Download the debugger package that matches YOUR machine's architecture http://www.microsoft.com/whdc/devtoo...g/default.mspx In other words, if you're running 32-bit Vista, install the 32-bit version of the "Debugging Tools for Windows", irrespective of whether you intend to debug 32-bit or 64-bit code. Vice versa for x64 - download and install the x64 package, and you'll still be able to debug 32-bit dumps. I suspect that few people would be running Itaniums around here, so don't grab the IA-64 build. "IA-64" (Itanium) is a vastly different architecture to "x64" (AMD64, a.k.a. EM64T when sold by Intel). Override the default install path and install to c:\debuggers instead This is entirely optional but you'll be happier, especially if you intend to do a fair amount of dump gazing. Choose the "custom" install option and use c:\debuggers (or d:\debuggers or whatever drive) as the install path. It makes it easier to work with the tools and removes that pesky "Program Files" space from the path name. The debugger package is a lot more command-line oriented than many apps nowadays. Register WinDBG as the default handler for dump files Another entirely optional step that makes life easier. By registering WinDBG (the main debugger you'll want to use) as the default handler for common dump file types, you'll be able to just double-click on a dump and have it open in WinDBG without having to go through the File | Open... rigmarole every time. This registration needs to be performed from an elevated CMD prompt (run CMD as administrator): C:\>cd debuggersWinDBG should fire up and pop up a dialog box that says this: ---------------------------Set your symbol path This is NOT optional. In fact, getting it wrong is the #1 reason for frustration when learning to debug. There are several ways to get it right, but the one that dk70 already mentioned is possibly the simplest: - Start WinDBG - WITHOUT opening any dump files, click File, "Symbol File Path..." - Set the path to be the following: SRV*C:\SymCache*http://msdl.microsoft.com/download/symbolsIt can be any valid local path, c:\Symbols or e:\MySymbols or whatever, but the SRV and http bits must be exactly as above. Don't move the local path around too much though because the idea is to build up a local cache of symbols that minimises your waiting time while symbols are being downloaded from MS. That local cache can grow quite large over time, if you do a lot of this. - Exit WinDBG. It should ask you whether you wish to save workspace settings. "Yes" is the answer. - Check that from now onwards the symbol file path is always set that way whenever you start WinDBG. Opening and analysing dumps Once you've done the preparatory steps above, you can double-click (if registered) or "File | Open Crash Dump..." in WinDBG to get it to open up and analyse a minidump or any other memory dump, including crashes from user-mode processes. If you want to re-invoke its automated analysis engine, use the !ANALYZE -V command. The "v" switch stands for "verbose" - it spews out a bit more detail. |
My System Specs![]() |
| | #9 (permalink) |
| I Tunes hates Me | Re: Reading BSOD crash files this is fantastic never seen it before i must read more stickies , im trying to learn how to read crash dumps properly i figured out he software months ago i just need the time to research and figure out exactly what im looking at and how to interperate the info |
My System Specs![]() |
| | #10 (permalink) |
| A bit of a numpty | Re: Reading BSOD crash files this is fantastic never seen it before i must read more stickies , im trying to learn how to read crash dumps properly i figured out he software months ago i just need the time to research and figure out exactly what im looking at and how to interperate the info There's a tutorial with a tad more info. If you have more in-depth questions, please don't be bashful about asking. I live to prattle |
My System Specs![]() |
![]() |
| Thread Tools | |
| |
Similar Threads | ||||
| Thread | Forum | |||
| Vista Crash after installing SP1 BSOD SYSTEM_SERVICE_EXCEPTION | Vista General | |||
| reading DVD files | Vista file management | |||
| BSoD and Game Crash Crashing and just restarts | Vista General | |||
| speakers crackling static'y, gets worse over time until inevitable BSOD crash | Vista hardware & devices | |||
| Vista boot BSOD nvlddmkm.sys Nvidia crash | Vista General | |||