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

Side by Side Diff: runtime/bin/thread_pool_linux.cc

Issue 9112013: Thread pool changes (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Added tread pool shutdown Created 8 years, 11 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 | Annotate | Revision Log
« no previous file with comments | « runtime/bin/thread_pool.cc ('k') | runtime/bin/thread_pool_macos.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file
2 // for details. All rights reserved. Use of this source code is governed by a 2 // for details. All rights reserved. Use of this source code is governed by a
3 // BSD-style license that can be found in the LICENSE file. 3 // BSD-style license that can be found in the LICENSE file.
4 4
5 #include <pthread.h> 5 #include <pthread.h>
6 6
7 #include "bin/thread_pool.h" 7 #include "bin/thread_pool.h"
8 8
9 TaskQueue::TaskQueue() : head_(NULL), tail_(NULL) { 9 TaskQueue::TaskQueue() : terminate_(false), head_(NULL), tail_(NULL) {
10 int result; 10 int result;
11 11
12 result = pthread_mutex_init(data_.mutex(), NULL); 12 result = pthread_mutex_init(data_.mutex(), NULL);
13 if (result != 0) { 13 if (result != 0) {
14 FATAL("pthread_mutex_init failed"); 14 FATAL("pthread_mutex_init failed");
15 } 15 }
16 16
17 result = pthread_cond_init(data_.cond(), NULL); 17 result = pthread_cond_init(data_.cond(), NULL);
18 if (result != 0) { 18 if (result != 0) {
19 FATAL("pthread_cond_init failed"); 19 FATAL("pthread_cond_init failed");
(...skipping 12 matching lines...) Expand all
32 tail_ = entry; 32 tail_ = entry;
33 } 33 }
34 pthread_mutex_unlock(data_.mutex()); 34 pthread_mutex_unlock(data_.mutex());
35 } 35 }
36 36
37 37
38 TaskQueueEntry* TaskQueue::Remove() { 38 TaskQueueEntry* TaskQueue::Remove() {
39 pthread_mutex_lock(data_.mutex()); 39 pthread_mutex_lock(data_.mutex());
40 TaskQueueEntry* result = head_; 40 TaskQueueEntry* result = head_;
41 while (result == NULL) { 41 while (result == NULL) {
42 if (terminate_) {
43 pthread_mutex_unlock(data_.mutex());
44 return NULL;
45 }
42 pthread_cond_wait(data_.cond(), data_.mutex()); 46 pthread_cond_wait(data_.cond(), data_.mutex());
47 if (terminate_) {
48 pthread_mutex_unlock(data_.mutex());
49 return NULL;
50 }
43 result = head_; 51 result = head_;
44 } 52 }
45 head_ = result->next(); 53 head_ = result->next();
46 ASSERT(head_ != NULL || tail_ == result); 54 ASSERT(head_ != NULL || tail_ == result);
47 pthread_mutex_unlock(data_.mutex()); 55 pthread_mutex_unlock(data_.mutex());
48 return result; 56 return result;
49 } 57 }
50 58
51 59
60 void TaskQueue::Shutdown() {
61 pthread_mutex_lock(data_.mutex());
62 terminate_ = true;
63 pthread_cond_broadcast(data_.cond());
64 pthread_mutex_unlock(data_.mutex());
65 }
66
67
52 void ThreadPool::Start() { 68 void ThreadPool::Start() {
53 pthread_t* threads 69 pthread_t* threads
54 = reinterpret_cast<pthread_t*>(calloc(size_, sizeof(pthread_t*))); 70 = reinterpret_cast<pthread_t*>(calloc(size_, sizeof(pthread_t*))); // NOL INT
55 data_.set_threads(threads); 71 data_.set_threads(threads);
56 for (int i = 0; i < size_; i++) { 72 for (int i = 0; i < size_; i++) {
57 pthread_t handler_thread; 73 pthread_t handler_thread;
58 int result = pthread_create(&handler_thread, 74 int result = pthread_create(&handler_thread,
59 NULL, 75 NULL,
60 &ThreadPool::Main, 76 &ThreadPool::Main,
61 this); 77 this);
62 if (result != 0) { 78 if (result != 0) {
63 FATAL("Create and start thread pool thread"); 79 FATAL("Create and start thread pool thread");
64 } 80 }
65 data_.threads()[i] = handler_thread; 81 data_.threads()[i] = handler_thread;
66 } 82 }
67 } 83 }
84
85
86 void ThreadPool::Shutdown() {
87 terminate_ = true;
88 queue_.Shutdown();
89 for (int i = 0; i < size_; i++) {
90 pthread_join(data_.threads()[i], NULL);
91 }
92 }
OLDNEW
« no previous file with comments | « runtime/bin/thread_pool.cc ('k') | runtime/bin/thread_pool_macos.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698