LSR $hhll, X
Mnemonic: | LSR $hhll,X | |||
Opcode: | $5E | |||
Operand(en): | $ll $hh | |||
Anzahl der Bytes: | 3 | |||
Befehlsgruppe: | Rotations- und Schiebebefehl | |||
Adressierung: | absolut X-indiziert | |||
Beeinflusste Flags im Statusregister: | ||||
Carry-Flag | ||||
Negative-Flag | ||||
Zero-Flag | ||||
Taktzyklen: | 7 | |||
1 | PC | R | Lese Befehl, inkrementiere PC | |
2 | PC | R | lese Adress-Lowbyte, inkrementiere PC | |
3 | PC | R | hole Highbyte der Adresse, addiere Indexregister X zum Adress-Lowbyte, inkrementiere PC | |
4 | Adresse + X | R | lese von effektiver Adresse, korrigiere Highbyte der effektiven Adresse | |
5 | Adresse + X | R* | lese erneut von effektiver Adresse | |
6 | Adresse + X | W | schreibe Wert auf effektive Adresse zurück und führe Operation auf den Wert aus | |
7 | Adresse + X | W | schreibe neuen Wert auf effektive Adresse | |
Anmerkung: | * das Highbyte der effektiven Adresse könnte zu diesem Zeitpunkt ungültig sein |
Der Assembler-Befehl LSR $hhll,X verschiebt die acht Bits der Speicherzelle ($hhll+X) um eine Bit-Position nach rechts (von den höherwertigen zu den niederwertigen Bits). Das höchstwertige Bit wird 0 und das herausfallende Bit wird im Carry-Flag aufgefangen.
Damit teilt dieser Befehl den Inhalt der Speicherzelle durch 2. Der Divisionsrest wird im Carry-Flag abgebildet.
Das Negative-Flag wird dabei immer zurückgesetzt, da das Ergebnis stets einem positiven Wert entspricht.
Die zu dieser logischen Operation korrespondierende arithmetische Operation (ein hypothetischer ASR-Befehl) ist nicht implementiert und muss entsprechend ausprogrammiert werden (siehe ASL-Beispiel).
Funktionsprinzip
Bedeutung der Buchstaben im Befehl
LSR | Logical Shift Right |
Logisches Rechts-Schieben |
Beispiel
Siehe auch Beispiele bei LSR $ll.
Vergleichbare BASIC-Anweisung
Für BASIC V2:
10 POKE (1234+X), PEEK(1234+X) / 2
Beispielsweise für die Adresse 1234 + X (als X-Register). Ein Überlauf der 16-Bit-Adresse wird hier nicht berücksichtigt.