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
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
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.