Aller au contenu

1. Contexte

Le processeur M999 est doté d'un jeu d'instructions.

Une instruction est un mot de 3 chiffres, appelé opcode, correspondant à une opération à effectuer par le processeur.

Le premier chiffre de l'opcode détermine le type de l'opération (copie, opération arithmétique, saut d'instruction ...).

Les deux derniers chiffres indiquent, selon le type de l'opération, une adresse mémoire, un registre, un sous-type d'opération...

2. Jeu d'instructions

op0 op1 op2 instruction à réaliser
0 addr copie le mot mémoire d’adresse addr dans le registre A
1 addr copie le mot mémoire d’adresse addr dans le registre B
2 addr copie le contenu du registre R dans le mot mémoire d'adresse addr
3 0 0 ajoute les valeurs des registres A et B, produit le résultat dans R
3 0 1 soustrait la valeur du registre B à celle du registre A, produit le résultat dans R
3 9 9 ne fait rien
4 rs rd copie la valeur du registre source rs dans le registre destination rd
5 addr branche en addr (PC reçoit la valeur addr)
6 addr branche en addr si la valeur du registre R est strictement positive

Les registres (rs, rd) sont désignés par les valeurs suivantes :

valeur registre
0 A
1 B
2 R