CMP $hhll, X
Aus C64-Wiki
Zur Navigation springenZur Suche springen
Mnemonic: | CMP $hhll, X | |||
Opcode: | $DD | |||
Operand(en): | $ll $hh | |||
Anzahl der Bytes: | 3 | |||
Befehlsgruppe: | Arithmetik und Logikbefehl | |||
Adressierung: | absolut X-indiziert | |||
Beeinflusste Flags im Statusregister: | ||||
Carry-Flag | ||||
Negative-Flag | ||||
Zero-Flag | ||||
Taktzyklen: | 4 | |||
1 Extratakt bei Überschreitung einer Page-Grenze | ||||
1 | PC | R | Lese Befehl, inkrementiere PC | |
2 | PC | R | lese Adress-Lowbyte, inkrementiere PC | |
3 | PC | R | hole Highbyte der Adresse, addiere Indexregister zum Adress-Lowbyte, inkrementiere PC | |
4 | Adresse + I | R* | lese von effektiver Adresse, korrigiere Highbyte der effektiven Adresse | |
5+ | Adresse + I | R | lese erneut von effektiver Adresse | |
Anmerkung: | I bezeichnet das Index-Register (X oder Y) | |||
Anmerkung: | * das Highbyte der effektiven Adresse könnte zu diesem Zeitpunkt ungültig sein | |||
Anmerkung: | + dieser Takt wird nur ausgeführt, wenn die effektive Adresse im Zyklus 4 ungültig war |
Der Assembler-Befehl CMP $hhll, X vergleicht den Akkumulator mit dem Inhalt der Speicherzelle ($hhll+X).
Der Wert wird vom Akkumulator subtrahiert und entsprechend dem nicht gespeicherten Zwischenergebnis werden die Flags des Statusregisters gesetzt.
Funktionsprinzip
Carry-Flag | Zero-Flag | Negative-Flag | wenn |
1 | 0 | 0 | Differenz > 0 |
1 | 1 | 0 | Differenz = 0 |
0 | 0 | 1 | Differenz < 0 |
Bedeutung der Buchstaben im Befehl
CMP | CoMPare with Accumulator |
Vergleiche mit Akkumulator |
Beispiel
Vergleiche Beispiel von CMP #$nn.
Vergleich mit Basic
Vergleich | BASIC | Assembler-Befehl(e) nach CMP |
= | IF A = nn THEN GOTO label | BEQ label |
<> | IF A <> nn THEN GOTO label | BNE label |
>= | IF A >= nn THEN GOTO label | vorzeichenlos: BCS label oder vorzeichenbehaftet: BPL label |
> | IF A > nn THEN GOTO label | vorzeichenlos: BEQ skip BCS label skip: ... oder vorzeichenbehaftet: BEQ skip BPL label skip: ... |
<= | IF A <= nn THEN GOTO label | vorzeichenlos: BEQ label BCC label oder vorzeichenbehaftet: BEQ label BMI label |
< | IF A < nn THEN GOTO label | vorzeichenlos: BCC label oder vorzeichenbehaftet: BMI label |
Anmerkung: Das Sprungziel label ist in der BASIC-Variante als Zeilennummer zu verstehen.