Hace unos días mi explorador de Windows 8.1 empezó a fallar, teniendo cuelgues cada cierto tiempo que me llegaban a bloquear una buena parte del sistema, y que concluían con un reinicio automático del explorador. Lo curioso es que no era posible reproducirlo, así que, para intentar averiguar qué pasaba, me he armado de valor y me he propuesto depurarlo.
En este artículo veremos los diferentes pasos que he ido dando.
1. Generar un dump:
Para poder depurar primero tenemos, o bien que adjuntar un depurador a la aplicación y esperar a que falle, o bien generar un volcado de la memoria (dump) en el momento del fallo. Como explorer no lo realiza de manera automática, hemos de agregar al registro de windows la siguiente clave:
https://onedrive.live.com/?cid=128FC518635BE2DC&id=128FC518635BE2DC%21346
De esta manera, cuando ocurra el crash, no podremos evitarlo (en principio) pero sabremos donde mirar.
Cuando terminemos de recopilar logs, podemos restaurar el estado anterios, empleando una clave de registro similar:
https://onedrive.live.com/?cid=128FC518635BE2DC&id=128FC518635BE2DC%21672
2. Instalar el SDK de Windows:
El SDK de Windows (8.1 en mi caso) incluye los depuradores para 32 y 64 bits, y se instala por defecto en C:\Program Files (x86)\Windows Kits\Debuggers\x64 El depurador que usaremos es WinDbg.
Para descargar el sdk deberemos ir a http://msdn.microsoft.com/en-us/windows/hardware/hh852365
3. Cargamos el dump anteriormente generado
Si hemos tenido suerte y desde que lo instalamos hemos sufrido algún crash, podemos entonces analizarlo. Para ello vamos a la ruta anterior, ejecutamos WinDbg, vamos a «File > «Open Crash Dump» y seleccionamos nuestro fichero de dump (Que estará situado en la carpeta
4. Inicializar los servidores de símbolos
Abrimos «Symbol File Path…»
SRV*C:\WebSymbols*http://msdl.microsoft.com/download/symbols
Recargamos la lista de símbolos de nuestro dump usando el siguiente comando.
.reload
5. Iniciar análisis
Una vez que la lista de símbolos está cargada, solamente nos queda iniciar el análisis
!analyze -v
Una vez terminado el análisis (que va a tardar bastante) tendremos un resultado como este:
******************************************************************************* * * * Exception Analysis * * * ******************************************************************************* *** ERROR: Symbol file could not be found. Defaulted to export symbols for sppc.dll - FAULTING_IP: comsvcs!CNewMonikerClassObject::ParseDisplayName+0 00007ff8`5ba62cf4 ?? ??? EXCEPTION_RECORD: ffffffffffffffff -- (.exr 0xffffffffffffffff) ExceptionAddress: 00007ff878c01759 (ntdll!RtlVirtualUnwind+0x0000000000000091) ExceptionCode: c0000006 (In-page I/O error) ExceptionFlags: 00000000 NumberParameters: 3 Parameter[0]: 0000000000000000 Parameter[1]: 00007ff85ba62cf4 Parameter[2]: 00000000c0000185 Inpage operation failed at 00007ff85ba62cf4, due to I/O error 00000000c0000185 CONTEXT: 0000000000000000 -- (.cxr 0x0;r) rax=000000001282de78 rbx=00000000127b1570 rcx=0000000000000001 rdx=00007ff85b960000 rsi=0000000000000000 rdi=00007ff85ba62cf4 rip=00007ff878c01759 rsp=00000000127b1410 rbp=00007ff85ba91b5c r8=00007ff85ba62cf4 r9=00007ff85babab2c r10=0000000000000b99 r11=00007ff85b960000 r12=0000000000000000 r13=00000000127b14e8 r14=00007ff85babab2c r15=0000000000000001 iopl=0 nv up ei ng nz ac po cy cs=0033 ss=002b ds=002b es=002b fs=0053 gs=002b efl=00010297 ntdll!RtlVirtualUnwind+0x91: 00007ff8`78c01759 803f48 cmp byte ptr [rdi],48h ds:00007ff8`5ba62cf4=?? DEFAULT_BUCKET_ID: WRONG_SYMBOLS PROCESS_NAME: explorer.exe ERROR_CODE: (NTSTATUS) 0xc0000006 - The instruction at 0x%p referenced memory at 0x%p. The required data was not placed into memory because of an I/O error status of 0x%x. EXCEPTION_CODE: (NTSTATUS) 0xc0000006 - The instruction at 0x%p referenced memory at 0x%p. The required data was not placed into memory because of an I/O error status of 0x%x. EXCEPTION_PARAMETER1: 0000000000000000 EXCEPTION_PARAMETER2: 00007ff85ba62cf4 EXCEPTION_PARAMETER3: 00000000c0000185 IO_ERROR: (NTSTATUS) 0xc0000185 - The I/O device reported an I/O error. EXCEPTION_STR: 0xc0000006_c0000185 ADDITIONAL_DEBUG_TEXT: Followup set based on attribute [Is_ChosenCrashFollowupThread] from Frame:[0] on thread:[PSEUDO_THREAD] LAST_CONTROL_TRANSFER: from 0000000000000000 to 0000000000000000 NTGLOBALFLAG: 0 APPLICATION_VERIFIER_FLAGS: 0 APP: explorer.exe ANALYSIS_VERSION: 6.3.9600.16384 (debuggers(dbg).130821-1623) amd64fre MANAGED_STACK: !dumpstack -EE OS Thread Id: 0x3eb4 (22) Current frame: Child-SP RetAddr Caller, Callee PRIMARY_PROBLEM_CLASS: WRONG_SYMBOLS BUGCHECK_STR: APPLICATION_FAULT_WRONG_SYMBOLS STACK_TEXT: 00000000`00000000 00000000`00000000 hardware_disk!Unknown+0x0 STACK_COMMAND: .ecxr ; kb ; ** Pseudo Context ** ; kb SYMBOL_STACK_INDEX: 0 SYMBOL_NAME: hardware_disk!Unknown FOLLOWUP_NAME: MachineOwner MODULE_NAME: hardware_disk DEBUG_FLR_IMAGE_TIMESTAMP: 0 FAILURE_BUCKET_ID: WRONG_SYMBOLS_c0000006_hardware_disk!Unknown BUCKET_ID: APPLICATION_FAULT_WRONG_SYMBOLS_hardware_disk!Unknown IMAGE_NAME: hardware_disk ANALYSIS_SOURCE: UM FAILURE_ID_HASH_STRING: um:wrong_symbols_c0000006_hardware_disk!unknown FAILURE_ID_HASH: {95c4d6f5-b6a7-b83a-dfd6-d872fc207cf6} Followup: MachineOwner ---------
Tras echar un vistazo al crash, y consultar por los rincones de Internet, parece ser que la clave está aquí: IO_ERROR: (NTSTATUS) 0xc0000185 – The I/O device reported an I/O error. Es decir, tengo algún tipo de error de disco. Tocará seguir investigando con otras herramientas. Aunque no he podido conseguir mi objetivo final (reducir o eliminar los fallos) usando windbg, he podido hacer un pequeño diagnóstico gracias a windbg.
Dejo abierta al lector la siguiente pregunta, qué tipo de problemas has podido resolver usando windbg o similar?
Sigue la conversación en Reddit