• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
2<html lang="en">
3<head>
4<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
5<meta http-equiv="Content-Style-Type" content="text/css">
6<meta http-equiv="cache-control" content="no-cache">
7<meta name="description" content="Open source FAT filesystem for embedded projects">
8<link rel="start" title="Site Top" href="../../">
9<link rel="up" title="Freewares" href="../../fsw_e.html">
10<link rel="stylesheet" href="css_e.css" type="text/css" media="screen" title="ELM Default">
11<title>FatFs - Generic FAT Filesystem Module</title>
12</head>
13
14<body>
15<h1>FatFs - Generic FAT Filesystem Module</h1>
16<hr>
17
18<div class="abst">
19<img src="res/layers.png" class="rset" width="245" height="255" alt="layer">
20<p>FatFs is a generic FAT/exFAT filesystem module for small embedded systems. The FatFs module is written in compliance with ANSI C (C89) and completely separated from the disk I/O layer. Therefore it is independent of the platform. It can be incorporated into small microcontrollers with limited resource, such as 8051, PIC, AVR, ARM, Z80, RX and etc. Also Petit FatFs module for tiny microcontrollers is available <a href="http://elm-chan.org/fsw/ff/00index_p.html">here</a>.</p>
21
22<h4>Features</h4>
23<ul>
24 <li>DOS/Windows Compatible FAT/exFAT Filesystem.</li>
25 <li>Platform Independent. <a href="doc/appnote.html#port">Easy to port</a>.</li>
26 <li>Very Small <a href="doc/appnote.html#memory">Footprint</a> for Program Code and Work Area.</li>
27 <li>Various <a href="doc/config.html">Configuration Options</a> to Support for:
28  <ul>
29   <li>Long File Name in ANSI/OEM or Unicode.</li>
30   <li>exFAT Filesystem, 64-bit LBA and GPT for Huge Storages.</li>
31   <li>Thread Safe for RTOS.</li>
32   <li>Multiple Volumes. (Physical Drives and Partitions)</li>
33   <li>Variable Sector Size.</li>
34   <li>Multiple Code Pages Including DBCS.</li>
35   <li>Read-only, Optional APIs, I/O Buffer and etc...</li>
36  </ul>
37 </li>
38</ul>
39</div>
40
41
42<div class="para">
43<h3>Application Interface</h3>
44<img src="res/layers1.png" class="rset" width="245" height="220" alt="layer">
45<p>FatFs provides various filesystem functions for the applications as shown below.</p>
46<ul>
47 <li>File Access
48 <ul>
49  <li><a href="doc/open.html">f_open</a> - Open/Create a file</li>
50  <li><a href="doc/close.html">f_close</a> - Close an open file</li>
51  <li><a href="doc/read.html">f_read</a> - Read data from the file</li>
52  <li><a href="doc/write.html">f_write</a> - Write data to the file</li>
53  <li><a href="doc/lseek.html">f_lseek</a> - Move read/write pointer, Expand size</li>
54  <li><a href="doc/truncate.html">f_truncate</a> - Truncate file size</li>
55  <li><a href="doc/sync.html">f_sync</a> - Flush cached data</li>
56  <li><a href="doc/forward.html">f_forward</a> - Forward data to the stream</li>
57  <li><a href="doc/expand.html">f_expand</a> - Allocate a contiguous block to the file</li>
58  <li><a href="doc/gets.html">f_gets</a> - Read a string</li>
59  <li><a href="doc/putc.html">f_putc</a> - Write a character</li>
60  <li><a href="doc/puts.html">f_puts</a> - Write a string</li>
61  <li><a href="doc/printf.html">f_printf</a> - Write a formatted string</li>
62  <li><a href="doc/tell.html">f_tell</a> - Get current read/write pointer</li>
63  <li><a href="doc/eof.html">f_eof</a> - Test for end-of-file</li>
64  <li><a href="doc/size.html">f_size</a> - Get size</li>
65  <li><a href="doc/error.html">f_error</a> - Test for an error</li>
66 </ul>
67 </li>
68 <li>Directory Access
69 <ul>
70  <li><a href="doc/opendir.html">f_opendir</a> - Open a directory</li>
71  <li><a href="doc/closedir.html">f_closedir</a> - Close an open directory</li>
72  <li><a href="doc/readdir.html">f_readdir</a> - Read a directory item</li>
73  <li><a href="doc/findfirst.html">f_findfirst</a> - Open a directory and read the first item matched</li>
74  <li><a href="doc/findnext.html">f_findnext</a> - Read a next item matched</li>
75 </ul>
76 </li>
77 <li>File and Directory Management
78 <ul>
79  <li><a href="doc/stat.html">f_stat</a> - Check existance of a file or sub-directory</li>
80  <li><a href="doc/unlink.html">f_unlink</a> - Remove a file or sub-directory</li>
81  <li><a href="doc/rename.html">f_rename</a> - Rename/Move a file or sub-directory</li>
82  <li><a href="doc/chmod.html">f_chmod</a> - Change attribute of a file or sub-directory</li>
83  <li><a href="doc/utime.html">f_utime</a> - Change timestamp of a file or sub-directory</li>
84  <li><a href="doc/mkdir.html">f_mkdir</a> - Create a sub-directory</li>
85  <li><a href="doc/chdir.html">f_chdir</a> - Change current directory</li>
86  <li><a href="doc/chdrive.html">f_chdrive</a> - Change current drive</li>
87  <li><a href="doc/getcwd.html">f_getcwd</a> - Retrieve the current directory and drive</li>
88 </ul>
89 </li>
90 <li>Volume Management and System Configuration
91 <ul>
92  <li><a href="doc/mount.html">f_mount</a> - Register/Unregister the work area of the volume</li>
93  <li><a href="doc/mkfs.html">f_mkfs</a> - Create an FAT volume on the logical drive</li>
94  <li><a href="doc/fdisk.html">f_fdisk</a> - Create partitions on the physical drive</li>
95  <li><a href="doc/getfree.html">f_getfree</a> - Get free space on the volume</li>
96  <li><a href="doc/getlabel.html">f_getlabel</a> - Get volume label</li>
97  <li><a href="doc/setlabel.html">f_setlabel</a> - Set volume label</li>
98  <li><a href="doc/setcp.html">f_setcp</a> - Set active code page</li>
99 </ul>
100 </li>
101</ul>
102</div>
103
104
105<div class="para">
106<h3>Media Access Interface</h3>
107<img src="res/layers2.png" class="rset" width="245" height="220" alt="layer">
108<p>Since FatFs module is the <em>Filesystem Layer</em> independent of platforms and storage media, it is completely separated from the physical devices, such as memory card, harddisk and any type of storage device. The storage device control module is <em>not any part of FatFs module</em> and it needs to be provided by implementer. FatFs controls the storage devices via a simple media access interface shown below. Also sample implementations for some platforms are available in the downloads. A function checker for storage device control module is available <a href="res/app4.c">here</a>.</p>
109<ul>
110 <li>Storage Device Controls
111 <ul>
112  <li><a href="doc/dstat.html">disk_status</a> - Get device status</li>
113  <li><a href="doc/dinit.html">disk_initialize</a> - Initialize device</li>
114  <li><a href="doc/dread.html">disk_read</a> - Read data</li>
115  <li><a href="doc/dwrite.html">disk_write</a> - Write data</li>
116  <li><a href="doc/dioctl.html">disk_ioctl</a> - Control device dependent functions</li>
117 </ul>
118 </li>
119 <li>Real Time Clock
120 <ul>
121  <li><a href="doc/fattime.html">get_fattime</a> - Get current time</li>
122 </ul>
123 </li>
124</ul>
125</div>
126
127
128<div class="para">
129<h3>Resources</h3>
130<p>The FatFs module is a free software opened for education, research and development. You can use, modify and/or redistribute it for any purpose without any restriction under your responsibility. For further information, refer to the application note.</p>
131<ul>
132 <li><em>Getting Started: <a href="doc/appnote.html">FatFs Application Note</a></em></li>
133 <li>Community: <a href="http://elm-chan.org/fsw/ff/bd/">FatFs User Forum</a></li>
134 <li><a href="https://msdn.microsoft.com/en-us/windows/hardware/gg463080.aspx">FAT32 Specification by Microsoft</a>↗ (The authorized document on FAT filesystem)</li>
135 <li><a href="http://elm-chan.org/docs/fat_e.html">The basics of FAT filesystem</a> (FatFs is written based on this documentation)</li>
136 <li><a href="http://elm-chan.org/docs/exfat_e.html">The basics of exFAT filesystem</a> (FatFs is written based on this documentation)</li>
137 <li><a href="http://elm-chan.org/docs/mmc/mmc_e.html">How to use MMC/SDC</a></li>
138 <li><a href="http://elm-chan.org/junk/fa/faff.html">Playing with FlashAir and FatFs</a></li>
139 <li><a href="http://nemuisan.blog.bai.ne.jp/">Nemuisan's Blog</a>↗ (Well written implementations for STM32F/SPI &amp; SDIO and LPC4088/SDMMC)</li>
140 <li><a href="http://stm32f4-discovery.net/2014/07/library-21-read-sd-card-fatfs-stm32f4xx-devices/">Read SD card with FatFs on STM32F4xx devices by Tilen Majerle</a>↗ (Quick and easy implementation for STM32F4-Discovery)</li>
141 <li><a href="res/rwtest1.png">Benchmark 1</a> (ATmega1284/20MHz with MMC via USART in SPI, CFC via GPIO)</li>
142 <li><a href="res/rwtest2.png">Benchmark 2</a> (LPC2368/72MHz with MMC via MCI)</li>
143</div>
144
145
146<hr>
147<p class="foot"><a href="../../fsw_e.html">Return</a></p>
148</body>
149</html>
150