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

このコンパイラ組み込み関数を使用して、コンパイラによって生成される命令ストリームに UQASX 命令を挿入します。第 2 オペランドのハーフワードを交換した上で、符号なし 16 ビット整数の加算と符号なし 16 ビットの減算を実行し、それぞの結果を 16 ビット符号なし整数範囲 0 ≤ x ≤ 216 - 1 にサチュレートすることができます。

unsigned int __uqasx(unsigned int val1, unsigned int val2)

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

val1

第 1 オペランドとなる 2 つのハーフワード値を保持します。

val2

第 2 オペランドとなる 2 つのハーフワード値を保持します。

__uqasx コンパイラ組み込み関数は、以下を返します。

結果は、16 ビット符号なし整数範囲 0 ≤ x ≤ 216 - 1 にサチュレートされます。

例:

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

    res = __uqasx(val1,val2); /* res[15:0] = val1[15:0] - val2[31:16]
                                 res[31:16] = val1[31:16] + val2[15:0]
                               */
    return res;
}

Show/hide関連項目

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