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

このコンパイラ組み込み関数を使用して、コンパイラによって生成される命令ストリームに USAT16 命令を挿入します。2 つの符号付き 16 ビット値を、選択した符号なし範囲にサチュレートすることができます。いずれかの演算がサチュレートされた場合、Q フラグが設定されます。

unsigned int __usat16(unsigned int val1, /* constant */ unsigned int val2)

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

val1

サチュレート対象の 2 つの 16 ビット値を保持します。

val2

サチュレーションのビット位置です。整数定数式で指定する必要があります。

__usat16 コンパイラ組み込み関数は、2 つの符号付き 16 ビット値のサチュレーション結果を負以外の値として返します。

例:

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

    res = __usax(val1,val2); /* val1 のハーフワードを、
                                val2 でビット位置によって指定された符号なし範囲にサチュレートします
                              */    return res;
}

Show/hide関連項目

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