Voici un tableau de référence des différents instructions du microprocesseur 4004:
| Nom | Opération | Description |
|---|---|---|
| ADD | A = A + indexreg + FlagCY | Cette instruction permet d'additionner une opérande au registre A (Accumulateur). |
| ADM | A = A + mem[-mem-addr-] + FlagCY | Cette instruction permet d'additionner la cellule mémoire du registre A (accumulateur). |
| BBL | Retire un de la pile PC; A = immediate4 | Cette instruction permet de retirer de la pile une valeur et la copie dans le registre A (accumulateur). |
| CLB | A = 0; FlagCY = 0 | Cette instruction permet de copier la valeur 0 dans le registre A (accumulateur) et l'indicateur de retenue (CY). |
| CLC | FlagCY = 0 | Cette instruction permet de copier la valeur 0 dans l'indicateur de retenue (CY). |
| CMA | A = NOT A | Cette instruction permet d'effectuer le complément du registre A (accumulateur). |
| CMC | FlagCY = NOT FlagCY | Cette instruction permet d'inverser la valeur de l'indicateur de retenue (CY). |
| DAA | Cette instruction corrige après coup les retenues lors de la manipulation de valeur DCB. | |
| DAC | A = A - 1 | Cette instruction permet de décrémenter le registre A (accumulateur) de 1. |
| DCL | -mem-addr-(bit9..8) = A(bit2..0) | Cette instruction permet de fixer la mémoire pour une ligne de commande. |
| FIM | indexregpair = progmem[PC+] (immediate8) | Cette instruction permet de copier dans une paire de registre d'index la valeur contenu dans une adresse mémoire de programme avec l'ajout d'une valeur immédiate à cette adresse. |
| FIN | indexregpair = progmem[PC(bit11..8),indexreg0,indexreg1] | Cette instruction permet de copier dans une paire de registre d'index la valeur contenu dans une adresse mémoire de programme avec l'ajout des valeurs des registres d'index 0 et 1 à cette adresse. |
| IAC | A = A + 1 | Cette instruction permet d'incrémenter le registre A (accumulateur) de 1. |
| INC | indexreg = indexreg + 1 | Cette instruction permet d'incrémenter le registre d'index de 1. |
| ISZ | indexreg = indexreg + 1; Si indexreg != 0 PC = PC(bit11..8),progmem[PC+] | Cette instruction permet d'incrémenter un registre d'index et effectue un saut du pointeur de programme si l'index contient la valeur 0. |
| JIN | PC = PC(bit11..8),indexreg,indexreg+1 | Cette instruction permet d'effectuer un saut du pointeur de programme à partir de l'adresse contenu dans la paire de registre d'index spécifié. |
| JCN | Si condition PC = PC(bit11..8),progmem[PC+] (address8) | Cette instruction permet d'effectuer un saut du pointeur de programme en fonction d'une condition à partir de l'adresse contenu dans la paire de registre d'index spécifié. |
| JMS | La pile PC avance de 1; PC = aaaa(bit11..8),progmem[PC+] | Cette instruction permet d'effectuer un saut du pointeur de programme à un sous-programme à partir de l'adresse spécifié. |
| JUN | PC = aaaa(bit11..8),progmem[PC+] (address12, 4 oct digit) | Cette instruction permet d'effectuer un saut du pointeur de programme à l'adresse spécifié. |
| KBP | A = table(A) | Cette instruction permet d'extraire une des valeurs du tampon clavier et le copie dans le registre A (accumulateur). |
| LD | A = indexreg | Cette instruction permet de copier une adresse de mémoire contenu dans un index dans le registre A (accumulateur). |
| LDM | A = immediate4 | Cette instruction permet de copier une adresse de mémoire directe dans le registre A (accumulateur). |
| NOP | do nothing | Cette instruction ne fait rien. |
| RAL | A <<= A | Cette instruction permet d'effectuer la rotation des bits du registre A (accumulateur) et le bit de l'indicateur de retenue vers la gauche. |
| RAR | A =>> A | Cette instruction permet d'effectuer la rotation des bits du registre A (accumulateur) et le bit de l'indicateur de retenue vers la droite. |
| RD0 | A = status0mem[-mem-addr-(bit9..4)] | Cette instruction permet d'écrire la valeur de l'adresse de mémoire d'état 0 dans le registre A (accumulateur). |
| RD1 | A = status1mem[-mem-addr-(bit9..4)] | Cette instruction permet d'écrire la valeur de l'adresse de mémoire d'état 1 dans le registre A (accumulateur). |
| RD2 | A = status2mem[-mem-addr-(bit9..4)] | Cette instruction permet d'écrire la valeur de l'adresse de mémoire d'état 2 dans le registre A (accumulateur). |
| RD3 | A = status3mem[-mem-addr-(bit9..4)] | Cette instruction permet d'écrire la valeur de l'adresse de mémoire d'état 3 dans le registre A (accumulateur). |
| RDM | A = mem[-mem-addr-] | Cette instruction permet d'écrire la valeur de la cellule mémoire dans le registre A (accumulateur). |
| RDR | A = ROM-input-port[-mem-addr-(bit7..4)] | Cette instruction permet d'écrire la valeur d'un port avec l'adresse du port contenu une cellule mémoire morte (ROM) dans le registre A (accumulateur). |
| SBM | A = A - mem[-mem-addr-] - FlagCY | Cette instruction permet de soustraire la cellule mémoire du registre A (accumulateur). |
| SRC | -mem-addr-(bit7..0) = indexreg,indexreg+1 | Cette instruction permet d'envoyer un registre de contrôle. |
| STC | FlagCY = 1 | Cette instruction permet de copier la valeur 1 dans l'indicateur de retenue (CY). |
| SUB | A = A - indexreg - FlagCY | Cette instruction permet de soustraire l'opérande source au registre A (accumulateur). |
| TCC | A = 0,0,0,FlagCY; FlagCY=0 | Cette instruction permet de copier la valeur de l'indicateur de retenue dans le registre A (accumulateur) et met la valeur 0 dans l'indicateur de retenue (CY). |
| TCS | A = 9 + FlagCY; FlagCY=0 | Cette instruction permet de soustraire la valeur de l'indicateur de retenue au registre A (accumulateur) et met la valeur 0 dans l'indicateur de retenue (CY). |
| WMP | RAM-output-port[-mem-addr-(bit9..4)] = A | Cette instruction permet d'écrire la valeur du registre A (accumulateur) dans un port avec l'adresse du port contenu une cellule mémoire. |
| WPM | progmem[-mem-addr-(bit7..0)](bit7..4-or-bit3..0) | Cette instruction permet d'écrire la valeur du registre A (accumulateur) dans une adresse de cellule mémoire de programme. |
| WR0 | status0mem[-mem-addr-(bit9..4)] = A | Cette instruction permet d'écrire la valeur du registre A (accumulateur) dans l'adresse de mémoire d'état 0. |
| WR1 | status1mem[-mem-addr-(bit9..4)] = A | Cette instruction permet d'écrire la valeur du registre A (accumulateur) dans l'adresse de mémoire d'état 1. |
| WR2 | status2mem[-mem-addr-(bit9..4)] = A | Cette instruction permet d'écrire la valeur du registre A (accumulateur) dans l'adresse de mémoire d'état 2. |
| WR3 | status3mem[-mem-addr-(bit9..4)] = A | Cette instruction permet d'écrire la valeur du registre A (accumulateur) dans l'adresse de mémoire d'état 3. |
| WRM | mem[-mem-addr-] = A | Cette instruction permet d'écrire la valeur du registre A (accumulateur) dans une cellule mémoire. |
| WRP | ROM-output-port[-mem-addr-(bit7..4)] = A | Cette instruction permet d'écrire la valeur du registre accumulateur dans un port avec l'adresse du port contenu une cellule mémoire morte (ROM). |
| XCH | A = indexreg; indexreg = A | Cette instruction permet d'échanger une adresse de mémoire contenu dans un index avec le registre A. |
Dernière mise à jour : Dimanche, le 28 juin 2015