Forum: Mikrocontroller und Digitale Elektronik PIC - FIRMWARE SIZE in RUNTIME


von felix (Gast)


Lesenswert?

Hallo, ich schreibe gerade an einer Firmware für den
- dsPIC22EP256MU806,
verwende die Entwicklungsumgebung:
- MPBLAB X IDE v4.10
verwende den Compiler:
- XC16 V 1.35
verwende den Programmer:
- ICD3
und verwende die Programmiersprache
C.

Folgendes Problem habe ich:
Ich schreibe gerade an einer Firmware, die in runtime den Flash-Speicher 
programmieren kann. Dabei muss ich aber herausfinden, wie groß die 
Firmware ist, damit ich nicht unabsichtlich so viel in den 
Flash-Speicher schreibe, dass ich die eigene Firmware überschreibe. 
Jetzt meine Frage: gibt es irgendein Compiler-Flag oder ähnliches, dass 
einem die Größe der eigenen Firmware anzeigt ? Oder fällt jemandem eine 
Möglichkeit ein, dieses größe herauszufinden (natürlich während der 
Laufzeit).
Ich hab zwar schon alle möglichen Foren abgegrast als auch das 
Compiler-Manual gelesen, hab aber nichts herausfinden können,

Danke für die Hilfe schon mal im Voraus,
GLG

von soso... (Gast)


Lesenswert?

Man legt im Linkerscript einen Speicherbereich fest, der vom Linker 
nicht für die Firmware benutzt wird.

Und nur in diesen Speicherbereich lässt man das Schreiben überhaupt zu. 
Das löst du so einfach in deiner Flash-Routine. Den Bereich kannst du 
dann beliebig beackern.

Wie bei einem Bootloader halt auch:
http://ww1.microchip.com/downloads/en/DeviceDoc/Bootloader%20Library_v111.pdf

Kuckst du unter Kapitel "Bootloader Placement in Memory".

Nur statt einen Bereich für die Applikation zu definieren, wählst du 
einen Bereich für deinen Speicherinhalt aus.

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.