first 2016/02 SDFileSystemDMA inherited from Official SDFileSystem.

Dependents:   SDFileSystemDMA-test DmdFullRGB_0_1

Fork of SDFileSystemDMA by mi mi

SDFileSystemDMA is enhanced SDFileSystem library for STM32 micros by using DMA functionality.
Max read transfer rate reaches over 2MByte/sec at 24MHz SPI clock if enough read buffer size is set.
Even though minimum read buffer size (512Byte) is set, read transfer rate will reach over 1MByte/sec at 24MHz SPI Clock.
( but depends on the ability of each SD card)

Test program is here.
https://developer.mbed.org/users/mimi3/code/SDFileSystemDMA-test/

/media/uploads/mimi3/sdfilesystemdma-speed-test3-read-buffer-512byte.png

/media/uploads/mimi3/sdfilesystemdma-speed-test-buffer-vs-spi-clock-nucleo-f411re-96mhz.png

Supported SPI port is shown below table.

(v): Verified. It works well.
(w): Probably it will work well. (not tested)
(c): Only compiled. (not tested)
(f): Over flash.
(r): Only read mode. (when _FS_READONLY==1)
(u) Under construction
(z): Dose not work.

Caution

If your board has SRAM less than or equal to 8KB, the buffer size must be set to 512 Bytes.

Supported Boards:
Cortex-M0

BoardSRAMSPI1SPI2SPI3
NUCLEO-F030R88KB(v)
DISCO-F051R88KB(w)
NUCLEO-F031K64KB(f)
NUCLEO-F042K66KB(r)
NUCLEO-F070RB16KB(w)
NUCLEO-F072RB16KB(w)
NUCLEO-F091RC32KB(c)

Cortex-L0

BoardSRAMSPI1SPI2SPI3
DISCO-L053C88KB(c)
NUCLEO-L053R88KB(c)
NUCLEO-L073RZ20KB(c)

Cortex-M3

BoardSRAMSPI1SPI2SPI3
DISCO-F100RB8KB(v)(v)-
BLUEPILL-F103CB20KB(w)(w)-
NUCLEO-F103RB20KB(v)(v)-
NUCLEO-L152RE80KB(v)(w)-
MOTE-L152RC32KB(w)(w)-

Cortex-M4
F3

BoardSRAMSPI1SPI2SPI3
DISCO-F303VC40KB-(v)(v)
NUCLEO-F303RE64KB(w)(w)(w)
NUCLEO-F302R816KB--(c)
NUCLEO-F303K812KB(c)--
DISCO-F334C812KB(c)--
NUCLEO-F334R812KB(c)--

F4

BoardSPI1SPI2SPI3
ELMO-F411RE(w)-(w)
MTS-MDOT-F411RE(u)-(u)
MTS-DRAGONFLY-F411RE(w)-(w)
NUCLEO-F411RE(v)-(v)
NUCLEO-F401RE(w)-(w)
MTS-MDOT-F405RG(u)-(u)
NUCLEO-F410RB(c)-(c)
NUCLEO-F446RE(c)-(c)
NUCLEO-F429ZI(c)-(c)
B96B-F446VE(c)-(c)
NUCLEO-F446ZE(c)-(c)
DISCO-F429ZI(u)-(u)
DISCO-F469NI(c)-(c)

Information

This library is set to use "short file name" in SDFileSystemDMA/FATFileSystem/ChaN/ffconf.h . ( _USE_LFN=0)
You can change this option to _USE_LFN=1 .

Committer:
mimi3
Date:
Sun Feb 14 21:58:51 2016 +0900
Revision:
10:b48d3ace55db
added: FATFileSystem

Who changed what in which revision?

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