FAT File System Registry Settings (Windows CE 5.0)

Send Feedback

The file allocation table file system (FATFS) retrieves driver specific settings from the registry.

You can place FATFS settings at two different tiers in the registry hierarchy

  • Root file system key

    Settings made at the root key of the file system registry, HKEY_LOCAL_MACHINE\System\StorageManager\ FATFS, apply to every mounted instance of FATFS, unless explicitly overridden by a setting at a lower level. These setting apply to FATFS for all profiles.

  • Profile-specific settings

    Settings made at the Profiles registry subkey, HKEY_LOCAL_MACHINE\System\StorageManager\Profile\<MyProfileName>\FATFS, apply locally. That is, settings at this registry key apply only to mounted instances of FATFS on devices that report the profile <MyProfileName>.

The following table shows the registry settings for the FAT file system that you can place in

HKEY_LOCAL_MACHINE\System\StorageManager\FATFS

- or -

HKEY_LOCAL_MACHINE\System\StorageManager\Profile\<MyProfileName>\FATFS.

Registry value: Type Description
BufferSize: REG_DWORD Specifies the number of sector-sized buffers to use for streams.

The default value is 64 for TFAT and 32 for FAT.

CacheSize: REG_DWORD This value is deprecated for Windows CE 5.0 and later. Replace with FatCacheSize or DataCacheSize.

Indicates the size of the disk cache, in number of sectors. This value must be a power of 2 and at least 16 sectors. If set to zero, FATFS will determine the best cache size to use.

For more information, see CacheSize registry subkey.

CodePage: REG_DWORD Overrides CP_OEMCP in all character conversions.
DataCacheSize: REG_DWORD Indicates the size of the data cache, in number of sectors. This value must be a power of 2 and at least 16 sectors. If set to zero, FATFS will determine the best cache size to use, up to twice the size of FatCacheSize.

For more information, see CacheSize registry subkey.

Dll: REG_SZ Specifies the name of the file system DLL.
EnableCache: REG_DWORD Controls caching.
  • 0 - Disables caching
  • 1 - Enables caching
EnableCacheWarm: REG_DWORD This value is deprecated for Windows CE 5.0 and later. Replace with EnableFatCacheWarm or EnableDataCacheWarm.

Set to 1 to enable pre-warming of the Fat cache. That is, the cache is pre-loaded to capacity with data on initialization. For example, if the cache is n sectors, the first n sectors of the cached region is read from disk.

EnableFatCacheWarm: REG_DWORD Set to 1 to enable pre-warming of the data cache. That is, the cache is pre-loaded to capacity with data on initialization. For example, if the cache is n sectors, the first n sectors of the cached region is read from disk.
EnableDataCacheWarm: REG_DWORD Set to 1 to enable pre-warming of the cache. That is, the cache is pre-loaded to capacity with data on initialization. For example, if the cache is n sectors, the first n sectors of the cached region is read from disk.
EnableWriteBack: REG_DWORD Enables a write-back or write-through cache.
  • 0 - To use a write-through cache
  • 1 - Enables write-back cache

This setting applies only to Windows CE 5.0 and later.

FatCacheSize: REG_DWORD Indicates the size of the FAT cache, in number of sectors. This value must be a power of 2 and at least 16 sectors. If set to zero, FATFS will determine the best cache size to use, based on size of the FATFS up to 512 sectors.

For more information, see CacheSize registry subkey.

Flags: REG_DWORD Indicates FAT file system registry flags. Default is 64.

For more information, see Flags registry subkey.

FormatTfat: REG_DWORD Formats the volume as TFAT on auto-format or through IOCTL_DISK_FORMAT_VOLUME.
FriendlyName: REG_SZ Specifies a friendly name for the file system.
MountFlags: REG_DWORD This value is deprecated for Windows CE 5.0 and later. For replacement values, see Mount Settings.
MountLabel: REG_DWORD Pulls the volume label and uses it as a mount point.
Paging: REG_DWORD Controls paging.
  • 0 - Disables paging
  • 1 - Enables paging
Util: REG_SZ Specifies the DLL name of utility to do format and scan.
LazyWriterThreadPrio256: REG_DWORD Sets the priority of the lazy writer thread. Default is idle.

For more information, see Lazy-Writer Thread.

Note: When you enable pre-warming of the FAT or data cache, you trade longer boot times for quicker cache access when fully booted. To determine the settings that offer the best performance for your target device, experiment with different values for EnableFatCacheWarm and EnableDataCacheWarm.

Default FATFS Settings

The following registry key example is the default for the FAT file system; profiles can override these values:

[HKEY_LOCAL_MACHINE\System\StorageManager\FATFS]
    "FriendlyName"="FAT FileSystem"
    "Dll"="fatfsd.dll"
    "Flags"=dword:00000024
    "Paging"=dword:1
    "CacheSize"=dword:0

Flags registry subkey

The following table shows the available values you can set for the Flags registry subkey; set Flags to a combination of these values.

Flag Value Description
FATFS_UPDATE_ACCESS 0x00000001 Updates access times.
FATFS_DISABLE_LOG 0x00000002 Disables event logging.
FATFS_DISABLE_AUTOSCAN 0x00000004 Disables automatic calls to ScanVolume.
FATFS_VERIFY_WRITES 0x00000008 Verifies all writes.
FATFS_ENABLE_BACKUP_FAT 0x00000010 Adds a backup FAT to all formats.
FATFS_FORCE_WRITETHROUGH 0x00000020 Sets all files to WRITE_THROUGH, regardless of the parameters to CreateFile.
FATFS_DISABLE_AUTOFORMAT 0x00000040 Disables automatic formatting of unformatted volumes.
FATFS_WFWS_NOWRITETHRU 0x00010000 Disables write through on the WriteFileWithSeek function. Improves memory-mapped file performance.
FATFS_DISABLE_FORMAT 0x00020000 Disables format.
FATFS_TRANS_DATA 0x00040000 Transacts data on a write operation.
FATFS_TFAT_NONATOMIC_SECTOR 0x00080000 Uses the cluster 1 entry in the FAT table for a TFAT transaction. TFAT uses the NOF field of the boot sector by default.
FATFS_DISABLE_TFAT_REDIR 0x00100000 Disables the redirect of the root directory to another hidden directory for FAT12 or 16.
FATFS_TFAT_ALWAYS 0x00200000 Marks transaction status, even if only one sector in FAT is changed.
FATFS_FORCE_TFAT 0x00400000 Forces TFAT transactions even if the volume is not formatted as TFAT.
FATFS_LFN_EXTENDED 0x00800000 Generate LFN entries for extended characters always
FATFS_TFAT_DISABLE_MOVEDIR 0x01000000 Disable movefile on a directory for TFAT because it isn't transaction-safe

CacheSize registry subkey

The CacheSize registry subkey is a hexadecimal number of sectors to cache. This has to be a power of two. The following table shows valid numbers for the CacheSize registry subkey.

Registry entry Number of sectors Cache in kilobytes (KB)
2 2 1
4 4 2
8 8 4
10 16 8
20 16 32
40 64 32
80 128 64
100 256 128
200 512 256
400 1024 512
800 2048 1024
1000 4096 2048

See Also

File System Driver Creation | File System Driver Loading | Storage Manager | File System Filters | Block Drivers

Send Feedback on this topic to the authors

Feedback FAQs

© 2006 Microsoft Corporation. All rights reserved.