C7. Structures. Directory contents. Table. File allocationbitmap, linked list. Bad blocks. Cluster tagging. Limits. Max. volume sizeca. Pi. B, 5. 12 Ti. B recommended1Max. Pi. B theoretical 1. Ei. B1nb 1Max. Max. UTF 1. 6 characters. Allowed characters in filenames. Unicode UTF 1. 6 except U0. NUL through U0. F US slash backslash colon asterisk Question mark quotelt less than greater than and pipeFeatures. Dates recorded. Creation, modified, last access. Date range. 19. 80 0. Date resolution. 10 ms. Forks. No. Attributes. Read only, hidden, system, subdirectory, archive. File system permissions. ACL Windows CE 6 onlyTransparent compression. No. Transparent encryption. No. Other. Supported operating systems. Windows Embedded CE 6. Windows XP including x. SP2 and later optional1Windows Server 2. SP2 optional1Windows Vista SP1 and later. Windows 7. Windows 8. Windows 1. 0Windows Server 2. Windows Server 2. R2. Linux via FUSE3 or non mainline kernel driver4Mac OS X 1. Some Android OS devices such as the Sony. Xperia Z running the latest firmwareex. FAT Extended File Allocation Table is a Microsoftfile system introduced in 2. USB flash drives and SD cards. It is proprietary and Microsoft owns patents on several elements of its design. FAT can be used where the NTFS file system is not a feasible solution due to data structure overhead, yet the file size limit of the standard FAT3. Gi. B is unacceptable. FAT has been adopted by the SD Card Association as the default file system for SDXC cards larger than 3. Gi. B. Overvieweditex. FAT was first introduced in late 2. Windows CE 6. 0, an embedded Windows operating system. Most of the vendors signing on for licenses of ex. FAT are either for embedded systems or device manufacturers that produce media that will be preformatted with ex. FAT. The entire File Allocation Table FAT family, ex. FAT included, is used for embedded systems because it is lightweight and is better suited for solutions that have low memory and low power requirements, and can be implemented in firmware. FAT allows individual files larger than 4 Gi. B, facilitating long continuous recording of HD video which can exceed the 4 Gi. B limit in less than an hour. Current digital cameras using FAT3. Gi. B. With the increase of capacity and the increase of data being transferred, the write operation needs to be made more efficient. SDXC cards, running at UHS I have a minimum guaranteed write speed of 1. MBps and ex. FAT plays a factor in achieving that throughput through the reduction of the file system overhead in cluster allocation. This is achieved through the introduction of a cluster bitmap and elimination or reduction of writes to the FAT. A single bit in the directory record indicates that the file is contiguous, telling the ex. FAT driver to ignore the FAT. This optimization is analogous to an extent in other file systems, except that it only applies to whole files, as opposed to contiguous parts of files. FAT is also supported in a number of media devices such as modern flat panel TVs,6 media centers, and portable media players. Some vendors of flash media, including USB pen drives, compact flash CF and solid state drives SSD are shipping from the factory with some of their high capacity media pre formatted with the ex. FAT file system. For example, Sandisk ships their 2. GB CF cards as ex. FAT. Technical specialitieseditFile name lookupeditLike NTFS and HFS, ex. FAT is a proprietary file system. Microsoft asserts that ex. FAT is covered by US Patent 8. November 2. 7, 2. US Patent 8. 32. 14. Quick File Name Lookup Using Name Hash, which is an algorithm used in ex. FAT to speed up file searches. Microsoft had also applied for, and so far in some cases, received additional US patents on separate components that are used within ex. FAT. Since Microsoft has not officially released the entire ex. FAT specification, the Name Hash patent application is a key document in providing internal details in the understanding of the file system, since those details were revealed in Appendix A of the application. File and cluster pre allocationeditLike NTFS, ex. FAT can pre allocate disk space for a file by just marking arbitrary space on disk as allocated. For each file, ex. FAT uses two separate 6. Valid Data Length VDL which indicates the real size of the file, and the physical data length. To provide improvement in the allocation of cluster storage for a new file, Microsoft incorporated a method to pre allocate contiguous clusters and bypass the use of updating the FAT table and on December 1. US patent office granted patent US8. One feature of ex. FAT used in the ex. FAT implementation within embedded systems provides atomic transactions for the multiple steps of updating the file system metadata. The feature, called Transaction Safe FAT, or Tex. FAT, was granted a patent by the US patent office under US7. November 3, 2. 00. Directory file seteditex. FAT and the rest of the FAT family of file systems does not use indexes for file names, unlike NTFS which uses B trees for file searching. When a file is accessed, the directory must be sequentially searched until a match is found. For file names shorter than 1. This is called a directory file set, and a 2. Mi. B sub directory can hold up to 2,7. If files have longer names, this number will decrease but this is the maximum based on the minimum three record file set. To help improve the sequential searching of the directories including the root a hash value of the file name is derived for each file and stored in the directory record. When searching for a file, the file name is first converted to upper case using the upcase table file names are case insensitive and then hashed using a proprietary patented algorithm into a 1. Each record in the directory is searched by comparing the hash value. When a match is found, the file names are compared to ensure that the proper file was located in case of hash collisions. This improves performance because only 2 bytes have to be compared for each file. This significantly reduces the CPU cycles because most file names are more than 2 characters bytes in size and virtually every comparison is performed on only 2 bytes at a time until the intended file is located. Metadata and checksumseditex. FAT introduces metadata integrity through the use of checksums. There are three checksums currently in use. The Volume Boot Record VBR is a 1. BIOS Parameter Block BPB, OEM parameters and the checksum sector. There are two VBR type regions, the main VBR and the backup VBR. The checksum sector is a checksum of the previous 1. Flags and percent used. This provides integrity of the VBR by determining if the VBR was modified. The most common cause could be a boot sector virus, but this would also catch any other corruption to the VBR. A second checksum is used for the upcase table. This is a static table and should never change. Any corruption in the table could prevent files from being located because this table is used to convert the filenames to upper case when searching to locate a file. The third checksum is in the directory file sets. Multiple directory records are used to define a single file and this is called a file set. This file set has metadata including the file name, time stamps, attributes, address of first cluster location of the data, file lengths, and the file name. A checksum is taken over the entire file set and a mismatch would occur if the directory file set was accidentally or maliciously changed. When the file system is mounted, and the integrity check is conducted, these hashes are verified. Mounting also includes comparison of the version of the ex.