16.02.2013 Aufrufe

24531904_j

24531904_j

24531904_j

MEHR ANZEIGEN
WENIGER ANZEIGEN

Erfolgreiche ePaper selbst erstellen

Machen Sie aus Ihren PDF Publikationen ein blätterbares Flipbook mit unserer einzigartigen Google optimierten e-Paper Software.

pshradd ─ 並列右シフトおよび加算 (Parallel Shift Right and Add)<br />

pshradd<br />

書式 : (qp) pshradd2r 1 = r 2 , count 2 , r 3 A10<br />

説明 : GR r 2 の 4 つの符号付き 16 ビット ・データ要素が、 count 2 ビ ッ ト だけ、 それぞれ独立に<br />

右にシフ ト され、 GR r 3 の 4 つの符号付き 16 ビ ッ ト ・ デ ー タ要素に加算 さ れる。 こ の右<br />

シフ ト操作では、 各要素の上位ビッ ト に GR r 2 の各デー タ要素の符号ビ ッ ト の初期値が<br />

埋められる。 加算操作の実行には符号付きの飽和が行われる。 4 つの符号付き 16 ビッ ト<br />

の加算結果は GR r 1 に格納される。 第 1 オペラン ド に対してシフ ト でき る ビ ッ ト 数は、<br />

1、 2、 あるいは 3 に限られる。<br />

操作 : if (PR[qp]) {<br />

check_target_register(r 1 );<br />

}<br />

割り込み : 無効操作フ ォ ル ト<br />

x[0] = GR[r 2 ]{15:0}; y[0] = GR[r 3 ]{15:0};<br />

x[1] = GR[r 2 ]{31:16}; y[1] = GR[r 3 ]{31:16};<br />

x[2] = GR[r 2 ]{47:32}; y[2] = GR[r 3 ]{47:32};<br />

x[3] = GR[r 2 ]{63:48}; y[3] = GR[r 3 ]{63:48};<br />

max = sign_ext(0x7fff, 16);<br />

min = sign_ext(0x8000, 16);<br />

for (i = 0; i < 4; i++) {<br />

temp[i] = shift_right_signed(sign_ext(x[i], 16), count 2 );<br />

}<br />

res[i] = temp[i] + sign_ext(y[i], 16);<br />

if (res[i] > max)<br />

res[i] = max;<br />

if (res[i] < min)<br />

res[i] = min;<br />

GR[r 1] = concatenate4(res[3], res[2], res[1], res[0]);<br />

GR[r 1 ].nat = GR[r 2 ].nat || GR[r 3 ].nat;<br />

3:200 第 3 巻 : 命令リファレンス

Hurra! Ihre Datei wurde hochgeladen und ist bereit für die Veröffentlichung.

Erfolgreich gespeichert!

Leider ist etwas schief gelaufen!