MULLO

下位16ビット乗算

MULLO

MULtiply LOw-order word


【構文】

(1)

MULLO src, src2

(2)

MULLO src, src2, Adest 【V2.01.00以降】

 

【オペレーション】

(1)

signed short tmp1, tmp2;

signed long long tmp3;

tmp1 = (signed short) src;

tmp2 = (signed short) src2;

tmp3 = (signed long) tmp1 * (signed long) tmp2;

ACC = (tmp3 << 16);

(2)

signed short tmp1, tmp2;

signed 72bit tmp3;

tmp1 = (signed short) src;

tmp2 = (signed short) src2;

tmp3 = (signed long) tmp1 * (signed long) tmp2;

Adest = (tmp3 << 16); 【V2.01.00以降】

 

【機能】

(1)

srcの下位16ビットとsrc2の下位16ビットの乗算を行い、その結果をアキュムレータ(ACC)に格納します。ただし、乗算結果の最下位ビットはアキュムレータのb16にあわせ、アキュムレータのb63〜b48に対応する部分は、符号拡張されます。また、アキュムレータのb15〜b0は、“0”になります。srcの下位16ビットとsrc2の下位16ビットは符号付き整数として扱われます。

(2)

srcの下位16ビットとsrc2の下位16ビットの乗算を行い、その結果をアキュムレータ(ACC0またはACC1)に格納します。ただし、乗算結果の最下位ビットはアキュムレータのb16にあわせ、アキュムレータのb71〜b48に対応する部分は、符号拡張されます。また、アキュムレータのb15〜b0は、“0”になります。srcの下位16ビットとsrc2の下位16ビットは符号付き整数として扱われます。アセンブルオプション-isaを用いてRXv2以降の命令セットを指定した場合にアセンブルできます。 【V2.01.00以降】

 

【命令フォーマット】

構文

対象

コードサイズ

(バイト)

src

src2

Adest

(1) MULLO src, src2

Rs

Rs2

3

(2) MULLO src, src2, Adest

【V2.01.00以降】

Rs

Rs2

A0, A1

3

Adestには、ACC0の場合A0、ACC1の場合A1を指定してください。

 

【フラグ変化】

フラグ変化はありません。

 

【記述例】

MULLO   R1, R2
MULLO   R1, R2, A1