__m64_muladd64hi, __m64_muladd64hi_u 

Microsoft Specific

Compute the high 64 bits of the expression a*b+c.

__m64 __m64_muladd64hi( 
   __m64 a, 
   __m64 b, 
   __m64 c 
);
__m64 __m64_muladd64hi_u( 
   __m64 a, 
   __m64 b, 
   __m64 c 
);

Parameters

  • [in] a
    The first factor.
  • [in] b
    The second factor.
  • [in] c
    The number to be added to the product of the first two parameters.

Requirements

Intrinsic Architecture

__m64_muladd64hi

IPF

__m64_muladd64hi_u

IPF

Header file <intrin.h>

Remarks

__m64_muladd64hi treats the arguments as signed 64-bit integers. __m64_muladd64hi_u treats the arguments as unsigned 64-bit integers.

Example

// muladd64hi.c
// processor: IPF

#include <stdio.h>
#include <intrin.h>
#include <limits.h>

#pragma intrinsic(__m64_muladd64hi, __m64_muladd64hi_u, __m64_muladd64lo)

int main()
{
    __m64 a, b, c, result;
    a.m64_i64 = 2I64;
    b.m64_i64 = _I64_MAX;
    c.m64_i64 = _I64_MAX;

    result = __m64_muladd64hi(a, b, c);
    printf_s("0x%I64x", result.m64_i64);

    result = __m64_muladd64lo(a, b, c);
    printf_s("%I64x\n", result.m64_i64);

    b.m64_u64 = _UI64_MAX;
    c.m64_u64 = _UI64_MAX;
    result = __m64_muladd64hi_u(a, b, c);
    printf_s("0x%I64x", result.m64_u64);

    result = __m64_muladd64lo(a, b, c);
    printf_s("%I64x", result.m64_u64);

    return 0;
}

Output

0x17ffffffffffffffd
0x2fffffffffffffffd

END Microsoft Specific

See Also

Reference

__m64_muladd64lo
__m64
Compiler Intrinsics