STM32F769IDiscovery  1.00
uDANTE Audio Networking with STM32F7 DISCO board
ffconf.h
Go to the documentation of this file.
1 /*---------------------------------------------------------------------------/
2 / FatFs - FAT file system module configuration file R0.11 (C)ChaN, 2015
3 /---------------------------------------------------------------------------*/
4 
5 #ifndef _FFCONF
6 #define _FFCONF 32020 /* Revision ID */
7 
8 /*-----------------------------------------------------------------------------/
9 / Additional user header to be used
10 /-----------------------------------------------------------------------------*/
11 /* Replace 'stm32xxx' with the STM32 Serie used, ex: stm32f4xx_hal.h */
12 #include "stm32f7xx_hal.h"
13 
14 /* If uSD is used, then include the uSD BSP header file.
15  Replace 'stm32xxx' with your EVAL board name, ex: stm324x9i_eval_sd.h
16  */
17 #ifndef _FS_SD_CARD
18 # ifdef USE_SD_CARD
19 # define _FS_SD_CARD 1
20 # else
21 # define _FS_SD_CARD 0
22 # endif
23 #endif
24 #if _FS_SD_CARD
25 # ifdef SD_CARD_HEADER
26 # include SD_CARD_HEADER
27 # else
28 # include "stm32xxx_eval_sd.h"
29 # endif
30 #endif
31 
32 
33 /* If USB Host MSC is used, then need to include the USBH and UBSH MSC core header files */
34 #ifndef _FS_USB_HOST
35 # ifdef USE_USB_HOST
36 # define _FS_USB_HOST 1
37 # else
38 # define _FS_USB_HOST 0
39 # endif
40 #endif
41 #if _FS_USB_HOST
42 #include "usbh_core.h"
43 #include "usbh_msc.h"
44 /* hUSBH to be updated with the USBH handle defined in the application code */
45 #define HOST_HANDLE hUSBH
46 #endif
47 
48 /*---------------------------------------------------------------------------/
49 / Functions and Buffer Configurations
50 /---------------------------------------------------------------------------*/
51 
52 #define _FS_TINY 0 /* 0:Normal or 1:Tiny */
53 /* This option switches tiny buffer configuration. (0:Normal or 1:Tiny)
54 / At the tiny configuration, size of the file object (FIL) is reduced _MAX_SS
55 / bytes. Instead of private sector buffer eliminated from the file object,
56 / common sector buffer in the file system object (FATFS) is used for the file
57 / data transfer. */
58 
59 
60 #define _FS_READONLY 0 /* 0:Read/Write or 1:Read only */
61 /* This option switches read-only configuration. (0:Read/Write or 1:Read-only)
62 / Read-only configuration removes writing API functions, f_write(), f_sync(),
63 / f_unlink(), f_mkdir(), f_chmod(), f_rename(), f_truncate(), f_getfree()
64 / and optional writing functions as well. */
65 
66 
67 #define _FS_MINIMIZE 0 /* 0 to 3 */
68 /* This option defines minimization level to remove some basic API functions.
69 /
70 / 0: All basic functions are enabled.
71 / 1: f_stat(), f_getfree(), f_unlink(), f_mkdir(), f_chmod(), f_utime(),
72 / f_truncate() and f_rename() function are removed.
73 / 2: f_opendir(), f_readdir() and f_closedir() are removed in addition to 1.
74 / 3: f_lseek() function is removed in addition to 2. */
75 
76 
77 #define _USE_STRFUNC 2 /* 0:Disable or 1-2:Enable */
78 /* This option switches string functions, f_gets(), f_putc(), f_puts() and
79 / f_printf().
80 /
81 / 0: Disable string functions.
82 / 1: Enable without LF-CRLF conversion.
83 / 2: Enable with LF-CRLF conversion. */
84 
85 
86 #define _USE_FIND 0
87 /* This option switches filtered directory read feature and related functions,
88 / f_findfirst() and f_findnext(). (0:Disable or 1:Enable) */
89 
90 
91 #define _USE_MKFS 1
92 /* This option switches f_mkfs() function. (0:Disable or 1:Enable) */
93 
94 
95 #define _USE_FASTSEEK 1
96 /* This option switches fast seek feature. (0:Disable or 1:Enable) */
97 
98 
99 #define _USE_LABEL 0
100 /* This option switches volume label functions, f_getlabel() and f_setlabel().
101 / (0:Disable or 1:Enable) */
102 
103 
104 #define _USE_FORWARD 0
105 /* This option switches f_forward() function. (0:Disable or 1:Enable)
106 / To enable it, also _FS_TINY need to be set to 1. */
107 
108 #define _USE_BUFF_WO_ALIGNMENT 0
109 /* This option is available only for usbh diskio interface and allow to disable
110 / the management of the unaligned buffer.
111 / When STM32 USB OTG HS or FS IP is used with internal DMA enabled, this define
112 / must be set to 0 to align data into 32bits through an internal scratch buffer
113 / before being processed by the DMA . Otherwise (DMA not used), this define must
114 / be set to 1 to avoid Data alignment and improve the performance.
115 / Please note that if _USE_BUFF_WO_ALIGNMENT is set to 1 and an unaligned 32bits
116 / buffer is forwarded to the FatFs Write/Read functions, an error will be returned.
117 / (0: default value or 1: unaligned buffer return an error). */
118 
119 
120 /*---------------------------------------------------------------------------/
121 / Locale and Namespace Configurations
122 /---------------------------------------------------------------------------*/
123 
124 #define _CODE_PAGE 1252
125 /* This option specifies the OEM code page to be used on the target system.
126 / Incorrect setting of the code page can cause a file open failure.
127 /
128 / 932 - Japanese Shift_JIS (DBCS, OEM, Windows)
129 / 936 - Simplified Chinese GBK (DBCS, OEM, Windows)
130 / 949 - Korean (DBCS, OEM, Windows)
131 / 950 - Traditional Chinese Big5 (DBCS, OEM, Windows)
132 / 1250 - Central Europe (Windows)
133 / 1251 - Cyrillic (Windows)
134 / 1252 - Latin 1 (Windows)
135 / 1253 - Greek (Windows)
136 / 1254 - Turkish (Windows)
137 / 1255 - Hebrew (Windows)
138 / 1256 - Arabic (Windows)
139 / 1257 - Baltic (Windows)
140 / 1258 - Vietnam (OEM, Windows)
141 / 437 - U.S. (OEM)
142 / 720 - Arabic (OEM)
143 / 737 - Greek (OEM)
144 / 775 - Baltic (OEM)
145 / 850 - Multilingual Latin 1 (OEM)
146 / 858 - Multilingual Latin 1 + Euro (OEM)
147 / 852 - Latin 2 (OEM)
148 / 855 - Cyrillic (OEM)
149 / 866 - Russian (OEM)
150 / 857 - Turkish (OEM)
151 / 862 - Hebrew (OEM)
152 / 874 - Thai (OEM, Windows)
153 / 1 - ASCII (No extended character. Valid for only non-LFN configuration.) */
154 
155 
156 #define _USE_LFN 3
157 #define _MAX_LFN 255 /* Maximum LFN length to handle (12 to 255) */
158 /* The _USE_LFN option switches the LFN feature.
159 /
160 / 0: Disable LFN feature. _MAX_LFN has no effect.
161 / 1: Enable LFN with static working buffer on the BSS. Always NOT thread-safe.
162 / 2: Enable LFN with dynamic working buffer on the STACK.
163 / 3: Enable LFN with dynamic working buffer on the HEAP.
164 /
165 / When enable the LFN feature, Unicode handling functions (option/unicode.c) must
166 / be added to the project. The LFN working buffer occupies (_MAX_LFN + 1) * 2 bytes.
167 / When use stack for the working buffer, take care on stack overflow. When use heap
168 / memory for the working buffer, memory management functions, ff_memalloc() and
169 / ff_memfree(), must be added to the project. */
170 
171 
172 #define _LFN_UNICODE 0 /* 0:ANSI/OEM or 1:Unicode */
173 /* This option switches character encoding on the API. (0:ANSI/OEM or 1:Unicode)
174 / To use Unicode string for the path name, enable LFN feature and set _LFN_UNICODE
175 / to 1. This option also affects behavior of string I/O functions. */
176 
177 
178 #define _STRF_ENCODE 3
179 /* When _LFN_UNICODE is 1, this option selects the character encoding on the file to
180 / be read/written via string I/O functions, f_gets(), f_putc(), f_puts and f_printf().
181 /
182 / 0: ANSI/OEM
183 / 1: UTF-16LE
184 / 2: UTF-16BE
185 / 3: UTF-8
186 /
187 / When _LFN_UNICODE is 0, this option has no effect. */
188 
189 
190 #define _FS_RPATH 0
191 /* This option configures relative path feature.
192 /
193 / 0: Disable relative path feature and remove related functions.
194 / 1: Enable relative path feature. f_chdir() and f_chdrive() are available.
195 / 2: f_getcwd() function is available in addition to 1.
196 /
197 / Note that directory items read via f_readdir() are affected by this option. */
198 
199 
200 /*---------------------------------------------------------------------------/
201 / Drive/Volume Configurations
202 /---------------------------------------------------------------------------*/
203 
204 #define _VOLUMES 1
205 /* Number of volumes (logical drives) to be used. */
206 
207 
208 #define _STR_VOLUME_ID 0
209 #define _VOLUME_STRS "RAM","NAND","CF","SD1","SD2","USB1","USB2","USB3"
210 /* _STR_VOLUME_ID option switches string volume ID feature.
211 / When _STR_VOLUME_ID is set to 1, also pre-defined strings can be used as drive
212 / number in the path name. _VOLUME_STRS defines the drive ID strings for each
213 / logical drives. Number of items must be equal to _VOLUMES. Valid characters for
214 / the drive ID strings are: A-Z and 0-9. */
215 
216 
217 #define _MULTI_PARTITION 0
218 /* This option switches multi-partition feature. By default (0), each logical drive
219 / number is bound to the same physical drive number and only an FAT volume found on
220 / the physical drive will be mounted. When multi-partition feature is enabled (1),
221 / each logical drive number is bound to arbitrary physical drive and partition
222 / listed in the VolToPart[]. Also f_fdisk() funciton will be available. */
223 
224 
225 #define _MIN_SS 512
226 #define _MAX_SS 512
227 /* These options configure the range of sector size to be supported. (512, 1024,
228 / 2048 or 4096) Always set both 512 for most systems, all type of memory cards and
229 / harddisk. But a larger value may be required for on-board flash memory and some
230 / type of optical media. When _MAX_SS is larger than _MIN_SS, FatFs is configured
231 / to variable sector size and GET_SECTOR_SIZE command must be implemented to the
232 / disk_ioctl() function. */
233 
234 
235 #define _USE_TRIM 0
236 /* This option switches ATA-TRIM feature. (0:Disable or 1:Enable)
237 / To enable Trim feature, also CTRL_TRIM command should be implemented to the
238 / disk_ioctl() function. */
239 
240 
241 #define _FS_NOFSINFO 0
242 /* If you need to know correct free space on the FAT32 volume, set bit 0 of this
243 / option, and f_getfree() function at first time after volume mount will force
244 / a full FAT scan. Bit 1 controls the use of last allocated cluster number.
245 /
246 / bit0=0: Use free cluster count in the FSINFO if available.
247 / bit0=1: Do not trust free cluster count in the FSINFO.
248 / bit1=0: Use last allocated cluster number in the FSINFO if available.
249 / bit1=1: Do not trust last allocated cluster number in the FSINFO.
250 */
251 
252 /*---------------------------------------------------------------------------/
253 / System Configurations
254 /---------------------------------------------------------------------------*/
255 
256 #define _FS_NORTC 0
257 #define _NORTC_MON 2
258 #define _NORTC_MDAY 1
259 #define _NORTC_YEAR 2015
260 /* The _FS_NORTC option switches timestamp feature. If the system does not have
261 / an RTC function or valid timestamp is not needed, set _FS_NORTC to 1 to disable
262 / the timestamp feature. All objects modified by FatFs will have a fixed timestamp
263 / defined by _NORTC_MON, _NORTC_MDAY and _NORTC_YEAR.
264 / When timestamp feature is enabled (_FS_NORTC == 0), get_fattime() function need
265 / to be added to the project to read current time form RTC. _NORTC_MON,
266 / _NORTC_MDAY and _NORTC_YEAR have no effect.
267 / These options have no effect at read-only configuration (_FS_READONLY == 1). */
268 
269 
270 #define _FS_LOCK 2
271 /* The _FS_LOCK option switches file lock feature to control duplicated file open
272 / and illegal operation to open objects. This option must be 0 when _FS_READONLY
273 / is 1.
274 /
275 / 0: Disable file lock feature. To avoid volume corruption, application program
276 / should avoid illegal open, remove and rename to the open objects.
277 / >0: Enable file lock feature. The value defines how many files/sub-directories
278 / can be opened simultaneously under file lock control. Note that the file
279 / lock feature is independent of re-entrancy. */
280 
281 
282 #ifndef _FS_REENTRANT
283 # ifdef USE_RTOS_SYSTICK
284 # define _FS_REENTRANT 1
285 # else
286 # define _FS_REENTRANT 0
287 # endif
288 #endif
289 #if _FS_REENTRANT
290 # include <cmsis_os.h>
291 
292 # define _FS_TIMEOUT 1000
293 # define _SYNC_t osSemaphoreId
294 #endif
295 /* The _FS_REENTRANT option switches the re-entrancy (thread safe) of the FatFs
296 / module itself. Note that regardless of this option, file access to different
297 / volume is always re-entrant and volume control functions, f_mount(), f_mkfs()
298 / and f_fdisk() function, are always not re-entrant. Only file/directory access
299 / to the same volume is under control of this feature.
300 /
301 / 0: Disable re-entrancy. _FS_TIMEOUT and _SYNC_t have no effect.
302 / 1: Enable re-entrancy. Also user provided synchronization handlers,
303 / ff_req_grant(), ff_rel_grant(), ff_del_syncobj() and ff_cre_syncobj()
304 / function, must be added to the project. Samples are available in
305 / option/syscall.c.
306 /
307 / The _FS_TIMEOUT defines timeout period in unit of time tick.
308 / The _SYNC_t defines O/S dependent sync object type. e.g. HANDLE, ID, OS_EVENT*,
309 / SemaphoreHandle_t and etc.. */
310 
311 
312 #define _WORD_ACCESS 0
313 /* The _WORD_ACCESS option is an only platform dependent option. It defines
314 / which access method is used to the word data on the FAT volume.
315 /
316 / 0: Byte-by-byte access. Always compatible with all platforms.
317 / 1: Word access. Do not choose this unless under both the following conditions.
318 /
319 / * Address misaligned memory access is always allowed to ALL instructions.
320 / * Byte order on the memory is little-endian.
321 /
322 / If it is the case, _WORD_ACCESS can also be set to 1 to reduce code size.
323 / Following table shows allowable settings of some processor types.
324 /
325 / ARM7TDMI 0 ColdFire 0 V850E 0
326 / Cortex-M3 0 Z80 0/1 V850ES 0/1
327 / Cortex-M0 0 x86 0/1 TLCS-870 0/1
328 / AVR 0/1 RX600(LE) 0/1 TLCS-900 0/1
329 / AVR32 0 RL78 0 R32C 0
330 / PIC18 0/1 SH-2 0 M16C 0/1
331 / PIC24 0 H8S 0 MSP430 0
332 / PIC32 0 H8/300H 0 8051 0/1
333 */
334 
335 
336 #endif /* _FFCONF */
Header of cmsis_os.c A new set of APIs are added in addition to existing ones, these APIs are specifi...
Header file for usbh_core.c.
This file contains all the prototypes for the usbh_msc.c.
This file contains all the functions prototypes for the HAL module driver.