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

Unified Diff: base/threading/worker_pool_win.cc

Issue 7316015: Support Closure in ALL the loops! (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: cleanup idle wait. Created 9 years, 5 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 side-by-side diff with in-line comments
Download patch
Index: base/threading/worker_pool_win.cc
diff --git a/base/threading/worker_pool_win.cc b/base/threading/worker_pool_win.cc
index 2072e525e84df34262253bce82efc4115c75fa89..bcf7b3e100952aa60b96bc892b3bf8492e0f9081 100644
--- a/base/threading/worker_pool_win.cc
+++ b/base/threading/worker_pool_win.cc
@@ -4,17 +4,47 @@
#include "base/threading/worker_pool.h"
+#include "base/bind.h"
#include "base/logging.h"
#include "base/task.h"
+#include "base/tracked_objects.h"
namespace base {
namespace {
+struct PendingTask {
+ PendingTask(
+ const tracked_objects::Location& posted_from,
+ const base::Closure& task)
+ : task(task) {
+#if defined(TRACK_ALL_TASK_OBJECTS)
+ post_births = tracked_objects::ThreadData::TallyABirthIfActive(posted_from);
+ time_posted = TimeTicks::Now();
+#endif // defined(TRACK_ALL_TASK_OBJECTS)
+ }
+
+#if defined(TRACK_ALL_TASK_OBJECTS)
+ // Counter for location where the Closure was posted from.
+ tracked_objects::Births* post_births;
+
+ // Time the task was posted.
+ TimeTicks time_posted;
+#endif // defined(TRACK_ALL_TASK_OBJECTS)
+
+ // The task to run.
+ base::Closure task;
+};
+
DWORD CALLBACK WorkItemCallback(void* param) {
- Task* task = static_cast<Task*>(param);
- task->Run();
- delete task;
+ PendingTask* pending_task = static_cast<PendingTask*>(param);
+ pending_task->task.Run();
+#if defined(TRACK_ALL_TASK_OBJECTS)
+ tracked_objects::ThreadData::TallyADeathIfActive(
darin (slow to review) 2011/07/07 21:54:01 nit: indentation is off by 2
awong 2011/07/08 00:38:40 Done.
+ pending_task->post_births,
+ TimeTicks::Now() - pending_task->time_posted);
+#endif // defined(TRACK_ALL_TASK_OBJECTS)
+ delete pending_task;
return 0;
}
@@ -22,15 +52,35 @@ DWORD CALLBACK WorkItemCallback(void* param) {
bool WorkerPool::PostTask(const tracked_objects::Location& from_here,
Task* task, bool task_is_slow) {
- task->SetBirthPlace(from_here);
+ PendingTask* pending_task =
+ new PendingTask(from_here,
+ base::Bind(&subtle::TaskClosureAdapter::Run,
+ new subtle::TaskClosureAdapter(task)));
+
+ ULONG flags = 0;
+ if (task_is_slow)
+ flags |= WT_EXECUTELONGFUNCTION;
+
+ if (!QueueUserWorkItem(WorkItemCallback, pending_task, flags)) {
+ DLOG(ERROR) << "QueueUserWorkItem failed: " << GetLastError();
+ delete pending_task;
+ return false;
+ }
+
+ return true;
+}
+
+bool WorkerPool::PostTask(const tracked_objects::Location& from_here,
+ const base::Closure& task, bool task_is_slow) {
+ PendingTask* pending_task = new PendingTask(from_here, task);
ULONG flags = 0;
if (task_is_slow)
flags |= WT_EXECUTELONGFUNCTION;
- if (!QueueUserWorkItem(WorkItemCallback, task, flags)) {
+ if (!QueueUserWorkItem(WorkItemCallback, pending_task, flags)) {
DLOG(ERROR) << "QueueUserWorkItem failed: " << GetLastError();
- delete task;
+ delete pending_task;
return false;
}

Powered by Google App Engine
This is Rietveld 408576698