Select one of the symbols to view example projects that use it.
 
Outline
#include "../ff.h"
Files
loading...
SourceVuSTM32 Libraries and SamplesFatFssrc/option/syscall.c
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
/*------------------------------------------------------------------------*/ /* Sample code of OS dependent controls for FatFs */ /* (C)ChaN, 2014 */ /* Portions COPYRIGHT 2017 STMicroelectronics */ /* Portions Copyright (C) 2014, ChaN, all right reserved */ /*------------------------------------------------------------------------*/ /** ****************************************************************************** * @attention * * Copyright (c) 2017 STMicroelectronics. All rights reserved. * * This software component is licensed by ST under BSD 3-Clause license, * the "License"; You may not use this file except in compliance with the * License. You may obtain a copy of the License at: * opensource.org/licenses/BSD-3-Clause * ****************************************************************************** **//* ... */ #include "../ff.h" #if _FS_REENTRANT /*------------------------------------------------------------------------*/ /* Create a Synchronization Object */ /*------------------------------------------------------------------------*/ /* This function is called in f_mount() function to create a new / synchronization object, such as semaphore and mutex. When a 0 is returned, / the f_mount() function fails with FR_INT_ERR. *//* ... */ int ff_cre_syncobj ( /* 1:Function succeeded, 0:Could not create the sync object */ BYTE vol, /* Corresponding volume (logical drive number) */ _SYNC_t *sobj /* Pointer to return the created sync object */ ) { int ret; #if _USE_MUTEX #if (osCMSIS < 0x20000U) osMutexDef(MTX); *sobj = osMutexCreate(osMutex(MTX));/* ... */ #else *sobj = osMutexNew(NULL); #endif /* ... */ #else #if (osCMSIS < 0x20000U) osSemaphoreDef(SEM); *sobj = osSemaphoreCreate(osSemaphore(SEM), 1);/* ... */ #else *sobj = osSemaphoreNew(1, 1, NULL); #endif /* ... */ #endif ret = (*sobj != NULL); return ret; }ff_cre_syncobj (/* 1:Function succeeded, 0:Could not create the sync object */ BYTE vol, /* Corresponding volume (logical drive number) */ _SYNC_t *sobj /* Pointer to return the created sync object */) { ... } /*------------------------------------------------------------------------*/ /* Delete a Synchronization Object */ /*------------------------------------------------------------------------*/ /* This function is called in f_mount() function to delete a synchronization / object that created with ff_cre_syncobj() function. When a 0 is returned, / the f_mount() function fails with FR_INT_ERR. *//* ... */ int ff_del_syncobj ( /* 1:Function succeeded, 0:Could not delete due to any error */ _SYNC_t sobj /* Sync object tied to the logical drive to be deleted */ ) { #if _USE_MUTEX osMutexDelete (sobj); #else osSemaphoreDelete (sobj); #endif return 1; }ff_del_syncobj (/* 1:Function succeeded, 0:Could not delete due to any error */ _SYNC_t sobj /* Sync object tied to the logical drive to be deleted */) { ... } /*------------------------------------------------------------------------*/ /* Request Grant to Access the Volume */ /*------------------------------------------------------------------------*/ /* This function is called on entering file functions to lock the volume. / When a 0 is returned, the file function fails with FR_TIMEOUT. *//* ... */ int ff_req_grant ( /* 1:Got a grant to access the volume, 0:Could not get a grant */ _SYNC_t sobj /* Sync object to wait */ ) { int ret = 0; #if (osCMSIS < 0x20000U) #if _USE_MUTEX if(osMutexWait(sobj, _FS_TIMEOUT) == osOK) #else if(osSemaphoreWait(sobj, _FS_TIMEOUT) == osOK) #endif /* ... */ #else #if _USE_MUTEX if(osMutexAcquire(sobj, _FS_TIMEOUT) == osOK) #else if(osSemaphoreAcquire(sobj, _FS_TIMEOUT) == osOK) #endif /* ... */ #endif { ret = 1; ...} return ret; }ff_req_grant (/* 1:Got a grant to access the volume, 0:Could not get a grant */ _SYNC_t sobj /* Sync object to wait */) { ... } /*------------------------------------------------------------------------*/ /* Release Grant to Access the Volume */ /*------------------------------------------------------------------------*/ /* This function is called on leaving file functions to unlock the volume. *//* ... */ void ff_rel_grant ( _SYNC_t sobj /* Sync object to be signaled */ ) { #if _USE_MUTEX osMutexRelease(sobj); #else osSemaphoreRelease(sobj); #endif }ff_rel_grant (_SYNC_t sobj /* Sync object to be signaled */) { ... } /* ... */ #endif #if _USE_LFN == 3 /* LFN with a working buffer on the heap */ /*------------------------------------------------------------------------*/ /* Allocate a memory block */ /*------------------------------------------------------------------------*/ /* If a NULL is returned, the file function fails with FR_NOT_ENOUGH_CORE. *//* ... */ void* ff_memalloc ( /* Returns pointer to the allocated memory block */ UINT msize /* Number of bytes to allocate */ ) { return ff_malloc(msize); /* Allocate a new memory block with POSIX API */ }ff_memalloc (/* Returns pointer to the allocated memory block */ UINT msize /* Number of bytes to allocate */) { ... } /*------------------------------------------------------------------------*/ /* Free a memory block */ /*------------------------------------------------------------------------*/ void ff_memfree ( void* mblock /* Pointer to the memory block to free */ ) { ff_free(mblock); /* Discard the memory block with POSIX API */ }ff_memfree (void* mblock /* Pointer to the memory block to free */) { ... } /* ... */ #endif
Details
Show:
from
Types: Columns:
This file uses the notable symbols shown below. Click anywhere in the file to view more details.