// @(#)root/io:$Id: TFilePrefetch.h 48307 2013-01-16 16:21:00Z pcanal $ // Author: Elvin Sindrilaru 19/05/2011 /************************************************************************* * Copyright (C) 1995-2011, Rene Brun and Fons Rademakers. * * All rights reserved. * * * * For the licensing terms see $ROOTSYS/LICENSE. * * For the list of contributors see $ROOTSYS/README/CREDITS. * *************************************************************************/ #ifndef ROOT_TFilePrefetch #define ROOT_TFilePrefetch ////////////////////////////////////////////////////////////////////////// // // // TFilePrefetch // // // // The prefetching mechanism uses two classes (TFilePrefetch and // // TFPBlock) to prefetch in advance a block of tree entries. There is // // a thread which takes care of actually transferring the blocks and // // making them available to the main requesting thread. Therefore, // // the time spent by the main thread waiting for the data before // // processing considerably decreases. Besides the prefetching // // mechanisms there is also a local caching option which can be // // enabled by the user. Both capabilities are disabled by default // // and must be explicitly enabled by the user. // // // ////////////////////////////////////////////////////////////////////////// #ifndef ROOT_TFile #include "TFile.h" #endif #ifndef ROOT_TThread #include "TThread.h" #endif #ifndef ROOT_TFPBlock #include "TFPBlock.h" #endif #ifndef ROOT_TCondition #include "TCondition.h" #endif #ifndef ROOT_TSemaphore #include "TSemaphore.h" #endif #ifndef ROOT_TMD5 #include "TMD5.h" #endif #ifndef ROOT_TObject #include "TObject.h" #endif #ifndef ROOT_TString #include "TString.h" #endif #ifndef ROOT_TObjString #include "TObjString.h" #endif #ifndef ROOT_TMutex #include "TMutex.h" #endif #ifndef ROOT_TObjArray #include "TObjArray.h" #endif #ifndef ROOT_TStopwatch #include "TStopwatch.h" #endif class TFilePrefetch : public TObject { private: TFile *fFile; // reference to the file TList *fPendingBlocks; // list of pending blocks to be read TList *fReadBlocks; // list of blocks read TThread *fConsumer; // consumer thread TMutex *fMutexPendingList; // mutex for the pending list TMutex *fMutexReadList; // mutex for the list of read blocks TCondition *fNewBlockAdded; // signal the addition of a new pending block TCondition *fReadBlockAdded; // signal the addition of a new red block TCondition *fCondNextFile; // signal TChain that we can move to the next file TSemaphore *fSemMasterWorker; // semaphore used to kill the consumer thread TSemaphore *fSemWorkerMaster; // semaphore used to notify the master that worker is killed TString fPathCache; // path to the cache directory TStopwatch fWaitTime; // time wating to prefetch a buffer (in usec) Bool_t fThreadJoined; // mark if async thread was joined static TThread::VoidRtnFunc_t ThreadProc(void*); //create a joinable worker thread public: TFilePrefetch(TFile*); virtual ~TFilePrefetch(); void ReadAsync(TFPBlock*, Bool_t&); void ReadListOfBlocks(); void AddPendingBlock(TFPBlock*); TFPBlock *GetPendingBlock(); void AddReadBlock(TFPBlock*); Bool_t ReadBuffer(char*, Long64_t, Int_t); void ReadBlock(Long64_t*, Int_t*, Int_t); TFPBlock *CreateBlockObj(Long64_t*, Int_t*, Int_t); TThread *GetThread() const; Int_t ThreadStart(); Bool_t SetCache(const char*); Bool_t CheckCachePath(const char*); Bool_t CheckBlockInCache(char*&, TFPBlock*); char *GetBlockFromCache(const char*, Int_t); void SaveBlockInCache(TFPBlock*); Int_t SumHex(const char*); Bool_t BinarySearchReadList(TFPBlock*, Long64_t, Int_t, Int_t*); Long64_t GetWaitTime(); void SetFile(TFile*); TCondition* GetCondNextFile() const { return fCondNextFile; }; void WaitFinishPrefetch(); ClassDef(TFilePrefetch, 0); // File block prefetcher }; #endif