Tutorial |
Dettaglio Istruzioni |
Istruzioni della Cpu 80x86 |
SCHEDA n° 07 [I/ 061 di 198] |
|
|
Questa istruzione non appartiene al Set dell'8088/86; si usa solo con 80286/486; esegue un salto condizionato dal valore del registro ECX. |
Fai attenzione: i salti condizionati sono sempre di tipo corto (Short), cioè rispetto alla posizione in cui vengono richiesti, possono puntare le istruzioni poste 127 locazioni in avanti o 128 indietro. Un errore frequente, nelle prime esperienze di programmazione è proprio quello di inserire troppe istruzioni tra il punto di partenza e il punto di arrivo del salto: in queste occasioni l'assemblatore segnala l'errore "error A2053: Jump out of range by nnn byte(s)" |
In realtà i processori dal 80386.consentono salti condizionati di tipo near (vicino), cioè nel range 32767 in avanti e 32768 indietro; se viene specificata la pseudoOperazione .386, l'assemblatore non segnala errore e codifica l'istruzione nel modo più corto possibile (anche short se è possibile). | |
Le sue caratteristiche sono riassunte nella seguente tabella (leggi le istruzioni ): |
JECXZ Destinazione | Salta alla locazione se il registro ECX contiene zero | |||||||||||||||
Esempio di Applicazione |
Cicli di Clock | Mem Acces |
N° Bytes |
Flag influenzate | ||||||||||||
Mnemonico | Operandi | 86 | 268 | 386 | 486 | O | D | I | T | S | Z | A | P | C | ||
JECXZ |
etichetta |
no | 8 | 9 | 8 | no | 2 | |||||||||
no | 4 | 5 | 5 | no |
La tabella mette in evidenza che in presenza di salto (prima riga) è necessario un numero maggiore di cicli di Clock, anche perchè il processore è costretto a reinizializzare la coda dell'istruzione al fine di assumere i codici operativi dell'istruzione a cui cedere il controllo (evidentemente non consecutiva a quella che richiede il salto..); se il salto non viene eseguito i tempi d'esecuzione (seconda riga) sono più rapidi. | |
Si evidenzia anche che JECXZ (salta se il registro ECX contiene 0) viene eseguita se il registro ECX=0; nessuna flag è invece influenzata da questa istruzione. |
L'istruzione specifica (dopo la J di Jump) la condizione che impone il salto, in questo caso ECXZ, llegata all'evento registro ECX a Zero, "salta se il registro ECX si è azzerato..."; subito dopo indica l'etichetta della locazione a cui saltare. | |
Naturalmente questa etichetta deve essere presente nelle prossimità dell'istruzione che l'ha dichiarata, seguita da ":" (2 punti), per esempio (leggi le istruzioni): |
|
|
Scheda n° 07 | Istruzioni Cpu 80x86 | |||||||
Istruzione 061 - JECXZ |
|
|
|
Home |
|
|||||||
|
Motore Ricerca |
|