¿Por qué mi programa consume el 100% de la CPU en nVidia NView?
Pregunta
Recientemente estuve trabajando en un programa de Windows que a veces no responde cuando se desplaza por una gran lista de elementos en un entorno de producción. Por supuesto que funciona bien en mi escritorio. El entorno de producción es:
- Estación de trabajo basada en Windows XP con 2 monitores
- nVidia Video Drivers con nView habilitado
Es de destacar que se genera un seguimiento de pila de Dr Watson cuando finaliza el proceso:
State Dump for Thread Id 0xef4 eax=00e3fff8 ebx=000000a0 ecx=00e00000 edx=00000000 esi=0003fff8 edi=00e40000 eip=00b920c2 esp=0012bcac ebp=00000000 iopl=0 nv up ei ng nz na pe cy cs=001b ss=0023 ds=0023 es=0023 fs=003b gs=0000 efl=00000283 \system32\nview.dll - function: nview!NVLoadDatabase 00b920a8 c80b0600 enter 0x60b,0x0 00b920ac 83c30f add ebx,0xf 00b920af 33f6 xor esi,esi 00b920b1 03f9 add edi,ecx 00b920b3 83e3f8 and ebx,0xfffffff8 00b920b6 3bcf cmp ecx,edi 00b920b8 89742414 mov [esp+0x14],esi 00b920bc 734c jnb nview!NVLoadDatabase+0xcaf (00b9210a) 00b920be 8bc1 mov eax,ecx 00b920c0 8b10 mov edx,[eax] 00b920c2 8b4004 mov eax,[eax+0x4] ds:0023:00e3fffc=00000000 00b920c5 89442414 mov [esp+0x14],eax 00b920c9 8bc2 mov eax,edx 00b920cb 2500000001 and eax,0x1000000 00b920d0 33ed xor ebp,ebp 00b920d2 0bc5 or eax,ebp 00b920d4 7414 jz nview!NVLoadDatabase+0xc8f (00b920ea) 00b920d6 8bc2 mov eax,edx 00b920d8 c1e008 shl eax,0x8 00b920db 8be8 mov ebp,eax 00b920dd c1f81f sar eax,0x1f ChildEBP RetAddr Args to Child 00000000 00000000 00000000 00000000 00000000 nview!NVLoadDatabase+0xc67
¿Por qué este problema solo se produjo en la producción?
Solución
Esto es interesante porque nView es una DLL de terceros proporcionada por NVidia. Las publicaciones en Internet sobre nview! NVLoadDatabase
sugieren que hay un defecto sin parchear en nview. Esto está respaldado por el hecho de que el explorador utiliza el 100% de la CPU, como lo confirman estos informes. Consulte: http://forums.nvidia.com/lofiversion/index.php? t36879.html
Una investigación detallada de este problema está disponible en este sitio: http: //blogs.technet.com/marcelofartura/archive/2007/02/28/real-case-random-apps-running-100-cpu.aspx
Según este artículo, el bloqueo se debe a un bucle infinito en nview.dll. Aunque las instrucciones de ensamblaje y los valores de registro descritos en línea no coinciden exactamente con los de nuestro registro, fueron lo suficientemente cercanos para que yo concluyera que es el mismo problema.
Para solucionar el problema, deshabilité nView Desktop Manager (haga clic con el botón derecho en el escritorio, seleccione nView Properties y haga clic en deshabilitar en el cuadro de grupo de nView Desktop Manager). Antes de hacer esto pude reproducir consistentemente la caída. Sin embargo, después de deshabilitar nView no pude reproducir el bloqueo. Por lo tanto, esto parece ser una solución viable.
De todos modos, publiqué esto aquí en caso de que sea útil para alguien. Me causó mucha pena perseguirlo.