Compiler Reference Guide

Technical Support

On-Line Manuals

Compiler Reference Guide

Conventions and Feedback Introduction Compiler Command-line Options Language Extensions Compiler-specific Features C and C++ Implementation Details ARMv6 SIMD Instruction Intrinsics ARMv6 SIMD intrinsics by prefix ARMv6 SIMD intrinsics, summary descriptions, byte ARMv6 SIMD intrinsics, compatible processors and a See also ARMv6 SIMD instruction intrinsics and APSR GE flag __qadd16 intrinsic See also __qadd8 intrinsic See also __qasx intrinsic See also __qsax intrinsic See also __qsub16 intrinsic See also __qsub8 intrinsic See also __sadd16 intrinsic See also __sadd8 intrinsic See also __sasx intrinsic See also __sel intrinsic See also __shadd16 intrinsic See also __shadd8 intrinsic See also __shasx intrinsic See also __shsax intrinsic See also __shsub16 intrinsic See also __shsub8 intrinsic See also __smlad intrinsic See also __smladx intrinsic See also __smlald intrinsic See also __smlaldx intrinsic See also __smlsd intrinsic See also __smlsdx intrinsic See also __smlsld intrinsic See also __smlsldx intrinsic See also __smuad intrinsic See also __smusd intrinsic See also __smusdx intrinsic See also __smuadx intrinsic See also __ssat16 intrinsic See also __ssax intrinsic See also __ssub16 intrinsic See also __ssub8 intrinsic See also __sxtab16 intrinsic See also __sxtb16 intrinsic See also __uadd16 intrinsic See also __uadd8 intrinsic See also __uasx intrinsic See also __uhadd16 intrinsic See also __uhadd8 intrinsic See also __uhasx intrinsic See also __uhsax intrinsic See also __uhsub16 intrinsic See also __uhsub8 intrinsic See also __uqadd16 intrinsic See also __uqadd8 intrinsic See also __uqasx intrinsic See also __uqsax intrinsic See also __uqsub16 intrinsic See also __uqsub8 intrinsic See also __usad8 intrinsic See also __usada8 intrinsic See also __usax intrinsic See also __usat16 intrinsic See also __usub16 intrinsic See also __usub8 intrinsic See also __uxtab16 intrinsic See also __uxtb16 intrinsic See also Via File Syntax Summary Table of GNU Language Extensions Standard C Implementation Definition Standard C++ Implementation Definition C and C++ Compiler Implementation Limits

__smusdx intrinsic

__smusdx intrinsic

This intrinsic inserts an SMUSDX instruction into the instruction stream generated by the compiler. It enables you to perform two 16-bit signed multiplications, subtracting one of the products from the other. The halfwords of the second operand are exchanged before performing the arithmetic. This produces top × bottom and bottom × top multiplication.

unsigned int__smusdx(unsigned int val1, unsigned int val2)

Where:

val1

holds the first halfword operands for each multiplication

val2

holds the second halfword operands for each multiplication.

The __smusdx intrinsic returns the difference of the products of the two 16-bit signed multiplications.

Example:

unsigned int dual_multiply_prods(unsigned int val1, unsigned int val2)
{
  unsigned int res;

    res = __smuad(val1,val2); /* p1 = val1[15:0] × val2[31:16]
                                 p2 = val1[31:16] × val2[15:0]
                                 res[31:0] = p1 - p2
                               */
    return res;
}
Copyright © 2007-2008, 2011 ARM. All rights reserved.ARM DUI 0376C
Non-ConfidentialID061811