Hallo,
Ein Datenlogger soll entstehen mit dem Olimex LPC-P2148 und dem Paket
_LPC2148__Codebase__v0.1__(http://www.microbuilder.eu/Files/Projects/LPC2148RefDesign/LPC2148CodeBase_v0.1.zip)
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).
1 | /* The LEDs are updated every 200 ticks, about 200 ms */
|
2 | const long blinkDelay = 200;
|
3 |
|
4 | FATFS Fatfs[_DRIVES]; /* File system object for each logical drive */
|
5 | FIL File1; /* File objects */
|
6 | printf("DISKINIT %d\n", diskInitialize(0));
|
7 | /* Initialize logical drive */
|
8 | printf("MOUNT %d\n", f_mount(0, &Fatfs[0]));
|
9 |
|
10 | /* Create file system */
|
11 | printf("MKFS %d\n", f_mkfs(0, 0, 512));
|
12 |
|
13 | printf("MKDIR %d\n", f_mkdir("100602_wast_log\0")); // Ordner anlegen
|
14 |
|
15 | printf("OPEN %d\n", f_open(&File1, "log.txt", FA_CREATE_ALWAYS | FA_WRITE | FA_READ));
|
16 |
|
17 | //f_printf(&File1, "%6d", -200);
|
18 | UINT bw, byte_len;
|
19 |
|
20 | printf("WRITE %d\n", f_write(&File1, "zalue", strlen("zalue"), &bw));
|
21 |
|
22 | printf("CLOSE %d\n", f_close(&File1));
|
23 |
|
24 | /* Unregister work area prior to discard it */
|
25 | printf("UMOUNT %d\n", f_mount(0, NULL));
|
26 |
|
27 | while (1)
|
28 | {
|
29 | /* Block the task for the defined time */
|
30 | vTaskDelay(blinkDelay);
|
31 | }
|
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