Example of using the SDFileSystem library on a K64F to write data to files and also read data into dynamically created arrays.

Dependencies:   mbed

Committer:
eencae
Date:
Mon Feb 03 12:06:21 2020 +0000
Revision:
1:caceb9d9d17a
Updated Mbed library. Removed serial. Confirmed working Jan 2020.

Who changed what in which revision?

UserRevisionLine numberNew contents of line
eencae 1:caceb9d9d17a 1 /* mbed Microcontroller Library
eencae 1:caceb9d9d17a 2 * Copyright (c) 2006-2012 ARM Limited
eencae 1:caceb9d9d17a 3 *
eencae 1:caceb9d9d17a 4 * Permission is hereby granted, free of charge, to any person obtaining a copy
eencae 1:caceb9d9d17a 5 * of this software and associated documentation files (the "Software"), to deal
eencae 1:caceb9d9d17a 6 * in the Software without restriction, including without limitation the rights
eencae 1:caceb9d9d17a 7 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
eencae 1:caceb9d9d17a 8 * copies of the Software, and to permit persons to whom the Software is
eencae 1:caceb9d9d17a 9 * furnished to do so, subject to the following conditions:
eencae 1:caceb9d9d17a 10 *
eencae 1:caceb9d9d17a 11 * The above copyright notice and this permission notice shall be included in
eencae 1:caceb9d9d17a 12 * all copies or substantial portions of the Software.
eencae 1:caceb9d9d17a 13 *
eencae 1:caceb9d9d17a 14 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
eencae 1:caceb9d9d17a 15 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
eencae 1:caceb9d9d17a 16 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
eencae 1:caceb9d9d17a 17 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
eencae 1:caceb9d9d17a 18 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
eencae 1:caceb9d9d17a 19 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
eencae 1:caceb9d9d17a 20 * SOFTWARE.
eencae 1:caceb9d9d17a 21 */
eencae 1:caceb9d9d17a 22 #ifndef MBED_FATFILESYSTEM_H
eencae 1:caceb9d9d17a 23 #define MBED_FATFILESYSTEM_H
eencae 1:caceb9d9d17a 24
eencae 1:caceb9d9d17a 25 #include "FileSystemLike.h"
eencae 1:caceb9d9d17a 26 #include "FileHandle.h"
eencae 1:caceb9d9d17a 27 #include "ff.h"
eencae 1:caceb9d9d17a 28 #include <stdint.h>
eencae 1:caceb9d9d17a 29
eencae 1:caceb9d9d17a 30 using namespace mbed;
eencae 1:caceb9d9d17a 31
eencae 1:caceb9d9d17a 32 /**
eencae 1:caceb9d9d17a 33 * FATFileSystem based on ChaN's Fat Filesystem library v0.8
eencae 1:caceb9d9d17a 34 */
eencae 1:caceb9d9d17a 35 class FATFileSystem : public FileSystemLike {
eencae 1:caceb9d9d17a 36 public:
eencae 1:caceb9d9d17a 37
eencae 1:caceb9d9d17a 38 FATFileSystem(const char* n);
eencae 1:caceb9d9d17a 39 virtual ~FATFileSystem();
eencae 1:caceb9d9d17a 40
eencae 1:caceb9d9d17a 41 static FATFileSystem * _ffs[_VOLUMES]; // FATFileSystem objects, as parallel to FatFs drives array
eencae 1:caceb9d9d17a 42 FATFS _fs; // Work area (file system object) for logical drive
eencae 1:caceb9d9d17a 43 char _fsid[2];
eencae 1:caceb9d9d17a 44
eencae 1:caceb9d9d17a 45 /**
eencae 1:caceb9d9d17a 46 * Opens a file on the filesystem
eencae 1:caceb9d9d17a 47 */
eencae 1:caceb9d9d17a 48 virtual FileHandle *open(const char* name, int flags);
eencae 1:caceb9d9d17a 49 virtual int open(FileHandle **file, const char *name, int flags);
eencae 1:caceb9d9d17a 50
eencae 1:caceb9d9d17a 51 /**
eencae 1:caceb9d9d17a 52 * Removes a file path
eencae 1:caceb9d9d17a 53 */
eencae 1:caceb9d9d17a 54 virtual int remove(const char *filename);
eencae 1:caceb9d9d17a 55
eencae 1:caceb9d9d17a 56 /**
eencae 1:caceb9d9d17a 57 * Renames a file
eencae 1:caceb9d9d17a 58 */
eencae 1:caceb9d9d17a 59 virtual int rename(const char *oldname, const char *newname);
eencae 1:caceb9d9d17a 60
eencae 1:caceb9d9d17a 61 /**
eencae 1:caceb9d9d17a 62 * Formats a logical drive, FDISK artitioning rule, 512 bytes per cluster
eencae 1:caceb9d9d17a 63 */
eencae 1:caceb9d9d17a 64 virtual int format();
eencae 1:caceb9d9d17a 65
eencae 1:caceb9d9d17a 66 /**
eencae 1:caceb9d9d17a 67 * Opens a directory on the filesystem
eencae 1:caceb9d9d17a 68 */
eencae 1:caceb9d9d17a 69 virtual DirHandle *opendir(const char *name);
eencae 1:caceb9d9d17a 70 virtual int open(DirHandle **dir, const char *name);
eencae 1:caceb9d9d17a 71
eencae 1:caceb9d9d17a 72 /**
eencae 1:caceb9d9d17a 73 * Creates a directory path
eencae 1:caceb9d9d17a 74 */
eencae 1:caceb9d9d17a 75 virtual int mkdir(const char *name, mode_t mode);
eencae 1:caceb9d9d17a 76
eencae 1:caceb9d9d17a 77 /**
eencae 1:caceb9d9d17a 78 * Mounts the filesystem
eencae 1:caceb9d9d17a 79 */
eencae 1:caceb9d9d17a 80 virtual int mount();
eencae 1:caceb9d9d17a 81
eencae 1:caceb9d9d17a 82 /**
eencae 1:caceb9d9d17a 83 * Unmounts the filesystem
eencae 1:caceb9d9d17a 84 */
eencae 1:caceb9d9d17a 85 virtual int unmount();
eencae 1:caceb9d9d17a 86
eencae 1:caceb9d9d17a 87 virtual int disk_initialize() { return 0; }
eencae 1:caceb9d9d17a 88 virtual int disk_status() { return 0; }
eencae 1:caceb9d9d17a 89 virtual int disk_read(uint8_t *buffer, uint32_t sector, uint32_t count) = 0;
eencae 1:caceb9d9d17a 90 virtual int disk_write(const uint8_t *buffer, uint32_t sector, uint32_t count) = 0;
eencae 1:caceb9d9d17a 91 virtual int disk_sync() { return 0; }
eencae 1:caceb9d9d17a 92 virtual uint32_t disk_sectors() = 0;
eencae 1:caceb9d9d17a 93
eencae 1:caceb9d9d17a 94 };
eencae 1:caceb9d9d17a 95
eencae 1:caceb9d9d17a 96 #endif