_control87()是否也设置了SSE MXCSR控制寄存器?

IIn*_*ble 3 sse crt msvcrt fpu visual-c++

_control87笔记文档:

_control87 [...]影响[s] x87和SSE2的控制字(如果存在).

似乎SSE和SSE2 MXCSR控制寄存器是相同的,但是,文档中没有提到SSE单元.是否_control87影响SSE单元的MXCSR控制寄存器或仅适用于SSE2?

IIn*_*ble 5

我挖出一个旧的奔腾III,并检查以下代码:

#include <Windows.h>
#include <float.h>
#include <xmmintrin.h>
#include <iostream>
#include <iomanip>

int _tmain( int argc, _TCHAR* argv[] ) {
    using namespace std;

    // Unmask all SSE/SSE2 exceptions
    _MM_SET_EXCEPTION_MASK( 0 );
    // Get SSE/SSE2 exception mask
    DWORD dwExceptionMask = _MM_GET_EXCEPTION_MASK();
    cout << "Exception Mask: 0x" << hex << setw( 8 )
         << setfill( '0' ) << dwExceptionMask << endl;

    // Mask all FPU exceptions
    _control87( 0xFFFF, _MCW_EM );

    // Get SSE/SSE2 exception mask
    dwExceptionMask = _MM_GET_EXCEPTION_MASK();
    cout << "Exception Mask: 0x" << hex << setw( 8 )
         << setfill( '0' ) << dwExceptionMask << endl;

    return 0;
}
Run Code Online (Sandbox Code Playgroud)

Pentium III(SSE)的结果:

Exception Mask: 0x00000000
Exception Mask: 0x00000000
Run Code Online (Sandbox Code Playgroud)

Xeon(SSE,SSE2,SSE3,SSSE3)的结果:

Exception Mask: 0x00000000
Exception Mask: 0x00001e80
Run Code Online (Sandbox Code Playgroud)

结果令人惊讶,但符合文档._control87仅当至少有一个SSE2单元可用时,才会对MXCSR控制寄存器产生影响.