_mm_maccslo_epi32
Visual Studio 2010 SP1 est requis
Spécifique à Microsoft
Génère l'instruction XOP vpmacssdql pour exécuter une opération multiplier-additionner de saturation d'un entier de ses sources.
__m128i _mm_maccslo_epi32 (
__m128i src1,
__m128i src2,
__m128i src3
);
Paramètres
[in] src1
Paramètre de 128 bits qui contient deux entiers signés de 32 bits dans ses mots doubles à index pair.[in] src2
Paramètre de 128 bits qui contient deux entiers signés de 32 bits dans ses mots doubles à index pair.[in] src3
Paramètre de 128 bits qui contient deux entiers de 64 bits signés.
Valeur de retour
Résultat r de 128 bits qui contient deux entiers signés de 64 bits.
r[0] := src1[0] * src2[0] + src3[0];
r[1] := src1[2] * src2[2] + src3[1];
Configuration requise
Intrinsèque |
Architecture |
---|---|
_mm_maccslo_epi32 |
XOP |
Fichier d'en-tête <intrin.h>
Notes
Chaque valeur de l'entier signé de 32 bits à index pair dans src1 est multipliée par la valeur de l'entier signé de 32 bits correspondante dans src2 ; chaque produit de l'entier signé de 64 bits est ajouté à la valeur de l'entier signé de 64 bits correspondante dans src3, et le résultat sous forme d'entier signé de 64 bits est stocké comme valeur correspondante dans la destination. Les mots doubles à index impair dans src1 et src2 sont ignorés.
Si le résultat de l'addition au produit de 64 bits est supérieur à 9223372036854775807 (0x7FFFFFFFFFFFFFFF) ou inférieur à -9223372036854775808 (0x8000000000000000), l'opération multiplier-ajouter sature en affectant respectivement 9223372036854775807 ou -9223372036854775808 à la valeur du résultat.
L'instruction vpmacssdql fait partie de la famille XOP des instructions. Avant d'utiliser cette fonction intrinsèque, vous devez vérifier que le processeur prend en charge cette instruction. Pour déterminer la prise en charge du matériel pour cette instruction, appelez la fonction intrinsèque __cpuid avec InfoType = 0x80000001 et vérifiez le bit 11 de CPUInfo[2] (ECX). Ce bit est égal à 1 lorsque l'instruction est prise en charge, sinon il est égal à 0.
Exemple
#include <stdio.h>
#include <intrin.h>
int main()
{
__m128i a, b, c, d;
int i;
a.m128i_i32[0] = 2000000000;
a.m128i_i32[2] = 2000000000;
b.m128i_i32[0] = -2000000000;
b.m128i_i32[2] = 2000000000;
c.m128i_i64[0] = 9000000000000000000ll;
c.m128i_i64[1] = 9000000000000000000ll;
d = _mm_maccslo_epi32(a, b, c);
for (i = 0; i < 2; i++)
printf_s(" %20I64d (0x%I64x)\n",
d.m128i_i64[i], d.m128i_i64[i]);
}
Voir aussi
Référence
Autres ressources
Fonctions XOP intrinsèques ajoutées pour Visual Studio 2010 SP1
Historique des modifications
Date |
Historique |
Motif |
---|---|---|
Mars 2011 |
Ce contenu a été ajouté. |
Modifications de fonctionnalités dans le SP1. |