Compartir a través de


MDA de invalidOverlappedToPinvoke

Nota:

Este artículo es específico de .NET Framework. No se aplica a implementaciones más recientes de .NET, incluidas .NET 6 y versiones posteriores.

El asistente para la depuración administrada (MDA) invalidOverlappedToPinvoke se activa cuando un puntero superpuesto que no se ha creado en el montón de recolección de elementos no utilizados se pasa a funciones de Win32 específicas.

Nota

De forma predeterminada, este MDA solo se activa si se define la llamada de invocación de plataforma en el código y el depurador informa del estado de JustMyCode de cada método. Un depurador que no entienda JustMyCode (como MDbg.exe sin extensiones) no activará este MDA, Este MDA se puede habilitar en este tipo de depuradores utilizando un archivo de configuración y estableciendo explícitamente justMyCode="false" en el archivo .mda.config ((<invalidOverlappedToPinvoke enable="true" justMyCode="false"/>).

Síntomas

Bloqueos o daños inexplicables del montón.

Causa

Se pasa un puntero superpuesto que no se ha creado en el montón de recolección de elementos no utilizados a funciones de sistema operativo concretas.

En la tabla siguiente se muestran las funciones de las que realiza el seguimiento este MDA.

Módulo Función
HttpApi.dll HttpReceiveHttpRequest
IpHlpApi.dll NotifyAddrChange
kernel32.dll ReadFile
kernel32.dll ReadFileEx
kernel32.dll WriteFile
kernel32.dll WriteFileEx
kernel32.dll ReadDirectoryChangesW
kernel32.dll PostQueuedCompletionStatus
MSWSock.dll ConnectEx
WS2_32.dll WSASend
WS2_32.dll WSASendTo
WS2_32.dll WSARecv
WS2_32.dll WSARecvFrom
MQRT.dll MQReceiveMessage

La probabilidad de daños en el montón es alta para esta condición porque se podría descargar el AppDomain que hace la llamada. Si se descarga el AppDomain, el código de la aplicación liberará la memoria del puntero superpuesto, provocando daños cuando termine la operación, o producirá la pérdida de memoria, lo que más adelante causará dificultades.

Solución

Use un objeto Overlapped, llamando al método Pack para obtener una estructura NativeOverlapped que se puede pasar a la función. Si se descarga el AppDomain, CLR espera hasta que la operación asincrónica finalice antes de liberar el puntero.

Efecto en el Runtime

Este MDA no tiene ningún efecto en el CLR.

Output

A continuación se muestra un ejemplo de resultado de este MDA.

An overlapped pointer (0x00ea3430) that was not allocated on the GC heap was passed via Pinvoke to the Win32 function 'WriteFile' in module 'KERNEL32.DLL'. If the AppDomain is shut down, this can cause heap corruption when the async I/O completes. The best solution is to pass a NativeOverlapped structure retrieved from a call to System.Threading.Overlapped.Pack(). If the AppDomain exits, the CLR will keep this structure alive and pinned until the I/O completes.

Configuración

<mdaConfig>
  <assistants>
    <invalidOverlappedToPinvoke/>
  </assistants>
</mdaConfig>

Consulte también