Partager via


_mm_sha_epi32

Visual Studio 2010 SP1 est requis

Spécifique à Microsoft

Génère le vpshad de l'instruction XOP pour effectuer un décalage arithmétique de chacun des mots doubles dans sa première source en appliquant le degré spécifié dans la seconde.

__m128i _mm_sha_epi32 (
   __m128i src,
   __m128i counts
);

Paramètres

  • [in] src
    Un paramètre de 128 bits qui contient quatre entiers signés de 32 bits.

  • [in] counts
    Paramètre de 128 bits qui contient seize entiers signés de 8 bits.

Valeur de retour

Résultat r de 128 bits qui contient quatre entiers signés de 32 bits.

r[i] := (counts[4*i] >= 0) ? src[i] << counts[4*i] :
                             src[i] >> -counts[4*i]);

Configuration requise

Intrinsèque

Architecture

_mm_sha_epi32

XOP

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

Notes

Chaque valeur de l'entier de 32 bits signé dans src est pivotée par le nombre de bits spécifié par la valeur dans l'octet de counts qui correspond à son octet de poids faible, et le résultat de l'entier de 32 bits signé est stocké comme valeur correspondante dans la destination. Si la valeur dans counts est positive, le décalage s'effectue à gauche (vers le bit le plus significatif) et les zéros sont décalés vers la fin à droite. Sinon, le décalage s'effectue à droite et les zéros sont décalés vers la fin à gauche. Si un compteur de décalage est supérieur à 31, la valeur du résultat correspondante est égale à 0 ; si un compteur de décalage est inférieure à -31, le résultat est égal à -1 si la valeur dans src est négative, sinon 0. Les autres valeurs dans counts sont ignorées.

L'instruction vpshad 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, d;
    int i, j;
    unsigned int temp;
    for (i = 0; i < 4; i++) {
        temp = 0;
        for (j = 0; j < 8; j++) {
            temp = temp << 4 | (8*i + j + 7) % 16;
        }
        a.m128i_u32[i] = temp;
        b.m128i_i8[4*i] = 11*i - 21;
    }
    d = _mm_sha_epi32(a, b);
    printf_s("data:       ");
    for (i = 0; i < 4; i++) printf_s(" %08x", a.m128i_u32[i]);
    printf_s("\nshifted by  ");
    for (i = 0; i < 4; i++) printf_s(" %8d", b.m128i_i8[4*i]);
    printf_s("\ngives       ");
    for (i = 0; i < 4; i++) printf_s(" %08x", d.m128i_u32[i]);
    printf_s("\n");
}
  

Voir aussi

Référence

__cpuid, __cpuidex

Autres ressources

_mm_sha_epi8

_mm_sha_epi16

_mm_sha_epi64

_mm_shl_epi32

_mm_rot_epi32

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.