12.54 __usad8 コンパイラ組み込み関数

このコンパイラ組み込み関数を使用して、コンパイラによって生成される命令ストリームに USAD8 命令を挿入します。

4 つの符号なし 8 ビット減算を実行して、それぞれの差の絶対値を加算し、単一の符号なし整数として結果を取得することができます。

構文

unsigned int __usad8(unsigned int val1 , unsigned int val2 )
各項目には以下の意味があります。
val1
減算の第 1 オペランドとなる 4 つの 8 ビット値を保持します。
val2
減算の第 2 オペランドとなる 4 つの 8 ビット値を保持します。

戻り値

__usad8 コンパイラ組み込み関数は、以下の各絶対差の合計を返します。
  • 第 1 オペランドの先頭バイトから第 2 オペランドの先頭バイトを減算した結果。
  • 第 1 オペランドの 2 番目のバイトから第 2 オペランドの 2 番目のバイトを減算した結果。
  • 第 1 オペランドの 3 番目のバイトから第 2 オペランドの 3 番目のバイトを減算した結果。
  • 第 1 オペランドの 4 番目のバイトから第 2 オペランドの 4 番目のバイトを減算した結果。
この合計が単一の符号なし整数として返されます。

unsigned int subtract_add_abs(unsigned int val1, unsigned int val2)
{
    unsigned int res;
    res = __usad8(val1,val2); /* absdiff1 = val1[7:0] - val2[7:0]
                                 absdiff2 = val1[15:8] - val2[15:8]
                                 absdiff3 = val1[23:16] - val2[23:16]
                                 absdiff4 = val1[31:24] - val2[31:24]
                                 res[31:0] = absdiff1 + absdiff2 + absdiff3
                                  + absdiff4
                              */
    return res;
}
関連する参考文書
10.153 ARMv6 SIMD コンパイラ組み込み関数
関連情報
USAD8
ARM 命令と Thumb 命令の概要
非機密扱いPDF file icon PDF 版ARM DUI0472LJ
Copyright © 2010-2015 ARM.All rights reserved.