SBC $ll
Mnemonic: | SBC $ll | ||
Opcode: | $E5 | ||
Operand(en): | $ll | ||
Anzahl der Bytes: | 2 | ||
Befehlsgruppe: | Arithmetik- und Logikbefehl | ||
Adressierung: | Zeropage | ||
Beeinflusste Flags im Statusregister: | |||
Carry-Flag | |||
Negative-Flag | |||
Overflow-Flag | |||
Zero-Flag | |||
Taktzyklen: | 3 | ||
1 | PC | R | Lese Befehl, inkrementiere PC |
2 | PC | R | hole Adresse, inkrementiere PC |
3 | Adresse | R | lese von effektiver Adresse |
Der Assembler-Befehl SBC $ll subtrahiert vom Inhalt des Akkumulators den Inhalt der Speicherzelle $ll 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.