Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(193)

Side by Side Diff: third_party/grpc/src/cpp/server/dynamic_thread_pool.h

Issue 1932353002: Initial checkin of gRPC to third_party/ Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 4 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 /* Copyright (c) 2010, Google Inc. 1 /*
2 *
3 * Copyright 2015, Google Inc.
2 * All rights reserved. 4 * All rights reserved.
3 * 5 *
4 * Redistribution and use in source and binary forms, with or without 6 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are 7 * modification, are permitted provided that the following conditions are
6 * met: 8 * met:
7 * 9 *
8 * * Redistributions of source code must retain the above copyright 10 * * Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer. 11 * notice, this list of conditions and the following disclaimer.
10 * * Redistributions in binary form must reproduce the above 12 * * Redistributions in binary form must reproduce the above
11 * copyright notice, this list of conditions and the following disclaimer 13 * copyright notice, this list of conditions and the following disclaimer
12 * in the documentation and/or other materials provided with the 14 * in the documentation and/or other materials provided with the
13 * distribution. 15 * distribution.
14 * * Neither the name of Google Inc. nor the names of its 16 * * Neither the name of Google Inc. nor the names of its
15 * contributors may be used to endorse or promote products derived from 17 * contributors may be used to endorse or promote products derived from
16 * this software without specific prior written permission. 18 * this software without specific prior written permission.
17 * 19 *
18 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 20 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
19 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 21 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
20 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 22 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
21 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 23 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
22 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 24 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
23 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 25 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
24 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 26 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
25 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 27 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
26 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 28 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 29 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
28 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 30 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29 * 31 *
30 * ---
31 * This file is an internal part spinlock.cc and once.cc
32 * It may not be used directly by code outside of //base.
33 */ 32 */
34 33
35 #ifndef BASE_SPINLOCK_INTERNAL_H_ 34 #ifndef GRPC_INTERNAL_CPP_DYNAMIC_THREAD_POOL_H
36 #define BASE_SPINLOCK_INTERNAL_H_ 35 #define GRPC_INTERNAL_CPP_DYNAMIC_THREAD_POOL_H
37 36
38 #include <config.h> 37 #include <list>
39 #include "base/basictypes.h" 38 #include <memory>
40 #include "base/atomicops.h" 39 #include <queue>
41 40
42 namespace base { 41 #include <grpc++/impl/sync.h>
43 namespace internal { 42 #include <grpc++/impl/thd.h>
43 #include <grpc++/support/config.h>
44 44
45 // SpinLockWait() waits until it can perform one of several transitions from 45 #include "src/cpp/server/thread_pool_interface.h"
46 // "from" to "to". It returns when it performs a transition where done==true. 46
47 struct SpinLockWaitTransition { 47 namespace grpc {
48 int32 from; 48
49 int32 to; 49 class DynamicThreadPool GRPC_FINAL : public ThreadPoolInterface {
50 bool done; 50 public:
51 explicit DynamicThreadPool(int reserve_threads);
52 ~DynamicThreadPool();
53
54 void Add(const std::function<void()>& callback) GRPC_OVERRIDE;
55
56 private:
57 class DynamicThread {
58 public:
59 DynamicThread(DynamicThreadPool* pool);
60 ~DynamicThread();
61
62 private:
63 DynamicThreadPool* pool_;
64 std::unique_ptr<grpc::thread> thd_;
65 void ThreadFunc();
66 };
67 grpc::mutex mu_;
68 grpc::condition_variable cv_;
69 grpc::condition_variable shutdown_cv_;
70 bool shutdown_;
71 std::queue<std::function<void()>> callbacks_;
72 int reserve_threads_;
73 int nthreads_;
74 int threads_waiting_;
75 std::list<DynamicThread*> dead_threads_;
76
77 void ThreadFunc();
78 static void ReapThreads(std::list<DynamicThread*>* tlist);
51 }; 79 };
52 80
53 // Wait until *w can transition from trans[i].from to trans[i].to for some i 81 } // namespace grpc
54 // satisfying 0<=i<n && trans[i].done, atomically make the transition,
55 // then return the old value of *w. Make any other atomic tranistions
56 // where !trans[i].done, but continue waiting.
57 int32 SpinLockWait(volatile Atomic32 *w, int n,
58 const SpinLockWaitTransition trans[]);
59 void SpinLockWake(volatile Atomic32 *w, bool all);
60 void SpinLockDelay(volatile Atomic32 *w, int32 value, int loop);
61 82
62 } // namespace internal 83 #endif // GRPC_INTERNAL_CPP_DYNAMIC_THREAD_POOL_H
63 } // namespace base
64 #endif
OLDNEW
« no previous file with comments | « third_party/grpc/src/cpp/server/create_default_thread_pool.cc ('k') | third_party/grpc/src/cpp/server/dynamic_thread_pool.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698