mikrocontroller.net

Forum: Mikrocontroller und Digitale Elektronik FreeRTOS+FATfs


Autor: Lukas Za (lukasi)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Hallo,
Ein Datenlogger soll entstehen mit dem Olimex LPC-P2148 und dem Paket 
_LPC2148__Codebase__v0.1__(http://www.microbuilder.eu/Files/Projects/LPC2148R...) 
das eigentlich eine Rowley Variante von jcwren' Demo Code ist. Das 
FreeRTOS mit ADC, RTC, LED laufen einwandfrei. So weit so gut.

Nun will ich FATfs verwenden um ADC Werte abzulegen. Dazu ist ein Task 
zuständig, dem eine Stacksize von 2048 zugeschrieben wurde, da es zuvor 
immer zu Stackoverflows gekommen ist. Als SD Karte verwende ich eine:
SanDisk SD Card 2GB, 512Byte Sektoren, FAT32 formatiert, primär, aktiv

Hier den Beispiel Code in einer Stack-Routine abgelegt (angepasst von 
http://elm-chan.org/fsw/ff/en/open.html).
  /* The LEDs are updated every 200 ticks, about 200 ms */
  const long blinkDelay = 200;

  FATFS Fatfs[_DRIVES]; /* File system object for each logical drive */
  FIL File1; /* File objects */
  printf("DISKINIT %d\n", diskInitialize(0));
  /* Initialize logical drive */
  printf("MOUNT %d\n", f_mount(0, &Fatfs[0]));

  /* Create file system */
  printf("MKFS %d\n", f_mkfs(0, 0, 512));

  printf("MKDIR %d\n", f_mkdir("100602_wast_log\0")); // Ordner anlegen

  printf("OPEN %d\n", f_open(&File1, "log.txt", FA_CREATE_ALWAYS | FA_WRITE | FA_READ));

  //f_printf(&File1, "%6d", -200);
  UINT bw, byte_len;

  printf("WRITE %d\n", f_write(&File1, "zalue", strlen("zalue"), &bw));

  printf("CLOSE %d\n", f_close(&File1));

  /* Unregister work area prior to discard it */
  printf("UMOUNT %d\n", f_mount(0, NULL));

  while (1)
  {
    /* Block the task for the defined time */
    vTaskDelay(blinkDelay);
  }

Lasse ich den Code ausführen(ARM Flash Release Mode), bekomme ich 
folgenden Output:
DISKINIT 0
MOUNT 0
MKDIR 11
0 (wird von mount(0, NULL) sein)

Im (ARM Flash Debug Mode)
DISKINIT 0
MOUNT 0
MKDIR 11
0 (wird von mount(0, NULL) sein)

Beim Aufruf von mkdir(...) wird in
Zeile 687 von ff.c --> fmt==1
Zeile 697 von ff.c --> FR_NO_FILESYSTEM

Ich komme nicht mehr weiter. Vielleicht weiss jemand wo man ansetzen 
muss.
Gruss und Dank

  ich

Autor: Lukas Za (lukasi)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Problem hat sich gelöst.
Ersetzt man die SD Karte durch eine kleinere (128MB und 512MB, 512Byte 
Sektoren, FAT32 formatiert, primär, aktiv) hat es funktioniert. ;-)

Antwort schreiben

Die Angabe einer E-Mail-Adresse ist freiwillig. Wenn Sie automatisch per E-Mail über Antworten auf Ihren Beitrag informiert werden möchten, melden Sie sich bitte an.

Wichtige Regeln - erst lesen, dann posten!

  • Groß- und Kleinschreibung verwenden
  • Längeren Sourcecode nicht im Text einfügen, sondern als Dateianhang

Formatierung (mehr Informationen...)

  • [c]C-Code[/c]
  • [avrasm]AVR-Assembler-Code[/avrasm]
  • [code]Code in anderen Sprachen, ASCII-Zeichnungen[/code]
  • [math]Formel in LaTeX-Syntax[/math]
  • [[Titel]] - Link zu Artikel
  • Verweis auf anderen Beitrag einfügen: Rechtsklick auf Beitragstitel,
    "Adresse kopieren", und in den Text einfügen




Bild automatisch verkleinern, falls nötig
Bitte das JPG-Format nur für Fotos und Scans verwenden!
Zeichnungen und Screenshots im PNG- oder
GIF-Format hochladen. Siehe Bildformate.
Hinweis: der ursprüngliche Beitrag ist mehr als 6 Monate alt.
Bitte hier nur auf die ursprüngliche Frage antworten,
für neue Fragen einen neuen Beitrag erstellen.

Mit dem Abschicken bestätigst du, die Nutzungsbedingungen anzuerkennen.