Export (0) Print
Expand All
Expand Minimize

__m64_pshladd2

Microsoft Specific

Emits the IPF Parallel Shift Left and Add (pshladd2) instruction.

__m64 __m64_pshladd2( 
   __m64 a, 
   const int nBit, 
   __m64 b 
);

[in] a

An __m64 union containing an array of four 16-bit signed integers to be shifted left and added to.

[in] nBit

The number of bits to left shift the integers in the first array. Valid values from 0 to 3.

[in] b

An __m64 union containing an array of four 16-bit signed integers to add.

An __m64 union containing an array of four 16-bit signed integers, the elements of which are computed according to the expression described here.

Intrinsic

Architecture

__m64_pshladd2

IPF

Header file <intrin.h>

This instruction computes:

c[i] = a[i] << nBit + b[i]

for each of the four elements i of a and b and returns the array c as an __m64 union.

// m64_pshladd2.c
// processor: IPF
#include <stdio.h>
#include <intrin.h>

#pragma intrinsic(__m64_pshladd2)

int main()
{
    __m64 a, b, result;

    a.m64_i16[0] = 0;
    a.m64_i16[1] = 1;
    a.m64_i16[2] = 2;
    a.m64_i16[3] = 100;
    
    b.m64_i16[0] = 1;
    b.m64_i16[1] = 2;
    b.m64_i16[2] = 3;
    b.m64_i16[3] = 4;

    printf_s("Input a: %d %d %d %d\n", a.m64_i16[0],
             a.m64_i16[1], a.m64_i16[2], 
             a.m64_i16[3]);

    printf_s("Input b: %d %d %d %d\n", b.m64_i16[0],
             b.m64_i16[1], b.m64_i16[2],
             b.m64_i16[3]);

    result = __m64_pshladd2(a, 1, b);

    printf_s("Results of pshladd2(a, 1, b): %d %d %d %d\n",
             result.m64_i16[0],
             result.m64_i16[1], result.m64_i16[2],
             result.m64_i16[3]);
}
Input a: 0 1 2 100
Input b: 1 2 3 4
Results of pshladd2(a, 1, b): 1 4 7 204

Community Additions

ADD
Show:
© 2014 Microsoft