FreeRTOS+FAT is still in the lab
FreeRTOS+FAT is already in use in commercial products
and we encourage you to try it yourself. Be aware however that
FreeRTOS+FAT was acquired by Real Time Engineers Ltd., and is
still being documented and updated to
ensure it meets our strict quality standards.
Please use the forum for support,
or contact us directly if you have a specific business interest.
FreeRTOS+FAT Configuration
The FreeRTOSFATConfig.h header file
Applications that use FreeRTOS+FAT must provide a FreeRTOSFATConfig.h header file -
in which the parameters described on this page can be defined:
Must be set to either pdFREERTOS_LITTLE_ENDIAN or pdFREERTOS_BIG_ENDIAN, depending
on the endian of the architecture on which FreeRTOS is running.
Set to 1 to maintain a current working directory (CWD) for each task that
accesses the file system, allowing relative paths to be used.
Set to 0 not to use a CWD, in which case full paths must be used for
each file access.
Set to an index within FreeRTOS's thread local storage array that is free for
use by FreeRTOS+FAT. FreeRTOS+FAT will use two consecutive indexes from this
that set by ffconfigCWD_THREAD_LOCAL_INDEX. The number of thread local storage
pointers provided by FreeRTOS is set by configNUM_THREAD_LOCAL_STORAGE_POINTERS
in FreeRTOSConfig.h.
Set to 1 to include long file name support. Set to 0 to exclude long
file name support.
If long file name support is excluded then only 8.3 file names can be used.
Long file names will be recognised, but ignored.
Users should familiarise themselves with any patent issues that may
potentially exist around the use of long file names in FAT file systems
before enabling long file name support.
Only used when ffconfigLFN_SUPPORT is set to 1.
Set to 1 to include a file's short name when listing a directory, i.e. when
calling findfirst()/findnext(). The short name will be stored in the
'pcShortName' field of FF_DIRENT.
Set to 0 to only include a file's long name.
Set to 1 to recognise and apply the case bits used by Windows XP+ when
using short file names - storing file names such as "readme.TXT" or
"SETUP.exe" in a short-name entry. This is the recommended setting for
maximum compatibility.
Set to 0 to ignore the case bits.
Only used when ffconfigLFN_SUPPORT is set to 1.
Set to 1 to use UTF-16 (wide-characters) for file and directory names.
Set to 0 to use either 8-bit ASCII or UTF-8 for file and directory names
(see the ffconfigUNICODE_UTF8_SUPPORT).
Only used when ffconfigLFN_SUPPORT is set to 1.
Set to 1 to use UTF-8 encoding for file and directory names.
Set to 0 to use either 8-bit ASCII or UTF-16 for file and directory
names (see the ffconfig_UTF_16_SUPPORT setting).
Set to 1 to include FAT12 support.
Set to 0 to exclude FAT12 support.
FAT16 and FAT32 are always enabled.
When writing and reading data, i/o becomes less efficient if sizes other
than 512 bytes are being used. When set to 1 each file handle will
allocate a 512-byte character buffer to facilitate "unaligned access".
Input and output to a disk uses buffers that are only flushed at the
following times:
-
When a new buffer is needed and no other buffers are available.
-
When opening a buffer in READ mode for a sector that has just been changed.
-
After creating, removing or closing a file or a directory.
Normally this is quick enough and it is efficient. If
ffconfigCACHE_WRITE_THROUGH is set to 1 then buffers will also be flushed each
time a buffer is released - which is less efficient but more secure.
In most cases, the FAT table has two identical copies on the disk,
allowing the second copy to be used in the case of a read error. If
Set to 1 to use both FATs - this is less efficient but more secure.
Set to 0 to use only one FAT - the second FAT will never be written to.
Set to 1 to have the number of free clusters and the first free cluster
to be written to the FS info sector each time one of those values changes.
Set to 0 not to store these values in the FS info sector, making booting
slower, but making changes faster.
Set to 1 to maintain file and directory time stamps for creation, modify
and last access.
Set to 0 to exclude time stamps.
If time support is used, the following function must be supplied:
time_t FreeRTOS_time( time_t *pxTime );
FreeRTOS_time has the same semantics as the standard time() function.
Set to 1 if the media is removable (such as a memory card).
Set to 0 if the media is not removable.
When set to 1 all file handles will be "invalidated" if the media is
extracted. If set to 0 then file handles will not be invalidated.
In that case the user will have to confirm that the media is still present
before every access.
Set to 1 to determine the disk's free space and the disk's first free
cluster when a disk is mounted.
Set to 0 to find these two values when they are first needed. Determining
the values can take some time.
Set to 1 to 'trust' the contents of the 'ulLastFreeCluster' and
ulFreeClusterCount fields.
Set to 0 not to 'trust' these fields.
Set to 1 to store recent paths in a cache, enabling much faster access
when the path is deep within a directory structure at the expense of
additional RAM usage.
Set to 0 to not use a path cache.
Only used if ffconfigPATH_CACHE is 1.
Sets the maximum number of paths that can exist in the patch cache at any
one time.
Set to 1 to calculate a HASH value for each existing short file name.
Use of HASH values can improve performance when working with large
directories, or with files that have a similar name.
Set to 0 not to calculate a HASH value.
Only used if ffconfigHASH_CACHE is set to 1
Set to CRC8 or CRC16 to use 8-bit or 16-bit HASH values respectively.
Set to 1 to add a parameter to ff_mkdir() that allows an entire directory
tree to be created in one go, rather than having to create one directory in
the tree at a time. For example mkdir( "/etc/settings/network", pdTRUE );.
Set to 0 to use the normal mkdir() semantics (without the additional
parameter).
Set to 1 for each call to fnReadBlocks and fnWriteBlocks to be performed
with a semphore lock.
Set to 0 for each call to fnReadBlocks and fnWriteBlocks not to use an
additional semaphore.
Set to a function that will be used for all dynamic memory allocations.
Setting to pvPortMalloc() will use the same memory allocator as FreeRTOS.
For example:
#define ffconfigMALLOC( size ) pvPortMalloc( size )
Set to a function that matches the above allocator defined with
ffconfigMALLOC. Setting to vPortFree() will use the same memory free
function as FreeRTOS. For example:
#define ffconfigFREE( ptr ) vPortFree( ptr )
Set to 1 to calculate the free size and volume size as a 64-bit number.
Set to 0 to calculate these values as a 32-bit number.
Defines the maximum number of partitions (and also logical partitions)
that can be recognised.
Defines how many drives can be combined in total. Should be set to at
least 2.
In case the low-level driver returns an error 'FF_ERR_DRIVER_BUSY',
the library will pause for a number of ms, defined in
ffconfigDRIVER_BUSY_SLEEP_MS before re-trying.
Set to 1 to include the ff_fprintf() function in the build.
Set to 0 to exclude the ff_fprintf() function from the build.
ff_fprintf() is quite a heavy function because it allocates RAM and
brings in a lot of string and variable argument handling code. If
ff_fprintf() is not being used then the code size can be reduced by setting
ffconfigFPRINTF_SUPPORT to 0.
ff_fprintf() will allocate a buffer of this size in which it will create
its formatted string. The buffer will be freed before the function
exits.
Set to 1 to inline some internal memory access functions.
Set to 0 not to use inline memory access functions.
Officially the only criteria to determine the FAT type (12, 16, or 32
bits) is the total number of clusters:
if( ulNumberOfClusters < 4085 ) : Volume is FAT12
if( ulNumberOfClusters < 65525 ) : Volume is FAT16
if( ulNumberOfClusters >= 65525 ) : Volume is FAT32
Not every formatted device follows the above rule.
Set to 1 to perform additional checks over and above inspecting the
number of clusters on a disk to determine the FAT type.
Set to 0 to only look at the number of clusters on a disk to determine the
FAT type.
Sets the maximum length for file names, including the path.
Note that the value of this define is directly related to the maximum stack
use of the +FAT library. In some API's, a character buffer of size
'ffconfigMAX_FILENAME' will be declared on stack.
|