SBC $hhll, X
Mnemonic: | SBC $hhll,X | |||
Opcode: | $FD | |||
Operand(en): | $ll $hh | |||
Anzahl der Bytes: | 3 | |||
Befehlsgruppe: | Arithmetik- und Logikbefehl | |||
Adressierung: | absolut X-indiziert | |||
Beeinflusste Flags im Statusregister: | ||||
Carry-Flag | ||||
Negative-Flag | ||||
Overflow-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 SBC $hhll,X subtrahiert vom Inhalt des Akkumulators den Inhalt der Speicherzelle ($hhll+X) und den komplementierten Inhalt des Carry-Flags.
Daher sollte vor jeder Subtraktion, sofern nicht der Übertrag in einer zusammengesetzten Subtraktion zu berücksichtigen ist, das Carry-Flag mit dem Befehl SEC gesetzt werden.
Das Ergebnis wird im Akkumulator gespeichert.
Der komplementierte Übertrag (0 oder 1), gewissermaßen in der Bedeutung eines Borge-Bits (engl. borrow), kommt ins Carry-Flag.
Bei gesetztem Decimal-Flag erfolgt die Berechnung in BCD-Arithmetik, wobei bei Operanden im gültigen BCD-Format nur das Carry-Flag und Zero-Flag entsprechend gesetzt werden. Negative-Flag und Overflow-Flag werden zwar entsprechend der Komplement-Darstellung der Operanden verändert, haben aber keine Bedeutung für die BCD-Arithmetik.
Funktionsprinzip
Bedeutung der Buchstaben im Befehl
SBC | SuBtract with Carry |
Subtrahiere vom Akkumulator den Operand und das komplementierte Carry-Flag |
Beispiel
Siehe Beispiel bei SBC $hhll.