Partager via


_mm_perm_epi8

Visual Studio 2010 SP1 est requis

Spécifique à Microsoft

Génère l'instruction XOP vpperm pour sélectionner des octets de ses deux premières sources et éventuellement les transformer.

__m128i _mm_perm_epi8 (
   __m128i src1,
   __m128i src2,
   __m128i selector
);

Paramètres

  • [in] src1
    Paramètre de 128 bits qui contient seize octets.

  • [in] src2
    Paramètre de 128 bits qui contient seize octets.

  • [in] selector
    Paramètre de 128 bits qui sélectionne des octets dans src1 et src2, et choisit éventuellement une transformation à appliquer à l'octet sélectionné.

Valeur de retour

Résultat r de 128 bits qui contient des octets sélectionnés de src1 et src2, et éventuellement transformé.

Configuration requise

Intrinsèque

Architecture

_mm_perm_epi8

XOP

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

Notes

Pour chaque octet dans selector, les bits de poids faible sélectionnent un octet dans src1 ou src2. Les valeurs comprises entre 0 et 15 sélectionnent les octets compris entre 0 et 15 de src1, tandis que les valeurs comprises entre 16 et 31 sélectionnent les octets compris entre 0 et 15 de src2. Les bits de poids fort de chaque octet dans selector déterminent la transformation, le cas échéant, à appliquer à l'octet sélectionné.

Valeur de 3 bits de poids fort du sélecteur

Transformation choisie

000b

Aucune transformation

001b

Inverse (opération de complément) l'octet source

010b

Octet source du bit inversé

011b

L'inverse du bit a inversé l'octet source

100b

Définissez l'octet du résultat sur 0x00

101b

Définissez l'octet du résultat sur 0xFF

110b

Répliquez le bit le plus significatif de l'octet source

111b

Répliquez le bit le plus significatif inversé de l'octet source

L'instruction vpperm 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, selector, d;
    int i;
    for (i = 15; i >= 0; i--) {
        a.m128i_u8[i] = i;               // 0x0f0e0d0c...
        b.m128i_u8[i] = (i << 4) | i;    // 0xffeeddcc...
    }
    selector.m128i_u64[1] = 0xfedcba9876543210ll;
    selector.m128i_u64[0] = 0x0011223344556677ll;
    d = _mm_perm_epi8(a, b, selector);
    printf_s("%016I64x %016I64x\n", d.m128i_u64[1], d.m128i_u64[0]);
}
  

Voir aussi

Référence

__cpuid, __cpuidex

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.