Étant donné deux registres $s0
, $s1
, comment puis-je convertir le pseudocode suivant en langage d'assemblage MIPS en utilisant uniquement les instructions slt
(défini sur less than) et beq
et bne
(branch si égal, branch si non égal).
if ($s0 > $s1) { goto label1 }
if ($s0 >= $s1) { goto label2 }
if ($s0 <= $s1) { go to label3 }
slt $t1,$s1,$s0 # checks if $s0 > $s1
beq $t1,1,label1 # if $s0 > $s1, goes to label1
beq $s1,$s2,label2 # if $s0 = $s2, goes to label2
beq $t1,$zero,label3 # if $s0 < $s1, goes to label3
Je suppose que le pseudocode s'exécute de manière séquentielle et que vous ne pouvez pas utiliser deux étiquettes différentes.
Je pense que cela devrait être:
stl $at, $s1, $s0
bne $at, $zero, label1
stl $t0, $s0, $s1
beq $t0, $zero, label2
stl $t1, $s1, $s0
beq $t1, $zero, label3
label1:
label2:
label3: