[解決済み] なぜSet on Less ThanはALU演算なのか?
質問
なぜ
slt
ALUの演算を考慮したのですか? 単に引き算をしてから*を得るだけだと思っていました。
Z
*ALUからの出力はゼロ?
ALU制御線|機能 -------------------+------------------- 0000|アンド 0001|OR 0010|追加 0110|減算 0111|未満に設定
それとも、ALUの結果が1であれば、1を出力するようになっているのでしょうか?
A - B
於
slt $t1, A, B
)が負になる。
どのように解決するのですか?
Aがbより小さければ1を、そうでなければ0を出力することになっている。この場合、A-Bの計算が必要になることが多いので、ALUが必要になります。
の符号ビットを計算するだけであれば、このようになります。
A - B
というのは冗長ですが、例えば
A = -2147483648 = 0x80000000
と
B = 1 = 0x00000001
ここで、引き算の結果は次のようになります。
0x7fffffff = 2147483647
であるにもかかわらず、最上位ビットが設定されていません。
A < B
.
Patterson, David A.; Hennessy, John L.: Computer Organization and Design" の表なので、第3章、特に "add and subtraction" を扱った小節(第2版では 3.3, 第4版では 3.2) を参照してください。オーバーフローとアンダーフローを扱った表があり、コーナーケースを調べることができます。
また、ALUの結果は32ビットであることを覚えておいてください。たとえ結果が減算結果の符号ビットだけだったとしても、完全な減算結果ではなく、結果ビットに連結された31個のゼロが返されるべきことを知らせるために、異なるALU演算コードが必要です。
この本で紹介されているアーキテクチャでは、quot;Zero"ラインは、等しい分岐と等しくない分岐に関する比較にのみ使用されています。
SLT/SLTI
は、結果をレジスタに格納します。
関連
-
[解決済み】なぜMIPS用のsubiオペコードは存在しないのですか?
-
[解決済み] ARMのアセンブリ言語でbx lrは何をするのですか?
-
[解決済み] アセンブリ言語 - Moduloはどのように行うのですか?
-
[解決済み] オブジェクトファイルのシンボルテーブルとリロケーションテーブル
-
[解決済み] テストのポイント %eax %eax [重複]。
-
[解決済み] LC3 LEA 命令と格納された値
-
[解決済み] なぜGCCはa*a*a*a*aを(a*a*a)*(a*a*a)に最適化しないのでしょうか?
-
[解決済み] <は<=より速いのか?
-
[解決済み] Collatz予想の検証を行うC++のコードは、なぜ手書きのアセンブリよりも高速に動作するのでしょうか?
-
[解決済み] Intel CPU の _mm_popcnt_u64 で、32 ビットのループカウンターを 64 ビットに置き換えると、パフォーマンスが著しく低下します。
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み] テスト
-
[解決済み】アセンブリJLEのjmp命令例
-
[解決済み] WAWハザードとは?
-
[解決済み] MIPSのコードのこの部分で、oriはどのように使われているのですか?
-
[解決済み] MIPSプログラムの中で`lw`と`sw`が実際にどのように機能するかを理解する
-
[解決済み] x86-64におけるmovqとmovabsqの違いについて
-
[解決済み] アセンブリ言語で数字をプリントアウトする?
-
[解決済み] .quadディレクティブはアセンブリでどのように機能するのですか?
-
[解決済み] アセンブリ言語 - sarqはコードの中で何をするのですか?
-
[解決済み] MIPSの擬似命令 "move "の "addi "と "add "の違い?