Leaked source code of windows server 2003
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

118 lines
3.7 KiB

  1. #ifndef __TPOOLEDDISPATCH_H__
  2. #define __TPOOLEDDISPATCH_H__
  3. /*---------------------------------------------------------------------------
  4. File: TPooledDispatch.h
  5. Comments: TJobDispatcher implements a thread pool to execute jobs. Jobs are
  6. executed on a FIFO basis. This dispatcher does not provide any support for
  7. job scheduling, only multithreaded dispatch of jobs.
  8. (c) Copyright 1999, Mission Critical Software, Inc., All Rights Reserved
  9. Proprietary and confidential to Mission Critical Software, Inc.
  10. REVISION LOG ENTRY
  11. Revision By: Christy Boles
  12. Revised on 02/19/99 16:35:54
  13. ---------------------------------------------------------------------------
  14. */
  15. #include "Common.hpp"
  16. #include "TNode.hpp"
  17. #include "TSync.hpp"
  18. class Job : public TNode
  19. {
  20. public:
  21. enum JobStatus { JobStatusUninitialized, JobStatusWaiting, JobStatusRunning, JobStatusFinished };
  22. private:
  23. LPTHREAD_START_ROUTINE m_pStartRoutine;
  24. LPVOID m_pArgs;
  25. JobStatus m_Status;
  26. DWORD m_ThreadID;
  27. time_t m_timeStarted;
  28. time_t m_timeEnded;
  29. int m_result;
  30. public:
  31. Job()
  32. {
  33. m_pStartRoutine = NULL;
  34. m_pArgs = NULL;
  35. m_Status = JobStatusUninitialized;
  36. m_ThreadID = 0;
  37. m_timeStarted = 0;
  38. m_timeEnded = 0;
  39. m_result = 0;
  40. }
  41. ~Job() {};
  42. void SetEntryPoint(LPTHREAD_START_ROUTINE pStart, LPVOID pArg)
  43. {
  44. MCSASSERT(m_Status == JobStatusUninitialized || m_Status == JobStatusFinished );
  45. MCSASSERT(pStart);
  46. m_pStartRoutine = pStart;
  47. m_pArgs = pArg;
  48. m_Status = JobStatusWaiting;
  49. }
  50. int Run();
  51. // int GetElapsedTime() { return m_timeEnded - m_timeStarted; }
  52. time_t GetElapsedTime() { return m_timeEnded - m_timeStarted; }
  53. int GetResult() { return m_result; }
  54. JobStatus GetStatus() { return m_Status; }
  55. };
  56. class JobList : public TNodeList
  57. {
  58. TCriticalSection m_cs;
  59. public:
  60. ~JobList() { DeleteAllListItems(Job); }
  61. Job * AddJob(LPTHREAD_START_ROUTINE pfnStart, void * arg) { Job * pJob = new Job; pJob->SetEntryPoint(pfnStart,arg);
  62. m_cs.Enter(); InsertBottom(pJob); m_cs.Leave(); return pJob; }
  63. void RemoveJob(Job * pJob) { m_cs.Enter(); Remove(pJob); m_cs.Leave(); }
  64. Job * GetFirstJob() { m_cs.Enter(); Job * pJob = (Job *)Head(); if ( pJob ) Remove(pJob); m_cs.Leave(); return pJob; }
  65. };
  66. class TJobDispatcher
  67. {
  68. DWORD m_numThreads;
  69. JobList m_JobsWaiting;
  70. JobList m_JobsInProgress;
  71. TSemaphoreNamed m_sem;
  72. TCriticalSection m_cs;
  73. DWORD m_numActiveThreads;
  74. BOOL m_Aborting;
  75. public:
  76. TJobDispatcher(DWORD maxThreads = 10) { InitThreadPool(maxThreads); m_Aborting = FALSE;}
  77. ~TJobDispatcher() { WaitForCompletion(); ShutdownThreads(); }
  78. // These are called by the client
  79. Job * SubmitJob(LPTHREAD_START_ROUTINE pStart,LPVOID pArg)
  80. {
  81. // Job * pJob = m_JobsWaiting.AddJob(pStart,pArg);
  82. m_JobsWaiting.AddJob(pStart,pArg);
  83. m_sem.Release(1);
  84. return 0;
  85. }
  86. void WaitForCompletion();
  87. int UnfinishedJobs();
  88. // These functions are called by the threads - clients should not call these functions!
  89. DWORD SignalForJob();
  90. Job * GetAvailableJob();
  91. void ThreadFinished() { m_cs.Enter(); m_numActiveThreads--; m_cs.Leave(); }
  92. protected:
  93. void InitThreadPool(DWORD nThreads);
  94. void ShutdownThreads();
  95. };
  96. #endif //__TPOOLEDDISPATCH_H__