__smuadx コンパイラ組み込み関数

このコンパイラ組み込み関数を使用して、コンパイラによって生成される命令ストリームに SMUADX 命令を挿入します。第 2 オペランドのハーフワードを交換した上で、2 つの 16 ビット符号付き整数乗算を実行し、その積を加算することができます。第 2 オペランドのハーフワードを交換することによって、上位×下位の乗算と下位×上位の乗算の結果を得ることができます。加算がオーバーフローした場合、Q フラグが設定されます。乗算でオーバーフローが発生することはありません。

unsigned int__smuadx(unsigned int val1, unsigned int val2)

各項目には以下の意味があります。

val1

それぞれの乗算の第 1 オペランドとなるハーフワードを保持します。

val2

それぞれの乗算の第 2 オペランドとなるハーフワードを保持します。

__smuadx コンパイラ組み込み関数は、2 つの 16 ビット符号付き乗算の積を返します。

例:

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

    res = __smuadx(val1,val2); /* val2[31:16][15:0] = val2[15:0][31:16]
                                  p1 = val1[15:0] ラ val2[15:0]
                                  p2 = val1[31:16] ラ val2[31:16]
                                  res[31:0] = p1 + p2
                                */
    return res;
}

Show/hide関連項目

Copyright © 2010-2011 ARM. All rights reserved.ARM DUI 0491EJ
Non-ConfidentialID081711