检查 XMM 寄存器中是否有所有零

Check XMM register for all zeroes

本文关键字:是否 XMM 寄存器 检查      更新时间:2023-10-16

有没有办法检查__m128i变量中的所有位/字节/字等是否都是0?
在我的应用程序中,我必须检查包含在 __m128i 变量中的所有整数是否都是零。我是否必须提取它们并分别比较它们?

<小时 />

编辑:

我现在正在做的是:

int next = 0;
do{
    //some code
    next = idata.m128i_i32[0] + idata.m128i_i32[1] + idata.m128i_i32[2] + idata.m128i_i32[3];
}while(next > 0);

我需要的是检查idata是否全为零而无需访问每个单独的元素,如果它们是......

<小时 />

根据哈罗德的评论,这是解决方案:

__m128i idata = _mm_setr_epi32(i,j,k,l);
do{
    //some code
}while( !_mm_testz_si128(idata, idata) );

如果idata中每个DW的所有低位均为0,这将退出循环...谢谢哈罗德!

_mm_testz_si128是SSE4.1,在某些CPU上不受支持(例如Intel Atom,AMD Phenom)

这是一个与SSE2兼容的变体

inline bool isAllZeros(__m128i xmm) {
    return _mm_movemask_epi8(_mm_cmpeq_epi8(xmm, _mm_setzero_si128())) == 0xFFFF;
}

就像Paul R对我最初的帖子评论的那样:

"你不需要为PTEST的第二个参数初始化一个虚拟参数,即你可以针对自身测试一个值,而不是_mm_testz_si128(idata, _mm_set1_epi32(0xFFFF))

ptest用一条指令完成整个工作。

这很有帮助。