diff options
author | Samuel Just <sam.just@inktank.com> | 2013-09-13 19:49:17 -0700 |
---|---|---|
committer | Samuel Just <sam.just@inktank.com> | 2013-09-19 12:16:38 -0700 |
commit | 63a933cd9fe9f7991f95da7052ec4f71fabe75e1 (patch) | |
tree | b280ff5078540adcb4235f0621ff4c077b109b18 | |
parent | aa327138df10822557dd27ae057f1cde48ebe0cf (diff) | |
download | ceph-63a933cd9fe9f7991f95da7052ec4f71fabe75e1.tar.gz |
WorkQueue: add a workqueue which simply runs queued GenContexts
Signed-off-by: Samuel Just <sam.just@inktank.com>
-rw-r--r-- | src/common/WorkQueue.h | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/src/common/WorkQueue.h b/src/common/WorkQueue.h index b2742accdce..e589b3c1463 100644 --- a/src/common/WorkQueue.h +++ b/src/common/WorkQueue.h @@ -390,6 +390,49 @@ public: void drain(WorkQueue_* wq = 0); }; +class GenContextWQ : + public ThreadPool::WorkQueueVal<GenContext<ThreadPool::TPHandle&>*> { + Mutex qlock; + list<GenContext<ThreadPool::TPHandle&>*> _queue; +public: + GenContextWQ(const string &name, time_t ti, ThreadPool *tp) + : ThreadPool::WorkQueueVal< + GenContext<ThreadPool::TPHandle&>*>(name, ti, ti*10, tp), + qlock(name.c_str()) {} + + void _enqueue(GenContext<ThreadPool::TPHandle&> *c) { + Mutex::Locker l(qlock); + _queue.push_back(c); + }; + void _enqueue_front(GenContext<ThreadPool::TPHandle&> *c) { + Mutex::Locker l(qlock); + _queue.push_front(c); + } + bool _empty() { + Mutex::Locker l(qlock); + return _queue.empty(); + } + GenContext<ThreadPool::TPHandle&> *_dequeue() { + Mutex::Locker l(qlock); + assert(!_queue.empty()); + GenContext<ThreadPool::TPHandle&> *c = _queue.front(); + _queue.pop_front(); + return c; + } + void _process(GenContext<ThreadPool::TPHandle&> *c, ThreadPool::TPHandle &tp) { + c->complete(tp); + } +}; +class QueueInWQ : public Context { + GenContextWQ *wq; + GenContext<ThreadPool::TPHandle&> *c; +public: + QueueInWQ(GenContextWQ *wq, GenContext<ThreadPool::TPHandle &> *c) + : wq(wq), c(c) {} + void finish(int) { + wq->queue(c); + } +}; #endif |