REVISIÓN: En un equipo que está ejecutando el Service Pack 1 de.NET Framework 3.5, el compilador JIT y Native Image Generator (Ngen.exe) que utilicen el archivo Mscorjit.dll pueden generar código incorrecto

Síntomas

En un equipo que está ejecutando el Service Pack 1 (SP1) de Microsoft.NET Framework 3.5, el compilador de just-in-time (JIT) y Native Image Generator (Ngen.exe) que utilicen el archivo Mscorjit.dll pueden generar código incorrecto. Por lo tanto, una aplicación de C++ administrado de 32 bits puede producir resultados incorrectos.

Este problema se produce si se cumplen las condiciones siguientes:
  • La estructura o la clase en el código fuente tiene menos de cuatro variedades de escalares y ninguna referencia de objeto administrado.
  • Utilice la instrucción Cpblk o la instrucción Initblk.
Nota: Este problema no ocurre en una aplicación de 64 bits.

Causa

Este problema se produce debido a una regresión en.NET Framework 3.5 SP1.

Solución

Información de la revisión

Existe un hotfix disponible desde Microsoft. Sin embargo, esta revisión se diseñó para corregir únicamente el problema que se describe en este artículo. Aplíquela sólo a sistemas que experimenten este problema específico. Esta revisión podría ser sometida a comprobaciones adicionales. Por lo tanto, si no se ve muy afectado por este problema, recomendamos que espere a la próxima actualización de software que contenga este hotfix.

Para descargar esta revisión desde MSDN Code Gallery, visite el siguiente sitio Web de Microsoft:


Nota: MSDN Code Gallery muestra los idiomas para los que la revisión está disponible. Si no ve su idioma en la lista, es porque la página de recursos de galería de código no está disponible para ese idioma.


Nota: Si se producen problemas adicionales o si se requiere cualquier otra solución, será necesario crear una solicitud de revisión independiente. Los costos habituales de soporte se aplicarán a las preguntas de soporte técnico adicionales y problemas que no califican para esta revisión específica. Para obtener una lista completa de los números de teléfono de servicio al cliente de Microsoft o para crear una solicitud de servicio independiente, visite el siguiente sitio Web de Microsoft:

Nota: Si tiene una aplicación de 32 bits que se ejecuta en una plataforma de 64 bits, aplique la revisión para la versión de 64 bits resolver este problema.

Requisitos previos

Debe tener la versión.NET Framework 3.5 SP1 instalado para aplicar esta revisión.

Requisito de reinicio

Tendrá que reiniciar el equipo si se utiliza alguno de los archivos que se actualizan.

Información de reemplazo de revisión

Este hotfix no sustituye a otras revisiones.

Información de archivo

La versión en inglés de esta revisión tiene los atributos de archivo (o atributos del archivo más reciente) mostrados en la tabla siguiente. Las fechas y horas de estos archivos se muestran en la hora Universal coordinada (UTC). Al ver la información del archivo, se convierte en hora local. Para encontrar la diferencia entre la hora UTC y la hora local, utilice la ficha Zona horaria en el elemento de Fecha y hora del Panel de control.
Windows 2000, Windows XP y Windows Server 2003, x86 versiones
Nombre del archivoVersión del archivoTamaño de archivoFechaHora
Mscordacwks.dll2.0.50727.3068992,26416-Sep-200813:13
Mscorjit.dll2.0.50727.3068367,10416-Sep-200813:13
Mscorlib.dll2.0.50727.30684,546,56016-Sep-200813:13
Mscorwks.dll2.0.50727.30685,815,80816-Sep-200813:13
Windows 2000, Windows XP y Windows Server 2003, x64 versiones
Nombre del archivoVersión del archivoTamaño de archivoFechaHoraPlataforma
Mscordacwks.dll2.0.50727.3068992,26416-Sep-200813:13x86
Mscorjit.dll2.0.50727.3068367,10416-Sep-200813:13x86
Mscorlib.dll2.0.50727.30684,546,56016-Sep-200813:13x86
Mscorwks.dll2.0.50727.30685,815,80816-Sep-200813:13x86
Mscordacwks.dll2.0.50727.30681,767,94416-Sep-200810:33x64
Mscorjit.dll2.0.50727.30681,580,03216-Sep-200810:33x64
Mscorlib.dll2.0.50727.30684,562,94416-Sep-200810:33x64
Mscorwks.dll2.0.50727.306810,079,74416-Sep-200810:33x64
Windows 2000, Windows XP y Windows Server 2003, versiones IA-64
Nombre del archivoVersión del archivoTamaño de archivoFechaHoraPlataforma
Mscordacwks.dll2.0.50727.3068992,26416-Sep-200813:13x86
Mscorjit.dll2.0.50727.3068367,10416-Sep-200813:13x86
Mscorlib.dll2.0.50727.30684,546,56016-Sep-200813:13x86
Mscorwks.dll2.0.50727.30685,815,80816-Sep-200813:13x86
Mscordacwks.dll2.0.50727.30683,087,88016-Sep-200810:44IA-64
Mscorjit.dll2.0.50727.30682,560,51216-Sep-200810:44IA-64
Mscorlib.dll2.0.50727.30684,005,88816-Sep-200810:44IA-64
Mscorwks.dll2.0.50727.306820,153,85616-Sep-200810:44IA-64
Windows Vista Service Pack 1 (SP1) y Windows Server 2008, x86 versiones
Nombre del archivoVersión del archivoTamaño de archivoFechaHoraPlataforma
Mscorlib.resources.dll2.0.50727.3053352,25615-Sep-200822:25x86
Mscorlib.resources.dll2.0.50727.3053303,10415-Sep-200822:25x86
Mscorlib.resources.dll2.0.50727.3053299,00815-Sep-200822:25x86
Mscorlib.resources.dll2.0.50727.3053315,39227-Jul-200817:58x86
Mscorlib.resources.dll2.0.50727.3053425,98415-Sep-200822:25x86
Mscorlib.resources.dll2.0.50727.3053307.20027-Jul-200817:58x86
Mscorlib.resources.dll2.0.50727.3053299,00815-Sep-200822:25x86
Mscorlib.resources.dll2.0.50727.3053311,29627-Jul-200817:58x86
Mscorlib.resources.dll2.0.50727.3053331,77615-Sep-200822:25x86
Mscorlib.resources.dll2.0.50727.3053315,39215-Sep-200822:25x86
Mscorlib.resources.dll2.0.50727.3053307.20027-Jul-200817:55x86
Mscorlib.resources.dll2.0.50727.3053348,16027-Jul-200817:58x86
Mscorlib.resources.dll2.0.50727.3053319,48827-Jul-200817:55x86
Mscorlib.resources.dll2.0.50727.3053290,81615-Sep-200822:25x86
Mscorlib.resources.dll2.0.50727.3053303,10415-Sep-200822:25x86
Mscorlib.resources.dll2.0.50727.3053311,29615-Sep-200822:25x86
Mscorlib.resources.dll2.0.50727.3053303,10427-Jul-200817:55x86
Mscorlib.resources.dll2.0.50727.3053307.20015-Sep-200822:25x86
Mscorlib.resources.dll2.0.50727.1434397,31211-Jan-200822:59x86
Mscorlib.resources.dll2.0.50727.3053299,00815-Sep-200822:25x86
Mscorlib.resources.dll2.0.50727.3053299,00815-Sep-200822:25x86
Mscorlib.resources.dll2.0.50727.3053278,52827-Jul-200817:55x86
Mscorlib.resources.dll2.0.50727.3053278,52827-Jul-200817:55x86
Big5.nlpNo aplicable66,72818-Dec-200721:03No aplicable
Bopomofo.nlpNo aplicable82,17218-Dec-200721:03No aplicable
Ksc.nlpNo aplicable116,75618-Dec-200721:04No aplicable
Mscorlib.dll2.0.50727.30684,546,56001-Oct-200822:27x86
Normidna.nlpNo aplicable59,34218-Dec-200721:05No aplicable
Normnfc.nlpNo aplicable45,79418-Dec-200721:05No aplicable
Normnfd.nlpNo aplicable39,28418-Dec-200721:05No aplicable
Normnfkc.nlpNo aplicable66,38418-Dec-200721:05No aplicable
Normnfkd.nlpNo aplicable60,29418-Dec-200721:05No aplicable
Prc.nlpNo aplicable83,74818-Dec-200721:05No aplicable
Prcp.nlpNo aplicable83,74818-Dec-200721:05No aplicable
Sortkey.nlpNo aplicable262,14818-Dec-200721:05No aplicable
Sorttbls.nlpNo aplicable20,32018-Dec-200721:05No aplicable
Xjis.nlpNo aplicable28,28818-Dec-200721:05No aplicable
Mscordacwks.dll2.0.50727.3068992,26401-Oct-200822:27x86
Mscorjit.dll2.0.50727.3068367,10424-Sep-200822:21x86
Mscorwks.dll2.0.50727.30685,815,80801-Oct-200822:27x86
Windows Vista SP1 y Windows Server 2008, x64 versiones
Nombre del archivoVersión del archivoTamaño de archivoFechaHoraPlataforma
Big5.nlpNo aplicable66,72818-Dec-200721:01No aplicable
Bopomofo.nlpNo aplicable82,17218-Dec-200721:01No aplicable
Ksc.nlpNo aplicable116,75618-Dec-200721:02No aplicable
Mscorlib.dll2.0.50727.30684,562,94401-Oct-200822:25x64
Normidna.nlpNo aplicable59,34218-Dec-200721:03No aplicable
Normnfc.nlpNo aplicable45,79418-Dec-200721:03No aplicable
Normnfd.nlpNo aplicable39,28418-Dec-200721:03No aplicable
Normnfkc.nlpNo aplicable66,38418-Dec-200721:03No aplicable
Normnfkd.nlpNo aplicable60,29418-Dec-200721:03No aplicable
Prc.nlpNo aplicable83,74818-Dec-200721:03No aplicable
Prcp.nlpNo aplicable83,74818-Dec-200721:03No aplicable
Sortkey.nlpNo aplicable262,14818-Dec-200721:03No aplicable
Sorttbls.nlpNo aplicable20,32018-Dec-200721:03No aplicable
Xjis.nlpNo aplicable28,28818-Dec-200721:03No aplicable
Mscordacwks.dll2.0.50727.30681,767,94401-Oct-200822:25x64
Mscorjit.dll2.0.50727.30681,580,03224-Sep-200823:06x64
Mscorwks.dll2.0.50727.306810,079,74401-Oct-200822:25x64
Mscorlib.resources.dll2.0.50727.3053352,25615-Sep-200822:26x86
Mscorlib.resources.dll2.0.50727.3053303,10415-Sep-200822:25x86
Mscorlib.resources.dll2.0.50727.3053299,00815-Sep-200822:26x86
Mscorlib.resources.dll2.0.50727.3053315,39227-Jul-200818:02x86
Mscorlib.resources.dll2.0.50727.3053425,98415-Sep-200822:26x86
Mscorlib.resources.dll2.0.50727.3053307.20027-Jul-200818:02x86
Mscorlib.resources.dll2.0.50727.3053299,00815-Sep-200822:26x86
Mscorlib.resources.dll2.0.50727.3053311,29627-Jul-200818:02x86
Mscorlib.resources.dll2.0.50727.3053331,77615-Sep-200822:26x86
Mscorlib.resources.dll2.0.50727.3053315,39215-Sep-200822:25x86
Mscorlib.resources.dll2.0.50727.3053307.20027-Jul-200817:56x86
Mscorlib.resources.dll2.0.50727.3053348,16027-Jul-200818:02x86
Mscorlib.resources.dll2.0.50727.3053319,48827-Jul-200817:56x86
Mscorlib.resources.dll2.0.50727.3053290,81615-Sep-200822:26x86
Mscorlib.resources.dll2.0.50727.3053303,10415-Sep-200822:25x86
Mscorlib.resources.dll2.0.50727.3053311,29615-Sep-200822:25x86
Mscorlib.resources.dll2.0.50727.3053303,10427-Jul-200817:56x86
Mscorlib.resources.dll2.0.50727.3053307.20015-Sep-200822:25x86
Mscorlib.resources.dll2.0.50727.1434397,31211-Jan-200822:59x86
Mscorlib.resources.dll2.0.50727.3053299,00815-Sep-200822:25x86
Mscorlib.resources.dll2.0.50727.3053299,00815-Sep-200822:25x86
Mscorlib.resources.dll2.0.50727.3053278,52827-Jul-200817:56x86
Mscorlib.resources.dll2.0.50727.3053278,52827-Jul-200817:56x86
Big5.nlpNo aplicable66,72818-Dec-200721:03No aplicable
Bopomofo.nlpNo aplicable82,17218-Dec-200721:03No aplicable
Ksc.nlpNo aplicable116,75618-Dec-200721:04No aplicable
Mscorlib.dll2.0.50727.30684,546,56001-Oct-200822:27x86
Normidna.nlpNo aplicable59,34218-Dec-200721:05No aplicable
Normnfc.nlpNo aplicable45,79418-Dec-200721:05No aplicable
Normnfd.nlpNo aplicable39,28418-Dec-200721:05No aplicable
Normnfkc.nlpNo aplicable66,38418-Dec-200721:05No aplicable
Normnfkd.nlpNo aplicable60,29418-Dec-200721:05No aplicable
Prc.nlpNo aplicable83,74818-Dec-200721:05No aplicable
Prcp.nlpNo aplicable83,74818-Dec-200721:05No aplicable
Sortkey.nlpNo aplicable262,14818-Dec-200721:05No aplicable
Sorttbls.nlpNo aplicable20,32018-Dec-200721:05No aplicable
Xjis.nlpNo aplicable28,28818-Dec-200721:05No aplicable
Mscordacwks.dll2.0.50727.3068992,26401-Oct-200822:27x86
Mscorjit.dll2.0.50727.3068367,10424-Sep-200822:21x86
Mscorwks.dll2.0.50727.30685,815,80801-Oct-200822:27x86
Windows Vista SP1 y Windows Server 2008, versiones IA-64
Nombre del archivoVersión del archivoTamaño de archivoFechaHoraPlataforma
Big5.nlpNo aplicable66,72818-Dec-200721:06No aplicable
Bopomofo.nlpNo aplicable82,17218-Dec-200721:06No aplicable
Ksc.nlpNo aplicable116,75618-Dec-200721:06No aplicable
Mscorlib.dll2.0.50727.30684,005,88801-Oct-200822:26IA-64
Normidna.nlpNo aplicable59,34218-Dec-200721:08No aplicable
Normnfc.nlpNo aplicable45,79418-Dec-200721:08No aplicable
Normnfd.nlpNo aplicable39,28418-Dec-200721:08No aplicable
Normnfkc.nlpNo aplicable66,38418-Dec-200721:08No aplicable
Normnfkd.nlpNo aplicable60,29418-Dec-200721:08No aplicable
Prc.nlpNo aplicable83,74818-Dec-200721:08No aplicable
Prcp.nlpNo aplicable83,74818-Dec-200721:08No aplicable
Sortkey.nlpNo aplicable262,14818-Dec-200721:08No aplicable
Sorttbls.nlpNo aplicable20,32018-Dec-200721:08No aplicable
Xjis.nlpNo aplicable28,28818-Dec-200721:08No aplicable
Mscordacwks.dll2.0.50727.30683,087,88001-Oct-200822:26IA-64
Mscorjit.dll2.0.50727.30682,560,51224-Sep-200823:14IA-64
Mscorwks.dll2.0.50727.306820,153,85601-Oct-200822:26IA-64
Mscorlib.resources.dll2.0.50727.3053315,39227-Jul-200817:58x86
Mscorlib.resources.dll2.0.50727.3053311,29627-Jul-200817:58x86
Mscorlib.resources.dll2.0.50727.3053348,16027-Jul-200817:58x86
Mscorlib.resources.dll2.0.50727.3053319,48827-Jul-200817:58x86
Mscorlib.resources.dll2.0.50727.3053278,52827-Jul-200817:58x86
Mscorlib.resources.dll2.0.50727.3053278,52827-Jul-200817:59x86
Big5.nlpNo aplicable66,72818-Dec-200721:03No aplicable
Bopomofo.nlpNo aplicable82,17218-Dec-200721:03No aplicable
Ksc.nlpNo aplicable116,75618-Dec-200721:04No aplicable
Mscorlib.dll2.0.50727.30684,546,56001-Oct-200822:27x86
Normidna.nlpNo aplicable59,34218-Dec-200721:05No aplicable
Normnfc.nlpNo aplicable45,79418-Dec-200721:05No aplicable
Normnfd.nlpNo aplicable39,28418-Dec-200721:05No aplicable
Normnfkc.nlpNo aplicable66,38418-Dec-200721:05No aplicable
Normnfkd.nlpNo aplicable60,29418-Dec-200721:05No aplicable
Prc.nlpNo aplicable83,74818-Dec-200721:05No aplicable
Prcp.nlpNo aplicable83,74818-Dec-200721:05No aplicable
Sortkey.nlpNo aplicable262,14818-Dec-200721:05No aplicable
Sorttbls.nlpNo aplicable20,32018-Dec-200721:05No aplicable
Xjis.nlpNo aplicable28,28818-Dec-200721:05No aplicable
Mscordacwks.dll2.0.50727.3068992,26401-Oct-200822:27x86
Mscorjit.dll2.0.50727.3068367,10424-Sep-200822:21x86
Mscorwks.dll2.0.50727.30685,815,80801-Oct-200822:27x86

Solución alternativa

Para evitar este problema, utilice uno de los métodos siguientes.

Método 1

Si el código de aplicación asemeja el código de ejemplo en la sección "Más información", busque la siguiente línea de código.
#define GETVECTOR3D(vec3d) (*reinterpret_cast<AcGeVector3d*>(&((vec3d).m_x))
Cambie esta línea de código como sigue.
#define GETVECTOR3D(vec3d) (*reinterpret_cast<AcGeVector3d*>(&((vec3d)))

Método 2

Implementar un archivo. ini. Para ello, cree un archivo que contiene el código siguiente.
[.NET Framework Debugging Control]AllowOptimize=0

Nombre del archivo .ini el mismo que el módulo problemático, pero utilice la extensión. ini en lugar de la extensión. dll. Por ejemplo, para el código de ejemplo en la sección "Más información", el nombre del archivo .ini el archivo Bug.ini. Coloque el archivo Bug.ini en el mismo directorio que el archivo Bug.dll.

Nota: El inconveniente de este método es el efecto de rendimiento potencial para sin optimizaciones. Si utiliza el generador de imágenes nativas (Ngen.exe) para precompilar el módulo, este método no es aplicable.

Método 3

Aplicar de forma selectiva la opción NoOptimization de la enumeración MethodImplOptions a los métodos problemáticos mediante la clase MethodImplAttribute .

Nota: Este método deshabilita las optimizaciones para el compilador JIT y Native Image Generator (Ngen.exe) a nivel de método. ¿Cuánto se ve afectado el rendimiento varía en función del método.

Estado

Microsoft ha confirmado que se trata de un problema de los productos de Microsoft que se enumeran en la sección "Aplicable a".

Más información

Pasos para reproducir el problema

  1. Crear una aplicación de C++ que se basa en el.NET Framework 3.5 SP1.
  2. Agregar un archivo .cpp al proyecto, el archivo Bug.cpp al archivo el nombre y, a continuación, pegue el código siguiente en el archivo Bug.cpp.
    #using <mscorlib.dll>#include <stdlib.h>
    class AcGeVector3d
    {
    double x, y, z;
    public:
    __forceinline AcGeVector3d(const AcGeVector3d& src): x(src.x),y(src.y),z(src.z)
    {
    }
    __forceinline AcGeVector3d(double xx, double yy, double zz) : x(xx),y(yy),z(zz)
    {
    }
    __forceinline AcGeVector3d operator / (double val) const
    {
    return AcGeVector3d (x/val, y/val, z/val);
    }
    };
    #define GETVECTOR3D(vec3d) (*reinterpret_cast<AcGeVector3d*>(&((vec3d).m_x)))
    namespace Geometry
    {
    [System::Runtime::InteropServices::StructLayout(System::Runtime::InteropServices::LayoutKind::Sequential)]
    public value class Vector3d
    {
    internal:
    double m_x, m_y, m_z;
    Vector3d(const AcGeVector3d* obj)
    {
    GETVECTOR3D(*this) = *obj;
    }
    public:
    Vector3d(double x, double y, double z):m_x(x),m_y(y), m_z(z) {}
    Vector3d DivideBy(double value)
    {
    return Vector3d(&GETVECTOR3D(*this).operator /(value));
    }
    virtual System::String^ ToString() override
    {
    return System::String::Format("{0}, {1}, {2}", m_x, m_y, m_z);
    }
    };
    }

  3. Para compilar el archivo Bug.cpp, ejecute el siguiente comando:
    cl/clr/GL/O2 bug.cpp /link /dll /out:bug.dll
  4. Cree un nuevo proyecto de Microsoft Visual C# que se utilizará como el proyecto de cliente.
  5. Nombre del archivo de código en el archivo Test.cs y, a continuación, pegue el código siguiente en el archivo Test.cs.
    using Geometry;namespace Test
    {
    class Tester
    {
    static void Main()
    {
    Vector3d v = new Vector3d(200, 200, 0);
    v = v.DivideBy(150);
    System.Console.WriteLine("{0}", v);
    }
    }
    }

  6. Para compilar el archivo Test.cs, ejecute el siguiente comando:
    csc /r:bug.dll test.cs
  7. Para incrustar el manifiesto en el archivo Test.exe, ejecute el siguiente comando:
    MT.exe - nologo-manifiesto bug.dll.manifest-outputresource:test.exe;1
  8. Ejecute el archivo Test.exe.
Observe que el resultado real es el siguiente:
1.33333333333333, 1.333333333333, 0
Sin embargo, el resultado esperado es como sigue:
1.33333333333333, 0, 0

Referencias

Para obtener más información acerca de la terminología de la actualización de software, haga clic en el número de artículo siguiente para verlo en Microsoft Knowledge Base:
824684 descripción de la terminología estándar que se utiliza para describir las actualizaciones de software de Microsoft
Propiedades

Id. de artículo: 957542 - Última revisión: 14 ene. 2017 - Revisión: 1

Comentarios