Forum: Compiler & IDEs ASM: add r1, r2 = add 1, 2 ?


von Peta (Gast)


Lesenswert?

Hallo

warum schreibt man manchmal das "r" und manchmal ohne?

Beispiel:

add r1, r2

=

add 1, 2


ist es wirklich dasselbe? ist doch verwirrend. Man könnte denken es 
seien Integer Werte. Wobei das nur mit addi sinnvoll wäre.

von Gast (Gast)


Lesenswert?

>ist es wirklich dasselbe?

Nein. Das siehst Du schon daran, dass Dir ein "add 1, 2" vom Assembler 
mit einem Syntax Error abgelehnt wird.

von Klugscheisser (Gast)


Lesenswert?

Von welchem Prozessor und welchem Assembler reden wir denn?

von Stefan E. (sternst)


Lesenswert?

Gast wrote:
> Das siehst Du schon daran, dass Dir ein "add 1, 2" vom Assembler
> mit einem Syntax Error abgelehnt wird.

Nein, vom GCC-Assembler für AVR eben nicht. Da kann man das so 
schreiben.

von Benedikt K. (benedikt)


Lesenswert?

Das liegt daran, dass diese Werte die Speicheradressen der Register 
sind. Die Register liegen im Speicher an den Adresse 0-31 (0x00-0x1F). 
Danach kommen die SFRs und danach der RAM.

Bei anderen Prozessoren die auch Operationen direkt aus dem RAM 
ausführen können, würde dieser Befehl je nach Assembler u.a. eine 
Addition der Inhalte der Speicheradressen 1 und 2 bewirken.

von Jörg W. (dl8dtl) (Moderator) Benutzerseite


Lesenswert?

Benedikt K. wrote:

> Das liegt daran, dass diese Werte die Speicheradressen der Register
> sind. Die Register liegen im Speicher an den Adresse 0-31 (0x00-0x1F).

Das kann man zwar als Eselsbrücke benutzen, aber das geht schon beim
Xmega schief, der die CPU-Register nicht mehr in den RAM-Adressbereich
einblendet.

Nein, es ist schlicht und ergreifend im Assembler so codiert, dass
er überall da, wo rN stehen darf, genauso gut auch einfach N akzeptiert.
Die AVR-Assembler-Syntax ist bereits durch die jeweils benutzte
Mnemonik auf ganz wenige mögliche Operanden eingeschränkt (anders als
beispielsweise x86), und diese möglichen Operanden sind dann alle
eindeutig unterscheidbar.  Dadurch fällt es dem Assembler ganz einfach,
die Zahlen alternativ zu den Registernamen zu unterstützen.  Ein
Befehl, der eine direkte Speicheradresse akzeptieren würde (LDS, STS
usw.) könnte ohnehin nicht alternativ auf ein Register angewandt werden.

von Michael U. (amiga)


Lesenswert?

Hallo,

Zum Glück beantwortet das der Atmel-ASM das völlig richtig mit "error: 
invalid register"...

Gruß aus Berlin
Michael

von Johann L. (gjlayde) Benutzerseite


Lesenswert?

Peta wrote:
> Hallo
>
> warum schreibt man manchmal das "r" und manchmal ohne?

Das kann in Makros sehr praktisch sein, weil es erlaubt, mit 
Register-Nummern zu rechnen, etwa bei operationen auf 16-Bit-Registern.

Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.