--- a/userlibandfileserver/fileserver/sfile/sf_plugin.h Tue Aug 31 16:34:26 2010 +0300
+++ b/userlibandfileserver/fileserver/sfile/sf_plugin.h Wed Sep 01 12:34:56 2010 +0100
@@ -60,20 +60,19 @@
static TInt InstallPluginFactory(CFsPluginFactory* aFactory,RLibrary aLib);
static CFsPluginFactory* GetPluginFactory(const TDesC& aName);
- static TInt NextPlugin(CFsPlugin*& aPlugin, CFsMessageRequest* aMsgRequest, TBool aCheckCurrentOperation=ETrue);
- static TInt PrevPlugin(CFsPlugin*& aPlugin, CFsMessageRequest* aMsgRequest);
+ static TInt NextPlugin(CFsPlugin*& aPlugin, CFsMessageRequest* aMsgRequest, TBool aLock, TBool aCheckCurrentOperation=ETrue);
+ static TInt PrevPlugin(CFsPlugin*& aPlugin, CFsMessageRequest* aMsgRequest, TBool aLock);
static TInt InsertInPluginStack(CFsPlugin*& aPlugin,TInt aPos);
static TInt IsInChain(TInt aUPos, TInt aPos,TInt aDrive, CFsPluginFactory* aPluginFactory);
static CFsPlugin* FindByUniquePosition(TInt aPos);
- static TInt InitPlugin(CFsPlugin& aPlugin, RLibrary aLibrary);
+ static TInt InitPlugin(CFsPlugin& aPlugin);
static void TransferRequests(CPluginThread* aPluginThread);
static void CancelPlugin(CFsPlugin* aPlugin,CSessionFs* aSession);
static TInt ChainCount();
static TInt Plugin(CFsPlugin*& aPlugin, TInt aPos);
- static void ReadLockChain();
- static void WriteLockChain();
+ static void LockChain();
static void UnlockChain();
static CFsPluginConn* CreatePluginConnL(TInt aUniquePosition, TUint aClientId);
@@ -92,7 +91,7 @@
static CFsObjectCon* iPluginConns;
static RPointerArray<CFsPlugin> iPluginChain;
- static RReadWriteLock iChainLock;
+ static RFastLock iChainLock;
static CFsSyncMessageScheduler* iScheduler;