_mm_haddq_epu8
Se requiere Visual Studio 2010 SP1.
Específicos de Microsoft
Genera la instrucción XOP vphaddubq para realizar la suma de un entero horizontal sin signo de su origen.
__m128i _mm_haddq_epu8 (
__m128i src
);
Parámetros
- [in] src
Un parámetro de 128 bits que contiene dieciséis enteros sin signo de 8 bits.
Valor devuelto
Un resultado de 128 bits r que contiene dos enteros sin signo de 64 bits.
r[i] := src[8*i] + src[8*i+1] + src[8*i+2] + src[8*i+3] +
src[8*i+4] + src[8*i+5] + src[8*i+6] + src[8*i+7];
Requisitos
Intrínseco |
Arquitectura |
---|---|
_mm_haddq_epu8 |
XOP |
Archivo de encabezado <intrin.h>
Comentarios
Cada uno de los dos grupos de ocho valores de entero sin signo de 8 bits en src se agrega para generar un resultado de entero sin signo de 64 bits que se almacena como el valor correspondiente en el destino. Ningún desbordamiento es posible en esta instrucción.
La instrucción vphaddubq forma parte de la familia XOP de instrucciones. Antes de utilizar este intrínseco, debe asegurarse de que el procesador admite esta instrucción. Para determinar la compatibilidad del hardware para obtener esta instrucción, llame a __cpuid intrínseco con InfoType = 0x80000001 y compruebe el bit 11 de CPUInfo [2] (ECX). Este bit es 1 cuando se admite la instrucción, de lo contrario es 0.
Ejemplo
#include <stdio.h>
#include <intrin.h>
int main()
{
__m128i a, d;
int i;
for (i = 0; i < 4; i++) {
a.m128i_i8[i] = -128;
a.m128i_i8[i+4] = i-128;
a.m128i_i8[i+8] = 10*i;
a.m128i_i8[i+12] = 127;
}
// Note that this intrinsic treats negative values as unsigned
// So, e.g., -128 becomes +128
d = _mm_haddq_epu8(a);
for (i = 0; i < 2; i++) printf_s(" %I64u", d.m128i_u64[i]);
printf_s("\n");
}
Vea también
Referencia
Otros recursos
Intrínsecos XOP agregados para Visual Studio 2010 SP1
Historial de cambios
Fecha |
Historial |
Motivo |
---|---|---|
Marzo de 2011 |
Se agrega este contenido. |
Cambio de características de SP1. |