Forum: Mikrocontroller und Digitale Elektronik IAR Workbench assembler / c code relocatable Konflikt?


von Tobias Rieper (Gast)


Lesenswert?

Hallo!

Ich benutze die "IAR Embedded Workbench for Atmel AVR V4.11A" und
simuliere damit den Atmel ATMega128...

Ich benutze einen vorgefertigten Assemler-Code zur
AES-Verschlüsselung.
(http://www.stud.uni-hamburg.de/~poetter/rijndael/rijndaelfast.asm)

Diesen Assembler-Code möchte ich aus einer C-Funktion aufrufen.

Ich habe offentsichtlich einen Konflikt zwischen C- & Assembler-Code

Ich erhalte vom Linker folgende Fehlermeldung:

Error[e16]: Segment INTVEC (size: 0x4 align: 0x1) is too long for
segment definition. At least 0x4 more bytes needed. The problem
occurred while
processing the segment placement command
"-Z(CODE)INTVEC=0-(_..X_INTVEC_SIZE-1)", where at the moment of
placement the available memory
ranges were "-none-"
   Reserved ranges relevant to this placement:
   CODE:0-56b           Absolute code from rijndaelfast

Daraufhin habe ich den Code der Assembler-Datei namens
"rijndaelfast.s90" relocatable gemacht, mit dem Befehl: "RSEG
CODE"

OK, jetzt liefert der Linker keine Fehlermeldungen mehr, dafür liefert
die Assembler-AES-Verschlüsselung komplett falsche Werte...

Daraufhin habe ich "RSEG CODE" wieder entfernt, der AssemblerCode ist
nun nicht mehr relocatable..
Stattdessen habe ich in der Datei "lnkm128s.xcl" die Zeile
"-Z(CODE)INTVEC=0-(_..X_INTVEC_SIZE-1)"
durch folgende ersetzt:
"-Z(CODE)INTVEC=0-FFFF", damit mehr Platz für die InterruptVektoren
vorhanden ist. (Ich hoffe, dass die InterruptVektoren so noch
funktionieren)

OK, auf diese Weise lässt sich mein Programm kompilieren, es wird
jedoch der zuvor eingelesene Plaintext von der Assemblerfunktion
teilweise überschrieben, da der Assembler-Code ja nicht relocatable
ist.

Zusammenfassung:
ASM non-relocatable, lnkm128s.xcl=original :
 Error[e16](siehe oben)

ASM relocatable, lnkm128s.xcl=original :
   Assembler liefert falsche Werte

ASM non-relocatable, lnkm128s.xcl=modifiziert :
  Assembler überschreibt Teile des C Codes.

Was muss ich machen, damit mein C Code nicht mehr überschreiben wird
und gleichzeitig die Assembler-Verschlüsselung korrekt durchgeführt
wird?

Die Assembler AES-Funktion möchte ich so wenig wie möglich verändern,
da sie relativ komplex ist.

Ich hoffe ich konnte mein Problem einigermassen verständlich erklären.

Schon mal vielen dank im voraus

Gruss   - Tobias

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.