Partager via


_mm_com_epu64

Visual Studio 2010 SP1 est requis

Spécifique à Microsoft

Génère le vpcomuq de l'instruction XOP pour retourner un masque de bits généré par une comparaison non signée mot quadruple par mot quadruple de ses deux premières sources à l'aide de la condition donnée par la troisième source.

__m128i _mm_com_epu64 (
   __m128i src1,
   __m128i src2,
   int condition
); 

Paramètres

  • [in] src1
    Tableau de 128 bits compressés de deux entiers non signés de 64 bits.

  • [in] src2
    Tableau de 128 bits compressés de deux entiers non signés de 64 bits.

  • [in] condition
    Condition de l'entier de 32 bits à utiliser dans la comparaison. Les valeurs autorisées sont comprises entre 0 et 7.

Valeur de retour

r du tableau de 128 bits compressés de deux entiers de 64 bits non signés, chacun avec la valeur 0x0000000000000000 ou 0xFFFFFFFFFFFFFFFF. Si cond est l'opérateur logique défini par la valeur de condition, alors

r[i] := src1[i] cond src2[i] ? 0xFFFFFFFFFFFFFFFF : 0x0000000000000000;

Configuration requise

Intrinsèque

Architecture

_mm_com_epu64

XOP

Fichier d'en-tête <intrin.h>

Notes

Cette instruction compare chaque mot quadruple de src1 au mot quadruple correspondant de src2, à l'aide de l'opérateur de comparaison décrit par condition. (Chaque paire de mots quadruples utilise le même opérateur de comparaison.) La condition des valeurs autorisées comprises entre 0 et 7. En incluant <intrin.h>, vous pouvez utiliser les noms suivants à la place des valeurs numériques de condition :

Valeur de type entier

Nom symbolique

Signification

0

_MM_PCOMCTRL_LT

r[i] = (src1[i] < src2[i]) ? 0xFFFFFFFFFFFFFFFF : 0x0000000000000000

1

_MM_PCOMCTRL_LE

r[i] = (src1[i] <= src2[i]) ? 0xFFFFFFFFFFFFFFFF : 0x0000000000000000

2

_MM_PCOMCTRL_GT

r[i] = (src1[i] > src2[i]) ? 0xFFFFFFFFFFFFFFFF : 0x0000000000000000

3

_MM_PCOMCTRL_GE

r[i] = (src1[i] >= src2[i]) ? 0xFFFFFFFFFFFFFFFF : 0x0000000000000000

4

_MM_PCOMCTRL_EQ

r[i] = (src1[i] == src2[i]) ? 0xFFFFFFFFFFFFFFFF : 0x0000000000000000

5

_MM_PCOMCTRL_NEQ

r[i] = (src1[i] != src2[i]) ? 0xFFFFFFFFFFFFFFFF : 0x0000000000000000

6

_MM_PCOMCTRL_FALSE

r[i] = 0x0000000000000000 (masque de tous les zéros)

7

_MM_PCOMCTRL_TRUE

r[i] = 0xFFFFFFFFFFFFFFFF (masque de tous les zéros)

Si vous préférez, vous pouvez utiliser les macros suivantes qui seront définies lorsque < intrin.h > est inclus :

Macro

Signification

_mm_comlt_epu64(src1, src2)

_mm_com_epu64(src1, src2, 0)

_mm_comle_epu64(src1, src2)

_mm_com_epu64(src1, src2, 1)

_mm_comgt_epu64(src1, src2)

_mm_com_epu64(src1, src2, 2)

_mm_comge_epu64(src1, src2)

_mm_com_epu64(src1, src2, 3)

_mm_comeq_epu64(src1, src2)

_mm_com_epu64(src1, src2, 4)

_mm_comneq_epu64(src1, src2)

_mm_com_epu64(src1, src2, 5)

_mm_comfalse_epu64(src1, src2)

_mm_com_epu64(src1, src2, 6)

_mm_comtrue_epu64(src1, src2)

_mm_com_epu64(src1, src2, 7)

L'instruction vpcomuq 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>
main()
{
    __m128i a, b, d;
    int i;
    a.m128i_i64[0] = -10;
    a.m128i_i64[1] =  10;
    b.m128i_i64[0] =  22;
    b.m128i_i64[1] = -22;
    printf("src1:     %20I64u %20I64u\n",
            a.m128i_u64[0], a.m128i_u64[1]);
    printf("src2:     %20I64u %20I64u\n",
            b.m128i_u64[0], b.m128i_u64[1]);
    d = _mm_com_epu64(a, b, _MM_PCOMCTRL_LT);
    printf("< mask:       %016I64x     %016I64x\n",
            d.m128i_u64[0], d.m128i_u64[1]);
    d = _mm_com_epu64(a, b, _MM_PCOMCTRL_GT);
    printf("> mask:       %016I64x     %016I64x\n",
            d.m128i_u64[0], d.m128i_u64[1]);
}
  

Voir aussi

Autres ressources

_mm_com_epi8

_mm_com_epu16

_mm_com_epu32

_mm_com_epi64

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.