author | Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> |
Mon, 21 Jun 2010 17:12:14 +0300 | |
branch | RCL_3 |
changeset 39 | 2bb754abd467 |
parent 28 | 5b5d147c7838 |
child 41 | 0ffb4e86fcc9 |
permissions | -rw-r--r-- |
0 | 1 |
// Copyright (c) 1995-2009 Nokia Corporation and/or its subsidiary(-ies). |
2 |
// All rights reserved. |
|
3 |
// This component and the accompanying materials are made available |
|
4 |
// under the terms of the License "Eclipse Public License v1.0" |
|
5 |
// which accompanies this distribution, and is available |
|
6 |
// at the URL "http://www.eclipse.org/legal/epl-v10.html". |
|
7 |
// |
|
8 |
// Initial Contributors: |
|
9 |
// Nokia Corporation - initial contribution. |
|
10 |
// |
|
11 |
// Contributors: |
|
12 |
// |
|
13 |
// Description: |
|
14 |
// f32\sfile\sf_std.h |
|
15 |
// |
|
16 |
// |
|
17 |
||
18 |
||
19 |
#ifndef SF_STD_H |
|
20 |
#define SF_STD_H |
|
21 |
||
22 |
#include "common.h" |
|
23 |
#include "message.h" |
|
24 |
#include <f32fsys.h> |
|
25 |
#include <f32ver.h> |
|
26 |
#include <f32dbg.h> |
|
27 |
#include <e32svr.h> |
|
28 |
#include <e32hal.h> |
|
29 |
#include <e32uid.h> |
|
30 |
#include <e32std_private.h> |
|
31 |
#include <e32def_private.h> |
|
32 |
#include <e32const_private.h> |
|
33 |
#include "sf_plugin.h" |
|
34 |
#include "sf_func.h" |
|
35 |
#include <F32plugin.h> |
|
36 |
#include "f32trace.h" |
|
37 |
#include <utraceefile.h> |
|
38 |
||
39 |
#define __PRINT1TEMP_ALWAYS(t,a) {{TBuf<KMaxFileName>temp(a);RDebug::Print(t,&temp);}} |
|
40 |
#define __PRINT2TEMP_ALWAYS(t,a,b) {{TBuf<KMaxFileName>temp(b);RDebug::Print(t,a,&temp);}} |
|
41 |
#define __PRINT3TEMP_ALWAYS(t,a,b,c) {{TBuf<KMaxFileName>temp(c);RDebug::Print(t,a,b,&temp);}} |
|
42 |
#define __PRINT4TEMP_ALWAYS(t,a,b,c,d) {{TBuf<KMaxFileName>temp(d);RDebug::Print(t,a,b,c,&temp);}} |
|
43 |
||
44 |
#define _THRD_BUF() (_L("thread id 0x"));buf.AppendNum(RThread().Id(),EHex);buf.Append(_L(" ")) |
|
45 |
#define __THRD_PRINT_ALWAYS(t) {{TBuf<KMaxFileName> buf=_THRD_BUF();buf.Append(t);RDebug::Print(buf);}} |
|
46 |
#define __THRD_PRINT1_ALWAYS(t,a) {{TBuf<KMaxFileName> buf=_THRD_BUF();buf.Append(t);RDebug::Print(buf,a);}} |
|
47 |
#define __THRD_PRINT2_ALWAYS(t,a,b) {{TBuf<KMaxFileName> buf=_THRD_BUF();buf.Append(t);RDebug::Print(buf,a,b);}} |
|
48 |
#define __THRD_PRINT3_ALWAYS(t,a,b,c) {{TBuf<KMaxFileName> buf=_THRD_BUF();buf.Append(t);RDebug::Print(buf,a,b,c);}} |
|
49 |
#define __THRD_PRINT4_ALWAYS(t,a,b,c,d) {{TBuf<KMaxFileName> buf=_THRD_BUF();buf.Append(t);RDebug::Print(buf,a,b,c,d);}} |
|
50 |
||
51 |
||
52 |
#if defined(_DEBUG) || defined(_DEBUG_RELEASE) |
|
53 |
#define __PRINT(t) {if (DebugReg&KFSERV) RDebug::Print(t);} |
|
54 |
#define __PRINT1(t,a) {if (DebugReg&KFSERV) RDebug::Print(t,a);} |
|
55 |
#define __PRINT2(t,a,b) {if (DebugReg&KFSERV) RDebug::Print(t,a,b);} |
|
56 |
#define __PRINT3(t,a,b,c) {if (DebugReg&KFSERV) RDebug::Print(t,a,b,c);} |
|
57 |
#define __PRINT4(t,a,b,c,d) {if (DebugReg&KFSERV) RDebug::Print(t,a,b,c,d);} |
|
58 |
#define __IF_DEBUG(t) {if (DebugReg&KFLDR) RDebug::t;} |
|
59 |
#define __LDRTRACE(t) {if (DebugReg&KFLDR) t;} |
|
60 |
#define __PRINTALLOC(t,a,b,c) {if (DebugReg&KALLOC) RDebug::Print(t,a,b,c);} |
|
61 |
#define __PRINT1TEMP(t,a) {if (DebugReg&KFSERV) {TBuf<KMaxFileName>temp(a);RDebug::Print(t,&temp);}} |
|
62 |
#define __PRINT2TEMP(t,a,b) {if (DebugReg&KFSERV) {TBuf<KMaxFileName>temp(b);RDebug::Print(t,a,&temp);}} |
|
63 |
#define __PRINT3TEMP(t,a,b,c) {if (DebugReg&KFSERV) {TBuf<KMaxFileName>temp(c);RDebug::Print(t,a,b,&temp);}} |
|
64 |
#define __PRINT4TEMP(t,a,b,c,d) {if (DebugReg&KFSERV) {TBuf<KMaxFileName>temp(d);RDebug::Print(t,a,b,c,&temp);}} |
|
65 |
#define __CALL(t) {t;} |
|
66 |
||
67 |
#define __THRD_PRINT(t) {if (DebugReg&KTHRD) {TBuf<KMaxFileName> buf=_THRD_BUF();buf.Append(t);RDebug::Print(buf);}} |
|
68 |
#define __THRD_PRINT1(t,a) {if (DebugReg&KTHRD) {TBuf<KMaxFileName> buf=_THRD_BUF();buf.Append(t);RDebug::Print(buf,a);}} |
|
69 |
#define __THRD_PRINT2(t,a,b) {if (DebugReg&KTHRD) {TBuf<KMaxFileName> buf=_THRD_BUF();buf.Append(t);RDebug::Print(buf,a,b);}} |
|
70 |
#define __THRD_PRINT3(t,a,b,c) {if (DebugReg&KTHRD) {TBuf<KMaxFileName> buf=_THRD_BUF();buf.Append(t);RDebug::Print(buf,a,b,c);}} |
|
71 |
#define __THRD_PRINT4(t,a,b,c,d) {if (DebugReg&KTHRD) {TBuf<KMaxFileName> buf=_THRD_BUF();buf.Append(t);RDebug::Print(buf,a,b,c,d);}} |
|
72 |
||
73 |
#define __CACHE_PRINT(t) {if (DebugReg&KCACHE) RDebug::Print(t);} |
|
74 |
#define __CACHE_PRINT1(t,a) {if (DebugReg&KCACHE) RDebug::Print(t,a);} |
|
75 |
#define __CACHE_PRINT2(t,a,b) {if (DebugReg&KCACHE) RDebug::Print(t,a,b);} |
|
76 |
#define __CACHE_PRINT3(t,a,b,c) {if (DebugReg&KCACHE) RDebug::Print(t,a,b,c);} |
|
77 |
#define __CACHE_PRINT4(t,a,b,c,d) {if (DebugReg&KCACHE) RDebug::Print(t,a,b,c,d);} |
|
78 |
#define __CACHE_PRINT5(t,a,b,c,d,e) {if (DebugReg&KCACHE) RDebug::Print(t,a,b,c,d,e);} |
|
79 |
#define __CACHE_PRINT6(t,a,b,c,d,e,f) {if (DebugReg&KCACHE) RDebug::Print(t,a,b,c,d,e,f);} |
|
80 |
#define __CACHE_PRINT7(t,a,b,c,d,e,f,g) {if (DebugReg&KCACHE) RDebug::Print(t,a,b,c,d,e,f,g);} |
|
81 |
#define __PLUGIN_PRINT(t) {if (DebugReg&KPLUGIN) RDebug::Print(t);} |
|
82 |
#define __PLUGIN_PRINT1(t,a) {if (DebugReg&KPLUGIN) RDebug::Print(t,a);} |
|
83 |
#define __PLUGIN_PRINT2(t,a,b) {if (DebugReg&KPLUGIN) RDebug::Print(t,a,b);} |
|
84 |
#define __PLUGIN_PRINT3(t,a,b,c) {if (DebugReg&KPLUGIN) RDebug::Print(t,a,b,c);} |
|
85 |
#else |
|
86 |
#define __PRINT(t) |
|
87 |
#define __PRINT1(t,a) |
|
88 |
#define __PRINT2(t,a,b) |
|
89 |
#define __PRINT3(t,a,b,c) |
|
90 |
#define __PRINT4(t,a,b,c,d) |
|
91 |
#define __IF_DEBUG(t) |
|
92 |
#define __LDRTRACE(t) |
|
93 |
#define __PRINTALLOC(t,a,b,c) {if (DebugReg&KALLOC) RDebug::Print(t,a,b,c);} |
|
94 |
#define __PRINT1TEMP(t,a) |
|
95 |
#define __PRINT2TEMP(t,a,b) |
|
96 |
#define __PRINT3TEMP(t,a,b,c) |
|
97 |
#define __PRINT4TEMP(t,a,b,c,d) |
|
98 |
#define __CALL(t) |
|
99 |
#define __THRD_PRINT(t) |
|
100 |
#define __THRD_PRINT1(t,a) |
|
101 |
#define __THRD_PRINT2(t,a,b) |
|
102 |
#define __THRD_PRINT3(t,a,b,c) |
|
103 |
#define __THRD_PRINT4(t,a,b,c,d) |
|
104 |
#define __CACHE_PRINT(t) |
|
105 |
#define __CACHE_PRINT1(t,a) |
|
106 |
#define __CACHE_PRINT2(t,a,b) |
|
107 |
#define __CACHE_PRINT3(t,a,b,c) |
|
108 |
#define __CACHE_PRINT4(t,a,b,c,d) |
|
109 |
#define __CACHE_PRINT5(t,a,b,c,d,e) |
|
110 |
#define __CACHE_PRINT6(t,a,b,c,d,e,f) |
|
111 |
#define __CACHE_PRINT7(t,a,b,c,d,e,f,g) |
|
112 |
#define __PLUGIN_PRINT(t) |
|
113 |
#define __PLUGIN_PRINT1(t,a) |
|
114 |
#define __PLUGIN_PRINT2(t,a,b) |
|
115 |
#define __PLUGIN_PRINT3(t,a,b,c) |
|
116 |
#endif |
|
117 |
||
118 |
const TInt KMaxTotalDriveReserved =0x100000; |
|
119 |
const TInt KMaxSessionDriveReserved =0x10000; |
|
120 |
||
121 |
// If TFsFileDuplciate::DoRequestL() is called a new sub-session is created and |
|
122 |
// the new sub-session handle is returned, mangled by KSubSessionMangleBit - |
|
123 |
// this is to discourage use of the duplicated handle. |
|
124 |
// If TFsFileAdopt::DoRequestL() is called then the passed sub-session handle is |
|
125 |
// assumed to be already mangled by KSubSessionMangleBit and the same sub-session |
|
126 |
// handle is returned de-mangled. |
|
127 |
const TInt KSubSessionMangleBit = 0x4000; |
|
128 |
||
129 |
||
130 |
#define __CHECK_DRIVETHREAD(d) {__ASSERT_DEBUG(FsThreadManager::IsDriveThread(d,ETrue),Fault(EFsDriveThreadError));} |
|
131 |
#define __CHECK_MAINTHREAD() {__ASSERT_DEBUG(FsThreadManager::IsMainThread(),Fault(EFsMainThreadError));} |
|
132 |
||
133 |
#define __LAZY_DLL_UNLOAD |
|
134 |
||
135 |
const TInt KMaxTempNameAttempts=50; |
|
136 |
const TInt KHeapMinSize=0x1000; |
|
137 |
const TInt KHeapMaxSize=0x400000; |
|
138 |
const TInt KLoaderStackSize=0x8000; |
|
139 |
||
140 |
//-- maximum file size that was supported before introducing File Server 64-bit addressing support. |
|
141 |
//-- It is 2G-1. Used in legacy code that does not understand RFile64 |
|
142 |
const TUint64 KMaxLegacyFileSize = 0x7fffffff; |
|
143 |
||
144 |
//-- absolute maximum file size that file server supports |
|
145 |
const TUint64 KMaxSupportedFileSize = KMaxTUint64; |
|
146 |
||
28
5b5d147c7838
Revision: 201021
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
23
diff
changeset
|
147 |
//-- this is a speculative value of a min. amount of free space on the volume necessary to create a file, directory etc. |
5b5d147c7838
Revision: 201021
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
23
diff
changeset
|
148 |
//-- it is used mostly in "reserve drive space" functionality, which is, actually, fundamentally flawed. |
5b5d147c7838
Revision: 201021
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
23
diff
changeset
|
149 |
//-- the problem is that the file server can't know exactly how much space is required to create some fs object on the volume, |
5b5d147c7838
Revision: 201021
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
23
diff
changeset
|
150 |
//-- so, it has to guess. This is a default "sector size" value; the file system can round it up internally to its cluster size if any. |
5b5d147c7838
Revision: 201021
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
23
diff
changeset
|
151 |
const TInt KMinFsCreateObjTreshold = KDefaultVolumeBlockSize; |
5b5d147c7838
Revision: 201021
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
23
diff
changeset
|
152 |
|
5b5d147c7838
Revision: 201021
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
23
diff
changeset
|
153 |
|
0 | 154 |
//__DATA_CAGING__ |
155 |
const TUint SHA1_LBLOCK=16; |
|
156 |
const TUint SHA1_HASH=20; |
|
157 |
#if defined(_DEBUG) || defined(_DEBUG_RELEASE) |
|
158 |
||
159 |
class TCorruptNameRec; |
|
160 |
class TCorruptLogRec |
|
161 |
{ |
|
162 |
public: |
|
163 |
TCorruptLogRec(); |
|
164 |
~TCorruptLogRec(); |
|
165 |
TInt Construct(TCorruptNameRec* aNameRec, TPtrC* aProcessName, TCorruptLogRec* aChain); |
|
166 |
inline TPtrC ProcessName(){return iProcessName->Des();}; |
|
167 |
static TInt GetLogRecord(TFsDebugCorruptLogRecordBuf& aLogRecord,TInt aLogRecNum); |
|
168 |
static void DestroyList(); |
|
169 |
private: |
|
170 |
HBufC* iProcessName; |
|
171 |
TCorruptNameRec* iNameRec; |
|
172 |
TCorruptLogRec* iNext; |
|
173 |
}; |
|
174 |
||
175 |
TInt OutputTraceInfo(TCorruptNameRec* aNameRec, CFsRequest* aRequest); |
|
176 |
||
177 |
class TText8FileReader |
|
178 |
{ |
|
179 |
enum {EMaxLine=1024}; |
|
180 |
public: |
|
181 |
TText8FileReader(); |
|
182 |
~TText8FileReader(); |
|
183 |
TInt Set(RFile& aFile); |
|
184 |
TInt Read(TPtr& aPtr); |
|
185 |
public: |
|
186 |
RFile iFile; |
|
187 |
TBuf8<EMaxLine> iBuf; |
|
188 |
TInt iBufPos; |
|
189 |
TText* iFileDataBuf; |
|
190 |
TInt iFileSize; |
|
191 |
}; |
|
192 |
||
193 |
class TCorruptNameRec |
|
194 |
{ |
|
195 |
public: |
|
196 |
TCorruptNameRec(); |
|
197 |
TInt Construct(TPtr* aName,TInt aReturnCode, TBool aUseOnce, TCorruptNameRec* aChain); |
|
198 |
static void ResetListConsumed(); |
|
199 |
inline TPtrC Name(){return iName->Des();}; |
|
200 |
inline TInt ReturnCode(){return iReturnCode;}; |
|
201 |
inline TBool Consumed(){return iConsumed;}; |
|
202 |
inline void SetConsumed(){iConsumed=iUseOnce;}; |
|
203 |
inline TCorruptNameRec* Next(){return iNext;}; |
|
204 |
private: |
|
205 |
HBufC* iName; |
|
206 |
TInt iReturnCode; |
|
207 |
TBool iUseOnce; |
|
208 |
TBool iConsumed; |
|
209 |
TCorruptNameRec* iNext; |
|
210 |
}; |
|
211 |
#endif |
|
212 |
// |
|
213 |
||
214 |
// |
|
215 |
_LIT(KFsClient,"FSCLIENT"); |
|
216 |
||
217 |
NONSHARABLE_CLASS(CSHA1) : public CBase |
|
218 |
{ |
|
219 |
public: |
|
220 |
static CSHA1* NewL(void); |
|
221 |
void Update(const TDesC8& aMessage); |
|
222 |
TPtrC8 Final(void); |
|
223 |
~CSHA1(void); |
|
224 |
void Reset(void); |
|
225 |
private: |
|
226 |
CSHA1(void); |
|
227 |
TUint iA; |
|
228 |
TUint iB; |
|
229 |
TUint iC; |
|
230 |
TUint iD; |
|
231 |
TUint iE; |
|
232 |
TBuf8<SHA1_HASH> iHash; |
|
233 |
TUint iNl; |
|
234 |
TUint iNh; |
|
235 |
TUint iData[SHA1_LBLOCK*5]; |
|
236 |
void DoUpdate(const TUint8* aData,TUint aLength); |
|
237 |
void DoFinal(void); |
|
238 |
void Block(); |
|
239 |
void ConstructL(void); |
|
240 |
TUint8* iTempData; |
|
241 |
}; |
|
242 |
||
243 |
enum TFsPanic |
|
244 |
{ |
|
23
1df514389a47
Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
21
diff
changeset
|
245 |
ELdrImportedOrdinalDoesNotExist, |
1df514389a47
Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
21
diff
changeset
|
246 |
ELdrHeapCorruptionOnRemove |
0 | 247 |
}; |
248 |
// |
|
249 |
enum TFsFault |
|
250 |
{ |
|
251 |
EDrvIllegalShareValue, //0 |
|
252 |
EMainCreateScheduler, |
|
253 |
EMainCreateServer, |
|
254 |
EMainStartServer, |
|
255 |
EMainCreateResources1, |
|
256 |
EMainGetLocalFileSystem, |
|
257 |
EMainGetLocalDefaultPath, |
|
258 |
EInitConnectLocalDrive, |
|
259 |
EMainCreateStartupThread1, |
|
260 |
EInitDriveMappingDriveInfo, |
|
261 |
EInitCreateDriveName, //10 |
|
262 |
EMainStartupNoEStart, |
|
263 |
ESesPathBadDrive, |
|
264 |
EFileDuplicateLock, |
|
265 |
ESysDefaultPathNotSupported, |
|
266 |
ESysAddLocalFileSystem, |
|
267 |
ESvrBadSessionIndex, |
|
268 |
EGetLocalDrive1, |
|
269 |
EGetLocalDrive2, |
|
270 |
ELdrRestartInit, |
|
271 |
ELdrRestartSemaphore, //20 |
|
272 |
EStripBackSlashBadName, |
|
273 |
EIsSubDirBadDes, |
|
274 |
ERawDiskBadAccessCount2, |
|
275 |
ERawDiskBadAccessCount1, |
|
276 |
ERawDiskBadAccessCount, |
|
277 |
EDriveNoDiskMounted, |
|
278 |
ESvrNotifierIsNULL, |
|
279 |
EMainCreateResources5, |
|
280 |
EMainCreateStartupThread2, |
|
281 |
EMainCreateStartupThread3, //30 |
|
282 |
EMainCreateStartupThread4, |
|
283 |
EMainStartupWriteToDiskSemaphore, |
|
284 |
EMainCreateResources6, |
|
285 |
EMainScanMediaDriversMem1, |
|
286 |
EMainScanMediaDriversLocation, |
|
287 |
EMainScanMediaDriversMem2, |
|
288 |
EMainScanMediaDriverConnect, |
|
289 |
EMainScanMediaDriverDirOpen, |
|
290 |
EMainScanMediaDriverDirRead, |
|
291 |
EMainLoadMediaDriver, //40 |
|
292 |
EInitCreateMediaChangeNotifier, |
|
293 |
ELdrCleanupCreate, |
|
294 |
ELdrSchedulerCreate, |
|
295 |
ELdrServerCreate, |
|
296 |
ELdrFsConnect, |
|
297 |
ELdrFsSetPath, |
|
298 |
ELdrCacheInit, |
|
299 |
ELdrSchedulerStopped, |
|
300 |
ESvrFormatOpenFailed, |
|
301 |
ESvrRawDiskOpenFailed, //50 |
|
302 |
EProxyDriveConstruction, |
|
303 |
ELocDrvInitLocalDrive, |
|
304 |
ELocDrvDismountedLocalDrive, |
|
305 |
EBaseExtConstruction, |
|
306 |
ECreateProxyDriveL, |
|
307 |
EExtensionInfoCount0, |
|
308 |
EExtensionInfoCount1, |
|
309 |
EExtensionInfoCount2, |
|
310 |
EStdChangeRequestType, |
|
311 |
EExtChangeNameLength, //60 |
|
312 |
EDiskSpaceThreshold, |
|
313 |
EDebugChangeType, |
|
314 |
EBaseQueConstruction, |
|
315 |
EChangeQueType, |
|
316 |
EDiskSpaceQueType1, |
|
317 |
EDiskSpaceQueType2, |
|
318 |
EBaseQueCancel, |
|
319 |
EDebugQueType, |
|
320 |
EBaseRequestSrc, |
|
321 |
EBaseRequestDest, //70 |
|
322 |
EBaseRequestDrive, |
|
323 |
EBaseRequestSubstedDrive, |
|
324 |
EBaseRequestSetDrive, |
|
325 |
EBaseRequestSetSubstedDrive, |
|
326 |
EBaseRequestMessage, |
|
327 |
EBaseRequestSet1, |
|
328 |
EBaseRequestSet2, |
|
329 |
EDiskSpaceQueDrive, |
|
330 |
ENotifyInfoDestructor, |
|
331 |
EChangeBadIndex, //80 |
|
332 |
EBadDiskNotifyType, |
|
333 |
EBadDebugNotifyType, |
|
334 |
EDiskChangeDrive, |
|
335 |
EBadChangeNotifyType, |
|
336 |
EDiskBadIndex1, |
|
337 |
EDiskBadIndex2, |
|
338 |
EDiskBadIndex3, |
|
339 |
ESvrFreeDiskSpace, |
|
340 |
EFsThreadBadDrvNum, |
|
341 |
EFsThreadConstructor, //90 |
|
342 |
EFsThreadDriveClose1, |
|
343 |
EFsThreadDriveClose2, |
|
344 |
EFsThreadGetThread, |
|
345 |
EMainInitialiseRomFs, |
|
346 |
EFsDriveThreadError, |
|
347 |
EFsMainThreadError, |
|
348 |
ETFsSetSubstNotNull, |
|
349 |
EMountFileSystemFSys, |
|
350 |
EDisMountFileSystemFSys, |
|
351 |
EIsValidDriveMapping, //100 |
|
352 |
EInitDriveMappingSocketNo, |
|
353 |
ECompleteNotifSocketNo, |
|
354 |
EObjRemoveContainerNotFound, |
|
355 |
EObjDestructorAccessCount, |
|
356 |
EObjDestructorContainer, |
|
357 |
EObjRemoveBadHandle, |
|
358 |
EArrayIndexOutOfRange, |
|
359 |
EObjFindBadHandle, |
|
360 |
EObjRemoveObjectNotFound, |
|
361 |
EObjFindIndexOutOfRange, //110 |
|
362 |
ESubOpenBadHandle, |
|
363 |
EMainDisconnectThread, |
|
364 |
EInternalRequestProcess, |
|
365 |
EInternalRequestComplete1, |
|
366 |
EInternalRequestComplete2, |
|
367 |
EInternalRequestComplete3, |
|
368 |
ERequestThreadDestructor, |
|
369 |
EThreadManagerInitDrive, |
|
370 |
EDriveCurrentWriteFunction, |
|
371 |
EDriveGetNotifyUser, //120 |
|
372 |
EDriveThreadWriteable, |
|
373 |
EDriveThreadNotifyUser1, |
|
374 |
EDriveThreadNotifyUser2, |
|
375 |
ERequestDestructorFree, |
|
376 |
ESessionDisconnectThread1, |
|
377 |
ESessionDisconnectThread2, |
|
378 |
EDismountFsDriveThread, |
|
379 |
EDisconnectRequestDispatch1, |
|
380 |
EDisconnectRequestDispatch2, |
|
381 |
EDisonncectRequestProcess, //130 |
|
382 |
EDispatchObjectDispatch, |
|
383 |
EDispatchObjectThread, |
|
384 |
EInternalRequestDispatch1, |
|
385 |
EInternalRequestDispatch2, |
|
386 |
EInternalRequestDispatch3, |
|
387 |
EFsObjectIxDestructor, |
|
388 |
EDisconnectRequestComplete, |
|
389 |
EMountExtensionFSys, |
|
390 |
EObjectConDestructor, |
|
391 |
EParseSubstSession, //140 |
|
392 |
ELdrGetKernelInfoFailed, |
|
393 |
EObjectIxMainThread, |
|
394 |
ESwapFileSystemNull, |
|
395 |
ESwapFileSystemMount, |
|
396 |
ESwapFileSystemRom, |
|
397 |
EReserveSpaceArithmetic, |
|
398 |
ECloseSubBadMessage, |
|
399 |
EFsCacheLockFailure, |
|
400 |
EFsPluginThreadError, |
|
401 |
EBadDismountNotifyType, //150 |
|
402 |
ENotifyDismount, |
|
403 |
EAllowDismount, |
|
404 |
ENotifyDismountCancel, |
|
405 |
EFileDuplicateAsyncReadRequest, |
|
406 |
EFileFailedToServiceAsyncReadRequest, |
|
407 |
ELdrCsIdWrap, |
|
408 |
EFileShareBadPromoteCount, |
|
409 |
EInternalRequestDispatchCancelPlugin, |
|
410 |
EMainCreateStartupThread0, |
|
411 |
ERequestAllocatorOpenSubFailed, //160 |
|
412 |
ETParsePoolGet, |
|
413 |
EInvalidDrive, |
|
414 |
ELocDrvInvalidLocalDrive, |
|
415 |
ELdrReaperCreate, |
|
416 |
ELdrReaperCleanupTimerCreate, |
|
417 |
EFsParsePoolLockFailure, |
|
418 |
ELdrReaperCantGetDriveList, |
|
419 |
EFileCacheCreateFailed, |
|
420 |
EBadOperationIndex, |
|
421 |
EBadOperationCompletionCode, //170 |
|
422 |
EReadOffsetNonZero, |
|
423 |
ETooManyOperations, |
|
424 |
EInvalidOperationIndex, |
|
425 |
EInvalidReadLength, |
|
426 |
EInvalidWriteLength, |
|
427 |
ERequestThreadNotInitialised, |
|
428 |
EMemoryInfoFailed, |
|
429 |
EMsgRestartBadFunction, |
|
430 |
EPushOpNoCallback, |
|
431 |
EFreeingMsgWithMsgOp, //180 |
|
432 |
ENotUnused, |
|
433 |
ELdrFileDataAllocInit, |
|
434 |
ELdrFileDataAllocError, |
|
435 |
EDismountLocked, |
|
436 |
EInvalidMsgState, |
|
437 |
EGetProxyDriveMapping1, |
|
438 |
EGetProxyDriveMapping2, |
|
439 |
EExtProxyDriveCaps, |
|
440 |
EIsProxyDrive, |
|
441 |
EClearProxyDriveMapping1, //190 |
|
442 |
EClearProxyDriveMapping2, |
|
443 |
ERequestQueueNotEmpty, |
|
444 |
ESetupMediaChange, |
|
445 |
ECancelNotifyChange, |
|
446 |
EPluginOpError, |
|
447 |
EBadMessageSlotIndex, |
|
448 |
EInvalidCompletionFlags, |
|
449 |
ECacheMemoryManagerCreateFailed, |
|
450 |
EFileBodyIsNull, |
|
451 |
ETraceLddLoadFailure, //200 |
|
452 |
ETooManyDrivesPerSocket, |
|
2
4122176ea935
Revision: 200948 + Removing redundant base integration tests and fixing build errors
John Imhofe <john.imhofe@nokia.com>
parents:
0
diff
changeset
|
453 |
ENotificationFault, |
4122176ea935
Revision: 200948 + Removing redundant base integration tests and fixing build errors
John Imhofe <john.imhofe@nokia.com>
parents:
0
diff
changeset
|
454 |
EFsObjectOpen |
0 | 455 |
}; |
456 |
||
457 |
||
458 |
NONSHARABLE_CLASS(CFsObjectConIx) : public CBase |
|
459 |
{ |
|
460 |
public: |
|
461 |
static CFsObjectConIx* NewL(); |
|
462 |
~CFsObjectConIx(); |
|
463 |
CFsObjectCon* CreateL(); |
|
464 |
void Remove(CFsObjectCon* aCon); |
|
465 |
protected: |
|
466 |
CFsObjectConIx(); |
|
467 |
void CreateContainerL(CFsObjectCon*& anObject); |
|
468 |
private: |
|
469 |
TInt iCount; |
|
470 |
TInt iAllocated; |
|
471 |
TInt iNextUniqueID; |
|
472 |
CFsObjectCon** iContainers; |
|
473 |
}; |
|
474 |
||
475 |
struct SFsObjectIxRec |
|
476 |
{ |
|
477 |
TInt16 instance; |
|
478 |
TInt16 uniqueID; |
|
479 |
CFsObject* obj; |
|
480 |
}; |
|
481 |
||
482 |
NONSHARABLE_CLASS(CFsObjectIx) : public CBase |
|
483 |
{ |
|
484 |
public: |
|
485 |
static CFsObjectIx* NewL(); |
|
486 |
~CFsObjectIx(); |
|
487 |
TInt AddL(CFsObject* anObj,TBool aLock); |
|
488 |
void Remove(TInt aHandle,TBool aLock); |
|
489 |
CFsObject* At(TInt aHandle,TInt aUniqueID,TBool aLock); |
|
490 |
CFsObject* At(TInt aHandle,TBool aLock); |
|
491 |
TInt At(const CFsObject* anObj,TBool aLock); |
|
492 |
CFsObject* operator[](TInt anIndex); |
|
493 |
void CloseMainThreadObjects(); |
|
494 |
inline TInt Count() const; |
|
495 |
inline TInt ActiveCount() const; |
|
496 |
inline void Lock(); |
|
497 |
inline void Unlock(); |
|
498 |
protected: |
|
499 |
CFsObjectIx(); |
|
500 |
private: |
|
501 |
TInt iNumEntries; // number of actual entries in the index |
|
502 |
TInt iHighWaterMark; // 1+highest active index |
|
503 |
TInt iAllocated; // max entries before realloc needed |
|
504 |
TInt iNextInstance; |
|
505 |
SFsObjectIxRec *iObjects; |
|
506 |
RFastLock iLock; |
|
507 |
}; |
|
508 |
||
509 |
NONSHARABLE_CLASS(CFsObjectCon) : public CBase |
|
510 |
{ |
|
511 |
protected: |
|
512 |
enum {ENotOwnerID}; |
|
513 |
public: |
|
514 |
static CFsObjectCon* NewL(); |
|
515 |
~CFsObjectCon(); |
|
516 |
void AddL(CFsObject* anObj,TBool aLock); |
|
517 |
void Remove(CFsObject* anObj,TBool aLock); |
|
518 |
CFsObject* operator[](TInt anIndex); |
|
519 |
CFsObject* At(TInt aFindHandle) const; |
|
520 |
CFsObject* AtL(TInt aFindHandle) const; |
|
521 |
TInt FindByName(TInt& aFindHandle,const TDesC& aMatch) const; |
|
522 |
inline void Lock(); |
|
523 |
inline void Unlock(); |
|
524 |
inline TInt UniqueID() const; |
|
525 |
inline TInt Count() const; |
|
526 |
protected: |
|
527 |
CFsObjectCon(TInt aUniqueID); |
|
528 |
TInt CheckUniqueName(const CFsObject* anObject) const; |
|
529 |
TBool NamesMatch(const TName& anObjectName, const CFsObject* aCurrentObject) const; |
|
530 |
public: |
|
531 |
TInt iUniqueID; |
|
532 |
TInt iCount; |
|
533 |
TInt iAllocated; |
|
534 |
CFsObject** iObjects; |
|
535 |
RFastLock iLock; |
|
536 |
friend class CFsObjectConIx; |
|
537 |
friend class CFsObject; |
|
538 |
}; |
|
539 |
||
540 |
||
541 |
NONSHARABLE_CLASS(CFsSyncMessageScheduler) : public CActive |
|
542 |
{ |
|
543 |
public: |
|
544 |
static CFsSyncMessageScheduler* NewL(); |
|
545 |
void DoCancel(); |
|
546 |
void RunL(); |
|
547 |
void Dispatch(CFsRequest* aRequest); |
|
548 |
void CompleteSessionRequests(CSessionFs* aSession, TInt aValue); |
|
549 |
private: |
|
550 |
CFsSyncMessageScheduler(); |
|
551 |
void ConstructL(); |
|
552 |
private: |
|
553 |
RThread iThread; |
|
554 |
RFastLock iLock; |
|
555 |
TDblQue<CFsRequest> iList; |
|
556 |
TBool iSignalled; |
|
557 |
}; |
|
558 |
||
559 |
||
560 |
NONSHARABLE_CLASS(CNotifyMediaChange) : public CActive |
|
561 |
{ |
|
562 |
public: |
|
563 |
CNotifyMediaChange(RLocalDrive* aDrive,TInt aSocketNo); |
|
564 |
void DoCancel() {}; |
|
565 |
void RunL(); |
|
566 |
private: |
|
567 |
RLocalDrive* iDrive; |
|
568 |
TInt iSocket; |
|
569 |
}; |
|
570 |
||
571 |
||
572 |
const TInt KMaxDrivesPerSocket=16; |
|
573 |
||
574 |
class LocalDrives |
|
575 |
{ |
|
576 |
public: |
|
577 |
static void Initialise(); |
|
578 |
static TBusLocalDrive& GetLocalDrive(TInt aDriveNumber); |
|
579 |
static CExtProxyDrive* GetProxyDrive(TInt aDrive); |
|
580 |
static TInt InitProxyDrive(CFsRequest* aRequest); |
|
581 |
static TInt MountProxyDrive(CFsRequest* aRequest); |
|
582 |
static TInt DismountProxyDrive(TInt iDriveNumber); |
|
583 |
static TBool IsValidDriveMapping(TInt aDrvNumber); |
|
584 |
static TInt DriveNumberToLocalDriveNumber(TInt aDrvNumber); |
|
585 |
static TInt SetDriveMappingL(CFsRequest* aRequest); |
|
586 |
static void CompleteNotifications(TInt aSocket); |
|
587 |
static void CompleteDriveNotifications(TInt aDriveNumber); |
|
588 |
static TInt GetLocalSocket(TInt aControllerRelativeSocket, TMediaDevice aMediaType); |
|
589 |
static TInt GetDriveFromLocalDrive(TInt aLocDrv); |
|
590 |
static TInt GetLocalDriveNumber(TBusLocalDrive* aLocDrv); |
|
591 |
static TBool IsProxyDrive(TInt aDrive); |
|
592 |
static void ClearProxyDriveMapping(TInt aDrive); |
|
593 |
static TBool IsProxyDriveInUse(CExtProxyDriveFactory* aDevice); |
|
594 |
static TInt SetupMediaChange(TInt aDrive); |
|
595 |
static void NotifyChangeCancel(TInt aDrive); |
|
596 |
private: |
|
597 |
static void InitDriveMapping(); |
|
598 |
static TInt SwapDriveMapping(TInt aFirstDrive,TInt aSecondDrive); |
|
599 |
private: |
|
600 |
class TSocketDesc |
|
601 |
{ |
|
602 |
public: |
|
603 |
TInt iDriveNumbers[KMaxDrivesPerSocket]; // drive numbers assigned to this socket |
|
604 |
CNotifyMediaChange* iMediaChanges; |
|
605 |
TMediaDevice iMediaType; |
|
606 |
TInt iControllerRelativeSocket; |
|
607 |
}; |
|
608 |
static TSocketDesc iSocketDescs[KMaxPBusSockets]; |
|
609 |
static TBusLocalDrive iLocalDrives[KMaxLocalDrives]; |
|
610 |
static TInt iMapping[KMaxDrives]; // maps drive to local drive |
|
611 |
static TBool iMappingSet; |
|
612 |
static TInt iReverseMapping[KMaxLocalDrives];// opposite mapping of iMapping. local drive to drive (1 to [potentially] many) |
|
613 |
// i.e. LocalDrive1 -> DriveX |
|
614 |
// LocalDrive2 -> DriveX |
|
615 |
static TBool iIsMultiSlotDrive[KMaxDrives]; // index is drive number |
|
616 |
static CExtProxyDrive* iProxyDriveMapping[KMaxProxyDrives]; |
|
617 |
||
618 |
friend void TFsAddCompositeMount::AddFsToCompositeMountL(TInt aDriveNumber, CFileSystem& aFileSystem, TInt aLocalDriveNumber); |
|
619 |
friend void TDrive::MultiSlotDriveCheck(); // for dual/multi slot drive map swapping. (iMapping/iReverseMapping) |
|
620 |
}; |
|
621 |
||
622 |
NONSHARABLE_CLASS(CLogon) : public CActive |
|
623 |
{ |
|
624 |
public: |
|
625 |
enum {EPriority=3000}; |
|
626 |
public: |
|
627 |
static CLogon* NewL(); |
|
628 |
TInt Logon(RThread aThread); |
|
629 |
virtual void DoCancel(); |
|
630 |
virtual void RunL(); |
|
631 |
protected: |
|
632 |
CLogon(TInt aPriority); |
|
633 |
private: |
|
634 |
RThread iThread; |
|
635 |
}; |
|
636 |
||
637 |
#ifdef __LAZY_DLL_UNLOAD |
|
638 |
NONSHARABLE_CLASS(CLazyUnloadTimer): public CTimer |
|
639 |
{ |
|
640 |
public: |
|
641 |
CLazyUnloadTimer(); |
|
642 |
~CLazyUnloadTimer(); |
|
643 |
static void New(); |
|
644 |
static void Finish(); |
|
645 |
private: |
|
646 |
void RunL(); |
|
647 |
void Start(); |
|
648 |
}; |
|
649 |
#endif |
|
650 |
||
651 |
NONSHARABLE_CLASS(CSessionLoader) : public CSession2 |
|
652 |
{ |
|
653 |
private: |
|
654 |
virtual void ServiceL(const RMessage2& aMessage); |
|
655 |
TInt DeleteExecutable(const TDesC& aName); |
|
656 |
}; |
|
657 |
||
658 |
NONSHARABLE_CLASS(CServerLoader) : public CServer2 |
|
659 |
{ |
|
660 |
public: |
|
661 |
enum {EPriority=2000}; |
|
662 |
public: |
|
663 |
static CServerLoader* New(); |
|
664 |
virtual CSession2* NewSessionL(const TVersion& aVersion,const RMessage2& aMessage) const; |
|
665 |
virtual TInt RunError(TInt aError); |
|
666 |
private: |
|
667 |
CServerLoader(TInt aPriority); |
|
668 |
}; |
|
669 |
||
670 |
class RLoaderMsg : public RMessage2 |
|
671 |
{ |
|
672 |
public: |
|
673 |
TInt GetString(HBufC8*& aBuf, TInt aParam, TInt aMaxLen, TInt aHeadroom, TBool aReduce) const; |
|
674 |
TInt GetLdrInfo(TLdrInfo& aInfo) const; |
|
675 |
TInt UpdateLdrInfo(const TLdrInfo& aInfo) const; |
|
676 |
}; |
|
677 |
||
678 |
void Fault(TFsFault aFault); |
|
679 |
||
680 |
class CSessionFs; |
|
681 |
class TOperation; |
|
682 |
class CRequestThread; |
|
683 |
||
684 |
typedef TInt (*TFsRequestFunc)(CFsRequest*); |
|
685 |
||
686 |
class TThreadTimer |
|
687 |
{ |
|
688 |
public: |
|
689 |
TThreadTimer(TInt (*aCallBackFunction)(TAny* aPtr),TAny* aPtr); |
|
690 |
||
691 |
void Start(CRequestThread* aRequestThread, TTimeIntervalMicroSeconds32 aTime); |
|
692 |
void Stop(); |
|
693 |
||
694 |
private: |
|
695 |
TTickCountQueLink iLink; |
|
696 |
TCallBack iCallBack; |
|
697 |
CRequestThread* iRequestThread; // the thread the timer is running on, NULL if timer not running |
|
698 |
||
699 |
friend class CFsDeltaTimer; |
|
700 |
}; |
|
701 |
||
702 |
// Class adapted from CDeltaTimer (but unlike CDeltaTimer, not derived from CActive). |
|
703 |
// Used to support multiple timer events in drive threads. |
|
704 |
NONSHARABLE_CLASS(CFsDeltaTimer) : public CBase |
|
705 |
{ |
|
706 |
public: |
|
707 |
static CFsDeltaTimer* New(CRequestThread& aRequestThread, TInt aPriority); |
|
708 |
~CFsDeltaTimer(); |
|
709 |
||
710 |
void Start(TThreadTimer& aEntry, TTimeIntervalMicroSeconds32 aTime); |
|
711 |
void Stop(TThreadTimer& aEntry); |
|
712 |
||
713 |
void RunL(); |
|
714 |
private: |
|
715 |
CFsDeltaTimer(CRequestThread& aRequestThread, TInt aPriority, TInt aTickPeriod); |
|
716 |
void Cancel(); |
|
717 |
void Activate(); |
|
718 |
TInt QueueLong(TTimeIntervalMicroSeconds aTimeInMicroSeconds, TThreadTimer& aEntry); |
|
719 |
private: |
|
720 |
CRequestThread& iRequestThread; |
|
721 |
TThreadId iThreadId; |
|
722 |
RTimer iTimer; |
|
723 |
TTickCountQue iQueue; |
|
724 |
const TInt iTickPeriod; |
|
725 |
TBool iQueueBusy; |
|
726 |
RFastLock iLock; |
|
727 |
TBool iRestartNeeded; // timer needs to be restarted as it was scheduled from a different thread |
|
728 |
public: |
|
729 |
TRequestStatus iStatus; |
|
730 |
}; |
|
731 |
||
732 |
||
733 |
NONSHARABLE_CLASS(CRequestThread) : public CBase |
|
734 |
{ |
|
735 |
public: |
|
736 |
TInt ThreadFunction(); |
|
737 |
void DeliverBack(CFsRequest* aRequest, TBool aLowPriority = EFalse); |
|
738 |
void DeliverFront(CFsRequest* aRequests); |
|
739 |
||
740 |
~CRequestThread(); |
|
741 |
||
742 |
CFsDeltaTimer* Timer(); |
|
743 |
||
744 |
void CompleteAllRequests(TInt aValue); |
|
745 |
protected: |
|
746 |
CRequestThread(); |
|
747 |
TInt DoStart(RThread& aThread); |
|
748 |
inline TInt Initialise(); |
|
749 |
void Deliver(CFsRequest* aRequest,TBool aIsFront, TBool aLowPriority = EFalse); |
|
750 |
void Receive(); |
|
751 |
virtual TInt DoThreadInitialise(); |
|
752 |
protected: |
|
753 |
CFsRequest* iRequest; |
|
754 |
TDblQue<CFsRequest> iList; |
|
755 |
RFastLock iListLock; |
|
756 |
TBool iIsWaiting; |
|
757 |
TBool iExit; |
|
758 |
RThread iThread; |
|
759 |
CFsDeltaTimer* iTimer; |
|
760 |
TBool iLowPriority; // if true, drive thread's priority has been (temporarily) reduced |
|
761 |
friend class CFsDeltaTimer; |
|
762 |
}; |
|
763 |
||
764 |
||
765 |
||
766 |
||
767 |
NONSHARABLE_CLASS(CDriveThread) : public CRequestThread |
|
768 |
{ |
|
769 |
public: |
|
770 |
void CompleteReadWriteRequests(); |
|
771 |
void CompleteSessionRequests(CSessionFs* aSession, TInt aValue); |
|
772 |
void CompleteClientRequests(TInt aValue); |
|
773 |
TBool IsRequestWriteable(); |
|
774 |
TBool IsSessionNotifyUser(); |
|
775 |
private: |
|
776 |
CDriveThread(); |
|
777 |
static CDriveThread* NewL(); |
|
778 |
TUint StartL(TInt aDrvNumber); |
|
779 |
TInt DoThreadInitialise(); |
|
780 |
||
781 |
void StartFinalisationTimer(); |
|
782 |
void StopFinalisationTimer(); |
|
783 |
||
784 |
static TInt FinaliseTimerEvent(TAny* aFileCache); |
|
785 |
private: |
|
786 |
TInt iDriveNumber; |
|
787 |
TThreadTimer iFinaliseTimer; |
|
788 |
||
789 |
friend class FsThreadManager; |
|
790 |
}; |
|
791 |
||
792 |
class CFsInternalRequest; |
|
793 |
||
794 |
NONSHARABLE_CLASS(CDisconnectThread) : public CRequestThread |
|
795 |
{ |
|
796 |
public: |
|
797 |
inline CFsInternalRequest* GetRequest(); |
|
798 |
private: |
|
799 |
static CDisconnectThread* NewL(); |
|
800 |
TUint StartL(); |
|
801 |
~CDisconnectThread(); |
|
802 |
private: |
|
803 |
CFsInternalRequest* iRequest; |
|
804 |
friend class FsThreadManager; |
|
805 |
}; |
|
806 |
||
807 |
class CFsPlugin; |
|
808 |
NONSHARABLE_CLASS(CPluginThread) : public CRequestThread |
|
809 |
{ |
|
810 |
public: |
|
811 |
CPluginThread(CFsPlugin& aPlugin); |
|
2
4122176ea935
Revision: 200948 + Removing redundant base integration tests and fixing build errors
John Imhofe <john.imhofe@nokia.com>
parents:
0
diff
changeset
|
812 |
~CPluginThread(); |
4122176ea935
Revision: 200948 + Removing redundant base integration tests and fixing build errors
John Imhofe <john.imhofe@nokia.com>
parents:
0
diff
changeset
|
813 |
|
0 | 814 |
void CompleteSessionRequests(CSessionFs* aSession, TInt aValue); |
815 |
||
816 |
/** @prototype */ |
|
817 |
void OperationLockWait(); |
|
818 |
||
819 |
/** @prototype */ |
|
820 |
void OperationLockSignal(); |
|
821 |
||
822 |
private: |
|
823 |
static CPluginThread* NewL(CFsPlugin& aPlugin); |
|
824 |
TUint StartL(); |
|
825 |
virtual TInt DoThreadInitialise(); |
|
826 |
private: |
|
827 |
CFsPlugin& iPlugin; |
|
828 |
||
829 |
/** @prototype */ |
|
830 |
RSemaphore iOperationLock; |
|
831 |
||
832 |
friend class FsPluginManager; |
|
833 |
}; |
|
834 |
||
835 |
class TFsDriveThread |
|
836 |
{ |
|
837 |
public: |
|
838 |
TFsDriveThread(); |
|
839 |
public: |
|
840 |
RMutex iFSLock; |
|
841 |
TBool iIsAvailable; |
|
842 |
TBool iIsSync; |
|
843 |
CDriveThread* iThread; |
|
844 |
TUint iId; |
|
845 |
TBool iIsHung; // drive is hung waiting for a critical notifier |
|
846 |
TBool iMediaChangePending; // media change is pending while hung |
|
847 |
}; |
|
848 |
||
849 |
||
850 |
class FsThreadManager |
|
851 |
{ |
|
852 |
public: |
|
853 |
static TInt CreateDisconnectThread(); |
|
854 |
static inline CDisconnectThread* GetDisconnectThread() {return(iDisconnectThread);} |
|
855 |
static TBool IsDisconnectThread(); |
|
856 |
// |
|
857 |
static void SetMainThreadId(); |
|
858 |
static TBool IsMainThread(); |
|
859 |
// |
|
860 |
static TInt InitDrive(TInt aDrvNumber,TBool aIsSync); |
|
861 |
static TInt ChangeSync(TInt aDrvNumber,TBool aIsSync); |
|
862 |
||
863 |
static TInt GetDriveThread(TInt aDrvNumber, CDriveThread** aDrvThread); |
|
864 |
static void CloseDrive(TInt aDrvNumber); |
|
865 |
static TBool IsDriveThread(TInt aDrvNumber,TBool aLock); |
|
866 |
static TBool IsDriveSync(TInt aDrvNumber,TBool aLock); |
|
867 |
static TBool IsDriveAvailable(TInt aDrvNumber,TBool aLock); |
|
868 |
static void LockDrive(TInt aDrvNumber); |
|
869 |
static void UnlockDrive(TInt aDrvNumber); |
|
870 |
static void SetDriveHung(TInt aDrvNumber, TBool aIsHung); |
|
871 |
static TBool IsDriveHung(TInt aDrvNumber); |
|
872 |
static void SetMediaChangePending(TInt aDrvNumber); |
|
873 |
static void StartFinalisationTimer(TInt aDriveNumber); |
|
874 |
static void StopFinalisationTimer(TInt aDriveNumber); |
|
875 |
private: |
|
876 |
inline static TFsDriveThread& GetFsDriveThread(TInt aDrvNumber) {return(iFsThreads[aDrvNumber]);} |
|
877 |
private: |
|
878 |
static TFsDriveThread iFsThreads[KMaxDrives]; |
|
879 |
static TUint iMainId; |
|
880 |
static CDisconnectThread* iDisconnectThread; |
|
881 |
static TUint iDisconnectThreadId; |
|
882 |
}; |
|
883 |
||
884 |
||
885 |
const TInt KReservedDriveAccessArrayGranularity = 2; |
|
886 |
||
887 |
class TReservedDriveAccess |
|
888 |
{ |
|
889 |
public: |
|
890 |
inline TReservedDriveAccess(TInt aDriveNumber); |
|
891 |
inline TReservedDriveAccess(TInt aDriveNumber, TInt aReservedSpace); |
|
892 |
private: |
|
893 |
TReservedDriveAccess(); |
|
894 |
public: |
|
895 |
TInt iDriveNumber; |
|
896 |
TInt iReservedSpace; |
|
897 |
TInt iReservedAccess; |
|
898 |
}; |
|
899 |
||
900 |
||
901 |
class CFsMessageRequest; |
|
902 |
NONSHARABLE_CLASS(CSessionFs) : public CSession2 |
|
903 |
{ |
|
904 |
public: |
|
905 |
static CSessionFs* NewL(); |
|
906 |
~CSessionFs(); |
|
907 |
virtual void CreateL(); |
|
908 |
TInt CurrentDrive(); |
|
909 |
void ServiceL(const RMessage2& aMessage); |
|
910 |
TInt CountResources(); |
|
911 |
void ResourceCountMarkStart(); |
|
912 |
void ResourceCountMarkEnd(const RMessage2& aMessage); |
|
913 |
TBool GetNotifyUser(); |
|
914 |
void SetNotifyUser(TBool aNotification); |
|
915 |
TBool IsChangeNotify(); |
|
916 |
void SetSessionFlags(TUint32 aBitsToSet, TUint32 aBitsToClear); |
|
917 |
TBool TestSessionFlags(TUint32 aFlags); |
|
918 |
void CloseRequestCountInc(); |
|
919 |
void CloseRequestCountDec(); |
|
920 |
||
921 |
// |
|
922 |
virtual void Disconnect(const RMessage2& aMessage); |
|
923 |
// |
|
924 |
inline void IncResourceCount(); |
|
925 |
inline void DecResourceCount(); |
|
926 |
inline CFsObjectIx& Handles(); |
|
927 |
inline HBufC& Path(); |
|
928 |
inline void SetPath(HBufC* aPath); |
|
929 |
inline TThreadId& ThreadId(); |
|
930 |
inline void SetThreadId(const TThreadId& aId); |
|
931 |
// |
|
932 |
TUint Reserved(TInt aDriveNumber) const; |
|
933 |
TInt SetReserved(const TInt aDriveNumber, const TInt aReservedValue); |
|
934 |
TBool ReservedAccess(TInt aDriveNumber) const; |
|
935 |
void SetReservedAccess(const TInt aDriveNumber, const TBool aReservedAccess); |
|
936 |
private: |
|
937 |
CSessionFs(); |
|
938 |
||
939 |
private: |
|
940 |
TInt iResourceCountMark; |
|
941 |
TInt iResourceCount; |
|
942 |
TInt iSessionFlags; |
|
943 |
RFastLock iSessionFlagsLock; |
|
944 |
CFsObjectIx* iHandles; |
|
945 |
HBufC* iPath; |
|
946 |
CFsMessageRequest* iDisconnectRequest; |
|
947 |
RArray<TReservedDriveAccess> iReservedDriveAccess; |
|
948 |
TThreadId iId; |
|
949 |
TInt iCloseRequestCount; // number of close requests owned by this sessions on the RequestAllocator close queue |
|
950 |
friend class CFsDisconnectRequest; |
|
951 |
}; |
|
952 |
||
953 |
NONSHARABLE_CLASS(CServerFs) : public CServer2 |
|
954 |
{ |
|
955 |
public: |
|
956 |
enum {EPriority=1000}; |
|
957 |
public: |
|
958 |
virtual ~CServerFs(); |
|
959 |
static void New(); |
|
960 |
virtual CSession2* NewSessionL(const TVersion& aVersion,const RMessage2& aMessage) const; |
|
961 |
CSessionFs* operator[](TInt anIndex); |
|
962 |
inline void SessionQueueLockWait(); |
|
963 |
inline void SessionQueueLockSignal(); |
|
964 |
protected: |
|
965 |
// from CServerFs |
|
966 |
void RunL(); |
|
967 |
||
968 |
private: |
|
969 |
CServerFs(TInt aPriority); |
|
970 |
// lock to protect iSessionQ |
|
971 |
RFastLock iSessionQueueLock; |
|
972 |
}; |
|
973 |
||
974 |
NONSHARABLE_CLASS(CActiveSchedulerFs) : public CActiveScheduler |
|
975 |
{ |
|
976 |
public: |
|
977 |
static void New(); |
|
978 |
virtual void Error(TInt anError) const; |
|
979 |
}; |
|
980 |
||
981 |
NONSHARABLE_CLASS(CActiveSchedulerLoader) : public CActiveScheduler |
|
982 |
{ |
|
983 |
public: |
|
984 |
static CActiveSchedulerLoader* New(); |
|
985 |
virtual void Error(TInt anError) const; |
|
986 |
}; |
|
987 |
||
988 |
||
989 |
class TNameChecker |
|
990 |
{ |
|
991 |
public: |
|
992 |
TNameChecker(const TDesC& aPathName): iName(aPathName){}; |
|
993 |
TBool IsIllegalChar(TText& aChar); |
|
994 |
TBool IsIllegalName(); |
|
995 |
TBool IsIllegalName(TText& aChar); |
|
996 |
TBool IsIllegalPath(); |
|
997 |
TBool IsIllegalPath(TText& aChar); |
|
998 |
void SetName(const TDesC& aName){iName=aName;}; |
|
999 |
private: |
|
1000 |
TBool IsIllegal(TText& aChar) const; |
|
1001 |
private: |
|
1002 |
TFileName iName; |
|
1003 |
TParse iParse; |
|
1004 |
}; |
|
1005 |
||
1006 |
enum TOperationFlags |
|
1007 |
{ |
|
1008 |
ESync = 0x01, |
|
1009 |
EInternalRequest = 0x02, // NB Not really used! |
|
1010 |
EParseSrc = 0x04, |
|
1011 |
EParseDst = 0x08, |
|
1012 |
EFileShare = 0x10, // Operates on an open file share |
|
1013 |
}; |
|
1014 |
||
1015 |
class TOperation |
|
1016 |
{ |
|
1017 |
public: |
|
1018 |
TBool IsChangeNotify() const; |
|
1019 |
TBool IsDiskSpaceNotify() const; |
|
1020 |
TBool IsWrite() const; |
|
1021 |
TUint NotifyType() const; |
|
1022 |
TBool IsCompleted() const; |
|
1023 |
TBool IsOpenSubSess() const; //used to allocate for close as well as open task for subsessions |
|
1024 |
TBool IsCloseSubSess() const; |
|
1025 |
||
1026 |
inline TBool IsSync() const; |
|
1027 |
inline TInt Function(); |
|
1028 |
inline TInt Initialise(CFsRequest* aRequest); |
|
1029 |
inline TInt PostInitialise(CFsRequest* aRequest); |
|
1030 |
inline TInt DoRequestL(CFsRequest* aRequest); |
|
1031 |
inline TFsPluginRequest::TF32ArgType Arg(TUint aIndex); |
|
1032 |
||
1033 |
public: |
|
1034 |
TInt iFunction; |
|
1035 |
TUint iFlags; |
|
1036 |
TFsRequestFunc iInitialise; |
|
1037 |
// optional processing step. Runs initially in context of main file server thread |
|
1038 |
// but may be executed again in drive thread context if request is postponed |
|
1039 |
TFsRequestFunc iPostInitialise; |
|
1040 |
TFsRequestFunc iDoRequestL; |
|
1041 |
TUint32 iArgs; |
|
1042 |
}; |
|
1043 |
||
1044 |
class TMsgOperation |
|
1045 |
{ |
|
1046 |
public: |
|
1047 |
inline void Set(TInt64 aPos, TInt aLength, TUint8* aData, TInt aOffset = 0, TInt aNextState = 0); |
|
1048 |
inline void Set(TInt64 aPos, TInt aLength, TDesC8* aData, TInt aOffset = 0, TInt aNextState = 0); |
|
1049 |
public: |
|
1050 |
||
1051 |
typedef struct |
|
1052 |
{ |
|
1053 |
TAny* iData; // pointer to local buffer (TUint8*) or remote client decriptor (TDesC8*) |
|
1054 |
TInt iTotalLength; |
|
1055 |
TInt64 iPos; |
|
1056 |
TInt iLength; // length of current fair-scheduled read/write |
|
1057 |
TInt iOffset; // offset into iData |
|
1058 |
} SReadWriteArgs; |
|
1059 |
||
1060 |
union |
|
1061 |
{ |
|
1062 |
TInt iArgs[KMaxMessageArguments]; |
|
1063 |
SReadWriteArgs iReadWriteArgs; |
|
1064 |
}; |
|
1065 |
||
1066 |
TInt iFunction; // the current function (usually, but not always the same as TOperation.iFunction |
|
1067 |
TFsRequestFunc iComplete; // function to call when CFsMessageRequest::Complete() is called |
|
1068 |
CFsPlugin* iCurrentPlugin; // The current plugin at the stage this Operation was pushed |
|
1069 |
||
1070 |
TBool iClientRequest; // The current request originated through RFile/RFilePlugin, so uses a descriptor buffer: |
|
1071 |
// An EFSRV client request non-local handle non-local buffer descriptor |
|
1072 |
// A plugin request local handle local buffer descriptor |
|
1073 |
// An internal (cache) request local handle local buffer raw pointer |
|
1074 |
TInt iState; |
|
1075 |
TMsgOperation* iNext; |
|
1076 |
TMsgOperation* iPrev; |
|
1077 |
TBool iIsAllocated; |
|
1078 |
TAny* iScratchValue0; |
|
1079 |
TAny* iScratchValue1; |
|
1080 |
TInt64 iClientPosition; |
|
1081 |
}; |
|
1082 |
||
1083 |
||
1084 |
||
1085 |
NONSHARABLE_CLASS(CFsRequest) : public CBase |
|
1086 |
{ |
|
1087 |
public: |
|
1088 |
/** Request states - these indicate a message's current stage of processing |
|
1089 |
*/ |
|
1090 |
enum TReqStates |
|
1091 |
{ |
|
1092 |
/** Need to call iOperation.iInitialise() */ |
|
1093 |
EReqStateInitialise, |
|
1094 |
/** Need to call PostInitialise() */ |
|
1095 |
EReqStatePostInitialise, |
|
1096 |
/** Need to call iOperation.iDoRequestL */ |
|
1097 |
EReqStateDoRequest, |
|
1098 |
}; |
|
1099 |
||
1100 |
||
1101 |
/** |
|
1102 |
Request actions - these indicate what further processing is required |
|
1103 |
and may be returned by any of: |
|
1104 |
||
1105 |
CFsRequest::iOperation->Initialise() |
|
1106 |
CFsPlugin::DoRequestL() |
|
1107 |
CFsMessageRequest::iOperation->iPostInitialise() |
|
1108 |
CFsRequest::iOperation->DoRequestL() |
|
1109 |
CFsMessageRequest::iCurrentOperation->iComplete() |
|
1110 |
||
1111 |
The last 3 bits of each return code are used in CFsMessageRequest::Complete() |
|
1112 |
as an array look up to determine what action to take |
|
1113 |
*/ |
|
1114 |
enum TReqActions |
|
1115 |
{ |
|
1116 |
/** |
|
1117 |
Continue with processing, dispatching to drive thread if necessary |
|
1118 |
NB same value as KErrNone to maintain compatibility with existing code |
|
1119 |
*/ |
|
1120 |
EReqActionContinue = KErrNone, // 0x00000000, last 3 bits = 0 |
|
1121 |
||
1122 |
/** |
|
1123 |
Complete and free the message |
|
1124 |
*/ |
|
1125 |
EReqActionComplete = KErrCompletion, // 0xFFFFFFEF, last 3 bits = 7 |
|
1126 |
||
1127 |
/** |
|
1128 |
A resource is in use, so dispatch message again to back of drive thread's request queue |
|
1129 |
If returned by Initialise(), then Initialse() will be called again |
|
1130 |
If returned by Complete(), then iPostInitialise() will be called again |
|
1131 |
*/ |
|
1132 |
EReqActionBusy = -0x1002, // 0xFFFFEFFE, last 3 bits = 6 |
|
1133 |
||
1134 |
/** |
|
1135 |
Neither dispatch nor complete the message - |
|
1136 |
a plugin thread has taken ownership of the message |
|
1137 |
*/ |
|
1138 |
EReqActionOwnedByPlugin = -0x1003, // 0xFFFFEFFD, last 3 bits = 5 |
|
1139 |
||
1140 |
/** |
|
1141 |
The request cannot be processed because there is already an active read/write request |
|
1142 |
for the associated file share. This request has been linked to the currently active |
|
1143 |
request and will be dispatched to the the drive thread when the current request has completed. |
|
1144 |
@see CFileShare::RequestStart() & CFileShare::RequestEnd() |
|
1145 |
*/ |
|
1146 |
EReqActionPending = EReqActionOwnedByPlugin, |
|
1147 |
}; |
|
1148 |
public: |
|
1149 |
~CFsRequest(); |
|
1150 |
||
1151 |
void ReadL(const TInt aMsgNum,TDes8& aDes); |
|
1152 |
void ReadL(const TInt aMsgNum,TDes8& aDes,TInt anOffset); |
|
1153 |
void ReadL(const TInt aMsgNum,TDes16& aDes); |
|
1154 |
void ReadL(const TInt aMsgNum,TDes16& aDes,TInt anOffset); |
|
1155 |
||
1156 |
void WriteL(const TInt aMsgNum,const TDesC8& aDes); |
|
1157 |
void WriteL(const TInt aMsgNum,const TDesC8& aDes,TInt anOffset); |
|
1158 |
void WriteL(const TInt aMsgNum,const TDesC16& aDes); |
|
1159 |
void WriteL(const TInt aMsgNum,const TDesC16& aDes,TInt anOffset); |
|
1160 |
||
1161 |
TInt Read(const TInt aMsgNum,TDes8& aDes); |
|
1162 |
TInt Read(const TInt aMsgNum,TDes8& aDes,TInt anOffset); |
|
1163 |
TInt Read(const TInt aMsgNum,TDes16& aDes); |
|
1164 |
TInt Read(const TInt aMsgNum,TDes16& aDes,TInt anOffset); |
|
1165 |
||
1166 |
TInt Write(const TInt aMsgNum,const TDesC8& aDes); |
|
1167 |
TInt Write(const TInt aMsgNum,const TDesC8& aDes,TInt anOffset); |
|
1168 |
TInt Write(const TInt aMsgNum,const TDesC16& aDes); |
|
1169 |
TInt Write(const TInt aMsgNum,const TDesC16& aDes,TInt anOffset); |
|
1170 |
||
1171 |
TInt GetDesLength(const TInt aMsgNum); |
|
1172 |
||
1173 |
inline void Kill(TInt aReason); |
|
1174 |
inline void Terminate(TInt aReason); |
|
1175 |
inline void Panic(const TDesC &aCategory,TInt aReason); |
|
1176 |
inline TBool ErrorPlugin(TInt aReason); |
|
1177 |
||
1178 |
TInt Read(TFsPluginRequest::TF32ArgType aType, TInt& aVal); |
|
1179 |
TInt Read(TFsPluginRequest::TF32ArgType aType, TUint& aVal); |
|
1180 |
TInt Read(TFsPluginRequest::TF32ArgType aType, TInt64& aVal); |
|
1181 |
// |
|
1182 |
TInt Read(TFsPluginRequest::TF32ArgType aType, TDes8& aDes, TInt aOffset = 0); |
|
1183 |
TInt Read(TFsPluginRequest::TF32ArgType aType, TDes16& aDes, TInt aOffset = 0); |
|
1184 |
// |
|
1185 |
TInt Write(TFsPluginRequest::TF32ArgType aType, const TDesC8& aDes, TInt aOffset = 0); |
|
1186 |
TInt Write(TFsPluginRequest::TF32ArgType aType, const TDesC16& aDes, TInt aOffset = 0); |
|
1187 |
||
1188 |
inline TInt Initialise(){return iOperation->Initialise(this);}; |
|
1189 |
virtual void Process()=0; |
|
1190 |
virtual void Complete(TInt aError)=0; |
|
1191 |
virtual void Dispatch()=0; |
|
1192 |
virtual void Free()=0; |
|
1193 |
// |
|
1194 |
virtual TParse& Src(); |
|
1195 |
virtual TParse& Dest(); |
|
1196 |
virtual TDrive* Drive(); |
|
1197 |
virtual TDrive* SubstedDrive(); |
|
1198 |
virtual void SetDrive(TDrive* aDrive); |
|
1199 |
virtual void SetSubstedDrive(TDrive* aDrive); |
|
1200 |
virtual const RMessage2& Message(); |
|
1201 |
// |
|
1202 |
inline TOperation* Operation(); |
|
1203 |
inline CSessionFs* Session(); |
|
1204 |
inline void SetSession(CSessionFs* aSession); |
|
1205 |
inline TInt DriveNumber(); |
|
1206 |
inline void SetDriveNumber(TInt aDriveNumber); |
|
1207 |
inline TBool IsCompleted(); |
|
1208 |
inline void SetCompleted(TBool aIsCompleted); |
|
1209 |
inline TUint ScratchValue(); |
|
1210 |
inline void SetScratchValue(const TUint aValue); |
|
1211 |
inline TInt64 ScratchValue64(); |
|
1212 |
inline void SetScratchValue64(const TInt64& aValue); |
|
1213 |
inline TBool IsSeparateThread(); |
|
1214 |
inline TBool IsPostOperation() const; |
|
1215 |
inline TBool IsPluginSpecific() const; |
|
1216 |
inline TBool IsExpectedResult(TInt err) const; |
|
1217 |
inline TBool IsChangeNotify() const; |
|
1218 |
inline void SetState(TReqStates aReqState); |
|
1219 |
inline TBool DirectToDrive(); |
|
1220 |
inline TBool IsDescData(TInt aMsgNum); |
|
1221 |
inline TInt FsFunction(); |
|
1222 |
||
1223 |
public: |
|
1224 |
CFsRequest(); |
|
1225 |
protected: |
|
1226 |
inline void Set(const TOperation& aOperation,CSessionFs* aSession); |
|
1227 |
inline void Set(CSessionFs* aSession); |
|
1228 |
inline void SetError(TInt aError); |
|
1229 |
inline TInt GetError() const; |
|
1230 |
inline void SetPostOperation(TBool aSet); |
|
1231 |
||
1232 |
inline TBool IsFsObjectOpen(); |
|
1233 |
inline void SetFsObjectOpen(TBool aSet); |
|
1234 |
void SetAndOpenScratchValue(const TInt64& aValue); |
|
1235 |
||
1236 |
private: |
|
1237 |
TInt GetSlot(TFsPluginRequest::TF32ArgType aType); |
|
1238 |
public: |
|
1239 |
TDblQueLink iLink; |
|
1240 |
CFsPlugin* iCurrentPlugin; |
|
1241 |
CFsPlugin* iOwnerPlugin; // the plugin which originated this request |
|
1242 |
TThreadId iClientThreadId; |
|
1243 |
TBool iDirectToDrive; |
|
1244 |
protected: |
|
1245 |
CSessionFs* iSession; |
|
1246 |
TOperation* iOperation; |
|
1247 |
TInt iDriveNumber; |
|
1248 |
TBool iIsCompleted; |
|
1249 |
TInt64 iScratchValue; |
|
1250 |
||
1251 |
TReqStates iReqState; |
|
1252 |
||
1253 |
/** defines for iFlags |
|
1254 |
*/ |
|
1255 |
enum TFsRequestFlags |
|
1256 |
{ |
|
1257 |
EIsAllocated = 0x01, |
|
1258 |
EFreeChanged = 0x02, // valid only for EFsFileWrite |
|
1259 |
EPostInterceptEnabled = 0x04, |
|
1260 |
EPostOperation = 0x08, |
|
1261 |
EFsObjectOpen = 0x10, |
|
1262 |
}; |
|
1263 |
TUint iFlags; |
|
1264 |
||
1265 |
TInt iError; |
|
1266 |
}; |
|
1267 |
||
1268 |
const TInt KOperationFunctionUnaltered = -1; |
|
1269 |
||
1270 |
NONSHARABLE_CLASS(CFsMessageRequest) : public CFsRequest |
|
1271 |
{ |
|
1272 |
public: |
|
1273 |
void Set(const RMessage2& aMessage,CSessionFs* aSession); |
|
1274 |
void Set(const RMessage2& aMessage,const TOperation& aOperation,CSessionFs* aSession); |
|
1275 |
void Set(const TOperation& aOperation); |
|
1276 |
inline void SetPostInitialise(TFsRequestFunc aCacheFunction); |
|
1277 |
// |
|
1278 |
inline void SetMessage(RMessage2& aMessage); |
|
1279 |
// |
|
1280 |
virtual void Process(); |
|
1281 |
virtual void Complete(TInt aError); |
|
1282 |
||
1283 |
virtual void Dispatch(); |
|
1284 |
virtual void Free(); |
|
1285 |
virtual TDrive* Drive(); |
|
1286 |
virtual TDrive* SubstedDrive(); |
|
1287 |
virtual void SetDrive(TDrive* aDrive); |
|
1288 |
virtual void SetSubstedDrive(TDrive* aDrive); |
|
1289 |
virtual const RMessage2& Message(); |
|
1290 |
||
1291 |
inline TBool IsFreeChanged(); |
|
1292 |
inline void SetFreeChanged(TBool aChanged); |
|
1293 |
||
1294 |
inline TBool PostInterceptEnabled(); |
|
1295 |
inline void EnablePostIntercept(TBool aEnable); |
|
1296 |
||
1297 |
inline TBool IsAllocated(); |
|
1298 |
inline void SetAllocated(); |
|
1299 |
inline CFsMessageRequest(); |
|
1300 |
||
1301 |
TInt PushOperation(TInt64 aPos, TInt aLength, TUint8* aData, TInt aOffset = 0, TFsRequestFunc aCallback = NULL, TInt aNextState = 0, TInt aFunction = KOperationFunctionUnaltered); |
|
1302 |
TInt PushOperation(TInt64 aPos, TInt aLength, TDesC8* aData, TInt aOffset = 0, TFsRequestFunc aCallback = NULL, TInt aNextState = 0, TInt aFunction = KOperationFunctionUnaltered); |
|
1303 |
TInt PushOperation(TFsRequestFunc aCallback = NULL, TInt aNextState = 0, TInt aFunction = KOperationFunctionUnaltered); |
|
1304 |
void PopOperation(); |
|
1305 |
void SetOperationFunc(TInt aFunction); |
|
1306 |
TMsgOperation& CurrentOperation(); |
|
1307 |
inline TMsgOperation* CurrentOperationPtr(); |
|
1308 |
void Dispatch(TBool aInitialise, TBool aLowPriority = EFalse, TBool aDispatchToFront = EFalse); |
|
1309 |
||
1310 |
inline TInt& LastError(); |
|
1311 |
inline void SetLastError(TInt aLastError); |
|
1312 |
inline void Init(); |
|
1313 |
void ReStart(); |
|
1314 |
TBool IsPluginRequest(); |
|
1315 |
||
1316 |
// UID of the process to touching the file. (To be used in notification framework). |
|
1317 |
// TUid iUID; |
|
1318 |
private: |
|
1319 |
void DoNotify(TInt aError); |
|
1320 |
TInt DoInitialise(); |
|
1321 |
TInt PostInitialise(); |
|
1322 |
TBool DispatchToPlugin(); |
|
1323 |
void ProcessPostOperation(); |
|
1324 |
void ProcessPreOperation(); |
|
1325 |
void ProcessDriveOperation(); |
|
1326 |
TBool CurrentPluginWaiting(); |
|
1327 |
inline TInt DispatchToDrive(TBool aLowPriority, TBool aDispatchToFront); |
|
1328 |
TBool IsNotifierSpecific() const; |
|
1329 |
TBool IsNotifierSupported() const; |
|
1330 |
protected: |
|
1331 |
RMessage2 iMessage; |
|
1332 |
TDrive* iDrive; |
|
1333 |
TDrive* iSubstedDrive; |
|
1334 |
private: |
|
1335 |
TMsgOperation* iCurrentOperation; |
|
1336 |
TInt iLastError; |
|
1337 |
}; |
|
1338 |
||
1339 |
||
1340 |
NONSHARABLE_CLASS(TParsePool) |
|
1341 |
{ |
|
1342 |
private: |
|
1343 |
enum {KEBlockSize = 4}; |
|
1344 |
||
1345 |
public: |
|
1346 |
static TInt Init(); |
|
1347 |
static TParsePool* Get(); |
|
1348 |
static void Release(TParsePool* aObject); |
|
1349 |
TParsePool (); |
|
1350 |
TParse& GetObject() {return iObject;}; |
|
1351 |
||
1352 |
private: |
|
1353 |
TParsePool* iNext; |
|
1354 |
TParsePool* iPrev; |
|
1355 |
||
1356 |
TBool iFree; |
|
1357 |
TParse iObject; |
|
1358 |
static TParsePool* iFreeHead; |
|
1359 |
static TParsePool* iClosedHead; |
|
1360 |
static TInt iCountFree; |
|
1361 |
static RFastLock iLock; |
|
1362 |
}; |
|
1363 |
||
1364 |
||
1365 |
NONSHARABLE_CLASS(CFsClientMessageRequest) : public CFsMessageRequest |
|
1366 |
{ |
|
1367 |
public: |
|
1368 |
CFsClientMessageRequest(); |
|
1369 |
virtual TParse& Src(); |
|
1370 |
virtual TParse& Dest(); |
|
1371 |
virtual void Free(); |
|
1372 |
TInt AllocParseObjects(const TOperation& aOperation); |
|
1373 |
public: |
|
1374 |
CFsClientMessageRequest* iNext; |
|
1375 |
protected: |
|
1376 |
TParsePool* iPoolSrc; |
|
1377 |
TParsePool* iPoolDest; |
|
1378 |
}; |
|
1379 |
||
1380 |
NONSHARABLE_CLASS(CFsDisconnectRequest) : public CFsMessageRequest |
|
1381 |
{ |
|
1382 |
public: |
|
1383 |
virtual void Process(); |
|
1384 |
virtual void Dispatch(); |
|
1385 |
virtual void Complete(TInt aError); |
|
1386 |
}; |
|
1387 |
||
1388 |
NONSHARABLE_CLASS(CFsInternalRequest) : public CFsRequest |
|
1389 |
{ |
|
1390 |
public: |
|
1391 |
CFsInternalRequest(); |
|
1392 |
void Set(const TOperation& aOperation,CSessionFs* aSession); |
|
1393 |
// |
|
1394 |
inline void SetThreadHandle(TInt aThreadHandle); |
|
1395 |
inline TInt ThreadHandle(); |
|
1396 |
inline TRequestStatus& Status(); |
|
1397 |
inline TBool IsAllocated(); |
|
1398 |
inline void SetAllocated(); |
|
1399 |
// |
|
1400 |
virtual void Process(); |
|
1401 |
virtual void Complete(TInt aError); |
|
1402 |
virtual void Dispatch(); |
|
1403 |
virtual void Free(); |
|
1404 |
private: |
|
1405 |
TUint iThreadHandle; |
|
1406 |
TRequestStatus iStatus; |
|
1407 |
TBool iIsAllocated; |
|
1408 |
}; |
|
21
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1409 |
|
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1410 |
// If the number of requests on the free queue reaches this value then completed requests |
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1411 |
// are returned to the heap rather than being added to thefree queue |
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1412 |
const TInt KFreeCountMax = 64; |
0 | 1413 |
|
1414 |
class TParseCon |
|
1415 |
{ |
|
1416 |
public: |
|
1417 |
TParse iParse; |
|
1418 |
TParseCon* iNext; |
|
1419 |
}; |
|
1420 |
||
1421 |
||
1422 |
class RequestAllocator |
|
1423 |
{ |
|
1424 |
public: |
|
21
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1425 |
static TInt Initialise(); |
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1426 |
|
0 | 1427 |
static TInt GetMessageRequest(const TOperation& aOperation,const RMessage2& aMessage,CFsClientMessageRequest* &aRequest); |
21
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1428 |
static void FreeRequest(CFsClientMessageRequest* aRequest); |
0 | 1429 |
static void OpenSubFailed(CSessionFs* aSession); |
21
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1430 |
|
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1431 |
#if defined(_USE_CONTROLIO) || defined(_DEBUG) || defined(_DEBUG_RELEASE) |
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1432 |
inline static TInt RequestCount(); |
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1433 |
inline static TInt RequestCountPeak(); |
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1434 |
static TInt CloseCount(); |
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1435 |
static TInt FreeCount(); |
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1436 |
#endif |
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1437 |
|
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1438 |
private: |
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1439 |
static CFsClientMessageRequest* GetRequest(); |
0 | 1440 |
|
21
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1441 |
private: |
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1442 |
static RFastLock iCacheLock; |
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1443 |
static CFsClientMessageRequest* iFreeHead; |
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1444 |
static CFsClientMessageRequest* iCloseHead; |
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1445 |
|
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1446 |
static TInt iRequestCount; // current number of requests |
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1447 |
static TInt iFreeCount; // current number of requests on free queue |
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1448 |
static TInt iRequestCountPeak; // maximum value of requests reached |
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1449 |
}; |
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1450 |
|
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1451 |
class OperationAllocator |
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1452 |
{ |
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1453 |
public: |
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1454 |
static TInt Initialise(); |
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1455 |
|
0 | 1456 |
static TInt GetOperation(TMsgOperation* &aOperation); |
1457 |
static void FreeOperation(TMsgOperation* aOperation); |
|
1458 |
||
1459 |
#if defined(_USE_CONTROLIO) || defined(_DEBUG) || defined(_DEBUG_RELEASE) |
|
21
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1460 |
inline static TInt RequestCount(); |
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1461 |
inline static TInt RequestCountPeak(); |
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1462 |
inline static TInt FreeCount(); |
0 | 1463 |
#endif |
21
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1464 |
|
0 | 1465 |
private: |
21
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1466 |
static RFastLock iCacheLock; |
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1467 |
static TMsgOperation* iFreeHead; |
0 | 1468 |
|
21
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1469 |
static TInt iRequestCount; // current number of requests |
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1470 |
static TInt iFreeCount; // current number of requests on free queue |
e7d2d738d3c2
Revision: 201010
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
19
diff
changeset
|
1471 |
static TInt iRequestCountPeak; // maximum value of requests reached |
0 | 1472 |
}; |
1473 |
||
1474 |
||
1475 |
NONSHARABLE_CLASS(CNotifyInfo) : public CBase |
|
1476 |
{ |
|
1477 |
public: |
|
1478 |
||
1479 |
enum TInfoType {EDiskSpace,EStdChange,EExtChange,EDebugChange,EDismount}; |
|
1480 |
||
1481 |
public: |
|
1482 |
~CNotifyInfo(); |
|
1483 |
void Initialise(TInfoType aType,TRequestStatus* aStatus,const RMessagePtr2& aMessage,CSessionFs* aSession); |
|
1484 |
void Complete(TInt aError); |
|
1485 |
// |
|
1486 |
inline CSessionFs* Session(); |
|
1487 |
inline TRequestStatus* Status(); |
|
1488 |
inline TInfoType Type() const {return(iType);} |
|
1489 |
public: |
|
1490 |
TDblQueLink iLink; |
|
1491 |
protected: |
|
1492 |
TInfoType iType; |
|
1493 |
TRequestStatus* iStatus; |
|
1494 |
RMessagePtr2 iMessage; |
|
1495 |
CSessionFs* iSession; |
|
1496 |
}; |
|
1497 |
||
1498 |
||
1499 |
NONSHARABLE_CLASS(CStdChangeInfo) : public CNotifyInfo |
|
1500 |
{ |
|
1501 |
public: |
|
1502 |
void Initialise(TNotifyType aChangeType,TRequestStatus* aStatus,const RMessagePtr2& aMessage,CSessionFs* aSession); |
|
1503 |
TUint RequestNotifyType(CFsRequest* aRequest); |
|
1504 |
TBool IsMatching(CFsRequest* aRequest); |
|
1505 |
protected: |
|
1506 |
TNotifyType iChangeType; |
|
1507 |
}; |
|
1508 |
||
1509 |
NONSHARABLE_CLASS(CExtChangeInfo) : public CStdChangeInfo |
|
1510 |
{ |
|
1511 |
public: |
|
1512 |
void Initialise(TNotifyType aChangeType,TRequestStatus* aStatus,const RMessagePtr2& aMessage,CSessionFs* aSession,const TDesC& aName); |
|
1513 |
TBool IsMatching(CFsRequest* aRequest); |
|
1514 |
private: |
|
1515 |
TFileName iName; |
|
1516 |
}; |
|
1517 |
||
1518 |
NONSHARABLE_CLASS(CDiskSpaceInfo) : public CNotifyInfo |
|
1519 |
{ |
|
1520 |
public: |
|
1521 |
void Initialise(TRequestStatus* aStatus,const RMessagePtr2& aMessage,CSessionFs* aSession,TInt64 aThreshold); |
|
1522 |
TBool IsMatching(TInt64& aBefore,TInt64& aAfter); |
|
1523 |
private: |
|
1524 |
TInt64 iThreshold; |
|
1525 |
}; |
|
1526 |
||
1527 |
NONSHARABLE_CLASS(CDebugChangeInfo) : public CNotifyInfo |
|
1528 |
{ |
|
1529 |
public: |
|
1530 |
void Initialise(TUint aDebugType,TRequestStatus* iStatus,const RMessagePtr2& aMessage,CSessionFs* aSession); |
|
1531 |
TBool IsMatching(TUint aChange); |
|
1532 |
private: |
|
1533 |
TUint iDebugType; |
|
1534 |
}; |
|
1535 |
||
1536 |
NONSHARABLE_CLASS(CDismountNotifyInfo) : public CNotifyInfo |
|
1537 |
{ |
|
1538 |
public: |
|
1539 |
~CDismountNotifyInfo(); |
|
1540 |
void Initialise(TNotifyDismountMode aMode, TInt aDriveNumber,TRequestStatus* iStatus,const RMessagePtr2& aMessage,CSessionFs* aSession); |
|
1541 |
TBool IsMatching(TNotifyDismountMode aMode, TInt aDriveNumber, CSessionFs* aSession); |
|
19
4a8fed1c0ef6
Revision: 201007
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
2
diff
changeset
|
1542 |
inline TInt DriveNumber() {return iDriveNumber;} |
0 | 1543 |
private: |
1544 |
TNotifyDismountMode iMode; |
|
1545 |
TInt iDriveNumber; |
|
1546 |
}; |
|
1547 |
||
1548 |
const TInt KMaxNotifyQues=KMaxDrives+1; |
|
1549 |
const TInt KMaxDiskQues=KMaxDrives; |
|
1550 |
||
1551 |
class TBaseQue |
|
1552 |
{ |
|
1553 |
protected: |
|
1554 |
TBaseQue(); |
|
1555 |
~TBaseQue(); |
|
1556 |
void DoAddNotify(CNotifyInfo* aInfo); |
|
1557 |
TBool DoCancelSession(CSessionFs* aSession,TInt aCompletionCode,TRequestStatus* aStatus=NULL); |
|
1558 |
void DoCancelAll(TInt aCompletionCode); |
|
19
4a8fed1c0ef6
Revision: 201007
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
2
diff
changeset
|
1559 |
CNotifyInfo* DoFindEntry(CSessionFs* aSession, TRequestStatus* aStatus=NULL); |
0 | 1560 |
TBool IsEmpty(); |
1561 |
protected: |
|
1562 |
TDblQue<CNotifyInfo> iHeader; |
|
1563 |
RFastLock iQLock; |
|
1564 |
}; |
|
1565 |
||
1566 |
class TChangeQue :public TBaseQue |
|
1567 |
{ |
|
1568 |
public: |
|
1569 |
TInt AddNotify(CNotifyInfo* aInfo); |
|
1570 |
TBool CancelSession(CSessionFs* aSession,TInt aCompletionCode,TRequestStatus* aStatus=NULL); |
|
1571 |
void CancelAll(TInt aCompletionCode); |
|
1572 |
void CheckChange(CFsRequest* aRequest); |
|
1573 |
TBool IsEmpty(); |
|
1574 |
}; |
|
1575 |
||
1576 |
class TDiskSpaceQue : public TBaseQue |
|
1577 |
{ |
|
1578 |
public: |
|
1579 |
inline void SetDriveNumber(TInt aDriveNumber) {iDriveNumber=aDriveNumber;} |
|
1580 |
TInt AddNotify(CNotifyInfo* aInfo); |
|
1581 |
TInt CancelSession(CSessionFs* aSession,TInt aCompletionCode,TRequestStatus* aStatus=NULL); |
|
1582 |
void CancelAll(TInt aCompletionCode); |
|
1583 |
void CheckDiskSpace(); |
|
1584 |
void CheckDiskSpace(TInt64& aFreeDiskSpace); |
|
1585 |
TBool IsEmpty(); |
|
1586 |
private: |
|
1587 |
TInt GetFreeDiskSpace(TInt64& aFreeDiskSpace); |
|
1588 |
private: |
|
1589 |
TInt64 iFreeDiskSpace; |
|
1590 |
TInt iDriveNumber; |
|
1591 |
TInt64 iReservedDiskSpace; |
|
1592 |
}; |
|
1593 |
||
1594 |
class TDebugQue : public TBaseQue |
|
1595 |
{ |
|
1596 |
public: |
|
1597 |
TInt AddNotify(CNotifyInfo* aInfo); |
|
1598 |
TInt CancelSession(CSessionFs* aSession,TInt aCompletionCode,TRequestStatus* aStatus=NULL); |
|
1599 |
void CancelAll(TInt aCompletionCode); |
|
1600 |
void CheckDebug(TUint aDebugChange); |
|
1601 |
}; |
|
1602 |
||
1603 |
class TDismountNotifyQue : public TBaseQue |
|
1604 |
{ |
|
1605 |
public: |
|
1606 |
TInt AddNotify(CNotifyInfo* aInfo); |
|
1607 |
TInt CancelSession(CSessionFs* aSession,TInt aCompletionCode,TRequestStatus* aStatus=NULL); |
|
1608 |
void CancelAll(TInt aCompletionCode); |
|
1609 |
void CheckDismount(TNotifyDismountMode aMode, TInt aDrive, TBool aRemove, TInt aError); |
|
1610 |
TBool HandlePendingDismount(CSessionFs* aSession, TInt aDrive); |
|
1611 |
}; |
|
1612 |
||
1613 |
class FsNotify |
|
1614 |
{ |
|
1615 |
public: |
|
1616 |
static void Initialise(); |
|
1617 |
static TInt AddChange(CNotifyInfo* aInfo,TInt aDrive); |
|
1618 |
static TInt AddDiskSpace(CNotifyInfo* aDiskInfo,TInt aDrive); |
|
1619 |
static TInt AddDebug(CNotifyInfo* aDebugInfo); |
|
1620 |
static TInt AddDismountNotify(CNotifyInfo* aDismountNotifyInfo); |
|
1621 |
static void DiskChange(TInt aDrive); |
|
1622 |
static void HandleChange(CFsRequest* aRequest,TInt aDrive); |
|
1623 |
static void HandleDiskSpace(CFsRequest* aRequest,TInt aDrive); |
|
1624 |
static void HandleDiskSpace(TInt aDrive, TInt64& aFreeSpace); |
|
1625 |
static void HandleDebug(TUint aFunction); |
|
1626 |
static void HandleDismount(TNotifyDismountMode aMode, TInt aDrive, TBool aRemove, TInt err); |
|
1627 |
static void CancelChangeSession(CSessionFs* aSession,TRequestStatus* aStatus=NULL); |
|
1628 |
static void CancelDiskSpaceSession(CSessionFs* aSession,TRequestStatus* aStatus=NULL); |
|
1629 |
static void CancelDebugSession(CSessionFs* aSession, TRequestStatus* aStatus=NULL); |
|
19
4a8fed1c0ef6
Revision: 201007
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
2
diff
changeset
|
1630 |
static TInt CancelDismountNotifySession(CSessionFs* aSession, TRequestStatus* aStatus=NULL); |
0 | 1631 |
static void CancelSession(CSessionFs* aSession); |
1632 |
static TBool HandlePendingDismount(CSessionFs* aSession, TInt aDriveNumber); |
|
1633 |
static TBool IsChangeQueEmpty(TInt aDrive); |
|
1634 |
static TBool IsDiskSpaceQueEmpty(TInt aDrive); |
|
1635 |
private: |
|
1636 |
static TInt ChangeIndex(TInt aDrive); |
|
1637 |
private: |
|
1638 |
static TChangeQue iChangeQues[KMaxNotifyQues]; |
|
1639 |
static TDiskSpaceQue iDiskSpaceQues[KMaxDiskQues]; |
|
1640 |
static TDebugQue iDebugQue; |
|
1641 |
static TDismountNotifyQue iDismountNotifyQue; |
|
1642 |
}; |
|
1643 |
||
1644 |
class CObjPromotion : public CFsObject |
|
1645 |
{ |
|
1646 |
public: |
|
1647 |
TInt UniqueID() const {return(CFsObject::UniqueID());} |
|
1648 |
}; |
|
1649 |
||
1650 |
NONSHARABLE_CLASS(CKernEventNotifier) : public CActive |
|
1651 |
{ |
|
1652 |
public: |
|
1653 |
static CKernEventNotifier* New(TInt aPriority=EPriorityStandard); |
|
1654 |
~CKernEventNotifier(); |
|
1655 |
void Start(); |
|
1656 |
inline TInt Change() const {return iChange;} |
|
1657 |
private: |
|
1658 |
CKernEventNotifier(TInt aPriority) : CActive(aPriority) {} |
|
1659 |
void RunL(); |
|
1660 |
void DoCancel(); |
|
1661 |
private: |
|
1662 |
static TInt LocaleChangeCallback(TAny* aPtr=NULL); |
|
1663 |
TInt FreeMemoryChangeCallback(); |
|
1664 |
private: |
|
1665 |
TInt iChange; |
|
1666 |
RChangeNotifier iChangeNotifier; |
|
1667 |
}; |
|
1668 |
||
1669 |
#if defined(_LOCKABLE_MEDIA) |
|
1670 |
||
1671 |
class TDelayedWriterInit |
|
1672 |
{ |
|
1673 |
public: |
|
1674 |
const TDesC *iFileName; |
|
1675 |
const TDesC8 *iData; |
|
1676 |
const TDesC *iSemName; |
|
1677 |
}; |
|
1678 |
||
1679 |
||
1680 |
class TDelayedWriter |
|
1681 |
{ |
|
1682 |
public: |
|
1683 |
TDelayedWriter(); |
|
1684 |
~TDelayedWriter(); |
|
1685 |
||
1686 |
static TDelayedWriter *NewL(const TDelayedWriterInit *dwi); |
|
1687 |
void ConstructL(const TDelayedWriterInit *dwi); |
|
1688 |
||
1689 |
HBufC *iFileName; |
|
1690 |
HBufC8 *iData; |
|
1691 |
}; |
|
1692 |
||
1693 |
#endif |
|
1694 |
||
1695 |
extern CFsObjectConIx* TheContainer; |
|
1696 |
extern CFsObjectCon* FileSystems; |
|
1697 |
extern CFsObjectCon* Files; |
|
1698 |
extern CFsObjectCon* FileShares; |
|
1699 |
extern CFsObjectCon* Dirs; |
|
1700 |
extern CFsObjectCon* Formats; |
|
1701 |
extern CFsObjectCon* RawDisks; |
|
1702 |
extern CFsObjectCon* Extensions; |
|
1703 |
extern CFsObjectCon* ProxyDrives; |
|
1704 |
||
1705 |
extern CKernEventNotifier* TheKernEventNotifier; |
|
1706 |
||
1707 |
extern RThread TheServerThread; |
|
1708 |
extern RAllocator* ServerThreadAllocator; |
|
1709 |
||
1710 |
extern CServerFs* TheFileServer; |
|
1711 |
||
1712 |
extern HBufC* TheDriveNames[]; |
|
1713 |
extern TDrive TheDrives[KMaxDrives]; |
|
1714 |
extern TFileName TheDefaultPath; |
|
1715 |
extern RFTrace TheFtrace; |
|
1716 |
||
1717 |
extern SCapabilitySet AllCapabilities; |
|
1718 |
extern SCapabilitySet DisabledCapabilities; |
|
1719 |
||
1720 |
const TInt KDispatchObjectClose=KMaxTInt-1; |
|
1721 |
const TInt KSessionDisconnect=KMaxTInt-2; |
|
1722 |
const TInt KCancelSession=KMaxTInt-3; |
|
1723 |
const TInt KCancelPlugin=KMaxTInt-4; |
|
1724 |
const TInt KFileShareClose=KMaxTInt-5; |
|
1725 |
const TInt KFlushDirtyData=KMaxTInt-6; |
|
1726 |
||
1727 |
const TOperation DispatchObjectCloseOp= {KDispatchObjectClose, EInternalRequest, &TFsCloseObject::Initialise, NULL, &TFsCloseObject::DoRequestL }; |
|
1728 |
const TOperation SessionDisconnectOp= {KSessionDisconnect, EInternalRequest, &TFsSessionDisconnect::Initialise, NULL, &TFsSessionDisconnect::DoRequestL }; |
|
1729 |
const TOperation CancelSessionOp= {KCancelSession, EInternalRequest, &TFsCancelSession::Initialise, NULL, &TFsCancelSession::DoRequestL }; |
|
1730 |
const TOperation CancelPluginOp= {KCancelPlugin, EInternalRequest, &TFsCancelPlugin::Initialise, NULL, &TFsCancelPlugin::DoRequestL }; |
|
1731 |
const TOperation FileShareCloseOp= {KFileShareClose, EInternalRequest, &TFsCloseFileShare::Initialise, NULL, &TFsCloseFileShare::DoRequestL }; |
|
1732 |
const TOperation FlushDirtyDataOp= {KFlushDirtyData, EInternalRequest, &TFsFlushDirtyData::Initialise, NULL, &TFsFlushDirtyData::DoRequestL }; |
|
1733 |
||
1734 |
extern TBool OpenOnDriveZOnly; |
|
1735 |
extern TBool LocalFileSystemInitialized; |
|
1736 |
extern TBool StartupInitCompleted; |
|
1737 |
extern TBool RefreshZDriveCache; |
|
1738 |
extern TBool CompFsMounted; |
|
1739 |
extern TBool CompFsSync; |
|
1740 |
||
1741 |
TInt InitializeLocalFileSystem(const TDesC& aName); |
|
1742 |
void InstallRomFileSystemL(); |
|
1743 |
void InstallFatFileSystemL(); |
|
1744 |
TInt InstallFileSystem(CFileSystem* aSys,RLibrary aLib); |
|
1745 |
||
1746 |
TInt LoadFileSystem(const TDesC& aName); |
|
1747 |
||
1748 |
CFsObject* SessionObjectFromHandle(TInt aHandle,TInt aUniqueID, CSessionFs* aSession); |
|
1749 |
CFileShare* GetShareFromHandle(CSessionFs* aSession, TInt aHandle); |
|
1750 |
||
1751 |
TInt ValidateDrive(TInt aDriveNumber,CFsRequest* aRequest); |
|
1752 |
TInt ValidateDriveDoSubst(TInt aDriveNumber,CFsRequest* aRequest); |
|
1753 |
void ValidateAtts(TUint anEntryAtt,TUint& aSetAttMask,TUint& aClearAttMask); |
|
1754 |
TInt ParseSubstPtr0(CFsRequest* aRequest,TParse& aParse, TBool aUseSessionPath = ETrue); |
|
1755 |
TInt ParseNoWildSubstPtr0(CFsRequest* aRequest,TParse& aParse, TBool aUseSessionPath = ETrue); |
|
1756 |
TInt ParseNoWildSubstPtr1(CFsRequest* aRequest,TParse& aParse); |
|
1757 |
TInt ParseNoWildSubstCheckPtr0(CFsRequest* aRequest,TParse& aParse, TBool aUseSessionPath = ETrue); |
|
1758 |
TInt ParseNoWildSubstCheckPtr1(CFsRequest* aRequest,TParse& aParse); |
|
1759 |
TInt ParseNoWildSubstFileCheckPtr1(CFsRequest* aRequest,TParse& aParse); |
|
1760 |
TInt ParseNoWildSubstCheckPathPtr0(CFsRequest* aRequest,TParse& aParse); |
|
1761 |
TInt ParseNoWildSubstCheckPathPtr1(CFsRequest* aRequest,TParse& aParse); |
|
1762 |
TInt ParsePathPtr0(CFsRequest* aRequest,TParse& aParse); |
|
1763 |
TInt ParseNotificationPath(CFsRequest* aRequest, TParse& aParse, TDes& aNotifyPath); |
|
1764 |
TBool IsIllegalFullName(const TDesC& aName); |
|
1765 |
TBool IsIllegalFullName(const TParse& aParse); |
|
1766 |
void AddResource(CMountCB& aMount); |
|
1767 |
void RemoveResource(CMountCB& aMount); |
|
1768 |
void AddDiskAccess(CMountCB& aMount); |
|
1769 |
void RemoveDiskAccess(CMountCB& aMount); |
|
1770 |
void NextInPath(const TDesC& aPath,TPtrC& anEntry,TInt& aPos); |
|
1771 |
TBool PowerOk(); |
|
1772 |
void Get16BitDllName(TDes& aFileName, const TDesC8& aDllName); |
|
1773 |
void Get8BitDllName(TDes8& aDllName, const TDesC& aFileName); |
|
1774 |
TInt MatchUidType(const TUidType &aMatch, const TUidType &aType); |
|
1775 |
TBool IsWriteFunction(TInt aFunction); |
|
1776 |
TInt InitLoader(); |
|
1777 |
TInt CheckDiskSpace(TInt64 aThreshold, CFsRequest* aRequest); |
|
1778 |
void CheckForLeaveAfterOpenL(TInt leaveError, CFsRequest* aRequest, TInt aHandle); |
|
1779 |
TInt ParseSubst(const TInt aP, CFsRequest* aRequest,TParse& aParse, TBool aUseSessionPath = ETrue); |
|
1780 |
||
1781 |
//#ifdef __DATA_CAGING__ |
|
1782 |
||
1783 |
TBool CompareResource(const TDesC & aThePath); |
|
1784 |
||
1785 |
#ifndef __REMOVE_PLATSEC_DIAGNOSTIC_STRINGS__ |
|
1786 |
TInt PathCheck(CFsRequest* aRequest, const TDesC& aThePath, const TSecurityPolicy* aSysCap, const TSecurityPolicy* aPriCap, const char* aDiag); |
|
1787 |
TInt PathCheck(CFsRequest* aRequest, const TDesC& aThePath, const TSecurityPolicy* aSysCap, const TSecurityPolicy* aPriCap, const TSecurityPolicy* aROCap, const char* aDiag); |
|
1788 |
TInt PathCheck(CFsRequest* aRequest, const TDesC& aThePath,const TSecurityPolicy* aCap, const char* aDiag, TBool aExactMatchAllowed = EFalse); |
|
1789 |
#else //__REMOVE_PLATSEC_DIAGNOSTIC_STRINGS__ |
|
1790 |
TInt PathCheck(CFsRequest* aRequest, const TDesC& aThePath, const TSecurityPolicy* aSysCap, const TSecurityPolicy* aPriCap, OnlyCreateWithNull aDiag); |
|
1791 |
TInt PathCheck(CFsRequest* aRequest, const TDesC& aThePath, const TSecurityPolicy* aSysCap, const TSecurityPolicy* aPriCap, const TSecurityPolicy* aROCap, OnlyCreateWithNull aDiag); |
|
1792 |
TInt PathCheck(CFsRequest* aRequest, const TDesC& aThePath,const TSecurityPolicy* aCap, OnlyCreateWithNull aDiag, TBool aExactMatchAllowed = EFalse); |
|
1793 |
#endif //!__REMOVE_PLATSEC_DIAGNOSTIC_STRINGS__ |
|
1794 |
||
1795 |
TBool ComparePrivate(const TDesC & aThePath); |
|
1796 |
TBool CompareSystem(const TDesC & aThePath); |
|
1797 |
TBool SIDCheck(CFsRequest* aRequest, const TDesC& aThePath); |
|
1798 |
TBool ComparePaths(const TDesC& aPath1,const TDesC& aPath2); |
|
1799 |
TUint32 CalcNameHash(const TDesC& aName); |
|
1800 |
||
1801 |
const TInt KResourceLength = 9; |
|
1802 |
const TInt KSystemLength = 4; |
|
1803 |
const TInt KPrivateLength = 8; |
|
1804 |
const TInt KPrivateLengthCheck = 17; |
|
1805 |
const TInt KSIDLength = 8; |
|
1806 |
const TInt KSIDPathOffset = 9; |
|
1807 |
||
1808 |
_LIT(KSlash, "\\"); |
|
1809 |
_LIT(KPrivate,"\\Private"); |
|
1810 |
_LIT(KPrivateSlash,"\\Private\\"); |
|
1811 |
_LIT(KSysHash,"?:\\Sys\\Hash\\"); |
|
1812 |
const TInt KBSlash='\\'; |
|
1813 |
const TInt KHashFileReadSize = 1024*8; |
|
1814 |
||
1815 |
||
1816 |
const TInt KMsgPtr0 = 0; |
|
1817 |
const TInt KMsgPtr1 = 1; |
|
1818 |
const TInt KMsgPtr2 = 2; |
|
1819 |
const TInt KMsgPtr3 = 3; |
|
1820 |
||
1821 |
const TInt KIpcFunctionMask = 0x0000ffff; |
|
1822 |
const TInt KIpcFlagMask = 0xffff0000; |
|
1823 |
const TInt KIpcFlagOffset = 16; |
|
1824 |
||
1825 |
#if defined(_DEBUG) || defined(_DEBUG_RELEASE) |
|
1826 |
void PrintStartUpReason(TMachineStartupType aReason); |
|
1827 |
TPtrC GetFunctionName(TInt aFunction); |
|
1828 |
void SimulateAllocFailure(TInt aFunctionReturnValue,TInt aFunction); |
|
1829 |
||
1830 |
extern TInt ErrorCondition; |
|
1831 |
extern TInt ErrorCount; |
|
1832 |
extern TUint32 DebugReg; |
|
1833 |
extern TInt UserHeapAllocFailCount; |
|
1834 |
extern TInt KernHeapAllocFailCount; |
|
1835 |
extern TInt MessageCount; |
|
19
4a8fed1c0ef6
Revision: 201007
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
2
diff
changeset
|
1836 |
extern TInt SessionCount; |
4a8fed1c0ef6
Revision: 201007
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
2
diff
changeset
|
1837 |
extern TInt ObjectCount; |
0 | 1838 |
|
1839 |
void PrintHeapSize(const TDesC& aMessage); |
|
1840 |
||
1841 |
extern TCorruptNameRec* gCorruptFileNameList; |
|
1842 |
extern TCorruptLogRec* gCorruptLogRecordList; |
|
1843 |
extern TInt gNumberOfCorruptHits; |
|
1844 |
extern HBufC* gCorruptFileNamesListFile; |
|
1845 |
#endif |
|
1846 |
||
1847 |
typedef TPckgBuf<TMediaPswdReplyNotifyInfoV1> TMediaPswdReplyNotifyInfoV1Buf; |
|
1848 |
||
1849 |
enum TDllFindMethod {EFindInPath, EFindInSystemLibs, EFindInSystemBin, EFindExhausted}; |
|
1850 |
||
1851 |
//--------------------------------------------------------------------------------------------------------------------- |
|
1852 |
||
1853 |
NONSHARABLE_CLASS(CFileBody) : public CBase, public CFileCB::MExtendedFileInterface |
|
1854 |
{ |
|
1855 |
protected: |
|
1856 |
~CFileBody(); |
|
1857 |
CFileBody(CFileCB* aFileCB, CFileCB::MExtendedFileInterface* aExtendedFileInterface); |
|
1858 |
void InitL(); |
|
1859 |
||
1860 |
TBool ExtendedFileInterfaceSupported(); |
|
1861 |
||
1862 |
// from MExtendedFileInterface |
|
1863 |
virtual void ReadL(TInt64 aPos,TInt& aLength,TDes8* aDes,const RMessagePtr2& aMessage, TInt aOffset = 0); |
|
1864 |
virtual void WriteL(TInt64 aPos,TInt& aLength,const TDesC8* aDes,const RMessagePtr2& aMessage, TInt aOffset = 0); |
|
1865 |
virtual void SetSizeL(TInt64 aSize); |
|
1866 |
||
1867 |
||
1868 |
private: |
|
1869 |
CFileCB* iFileCB; |
|
1870 |
CFileCB::MExtendedFileInterface* iExtendedFileInterface; |
|
1871 |
TInt iFairSchedulingLen; |
|
1872 |
TBool iNotifyAsyncReadersPending; |
|
1873 |
TBool iDeleteOnClose; |
|
1874 |
||
1875 |
protected: |
|
1876 |
TInt iPromotedShares; |
|
1877 |
RArray<TAsyncReadRequest>* iAsyncReadRequests; |
|
1878 |
CFileCache* iFileCache; // pointer to owner CFileCache |
|
1879 |
TBool iLocalBufferSupport; |
|
1880 |
||
1881 |
/** |
|
1882 |
maximum file size supported by the filesystem that instantiates the CFileCB, associated with this object. |
|
1883 |
For example, FAT32 supports files not larger than 4GB-1. Other file systems can support larger files. |
|
1884 |
This member allows file server to know maximum allowed position in the file. |
|
1885 |
The default value is KMaxTUint64 |
|
1886 |
*/ |
|
1887 |
TUint64 iMaxSupportedFileSize; |
|
1888 |
||
1889 |
public: |
|
1890 |
// Provides support for large file size ( file size > 4GB - 1) |
|
1891 |
// Upper / High 32 bit word of the file size is saved here. |
|
1892 |
// This can be non-zero only if the CFileShare::iMode is ORed with EFileBigFile |
|
1893 |
// and the file size is > 4GB - 1. |
|
1894 |
// This shall be queried by CFileCB::Size64() from file systems or by direct access from file server |
|
1895 |
// This shall be updated by CFileCB::SetSize64() from file systems or by direct access from file server. |
|
1896 |
TUint iSizeHigh; |
|
1897 |
||
1898 |
protected: |
|
1899 |
friend class CFileCB; |
|
1900 |
friend class CFileCache; |
|
1901 |
}; |
|
1902 |
||
1903 |
//--------------------------------------------------------------------------------------------------------------------- |
|
1904 |
||
1905 |
NONSHARABLE_CLASS(CMountBody) : public CBase, public CMountCB::MFileAccessor, public CMountCB::MFileExtendedInterface |
|
1906 |
{ |
|
1907 |
protected: |
|
1908 |
CMountBody(CMountCB* aMountCB, CMountCB::MFileAccessor* aFileAccessor = NULL, CMountCB::MFileExtendedInterface* aFileInterface = NULL); |
|
1909 |
~CMountBody(); |
|
1910 |
||
1911 |
// Clamping support |
|
1912 |
TInt ClampFile(const TInt aDriveNo,const TDesC& aName,TAny* aHandle); |
|
1913 |
TInt UnclampFile(RFileClamp* aHandle); |
|
1914 |
TInt IsFileClamped(const TInt64 aUniqueId); |
|
1915 |
TInt NoOfClamps(); |
|
1916 |
||
1917 |
// Internal support clamping |
|
1918 |
static TInt CompareClampsByIdAndCount(const RFileClamp& aClampA, const RFileClamp& aClampB); |
|
1919 |
static TInt CompareClampsById(const RFileClamp& aClampA, const RFileClamp& aClampB); |
|
1920 |
static TInt FindClampByIdAndCount(const RFileClamp& aClampA, const RFileClamp& aClampB); |
|
1921 |
static TInt FindClampById(const RFileClamp& aClampA, const RFileClamp& aClampB); |
|
1922 |
||
1923 |
// from MFileAccessor |
|
1924 |
virtual TInt GetFileUniqueId(const TDesC& aName, TInt64& aUniqueId); |
|
1925 |
virtual TInt Spare3(TInt aVal, TAny* aPtr1, TAny* aPtr2); |
|
1926 |
virtual TInt Spare2(TInt aVal, TAny* aPtr1, TAny* aPtr2); |
|
1927 |
virtual TInt Spare1(TInt aVal, TAny* aPtr1, TAny* aPtr2); |
|
1928 |
||
1929 |
// From MFileExtendedInterface |
|
1930 |
virtual void ReadSection64L(const TDesC& aName, TInt64 aPos, TAny* aTrg, TInt aLength, const RMessagePtr2& aMessage); |
|
1931 |
||
1932 |
void SetProxyDriveDismounted(); |
|
1933 |
TBool ProxyDriveDismounted(); |
|
1934 |
||
1935 |
||
1936 |
inline CFileSystem* GetFileSystem() const; |
|
1937 |
inline void SetFileSystem(CFileSystem* aFsys); |
|
1938 |
||
1939 |
private: |
|
1940 |
CMountCB* iMountCB; |
|
1941 |
RArray<RFileClamp> iClampIdentifiers; |
|
1942 |
TInt32 iClampCount; |
|
1943 |
CMountCB::MFileAccessor* iFileAccessor; |
|
1944 |
CMountCB::MFileExtendedInterface* iFileExtendedInterface; |
|
1945 |
TBool iProxyDriveDismounted; |
|
1946 |
CFileSystem* iFSys; ///< link to the FileSystem object that has produced the mount (iMountCB) |
|
1947 |
friend class CMountCB; |
|
1948 |
}; |
|
1949 |
||
1950 |
||
1951 |
#include "sf_ops.h" |
|
1952 |
#include "sf_std.inl" |
|
1953 |
||
1954 |
||
1955 |
#endif //SF_STD_H |