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

Unified Diff: tools/skpdiff/SkDifferentPixelsMetric_opencl.cpp

Issue 60833002: fix multithread related crashes in skpdiff (Closed) Base URL: https://skia.googlecode.com/svn/trunk
Patch Set: Created 7 years, 1 month 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: tools/skpdiff/SkDifferentPixelsMetric_opencl.cpp
diff --git a/tools/skpdiff/SkDifferentPixelsMetric_opencl.cpp b/tools/skpdiff/SkDifferentPixelsMetric_opencl.cpp
index b3f5d2d7e0b00c70fb813e5b73ca4df3b5b9430d..2fe5999b734cfc2438d21db1324fe93482718ab4 100644
--- a/tools/skpdiff/SkDifferentPixelsMetric_opencl.cpp
+++ b/tools/skpdiff/SkDifferentPixelsMetric_opencl.cpp
@@ -52,9 +52,14 @@ bool SkDifferentPixelsMetric::enablePOIAlphaMask() {
}
int SkDifferentPixelsMetric::queueDiff(SkBitmap* baseline, SkBitmap* test) {
- int diffID = fQueuedDiffs.count();
double startTime = get_seconds();
+
+ // since we currently synchronously do the diff within queueDiff we only need
+ // to protect the createion of the ID and queuedDiff object.
scroggo 2013/11/07 21:43:23 creation*
+ SkAutoMutexAcquire queueLock(fQueueMutex);
+ int diffID = fQueuedDiffs.count();
QueuedDiff* diff = fQueuedDiffs.push();
+ queueLock.release();
// If we never end up running the kernel, include some safe defaults in the result.
diff->finished = false;

Powered by Google App Engine
This is Rietveld 408576698