CMP ($ll), Y
Aus C64-Wiki
Zur Navigation springenZur Suche springen
| Mnemonic: | CMP ($ll), Y | |||
| Opcode: | $D1 | |||
| Operand(en): | $ll | |||
| Anzahl der Bytes: | 2 | |||
| Befehlsgruppe: | Arithmetik und Logikbefehl | |||
| Adressierung: | indirekt Y-nachindiziert | |||
| Beeinflusste Flags im Statusregister: | ||||
| Carry-Flag | ||||
| Negative-Flag | ||||
| Zero-Flag | ||||
| Taktzyklen: | 5 | |||
| 1 Extratakt bei Überschreitung einer Page-Grenze | ||||
| 1 | PC | R | Lese Opcode, inkrementiere PC | |
| 2 | PC | R | Lese Zeigeradresse, inkrementiere PC | |
| 3 | Pointer | R | lese effektive Adresse Low | |
| 4 | Pointer | R | lese effektive Adresse High, addiere Y zum Lowbyte der effektiven Adresse | |
| 5 | Adresse + Y* | R | lese von effektiver Adresse, korrigiere Highbyte der effektiven Adresse | |
| 6+ | Adresse + Y | R | lese von effektiver Adresse | |
| Anmerkung: | Die effektive Adresse wird immer aus der Zeropage gelesen | |||
| Anmerkung: | * das Highbyte der effektiven Adresse könnte zu diesem Zeitpunkt ungültig sein | |||
| Anmerkung: | + dieser Zyklus wird nur ausgeführt, wenn die effektive Adresse während Zyklus #5 ungültig war | |||
Der Assembler-Befehl CMP ($ll), Y vergleicht den Akkumulator mit dem Inhalt der Speicherzelle (LSB= $ll ; MSB= $ll+1)+Y.
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.
