SBC ($ll, X)

Aus C64-Wiki
Zur Navigation springenZur Suche springen
Mnemonic: SBC ($ll,X)
Opcode: $E1
Operand(en): $ll
Anzahl der Bytes: 2
Befehlsgruppe: Arithmetik- und Logikbefehl
Adressierung: indirekt X-indiziert
Beeinflusste Flags im Statusregister:
Carry-Flag
Negative-Flag
Overflow-Flag
Zero-Flag
Taktzyklen: 6


Der Assembler-Befehl SBC ($ll,X) subtrahiert vom Inhalt des Akkumulators den Inhalt der der Speicheradresse (LSB= $ll+X ; MSB= $ll+X+1) 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

Ass befehl e1.gif

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.

Beispielprogramme