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

このコンパイラ組み込み関数を使用して、コンパイラによって生成される命令ストリームに SMLAD 命令を挿入します。2 つの符号付き 16 ビット乗算を実行し、その両方の結果を 32 ビット累算オペランドに加算することができます。加算がオーーフローした場合、Q ビットが設定されます。乗算中にオーバーフローが発生することはありません。

unsigned int __smlad(unsigned int val1, unsigned int val2, unsigned int val3)

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

val1

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

val2

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

val3

累算値を保持します。

__smlad コンパイラ組み込み関数は、各乗算の積を累算値に加算して、32 ビット整数として返します。

例:

unsigned int dual_multiply_accumulate(unsigned int val1, unsigned int val2, unsigned int val3)
{
  unsigned int res;

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

Show/hide関連項目

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