summaryrefslogtreecommitdiff
path: root/lib/simulator.c
diff options
context:
space:
mode:
Diffstat (limited to 'lib/simulator.c')
-rw-r--r--lib/simulator.c25
1 files changed, 17 insertions, 8 deletions
diff --git a/lib/simulator.c b/lib/simulator.c
index cd393b6..21e34bd 100644
--- a/lib/simulator.c
+++ b/lib/simulator.c
@@ -84,13 +84,15 @@ void DecodeExec(Uint32 instruction, Uint32 entrypoint)
/* ALU */
champ_registre_resultat = Champ1(instruction); /* Champ du registre dans lequel va etre stocké le résultat */
val1 = LireRegistre(Champ2(instruction)); /* Premier entier qui va etre utilisé dans l'opération */
- if (ValeurBit(Extension(instruction), 0) == 0)
- val2 = LireRegistre(Champ3(instruction)); /* Deuxième entier, stocké dans un registre, qui va etre utilisé dans l'opération */
- else {
- val2 = LireInstruction(); /* Deuxième entier, stocké après l'instruction, qui va etre utilisé dans l'opération */
- IncrementeCompteurOrdinal();
+ if (Opcode(instruction) < 6) {
+ if (ValeurBit(Extension(instruction), 0) == 0)
+ val2 = LireRegistre(Champ3(instruction)); /* Deuxième entier, stocké dans un registre, qui va etre utilisé dans l'opération */
+ else {
+ val2 = LireInstruction(); /* Deuxième entier, stocké après l'instruction, qui va etre utilisé dans l'opération */
+ IncrementeCompteurOrdinal();
+ }
}
- if (ValeurBit(Extension(instruction), 1) == 0) /* Teste si l'opération est signée ou pas */
+ if (ValeurBit(Extension(instruction), 1) == 0) {/* Teste si l'opération est signée ou pas */
switch (Opcode(instruction)) {
case 0:
resultat = AdditionNonSigne(val1, val2);
@@ -116,7 +118,8 @@ void DecodeExec(Uint32 instruction, Uint32 entrypoint)
case 7:
resultat = SHR(val1);
break;
- } else
+ }
+ } else {
switch (Opcode(instruction)) {
case 0:
resultat = AdditionSigne(val1, val2);
@@ -143,7 +146,13 @@ void DecodeExec(Uint32 instruction, Uint32 entrypoint)
resultat = SHR(val1);
break;
}
- EcrireRegistre(champ_registre_resultat, resultat); /* On écrit le résultat dans le registre de sortie */
+ }
+ if ((Opcode(instruction) & 2) && !(Opcode(instruction & 3))) {
+ EcrireRegistre(32, resultat);
+ EcrireRegistre(33, SecondResultat);
+ } else {
+ EcrireRegistre(champ_registre_resultat, resultat); /* On écrit le résultat dans le registre de sortie */
+ }
break;
case 8: /* MOV */
if (ValeurBit(Extension(instruction), 4) == 1) { /* MOV conditionnel */