UsbFat
 All Classes Files Functions Variables Typedefs Enumerations Enumerator Macros Pages
Macros
FatLibConfig.h File Reference

configuration definitions More...

#include "../UsbFatConfig.h"
#include <stdint.h>
Include dependency graph for FatLibConfig.h:
This graph shows which files directly or indirectly include this file:

Macros

#define ENABLE_ARDUINO_FEATURES   1
 

Detailed Description

configuration definitions

Macro Definition Documentation

#define ENABLE_ARDUINO_FEATURES   1

Set USE_LONG_FILE_NAMES nonzero to use long file names (LFN). Long File Name are limited to a maximum length of 255 characters.

This implementation allows 7-bit characters in the range 0X20 to 0X7E. The following characters are not allowed:

< (less than)

(greater than)

: (colon) " (double quote) / (forward slash) \ (backslash) | (vertical bar or pipe) ? (question mark)

  • (asterisk) Set ARDUINO_FILE_USES_STREAM nonzero to use Stream as the base class for the Arduino File class. If ARDUINO_FILE_USES_STREAM is zero, Print will be used as the base class for the Arduino File class.

You can save some flash if you do not use Stream input functions such as find(), findUntil(), readBytesUntil(), readString(), readStringUntil(), parseInt(), and parsefloat(). Set USE_SEPARATE_FAT_CACHE non-zero to use a second 512 byte cache for FAT table entries. Improves performance for large writes that are not a multiple of 512 bytes. Set USE_MULTI_BLOCK_IO non-zero to use multi-block SD read/write.

Don't use mult-block read/write on small AVR boards. Set DESTRUCTOR_CLOSES_FILE non-zero to close a file in its destructor.

Causes use of lots of heap in ARM. Call flush for endl if ENDL_CALLS_FLUSH is non-zero

The standard for iostreams is to call flush. This is very costly for SdFat. Each call to flush causes 2048 bytes of I/O to the SD.

SdFat has a single 512 byte buffer for I/O so it must write the current data block to the SD, read the directory block from the SD, update the directory entry, write the directory block to the SD and read the data block back into the buffer.

The SD flash memory controller is not designed for this many rewrites so performance may be reduced by more than a factor of 100.

If ENDL_CALLS_FLUSH is zero, you must call flush and/or close to force all data to be written to the SD. Allow FAT12 volumes if FAT12_SUPPORT is non-zero. FAT12 has not been well tested. Enable Extra features for Arduino.